<?xml version="1.0" encoding="UTF-8"?>
<robot generator="Robot 7.4.2 (Python 3.11.10 on linux)" generated="2026-06-06T03:05:30.002161" rpa="false" schemaversion="5">
<suite id="s1" name="bgpcep-userfeatures.txt">
<suite id="s1-s1" name="050 Bmp Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/050_bmp_basic.robot">
<kw name="Set_It_Up" type="SETUP">
<kw name="Initialize_Artifact_Deployment_And_Usage" owner="NexusKeywords">
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:30.535326" level="INFO">${odl_connection} = 1</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-06-06T03:05:30.534766" elapsed="0.000601"/>
</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-06-06T03:05:30.538042" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:05:30.538134" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:30.537569" elapsed="0.000596"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:30.538319" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:05:30.540285" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:05:30.911594" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:05:28 UTC 2026

  System load:  0.91               Processes:             126
  Usage of /:   11.2% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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-26932-288-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-06-06T03:05:30.539254" elapsed="0.372568"/>
</kw>
<msg time="2026-06-06T03:05:30.911941" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:30.538898" elapsed="0.373150"/>
</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-06-06T03:05:30.537099" elapsed="0.375087"/>
</kw>
<msg time="2026-06-06T03:05:30.912247" 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-06-06T03:05:30.536558" elapsed="0.375746"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:05:30.535997" elapsed="0.376398"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-06-06T03:05:30.912465" elapsed="0.000054"/>
</return>
<msg time="2026-06-06T03:05:30.912756" level="INFO">${odl} = 1</msg>
<var>${odl}</var>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:05:30.534332" elapsed="0.378454"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:05:30.922147" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:05:30.931577" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/../../tools/deployment/search.sh' -&gt; '/home/jenkins//search.sh'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/../../tools/deployment/search.sh</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:05:30.912995" elapsed="0.018735"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:05:30.932086" elapsed="0.000487"/>
</kw>
<if>
<branch type="IF" condition="not (${tools_system_connect})">
<return>
<status status="NOT RUN" start="2026-06-06T03:05:30.932985" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:30.932740" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:30.932693" elapsed="0.000398"/>
</if>
<kw name="Open_Connection_To_Tools_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:30.939660" level="INFO">${tools_connection} = 2</msg>
<var>${tools_connection}</var>
<arg>${ip_address}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:05:30.939025" elapsed="0.000676"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:05:30.942203" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:05:30.942345" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:30.941707" elapsed="0.000680"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:30.942592" elapsed="0.000513"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:05:30.944022" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:05:31.666140" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:05:31 UTC 2026

  System load:  0.06               Processes:             110
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:05:30.943606" elapsed="0.722797"/>
</kw>
<msg time="2026-06-06T03:05:31.666494" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:30.943259" elapsed="0.723324"/>
</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-06-06T03:05:30.941067" elapsed="0.725658"/>
</kw>
<msg time="2026-06-06T03:05:31.666782" 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-06-06T03:05:30.940417" elapsed="0.726416"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:05:30.939950" elapsed="0.726960"/>
</kw>
<return>
<value>${tools_connection}</value>
<status status="PASS" start="2026-06-06T03:05:31.666968" elapsed="0.000049"/>
</return>
<doc>Open a connection to the tools system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:05:30.938446" elapsed="0.728711"/>
</kw>
<doc>Places search utility to ODL system, which will be needed for version detection.
By default also initialize a SSH connection to Tools system,
as following Keywords assume a working connection towards target system.</doc>
<status status="PASS" start="2026-06-06T03:05:30.530408" elapsed="1.136807"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:31.667858" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e77dd790&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:05:31.667483" elapsed="0.000654"/>
</kw>
<kw name="Deploy_Test_Tool" owner="NexusKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:31.684230" level="INFO">${name_prefix} = bgp-bmp-mock-</msg>
<var>${name_prefix}</var>
<arg>${artifact}-</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:31.683726" elapsed="0.000545"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:31.684944" level="INFO">${extension} = jar</msg>
<var>${extension}</var>
<arg>'${component}'=='odl-micro'</arg>
<arg>tar</arg>
<arg>jar</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:31.684490" elapsed="0.000482"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:31.685543" level="INFO">${name_suffix} = -executable.jar</msg>
<var>${name_suffix}</var>
<arg>"${suffix}" != ""</arg>
<arg>-${suffix}.${extension}</arg>
<arg>.${extension}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:31.685129" elapsed="0.000441"/>
</kw>
<kw name="Deploy_Artifact" owner="NexusKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${explicit_url}""" != ""</arg>
<arg>Deploy_From_Url</arg>
<arg>${explicit_url}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.686851" elapsed="0.000347"/>
</kw>
<kw name="Fetch From Left" owner="String">
<msg time="2026-06-06T03:05:31.687665" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>${BUNDLE_URL}</arg>
<arg>/org/opendaylight</arg>
<doc>Returns contents of the ``string`` before the first occurrence of ``marker``.</doc>
<status status="PASS" start="2026-06-06T03:05:31.687423" elapsed="0.000271"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:31.688277" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>'${urlbase}' != '${BUNDLE_URL}'</arg>
<arg>${urlbase}</arg>
<arg>${fallback_url}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:31.687843" elapsed="0.000472"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Magnesium" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.706991" elapsed="0.000532"/>
</kw>
<arg>magnesium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'carpeople'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:31.706383" elapsed="0.001240"/>
</kw>
<msg time="2026-06-06T03:05:31.707703" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>magnesium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.698713" elapsed="0.009066"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>carpeople</arg>
<doc>Compare magnesium to vanadium and in case vanadium is at most magnesium,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:31.698194" elapsed="0.009670"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Aluminium" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.727172" elapsed="0.000547"/>
</kw>
<arg>aluminium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'netconf'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:31.726568" elapsed="0.001241"/>
</kw>
<msg time="2026-06-06T03:05:31.727866" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>aluminium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.718337" elapsed="0.009602"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>netconf</arg>
<doc>Compare aluminium to vanadium and in case vanadium is at most aluminium,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:31.717702" elapsed="0.010331"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Silicon" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.745819" elapsed="0.000452"/>
</kw>
<arg>silicon</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'bgpcep'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:31.745364" elapsed="0.000998"/>
</kw>
<msg time="2026-06-06T03:05:31.746420" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>silicon</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.737216" elapsed="0.009272"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>bgpcep</arg>
<doc>Compare silicon to vanadium and in case vanadium is at most silicon,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:31.736641" elapsed="0.009926"/>
</kw>
<if>
<branch type="IF" condition="'${build_version}'=='${EMPTY}'">
<kw name="NexusKeywords__Detect_Version_To_Pull" owner="NexusKeywords">
<kw name="NexusKeywords__Get_Items_To_Look_At" owner="NexusKeywords">
<kw name="Dictionary Should Contain Key" owner="Collections">
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<arg>Component not supported by NexusKeywords version detection: ${component}</arg>
<doc>Fails if ``key`` is not found from ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:05:31.749479" elapsed="0.000366"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-06-06T03:05:31.750392" elapsed="0.000184"/>
</kw>
<msg time="2026-06-06T03:05:31.750628" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Collections.Get_From_Dictionary</arg>
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.750017" elapsed="0.000683"/>
</kw>
<msg time="2026-06-06T03:05:31.750813" level="INFO">${itemlist} = pcep-impl</msg>
<var>${itemlist}</var>
<arg>${component}</arg>
<doc>Get a list of items that might contain the version number that we are looking for.</doc>
<status status="PASS" start="2026-06-06T03:05:31.749061" elapsed="0.001785"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:31.751217" level="INFO">index=2
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:05:31.751345" level="INFO">${current_ssh_connection} = index=2
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:05:31.751037" elapsed="0.000340"/>
</kw>
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:31.756088" level="INFO">${odl_connection} = 3</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-06-06T03:05:31.755534" elapsed="0.000591"/>
</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-06-06T03:05:31.757887" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:05:31.757971" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:31.757529" elapsed="0.000471"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.758144" elapsed="0.000347"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:05:31.759905" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:05:32.066673" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:05:28 UTC 2026

  System load:  0.91               Processes:             126
  Usage of /:   11.2% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:05:30 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:05:31.759020" elapsed="0.307844"/>
</kw>
<msg time="2026-06-06T03:05:32.066960" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:31.758659" elapsed="0.308403"/>
</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-06-06T03:05:31.757101" elapsed="0.310099"/>
</kw>
<msg time="2026-06-06T03:05:32.067255" 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-06-06T03:05:31.756708" elapsed="0.310612"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:05:31.756318" elapsed="0.311167"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-06-06T03:05:32.067553" elapsed="0.000050"/>
</return>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:05:31.755224" elapsed="0.312544"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:32.068347" level="INFO">Executing command 'sh search.sh /tmp/karaf-0.24.0/system pcep-impl'.</msg>
<msg time="2026-06-06T03:05:32.111829" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:32.112145" level="INFO">${version} = 2.0.0
org/opendaylight/bgpcep</msg>
<msg time="2026-06-06T03:05:32.112221" level="INFO">${result} = 0</msg>
<var>${version}</var>
<var>${result}</var>
<arg>sh search.sh ${WORKSPACE}/${BUNDLEFOLDER}/system ${itemlist}</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:32.067992" elapsed="0.044267"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:05:32.112572" elapsed="0.000423"/>
</kw>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:05:32.117592" elapsed="0.000250"/>
</kw>
<msg time="2026-06-06T03:05:32.117913" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:32.116523" elapsed="0.001477"/>
</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="NOT RUN" start="2026-06-06T03:05:32.118312" elapsed="0.000054"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.118675" elapsed="0.000048"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:05:32.113419" elapsed="0.005447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.119769" level="INFO">2.0.0
org/opendaylight/bgpcep</msg>
<arg>${version}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.119154" elapsed="0.000747"/>
</kw>
<if>
<branch type="IF" condition="${result}!=0">
<kw name="Fail" owner="BuiltIn">
<arg>Component "${component}": searching for "${itemlist}" found no version, cannot locate test tool.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.120749" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.120151" elapsed="0.000728"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.120066" elapsed="0.000874"/>
</if>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:05:32.121880" level="INFO">${version} = 2.0.0</msg>
<msg time="2026-06-06T03:05:32.121986" level="INFO">${location} = org/opendaylight/bgpcep</msg>
<var>${version}</var>
<var>${location}</var>
<arg>${version}</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:05:32.121222" elapsed="0.000815"/>
</kw>
<return>
<value>${version}</value>
<value>${location}</value>
<status status="PASS" start="2026-06-06T03:05:32.122139" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:05:32.122467" level="INFO">${version} = 2.0.0</msg>
<msg time="2026-06-06T03:05:32.122534" level="INFO">${location} = org/opendaylight/bgpcep</msg>
<var>${version}</var>
<var>${location}</var>
<arg>${component}</arg>
<doc>Determine the exact Nexus directory to be used as a source for a particular test tool
Figure out what version of the tool needs to be pulled out of the
Nexus by looking at the version directory of the subsystem from
which the tool is being pulled. This code is REALLY UGLY but there
is no way around it until the bug
https://bugs.opendaylight.org/show_bug.cgi?id=5206 gets fixed.
I also don't want to depend on maven-metadata-local.xml and other
bits and pieces of ODL distribution which are not required for ODL
to function properly.</doc>
<status status="PASS" start="2026-06-06T03:05:31.748701" elapsed="0.373867"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:31.746690" elapsed="0.375942"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${version}</var>
<var>${location}</var>
<arg>${build_version}</arg>
<arg>${build_location}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.122904" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.122696" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:31.746639" elapsed="0.376390"/>
</if>
<if>
<branch type="IF" condition="'SNAPSHOT' in '${version}'">
<kw name="Remove Values From List" owner="Collections">
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>netconf</arg>
<arg>bgpcep</arg>
<doc>Removes all occurrences of given ``values`` from ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.123426" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.123125" elapsed="0.000387"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.123097" elapsed="0.000454"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.124354" level="INFO">${is_staged} = "TRUE"</msg>
<var>${is_staged}</var>
<arg>"opendaylight.release" not in '${urlbase}' and "opendaylight.snapshot" not in '${urlbase}'</arg>
<arg>"TRUE"</arg>
<arg>"FALSE"</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:32.123774" elapsed="0.000630"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.125269" level="INFO">${is_mri_component} = "TRUE"</msg>
<var>${is_mri_component}</var>
<arg>'${component}' in ${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>"TRUE"</arg>
<arg>"FALSE"</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:32.124635" elapsed="0.000673"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.126216" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>${is_mri_component} == "TRUE" and ${is_staged} == "FALSE"</arg>
<arg>${NEXUS_RELEASE_BASE_URL}</arg>
<arg>${urlbase}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:32.125574" elapsed="0.000684"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.127094" level="INFO">${url} = https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0</msg>
<var>${url}</var>
<arg>${urlbase}/${location}/${artifact}/${version}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:32.126473" elapsed="0.000666"/>
</kw>
<kw name="Execute_Command_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:32.130064" level="INFO">Executing command 'curl -L https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml'.</msg>
<msg time="2026-06-06T03:05:32.275924" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:32.276501" level="INFO">${stdout} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorel...</msg>
<msg time="2026-06-06T03:05:32.276614" level="INFO">${stderr} =   % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0   ...</msg>
<msg time="2026-06-06T03:05:32.276808" 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-06-06T03:05:32.129683" elapsed="0.147193"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.279663" level="INFO">Length is 316.</msg>
<msg time="2026-06-06T03:05:32.279886" level="FAIL">'  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1095    0  1095    0     0   9157      0 --:--:-- --:--:-- --:--:--  9201' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:05:32.278247" elapsed="0.001816">'  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1095    0  1095    0     0   9157      0 --:--:-- --:--:-- --:--:--  9201' should be empty.</status>
</kw>
<msg time="2026-06-06T03:05:32.280314" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:05:32.280414" level="INFO">${result} = '  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0  ...</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-06-06T03:05:32.277321" elapsed="0.003147"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.281885" 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-06-06T03:05:32.280836" elapsed="0.001108"/>
</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-06-06T03:05:32.284269" level="INFO">&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8"/&gt;

    &lt;link rel="icon" type="image/png" href="https://nexus.opendaylight.org/favicon.png"&gt;
    &lt;!--[if IE]&gt;
    &lt;link rel="SHORTCUT ICON" href="https://nexus.opendaylight.org/favicon.ico"/&gt;
    &lt;![endif]--&gt;

    &lt;link rel="stylesheet" href="https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02" type="text/css" media="screen" title="no title" charset="utf-8"&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/h1&gt;
    &lt;p&gt;Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/p&gt;
  &lt;/body&gt;
&lt;/html&gt;</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.283708" elapsed="0.000692"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.285258" level="INFO">  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1095    0  1095    0     0   9157      0 --:--:-- --:--:-- --:--:--  9201</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.284722" elapsed="0.000637"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.286194" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.285681" elapsed="0.000556"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:05:32.282927" elapsed="0.003365"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:32.282140" elapsed="0.004187"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.282086" elapsed="0.004271"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.286527" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:32.286418" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.286400" elapsed="0.000200"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:05:32.286770" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:05:32.286671" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.286637" elapsed="0.000225"/>
</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-06-06T03:05:32.286988" elapsed="0.000021"/>
</kw>
<arg>${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-06-06T03:05:32.128807" elapsed="0.158300"/>
</kw>
<msg time="2026-06-06T03:05:32.287173" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${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-06-06T03:05:32.127973" elapsed="0.159249"/>
</kw>
<msg time="2026-06-06T03:05:32.287438" level="INFO">${metadata} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorel...</msg>
<var>${metadata}</var>
<arg>curl -L ${url}/maven-metadata.xml</arg>
<doc>A wrapper for Execute_Command_Passes with return_success_only=False
Also, log_on_success defaults to True (but is customizable, unlike return_success_only)..</doc>
<status status="PASS" start="2026-06-06T03:05:32.127435" elapsed="0.160040"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Command_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:32.289713" level="INFO">Executing command 'echo "&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8"/&gt;

    &lt;link rel="icon" type="image/png" href="https://nexus.opendaylight.org/favicon.png"&gt;
    &lt;!--[if IE]&gt;
    &lt;link rel="SHORTCUT ICON" href="https://nexus.opendaylight.org/favicon.ico"/&gt;
    &lt;![endif]--&gt;

    &lt;link rel="stylesheet" href="https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02" type="text/css" media="screen" title="no title" charset="utf-8"&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/h1&gt;
    &lt;p&gt;Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/p&gt;
  &lt;/body&gt;
&lt;/html&gt;" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1'.</msg>
<msg time="2026-06-06T03:05:32.330086" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:32.330451" level="INFO">${stdout} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorel...</msg>
<msg time="2026-06-06T03:05:32.330562" level="INFO">${stderr} = bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text...</msg>
<msg time="2026-06-06T03:05:32.330715" 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-06-06T03:05:32.289493" elapsed="0.041289"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.332820" level="INFO">Length is 253.</msg>
<msg time="2026-06-06T03:05:32.333040" level="FAIL">'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:05:32.332073" elapsed="0.001135">'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory' should be empty.</status>
</kw>
<msg time="2026-06-06T03:05:32.333476" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:05:32.333635" level="INFO">${result} = 'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=tex...</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-06-06T03:05:32.331218" elapsed="0.002548"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.335387" level="INFO">${success} = False</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-06-06T03:05:32.334271" elapsed="0.001191"/>
</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-06-06T03:05:32.337356" level="INFO">&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv=Content-Type content=text/html</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.336968" elapsed="0.000462"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.338476" level="INFO">bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.337682" elapsed="0.000869"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.339160" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.338776" elapsed="0.000449"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:05:32.336362" elapsed="0.002946"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:32.335693" elapsed="0.003667"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.335609" elapsed="0.003790"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.339669" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:32.339489" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.339463" elapsed="0.000317"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.339994" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:32.339860" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.339835" elapsed="0.000256"/>
</if>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.340825" level="FAIL">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</msg>
<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="FAIL" start="2026-06-06T03:05:32.340271" elapsed="0.000742">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<arg>${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="FAIL" start="2026-06-06T03:05:32.288968" elapsed="0.052263">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<msg time="2026-06-06T03:05:32.341333" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${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="FAIL" start="2026-06-06T03:05:32.288447" elapsed="0.052961"/>
</kw>
<arg>echo "${metadata}" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1</arg>
<arg>stderr_must_be_empty=${True}</arg>
<doc>A wrapper for Execute_Command_Passes with return_success_only=False
Also, log_on_success defaults to True (but is customizable, unlike return_success_only)..</doc>
<status status="FAIL" start="2026-06-06T03:05:32.288048" elapsed="0.053516">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<msg time="2026-06-06T03:05:32.341836" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:05:32.341945" level="INFO">${namepart} = Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonaty...</msg>
<var>${status}</var>
<var>${namepart}</var>
<arg>SSHKeywords.Execute_Command_Should_Pass</arg>
<arg>echo "${metadata}" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1</arg>
<arg>stderr_must_be_empty=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:05:32.287622" elapsed="0.054364"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.342662" level="INFO">Length is 288.</msg>
<msg time="2026-06-06T03:05:32.342782" level="INFO">${length} = 288</msg>
<var>${length}</var>
<arg>${namepart}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:32.342218" elapsed="0.000600"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.343674" level="INFO">${namepart} = 2.0.0</msg>
<var>${namepart}</var>
<arg>"${status}" != "PASS" or ${length} == 0</arg>
<arg>${version}</arg>
<arg>${namepart}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:32.343036" elapsed="0.000679"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.344512" level="INFO">${filename} = bgp-bmp-mock-2.0.0-executable.jar</msg>
<var>${filename}</var>
<arg>${name_prefix}${namepart}${name_suffix}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:32.343987" elapsed="0.000564"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.345155" level="INFO">bgp-bmp-mock-2.0.0-executable.jar</msg>
<arg>${filename}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.344774" elapsed="0.000448"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.345957" level="INFO">${url} = https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/bgp-bmp-mock-2.0.0-executable.jar</msg>
<var>${url}</var>
<arg>${url}/${filename}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:32.345417" elapsed="0.000585"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:32.346533" level="INFO">Executing command 'wget -q -N 'https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/bgp-bmp-mock-2.0.0-executable.jar' 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:05:32.415675" level="INFO">Command exited with return code 8.</msg>
<msg time="2026-06-06T03:05:32.416079" level="INFO">${response} = </msg>
<msg time="2026-06-06T03:05:32.416190" level="INFO">${result} = 8</msg>
<var>${response}</var>
<var>${result}</var>
<arg>wget -q -N '${url}' 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:32.346197" elapsed="0.070051"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.417400" level="INFO"/>
<arg>${response}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.416717" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${result} == 0">
<return>
<value>${filename}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.418021" elapsed="0.000107"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:32.417711" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.417626" elapsed="0.000662"/>
</if>
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:05:32.419420" level="INFO">${release_url} = https://nexus.opendaylight.org/content/repositories//opendaylight.release/org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/bgp-bmp-mock-2.0.0-executable.jar</msg>
<var>${release_url}</var>
<arg>${url}</arg>
<arg>autorelease-[0-9]{4}</arg>
<arg>opendaylight.release</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:05:32.418598" elapsed="0.000886"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:32.420306" level="INFO">Executing command 'wget -q -N 'https://nexus.opendaylight.org/content/repositories//opendaylight.release/org/opendaylight/bgpcep/bgp-bmp-mock/2.0.0/bgp-bmp-mock-2.0.0-executable.jar' 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:05:32.624438" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:32.624935" level="INFO">${response} = </msg>
<msg time="2026-06-06T03:05:32.625047" level="INFO">${result} = 0</msg>
<var>${response}</var>
<var>${result}</var>
<arg>wget -q -N '${release_url}' 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:32.419870" elapsed="0.205233"/>
</kw>
<if>
<branch type="IF" condition="${result} != 0">
<kw name="Fail" owner="BuiltIn">
<arg>Artifact "${artifact}" in component "${component}" could not be downloaded from ${release_url} nor ${url}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.625954" elapsed="0.000182"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.625368" elapsed="0.000858"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.625304" elapsed="0.000984"/>
</if>
<return>
<value>${filename}</value>
<status status="PASS" start="2026-06-06T03:05:32.626373" elapsed="0.000082"/>
</return>
<msg time="2026-06-06T03:05:32.626945" level="INFO">${filename} = bgp-bmp-mock-2.0.0-executable.jar</msg>
<var>${filename}</var>
<arg>${component}</arg>
<arg>${artifact}</arg>
<arg>${name_prefix}</arg>
<arg>${name_suffix}</arg>
<arg>${fallback_url}</arg>
<arg>${explicit_url}</arg>
<arg>${build_version}</arg>
<arg>${build_location}</arg>
<doc>Deploy the specified artifact from Nexus to the cwd of the machine to which the active SSHLibrary connection points.
bgpcep is a name part of an artifact present in system/ of ODl installation with the same version as bgp-bmp-mock should have.
Must have https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/integration/karaf/0.24.0/karaf-0.24.0.zip variable set to the URL from which the
tested ODL distribution was downloaded and this place must be
inside a repository created by a standard distribution
construction job. If this is detected to ne be the case, fallback URL is used.
If  is non-empty, Deploy_From_Utrl is called instead.
TODO: Allow deploying to a specific directory, we have SSHKeywords.Execute_Command_At_Cwd_Should_Pass now.</doc>
<status status="PASS" start="2026-06-06T03:05:31.686221" elapsed="0.940790"/>
</kw>
<return>
<value>${filename}</value>
<status status="PASS" start="2026-06-06T03:05:32.627167" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:05:32.627390" level="INFO">${name} = bgp-bmp-mock-2.0.0-executable.jar</msg>
<var>${name}</var>
<arg>bgpcep</arg>
<arg>bgp-bmp-mock</arg>
<doc>Deploy a test tool.
The test tools have naming convention of the form
"&lt;repository_url&gt;/some/dir/somewhere/&lt;tool-name&gt;/&lt;tool-name&gt;-&lt;version-tag&gt;-${suffix}.jar"
where "&lt;tool-name&gt;" is the name of the tool and "&lt;version-tag&gt;" is
the version tag that is digged out of the maven metadata. This
keyword calculates ${name_prefix} and ${name_suffix} for
"Deploy_Artifact" and then calls "Deploy_Artifact" to do the real
work of deploying the artifact.</doc>
<status status="PASS" start="2026-06-06T03:05:31.678403" elapsed="0.949023"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.632992" level="INFO">${filename} = bgp-bmp-mock-2.0.0-executable.jar</msg>
<arg>${filename}</arg>
<arg>${name}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:05:32.627670" elapsed="0.005389"/>
</kw>
<doc>Create SSH session to ToolsVm, prepare HTTP client session to Controller.
Figure out latest pcc-mock version and download it from Nexus to ToolsVm.</doc>
<status status="PASS" start="2026-06-06T03:05:30.529847" elapsed="2.103307"/>
</kw>
<test id="s1-s1-t1" name="Verify BMP Feature" line="39">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.634757" level="INFO">&amp;{mapping} = { TOOL_IP=10.30.171.194 }</msg>
<var>&amp;{mapping}</var>
<arg>TOOL_IP=${TOOLS_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:05:32.634040" elapsed="0.000765"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.669485" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:32.669096" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:32.670429" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:32.670122" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:32.670612" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:32.669685" elapsed="0.000953"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.671257" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:32.670846" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:05:32.671587" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:05:32.671786" level="INFO">${template} = /rests/data/bmp-monitor:bmp-monitor
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:05:32.671439" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.672229" level="INFO">/rests/data/bmp-monitor:bmp-monitor
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.671961" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.673250" level="INFO">mapping: {'TOOL_IP': '10.30.171.194'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.672980" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.673780" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:05:32.673437" elapsed="0.000371"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.674560" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:05:32.674198" elapsed="0.000389"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:05:32.675673" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:05:32.675238" elapsed="0.000463"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:05:32.675757" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:05:32.675920" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:05:32.674874" elapsed="0.001071"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:05:32.676079" elapsed="0.000386"/>
</kw>
<var name="${key}">TOOL_IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:05:32.674070" elapsed="0.002440"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:05:32.673874" elapsed="0.002676"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:05:32.676596" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:05:32.676781" level="INFO">${mapping_to_use} = {'TOOL_IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:05:32.672668" elapsed="0.004139"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:32.672350" elapsed="0.004489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.676997" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.676865" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.672328" elapsed="0.004747"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.677848" level="INFO">${final_text} = /rests/data/bmp-monitor:bmp-monitor</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:05:32.677198" elapsed="0.000678"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:05:32.677927" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:05:32.668491" elapsed="0.009565"/>
</kw>
<msg time="2026-06-06T03:05:32.678110" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:32.667689" elapsed="0.010470"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.678659" elapsed="0.000066"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.679195" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.679715" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.679885" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.680041" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.680430" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.680270" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:32.680255" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.680638" elapsed="0.000038"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.680826" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.680981" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:05:32.680225" elapsed="0.000812"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.680119" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.681204" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.681283" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:05:32.681396" level="INFO">${uri} = /rests/data/bmp-monitor:bmp-monitor</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:05:32.663681" elapsed="0.017742"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:32.682666" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:32.682382" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:32.682862" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:32.682054" elapsed="0.000833"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.683215" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:32.682968" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.683993" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:32.683680" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:32.683299" elapsed="0.000757"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.682948" elapsed="0.001129"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.686235" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:32.684212" elapsed="0.002070"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:05:32.686345" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:05:32.686509" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:05:32.681745" elapsed="0.004790"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:32.687772" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:32.687511" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:32.687938" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:32.687187" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:05:32.688196" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:05:32.688035" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.688015" elapsed="0.000269"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.688412" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:32.688565" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:05:32.688631" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:05:32.690524" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:05:32.686875" elapsed="0.003676"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.691960" level="INFO">/rests/data/bmp-monitor:bmp-monitor</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.691702" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:32.692389" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:32.692142" elapsed="0.000292"/>
</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-06-06T03:05:33.485901" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bmp-monitor:bmp-monitor 
 path_url=/rests/data/bmp-monitor:bmp-monitor 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:33.487016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bmp-monitor:bmp-monitor 
 status=200, reason=OK 
 headers={'Set-Cookie': 'JSESSIONID=node0cai9uvcb7e8hwuyyixdowq0x0.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:05:33 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '78'} 
 body={"bmp-monitor:bmp-monitor":{"monitor":[{"monitor-id":"example-bmp-monitor"}]}} 
 </msg>
<msg time="2026-06-06T03:05:33.487298" 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-06-06T03:05:32.694319" elapsed="0.793045"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:32.692501" elapsed="0.794980"/>
</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-06-06T03:05:33.487977" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:33.487552" elapsed="0.000581"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:32.692483" elapsed="0.795702"/>
</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-06-06T03:05:33.493340" level="INFO">{"bmp-monitor:bmp-monitor":{"monitor":[{"monitor-id":"example-bmp-monitor"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:33.490186" elapsed="0.003225"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.489868" elapsed="0.003593"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.489836" elapsed="0.003661"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.496741" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:33.493896" elapsed="0.002912"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.493578" elapsed="0.003280"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.493553" elapsed="0.003340"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.500751" 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-06-06T03:05:33.497104" elapsed="0.003676"/>
</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-06-06T03:05:33.501078" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:33.500856" elapsed="0.000281"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.501610" 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-06-06T03:05:33.501303" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.501164" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.500837" elapsed="0.000874"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.502220" 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-06-06T03:05:33.501848" elapsed="0.000399"/>
</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-06-06T03:05:33.502527" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:33.502318" elapsed="0.000266"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.503056" 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-06-06T03:05:33.502758" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.502608" elapsed="0.000510"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.502300" elapsed="0.000838"/>
</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-06-06T03:05:33.503275" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:05:33.504245" 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-06-06T03:05:33.503796" elapsed="0.000476"/>
</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-06-06T03:05:33.504410" elapsed="0.002066"/>
</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-06-06T03:05:33.489171" elapsed="0.017432"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.506808" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:33.506692" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.506672" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:05:33.509449" level="INFO">${text_normalized} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor"
   }
  ]
 }
}
</msg>
<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="PASS" start="2026-06-06T03:05:33.507006" elapsed="0.002472"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:05:33.509531" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:05:33.509713" level="INFO">${response_text} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor"
   }
  ]
 }
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:05:32.690879" elapsed="0.818860"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:05:33.509804" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:05:33.509954" level="INFO">${response_text} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor"
   }
  ]
 }
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:05:32.642822" elapsed="0.867158"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.526417" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:33.526020" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:33.527430" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:33.527088" elapsed="0.000428">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:33.527616" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:33.526763" elapsed="0.000905"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.528209" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:33.527820" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:05:33.528521" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/empty_structure/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:05:33.528936" level="INFO">${template} = {
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor"
            }
        ]
    }
}
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:05:33.528376" elapsed="0.000599"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.529456" level="INFO">{
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:33.529139" elapsed="0.000366"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:05:33.529924" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:33.529588" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.530436" level="INFO">${mapping_to_use} = {'TOOL_IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:33.530139" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.530013" elapsed="0.000484"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.529562" elapsed="0.000957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.531108" level="INFO">${final_text} = {
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor"
            }
        ]
    }
}</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:05:33.530661" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:05:33.531189" elapsed="0.000041"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:05:33.525409" elapsed="0.005985"/>
</kw>
<msg time="2026-06-06T03:05:33.531449" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:33.524505" elapsed="0.006993"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.532000" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.532486" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/empty_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.533067" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.533245" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.533412" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.533819" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:33.533693" elapsed="0.000183"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:33.533675" elapsed="0.000225"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.534028" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.534177" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.534340" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:05:33.533624" elapsed="0.000773"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.533503" elapsed="0.000923"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.534557" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.534634" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:05:33.534770" level="INFO">${expected_text} = {
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor"
            }
        ]
    }
}</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:05:33.520527" elapsed="0.014270"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:33.534987" elapsed="0.002304"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:05:33.538347" level="INFO">${expected_normalized} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor"
   }
  ]
 }
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:05:33.538022" elapsed="0.000353"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:05:33.538807" level="INFO">${actual_normalized} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor"
   }
  ]
 }
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:05:33.538510" elapsed="0.000325"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:05:33.538969" elapsed="0.000351"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:05:33.537595" elapsed="0.001786"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.537374" elapsed="0.002041"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.539570" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:33.539440" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.537355" elapsed="0.002305"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:05:33.511117" elapsed="0.028596"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:05:33.510297" elapsed="0.029493"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:33.510062" elapsed="0.029773"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.510045" elapsed="0.029814"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:05:33.539893" elapsed="0.000029"/>
</return>
<arg>folder=${BGP_BMP_FEAT_DIR}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:05:32.638926" elapsed="0.901094"/>
</kw>
<arg>180s</arg>
<arg>5s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>folder=${BGP_BMP_FEAT_DIR}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:05:32.635036" elapsed="0.905042"/>
</kw>
<doc>Verifies if feature is up</doc>
<status status="PASS" start="2026-06-06T03:05:32.633263" elapsed="0.906973"/>
</test>
<test id="s1-s1-t2" name="Start_Bmp_Mock" line="51">
<kw name="Compose_Full_Java_Command" owner="NexusKeywords">
<kw name="Compose_Base_Java_Command" owner="NexusKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${openjdk}""" == "openjdk8"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_8_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_8_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:33.542191" elapsed="0.000326"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${openjdk}""" == "openjdk11"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_11_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_11_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:33.542684" elapsed="0.000308"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${openjdk}""" == "openjdk17"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_17_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_17_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:33.543140" elapsed="0.000305"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Compose_Dilemma_Filepath" owner="NexusKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:33.544673" level="INFO">Executing command 'ls -lA /usr/lib/jvm/java-21-openjdk-amd64/bin/java 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:05:33.558531" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:33.558678" level="INFO">${out} = -rwxr-xr-x 1 root root 14456 Jul 16  2025 /usr/lib/jvm/java-21-openjdk-amd64/bin/java</msg>
<msg time="2026-06-06T03:05:33.558725" level="INFO">${rc} = 0</msg>
<var>${out}</var>
<var>${rc}</var>
<arg>ls -lA ${specific_path} 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:33.544469" elapsed="0.014280"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>${specific_path}</value>
<status status="PASS" start="2026-06-06T03:05:33.558954" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:05:33.558838" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:33.558812" elapsed="0.000234"/>
</if>
<return>
<value>${default_path}</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.559081" elapsed="0.000015"/>
</return>
<arg>${JAVA_21_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_21_HOME_UBUNTU}/bin/java</arg>
<doc>Query active SSH connection, return specific path if it exists else default path.</doc>
<status status="PASS" start="2026-06-06T03:05:33.544094" elapsed="0.015098"/>
</kw>
<msg time="2026-06-06T03:05:33.559237" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>"""${openjdk}""" == "openjdk21"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_21_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_21_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:33.543591" elapsed="0.015694"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${out}</var>
<var>${rc}</var>
<arg>java -version 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.559439" elapsed="0.000022"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>java</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.559625" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:33.559587" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:33.559569" elapsed="0.000143"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${java}</var>
<arg>echo $JAVA_HOME/bin/java 2&gt;&amp;1</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.559843" elapsed="0.000021"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${out}</var>
<var>${rc}</var>
<arg>${java} -version 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.559998" elapsed="0.000020"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>${java}</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.560124" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:33.560089" elapsed="0.000075"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:33.560072" elapsed="0.000114"/>
</if>
<kw name="Get Environment Variable" owner="OperatingSystem">
<var>${JAVA_HOME}</var>
<arg>JAVA_HOME</arg>
<arg>${EMPTY}</arg>
<doc>Returns the value of an environment variable with the given name.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.560308" elapsed="0.000020"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${java}</var>
<arg>"""${JAVA_HOME}"""!=""</arg>
<arg>${JAVA_HOME}/bin/java</arg>
<arg>false</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.560468" elapsed="0.000020"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${out}</var>
<var>${rc}</var>
<arg>${java} -version 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.560625" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>${java}</value>
<status status="NOT RUN" start="2026-06-06T03:05:33.560785" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:33.560748" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:33.560717" elapsed="0.000130"/>
</if>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to find Java; specify \${JDKVERSION}, put it to your PATH or set JAVA_HOME environment variable.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:33.560966" elapsed="0.000020"/>
</kw>
<msg time="2026-06-06T03:05:33.561087" level="INFO">${base_command} = /usr/lib/jvm/java-21-openjdk-amd64/bin/java</msg>
<var>${base_command}</var>
<arg>openjdk=${openjdk}</arg>
<doc>Return string suitable for launching Java programs over SSHLibrary, depending on JRE version needed.
This requires that the SSH connection on which the command is going to be used is active as it is needed for querying files.
Commands composed for one SSH connection shall not be reused on other SSH connections as the two connections may have different Java setups.
Not directly related to Nexus, but versioned Java tools may need this.</doc>
<status status="PASS" start="2026-06-06T03:05:33.541842" elapsed="0.019270"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.561592" level="INFO">${full_command} = /usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar bgp-bmp-mock-2.0.0-executable.jar --local_address 10.30.171.194 --remote_address 10.30.170.38:12345 --routers_count 1 --peers_count 1 --log_level DEBUG...</msg>
<var>${full_command}</var>
<arg>${base_command} ${options}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:33.561252" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.562023" level="INFO">/usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar bgp-bmp-mock-2.0.0-executable.jar --local_address 10.30.171.194 --remote_address 10.30.170.38:12345 --routers_count 1 --peers_count 1 --log_level DEBUG 2&gt;&amp;1 | tee bmpmock.log</msg>
<arg>${full_command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:33.561777" elapsed="0.000294"/>
</kw>
<return>
<value>${full_command}</value>
<status status="PASS" start="2026-06-06T03:05:33.562114" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:05:33.562267" level="INFO">${command} = /usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar bgp-bmp-mock-2.0.0-executable.jar --local_address 10.30.171.194 --remote_address 10.30.170.38:12345 --routers_count 1 --peers_count 1 --log_level DEBUG...</msg>
<var>${command}</var>
<arg>-jar ${filename} --local_address ${TOOLS_SYSTEM_IP} --remote_address ${ODL_SYSTEM_IP}:12345 --routers_count 1 --peers_count 1 --log_level DEBUG 2&gt;&amp;1 | tee ${BMP_LOG_FILE}</arg>
<doc>Return full Bash command to run Java with given options.
This requires that the SSH connection on which the command is going to be used is active as it is needed for querying files.
The options may include JVM options, application command line arguments, Bash redirects and other constructs.</doc>
<status status="PASS" start="2026-06-06T03:05:33.541188" elapsed="0.021106"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.562692" level="INFO">/usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar bgp-bmp-mock-2.0.0-executable.jar --local_address 10.30.171.194 --remote_address 10.30.170.38:12345 --routers_count 1 --peers_count 1 --log_level DEBUG 2&gt;&amp;1 | tee bmpmock.log</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:33.562434" elapsed="0.000306"/>
</kw>
<kw name="Set Client Configuration" owner="SSHLibrary">
<arg>timeout=30s</arg>
<doc>Update the `configuration` of the current connection.</doc>
<status status="PASS" start="2026-06-06T03:05:33.562871" elapsed="0.000194"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:05:33.600097" level="INFO">/usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar bgp-bmp-mock-2.0.0-executable.jar --local_address 10.30.171.194 --remote_address 10.30.170.38:12345 --routers_count 1 --peers_count 1 --log_level DEBUG 2&gt;&amp;1 | tee bmpmock.log</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:05:33.563196" elapsed="0.036978"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:33.600685" level="INFO">${until_phrase} = successfully established.</msg>
<var>${until_phrase}</var>
<arg>successfully established.</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:33.600374" elapsed="0.000339"/>
</kw>
<kw name="Read Until" owner="SSHLibrary">
<msg time="2026-06-06T03:05:35.386979" level="INFO">[?2004l03:05:34.035 [main] INFO org.opendaylight.protocol.bmp.mock.BmpMock -- Starting BMP test tool.
03:05:34.251 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler, preferring the latter
03:05:34.252 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler@448ff1a8
03:05:34.252 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler, preferring the latter
03:05:34.253 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler@448ff1a8
03:05:34.253 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler, preferring the latter
03:05:34.253 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler@448ff1a8
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler, preferring the latter
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler@36f0f1be
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler, preferring the latter
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler@36f0f1be
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler, preferring the latter
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler@36f0f1be
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler, preferring the latter
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler@4de5031f
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler, preferring the latter
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler@4de5031f
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler, preferring the latter
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler@4de5031f
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler, preferring the latter
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler@568bf312
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler, preferring the latter
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler@568bf312
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler, preferring the latter
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler@568bf312
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler, preferring the latter
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler@35083305
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler, preferring the latter
03:05:34.259 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler@35083305
03:05:34.259 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler, preferring the latter
03:05:34.259 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler@35083305
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler, preferring the latter
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler@3ec300f1
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler, preferring the latter
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler@3ec300f1
03:05:34.261 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler, preferring the latter
03:05:34.261 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler@3ec300f1
03:05:34.261 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler, preferring the latter
03:05:34.262 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler@25b485ba
03:05:34.262 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler, preferring the latter
03:05:34.262 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler@25b485ba
03:05:34.263 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler, preferring the latter
03:05:34.263 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler@25b485ba
03:05:34.264 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC, preferring the latter
03:05:34.264 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC@5af97850
03:05:34.264 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC, preferring the latter
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC@5af97850
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler, preferring the latter
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler@4034c28c
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler, preferring the latter
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler@4034c28c
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler, preferring the latter
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler@4034c28c
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler, preferring the latter
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler@4b168fa9
03:05:34.267 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler, preferring the latter
03:05:34.267 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler@4b168fa9
03:05:34.267 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler, preferring the latter
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler@55a561cf
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler, preferring the latter
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler@55a561cf
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC, preferring the latter
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC@6295d394
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC, preferring the latter
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC@6295d394
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler, preferring the latter
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler@2aa5fe93
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler, preferring the latter
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler@2aa5fe93
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler, preferring the latter
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler@3e3047e6
03:05:34.271 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler, preferring the latter
03:05:34.271 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler@3e3047e6
03:05:34.271 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler, preferring the latter
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler@6ab7a896
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler, preferring the latter
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler@6ab7a896
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler, preferring the latter
03:05:34.273 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler@d83da2e
03:05:34.273 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler, preferring the latter
03:05:34.273 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler@d83da2e
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler, preferring the latter
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler@4f638935
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler, preferring the latter
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler@4f638935
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler, preferring the latter
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler@7ff95560
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler, preferring the latter
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler@7ff95560
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler, preferring the latter
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler@78dd667e
03:05:34.276 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler, preferring the latter
03:05:34.276 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler@78dd667e
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler, preferring the latter
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler@6293abcc
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler, preferring the latter
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler@6293abcc
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler, preferring the latter
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler@23986957
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler, preferring the latter
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler@23986957
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser, preferring the latter
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser@6b19b79
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser, preferring the latter
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser@6b19b79
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler, preferring the latter
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler@4fe767f3
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler, preferring the latter
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler@4fe767f3
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser, preferring the latter
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser@ec756bd
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser, preferring the latter
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser@ec756bd
03:05:34.286 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser, preferring the latter
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser@5dd6264
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser, preferring the latter
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser@5dd6264
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser, preferring the latter
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser@6ac13091
03:05:34.288 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser, preferring the latter
03:05:34.288 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser@6ac13091
03:05:34.289 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser, preferring the latter
03:05:34.289 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser@1ed1993a
03:05:34.289 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser, preferring the latter
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser@1ed1993a
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser, preferring the latter
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser@60d8c9b7
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser, preferring the latter
03:05:34.291 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser@60d8c9b7
03:05:34.291 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser, preferring the latter
03:05:34.291 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser@65466a6a
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser, preferring the latter
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser@65466a6a
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser, preferring the latter
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser@79b06cab
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser, preferring the latter
03:05:34.293 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser@79b06cab
03:05:34.293 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser, preferring the latter
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser@7880cdf3
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser, preferring the latter
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser@7880cdf3
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser, preferring the latter
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser@22a637e7
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser, preferring the latter
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser@22a637e7
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser, preferring the latter
03:05:34.296 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser@5ae50ce6
03:05:34.296 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser, preferring the latter
03:05:34.296 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser@5ae50ce6
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser, preferring the latter
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser@418e7838
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser, preferring the latter
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser@418e7838
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser, preferring the latter
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser@5a63f509
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser, preferring the latter
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser@5a63f509
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser, preferring the latter
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser@a9cd3b1
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser, preferring the latter
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser@a9cd3b1
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser, preferring the latter
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser@63355449
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser, preferring the latter
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser@63355449
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser, preferring the latter
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser@5c30a9b0
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser, preferring the latter
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser@5c30a9b0
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4AggregatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4AggregatorAttributeParser, preferring the latter
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AS4AggregatorAttributeParser@3f197a46
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4PathAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4PathAttributeParser, preferring the latter
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AS4PathAttributeParser@6ca8564a
03:05:34.303 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.UnrecognizedAttributesSerializer is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.UnrecognizedAttributesSerializer, preferring the latter
03:05:34.303 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.UnrecognizedAttributesSerializer@76508ed1
03:05:34.304 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser, preferring the latter
03:05:34.304 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser@481a996b
03:05:34.305 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser, preferring the latter
03:05:34.305 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser@481a996b
03:05:34.306 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser, preferring the latter
03:05:34.306 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser@708f5957
03:05:34.312 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser, preferring the latter
03:05:34.312 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser@708f5957
03:05:34.312 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser, preferring the latter
03:05:34.313 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser@1ea9f6af
03:05:34.313 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser, preferring the latter
03:05:34.313 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser@1ea9f6af
03:05:34.381 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser, preferring the latter
03:05:34.381 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser@62ddbd7e
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser, preferring the latter
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser@62ddbd7e
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser, preferring the latter
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser@15de0b3c
03:05:34.383 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser, preferring the latter
03:05:34.383 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser@15de0b3c
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler, preferring the latter
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler@c86b9e3
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler, preferring the latter
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler@c86b9e3
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler, preferring the latter
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler@ed7f8b4
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler, preferring the latter
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler@ed7f8b4
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler, preferring the latter
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler@5c90e579
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler, preferring the latter
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler@5c90e579
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler, preferring the latter
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler@63070bab
03:05:34.399 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler, preferring the latter
03:05:34.399 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler@63070bab
03:05:34.399 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler, preferring the latter
03:05:34.400 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler@762ef0ea
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler, preferring the latter
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler@762ef0ea
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler, preferring the latter
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler@5f8edcc5
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler, preferring the latter
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler@5f8edcc5
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler, preferring the latter
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler@15ca7889
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler, preferring the latter
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler@15ca7889
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler, preferring the latter
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler@2898ac89
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler, preferring the latter
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler@2898ac89
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler, preferring the latter
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler@6ff29830
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler@6ff29830
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler@548e6d58
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler@548e6d58
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler@3098cf3b
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler, preferring the latter
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler@3098cf3b
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler, preferring the latter
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler@57250572
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler, preferring the latter
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler@57250572
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler, preferring the latter
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler@11fc564b
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler, preferring the latter
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler@11fc564b
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler, preferring the latter
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler@fa36558
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler, preferring the latter
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler@fa36558
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler, preferring the latter
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler@3571b748
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler, preferring the latter
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler@3571b748
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler, preferring the latter
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler@7c83dc97
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler, preferring the latter
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler@7c83dc97
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler, preferring the latter
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler@55740540
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler, preferring the latter
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler@55740540
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler, preferring the latter
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler@65b3f4a4
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler, preferring the latter
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler@65b3f4a4
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.InitiationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.InitiationHandler, preferring the latter
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.InitiationHandler@2a266d09
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.InitiationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.InitiationHandler, preferring the latter
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.InitiationHandler@2a266d09
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.TerminationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.TerminationHandler, preferring the latter
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.TerminationHandler@757acd7b
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.TerminationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.TerminationHandler, preferring the latter
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.TerminationHandler@757acd7b
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler, preferring the latter
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerUpHandler@343570b7
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler, preferring the latter
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerUpHandler@343570b7
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler, preferring the latter
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerDownHandler@69fb6037
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler, preferring the latter
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerDownHandler@69fb6037
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler, preferring the latter
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler@609db43b
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler, preferring the latter
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler@609db43b
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler, preferring the latter
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler@41c2284a
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler, preferring the latter
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler@41c2284a
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler, preferring the latter
03:05:34.416 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler@4f67eb2a
03:05:34.416 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler, preferring the latter
03:05:34.416 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler@4f67eb2a
03:05:34.599 [main] INFO  o.o.p.b.m.BmpMockDispatcher - BMP client /10.30.171.194:0 &lt;--&gt; /10.30.170.38:12345 deployed
03:05:34.617 [bmp-worker-0] DEBUG o.o.p.b.m.BmpMockDispatcher - Connection AbstractBootstrap$PendingRegistrationPromise@6a5a6961(success) succeeded!
03:05:34.618 [bmp-worker-0] INFO  o.o.p.b.m.BmpMockSession - BMP session [id: 0xd080e4b2, L:/10.30.171.194:43527 - R:10.30.170.38/10.30.170.38:12345] successfully established.</msg>
<arg>${until_phrase}</arg>
<doc>Consumes and returns the server output until ``expected`` is encountered.</doc>
<status status="PASS" start="2026-06-06T03:05:33.600885" elapsed="1.788383"/>
</kw>
<doc>Starts bmp-mock on tools vm</doc>
<status status="PASS" start="2026-06-06T03:05:33.540605" elapsed="1.849072"/>
</test>
<test id="s1-s1-t3" name="Verify Data Reported" line="61">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.391433" level="INFO">&amp;{mapping} = { TOOL_IP=10.30.171.194 }</msg>
<var>&amp;{mapping}</var>
<arg>TOOL_IP=${TOOLS_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:05:35.390880" elapsed="0.000583"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.425815" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:35.425359" elapsed="0.000490"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.426734" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:35.426365" elapsed="0.000471">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:35.426945" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:35.426007" elapsed="0.000964"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.427534" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:35.427127" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.427881" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:05:35.428069" level="INFO">${template} = /rests/data/bmp-monitor:bmp-monitor
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:05:35.427727" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.428558" level="INFO">/rests/data/bmp-monitor:bmp-monitor
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.428263" elapsed="0.000347"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.429591" level="INFO">mapping: {'TOOL_IP': '10.30.171.194'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.429323" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.430123" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:05:35.429797" elapsed="0.000361"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.431078" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:05:35.430663" elapsed="0.000448"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:05:35.432384" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:05:35.431962" elapsed="0.000451"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:05:35.432470" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:05:35.432683" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:05:35.431339" elapsed="0.001372"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:05:35.432878" elapsed="0.000320"/>
</kw>
<var name="${key}">TOOL_IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:05:35.430508" elapsed="0.002734"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:05:35.430237" elapsed="0.003047"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:05:35.433330" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:05:35.433494" level="INFO">${mapping_to_use} = {'TOOL_IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:05:35.429004" elapsed="0.004516"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.428705" elapsed="0.004847"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.433730" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.433578" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.428680" elapsed="0.005128"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.434411" level="INFO">${final_text} = /rests/data/bmp-monitor:bmp-monitor</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:05:35.433938" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:05:35.434488" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:05:35.424730" elapsed="0.009976"/>
</kw>
<msg time="2026-06-06T03:05:35.434765" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:35.423768" elapsed="0.011048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.435306" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.435844" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.436354" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.436565" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.436812" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.437189" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.437061" elapsed="0.000185"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:35.437045" elapsed="0.000225"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.437411" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.437567" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.437732" elapsed="0.000046"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:05:35.437017" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:05:35.436910" elapsed="0.000946"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.437992" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:05:35.438071" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:05:35.438184" level="INFO">${uri} = /rests/data/bmp-monitor:bmp-monitor</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:05:35.419685" elapsed="0.018525"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.439490" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:35.439233" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:35.439684" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:35.438898" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.440057" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.439784" elapsed="0.000350"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.440633" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:35.440310" elapsed="0.000375"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.440161" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.439765" elapsed="0.000978"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.443246" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:35.440878" elapsed="0.002396"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:05:35.443329" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:05:35.443488" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:05:35.438549" elapsed="0.004966"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.444784" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:35.444457" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:35.444949" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:35.444134" elapsed="0.000839"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:05:35.445185" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:05:35.445047" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.445028" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.445402" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.445556" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:05:35.445622" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:05:35.447370" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:05:35.443821" elapsed="0.003576"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.448883" level="INFO">/rests/data/bmp-monitor:bmp-monitor</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.448604" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.449312" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.449065" elapsed="0.000291"/>
</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-06-06T03:05:35.468730" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bmp-monitor:bmp-monitor 
 path_url=/rests/data/bmp-monitor:bmp-monitor 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0cai9uvcb7e8hwuyyixdowq0x0.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:35.470326" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bmp-monitor:bmp-monitor 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '882'} 
 body={"bmp-monitor:bmp-monitor":{"monitor":[{"monitor-id":"example-bmp-monitor","router":[{"router-id":"10.30.171.194","peer":[{"peer-id":"1.1.1.1","pre-policy-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"type":"global","bgp-id":"1.1.1.1","address":"1.1.1.1","post-policy-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-session":{"remote-port":179,"local-address":"10.30.171.194","status":"up","sent-open":{"hold-timer":180,"my-as-number":65431,"bgp-identifier":"10.30.171.194"},"timestamp-sec":0,"local-port":179,"received-open":{"hold-timer":180,"my-as-number":65431,"bgp-identifier":"1.1.1.1"}},"as":65431}],"status":"up","description":"OpenDaylight","name":"BMP mock","info":""}]}]}} 
 </msg>
<msg time="2026-06-06T03:05:35.470606" 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-06-06T03:05:35.451284" elapsed="0.019506"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.449424" elapsed="0.021473"/>
</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-06-06T03:05:35.471342" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.470961" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.449404" elapsed="0.022141"/>
</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-06-06T03:05:35.479351" level="INFO">{"bmp-monitor:bmp-monitor":{"monitor":[{"monitor-id":"example-bmp-monitor","router":[{"router-id":"10.30.171.194","peer":[{"peer-id":"1.1.1.1","pre-policy-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"type":"global","bgp-id":"1.1.1.1","address":"1.1.1.1","post-policy-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-session":{"remote-port":179,"local-address":"10.30.171.194","status":"up","sent-open":{"hold-timer":180,"my-as-number":65431,"bgp-identifier":"10.30.171.194"},"timestamp-sec":0,"local-port":179,"received-open":{"hold-timer":180,"my-as-number":65431,"bgp-identifier":"1.1.1.1"}},"as":65431}],"status":"up","description":"OpenDaylight","name":"BMP mock","info":""}]}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.473891" elapsed="0.005656"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.473401" elapsed="0.006234"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.473358" elapsed="0.006373"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.483004" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.480392" elapsed="0.002659"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.479872" elapsed="0.003215"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.479829" elapsed="0.003283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.483702" 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-06-06T03:05:35.483271" elapsed="0.000459"/>
</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-06-06T03:05:35.484019" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.483804" elapsed="0.000274"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.484551" 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-06-06T03:05:35.484241" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.484103" elapsed="0.000565"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.483785" elapsed="0.000907"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.485205" 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-06-06T03:05:35.484833" elapsed="0.000402"/>
</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-06-06T03:05:35.485516" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.485306" elapsed="0.000266"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.486041" 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-06-06T03:05:35.485745" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.485596" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.485287" elapsed="0.000837"/>
</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-06-06T03:05:35.486259" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:05:35.487078" 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-06-06T03:05:35.486770" elapsed="0.000335"/>
</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-06-06T03:05:35.487242" elapsed="0.002434"/>
</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-06-06T03:05:35.472353" elapsed="0.017394"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:05:35.489929" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:35.489817" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.489798" elapsed="0.000201"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:05:35.493616" level="INFO">${text_normalized} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor",
    "router": [
     {
      "description": "OpenDaylight",
      "info": "",
      "name": "BMP mock",
   ...</msg>
<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="PASS" start="2026-06-06T03:05:35.490125" elapsed="0.003536"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:05:35.493717" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:05:35.493952" level="INFO">${response_text} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor",
    "router": [
     {
      "description": "OpenDaylight",
      "info": "",
      "name": "BMP mock",
   ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:05:35.447744" elapsed="0.046236"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:05:35.494045" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:05:35.494207" level="INFO">${response_text} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor",
    "router": [
     {
      "description": "OpenDaylight",
      "info": "",
      "name": "BMP mock",
   ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:05:35.399681" elapsed="0.094560"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.508930" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:35.508507" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.509759" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:05:35.509416" elapsed="0.000421">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:05:35.509933" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:05:35.509101" elapsed="0.000856"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.510491" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:35.510103" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.510818" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bmp_basic/filled_structure/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:05:35.510989" level="INFO">${template} = {
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor",
                "router": [
                    {
                        "ro...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:05:35.510675" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.511403" level="INFO">{
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor",
                "router": [
                    {
                        "router-id": "$TOOL_IP",
                        "peer": [
                            {
                                "peer-id": "1.1.1.1",
                                "as": 65431,
                                "address": "1.1.1.1",
                                "bgp-id": "1.1.1.1",
                                "pre-policy-rib": {
                                    "tables": [
                                        {
                                            "afi": "bgp-types:ipv4-address-family",
                                            "safi": "bgp-types:unicast-subsequent-address-family",
                                            "attributes": {
                                                "uptodate": false
                                            }
                                        }
                                    ]
                                },
                                "peer-session": {
                                    "received-open": {
                                        "hold-timer": 180,
                                        "bgp-identifier": "1.1.1.1",
                                        "my-as-number": 65431
                                    },
                                    "remote-port": 179,
                                    "status": "up",
                                    "local-address": "$TOOL_IP",
                                    "timestamp-sec": 0,
                                    "sent-open": {
                                        "hold-timer": 180,
                                        "bgp-identifier": "$TOOL_IP",
                                        "my-as-number": 65431
                                    },
                                    "local-port": 179
                                },
                                "post-policy-rib": {
                                    "tables": [
                                        {
                                            "afi": "bgp-types:ipv4-address-family",
                                            "safi": "bgp-types:unicast-subsequent-address-family",
                                            "attributes": {
                                                "uptodate": false
                                            }
                                        }
                                    ]
                                },
                                "type": "global"
                            }
                        ],
                        "status": "up",
                        "info": "",
                        "description": "OpenDaylight",
                        "name": "BMP mock"
                    }
                ]
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.511156" elapsed="0.000343"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:05:35.511864" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.511569" elapsed="0.000354"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.512381" level="INFO">${mapping_to_use} = {'TOOL_IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:35.512079" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.511948" elapsed="0.000494"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.511549" elapsed="0.000915"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.513618" level="INFO">${final_text} = {
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor",
                "router": [
                    {
                        "ro...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:05:35.512588" elapsed="0.001088"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:05:35.513729" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:05:35.507917" elapsed="0.005941"/>
</kw>
<msg time="2026-06-06T03:05:35.513927" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:35.507125" elapsed="0.006851"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.514468" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.515201" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure.vanadium/bgp-bmp-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bmp_basic/filled_structure/bgp-bmp-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.515708" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.515876" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.516046" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.516422" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.516295" elapsed="0.000183"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:05:35.516280" elapsed="0.000223"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.516624" elapsed="0.000037"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.516823" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.516974" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:05:35.516249" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:05:35.516137" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.517227" elapsed="0.000027"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:05:35.517323" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:05:35.517453" level="INFO">${expected_text} = {
    "bmp-monitor:bmp-monitor": {
        "monitor": [
            {
                "monitor-id": "example-bmp-monitor",
                "router": [
                    {
                        "ro...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:05:35.504753" elapsed="0.012728"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:35.517668" elapsed="0.002057"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:05:35.521353" level="INFO">${expected_normalized} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor",
    "router": [
     {
      "description": "OpenDaylight",
      "info": "",
      "name": "BMP mock",
   ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:05:35.520490" elapsed="0.000893"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:05:35.522328" level="INFO">${actual_normalized} = {
 "bmp-monitor:bmp-monitor": {
  "monitor": [
   {
    "monitor-id": "example-bmp-monitor",
    "router": [
     {
      "description": "OpenDaylight",
      "info": "",
      "name": "BMP mock",
   ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:05:35.521522" elapsed="0.000836"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:05:35.522503" elapsed="0.000364"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:05:35.520071" elapsed="0.002859"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.519809" elapsed="0.003154"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:35.523119" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:35.522989" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.519789" elapsed="0.003407"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:05:35.495451" elapsed="0.027794"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:05:35.494599" elapsed="0.028721"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:35.494331" elapsed="0.029034"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:35.494311" elapsed="0.029080"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:05:35.523426" elapsed="0.000028"/>
</return>
<arg>folder=${BGP_BMP_DIR}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:05:35.395521" elapsed="0.128035"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>folder=${BGP_BMP_DIR}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:05:35.391620" elapsed="0.131996"/>
</kw>
<doc>Verifies if the tool reported expected data</doc>
<status status="PASS" start="2026-06-06T03:05:35.390328" elapsed="0.133442"/>
</test>
<test id="s1-s1-t4" name="Stop_Bmp_Mock" line="73">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.525112" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:05:35.524785" elapsed="0.000355"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:05:35.525276" elapsed="0.000314"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:05:35.524438" elapsed="0.001255"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:05:35.809421" level="INFO">03:05:34.778 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: InitiationMessage{tlvs=Tlvs{descriptionTlv=DescriptionTlv{description=OpenDaylight}, nameTlv=NameTlv{name=BMP mock}}}
03:05:34.806 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: PeerUpNotification{localAddress=IpAddressNoZone{ipv4AddressNoZone=Ipv4Address{value=10.30.171.194}}, localPort=PortNumber{value=179}, peerHeader=PeerHeader{address=IpAddressNoZone{ipv4AddressNoZone=Ipv4Address{value=1.1.1.1}}, adjRibInType=PrePolicy, as=AsNumber{value=65431}, bgpId=Ipv4Address{value=1.1.1.1}, ipv4=true, type=Global}, receivedOpen=ReceivedOpen{bgpIdentifier=Ipv4Address{value=1.1.1.1}, holdTimer=180, myAsNumber=65431, version=ProtocolVersion{value=4}}, remotePort=PortNumber{value=179}, sentOpen=SentOpen{bgpIdentifier=Ipv4Address{value=10.30.171.194}, holdTimer=180, myAsNumber=65431, version=ProtocolVersion{value=4}}}
03:05:34.807 [bmp-worker-0] DEBUG o.o.p.b.m.BmpMockSession - BMP router /10.30.171.194:43527 advertized peer Ipv4Address{value=1.1.1.1}
^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:05:35.809899" level="INFO">${output} = 
03:05:34.778 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: InitiationMessage{tlvs=Tlvs{descriptionTlv=DescriptionTlv{description=OpenDaylight}, nameTlv=NameTlv{nam...</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:05:35.525836" elapsed="0.284125"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.810970" level="INFO">
03:05:34.778 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: InitiationMessage{tlvs=Tlvs{descriptionTlv=DescriptionTlv{description=OpenDaylight}, nameTlv=NameTlv{name=BMP mock}}}
03:05:34.806 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: PeerUpNotification{localAddress=IpAddressNoZone{ipv4AddressNoZone=Ipv4Address{value=10.30.171.194}}, localPort=PortNumber{value=179}, peerHeader=PeerHeader{address=IpAddressNoZone{ipv4AddressNoZone=Ipv4Address{value=1.1.1.1}}, adjRibInType=PrePolicy, as=AsNumber{value=65431}, bgpId=Ipv4Address{value=1.1.1.1}, ipv4=true, type=Global}, receivedOpen=ReceivedOpen{bgpIdentifier=Ipv4Address{value=1.1.1.1}, holdTimer=180, myAsNumber=65431, version=ProtocolVersion{value=4}}, remotePort=PortNumber{value=179}, sentOpen=SentOpen{bgpIdentifier=Ipv4Address{value=10.30.171.194}, holdTimer=180, myAsNumber=65431, version=ProtocolVersion{value=4}}}
03:05:34.807 [bmp-worker-0] DEBUG o.o.p.b.m.BmpMockSession - BMP router /10.30.171.194:43527 advertized peer Ipv4Address{value=1.1.1.1}
^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.810367" elapsed="0.000700"/>
</kw>
<doc>Send ctrl+c to bmp-mock to stop it</doc>
<status status="PASS" start="2026-06-06T03:05:35.523998" elapsed="0.287253"/>
</test>
<kw name="Tear_It_Down" type="TEARDOWN">
<kw name="Get File" owner="SSHLibrary">
<msg time="2026-06-06T03:05:35.823934" level="INFO">[chan 6] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:05:35.833828" level="INFO">'bmpmock.log' -&gt; '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bmpmock.log'</msg>
<arg>${BMP_LOG_FILE}</arg>
<doc>Downloads file(s) from the remote machine to the local machine.</doc>
<status status="PASS" start="2026-06-06T03:05:35.812468" elapsed="0.021533"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:05:35.834874" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bmpmock.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bmpmock.log&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:05:35.835393" level="INFO">${cnt} = 03:05:34.035 [main] INFO org.opendaylight.protocol.bmp.mock.BmpMock -- Starting BMP test tool.
03:05:34.251 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message...</msg>
<var>${cnt}</var>
<arg>${BMP_LOG_FILE}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:05:35.834415" elapsed="0.001043"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:35.836512" level="INFO">03:05:34.035 [main] INFO org.opendaylight.protocol.bmp.mock.BmpMock -- Starting BMP test tool.
03:05:34.251 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler, preferring the latter
03:05:34.252 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler@448ff1a8
03:05:34.252 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler, preferring the latter
03:05:34.253 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler@448ff1a8
03:05:34.253 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler, preferring the latter
03:05:34.253 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.AsTwoOctetSpecificEcHandler@448ff1a8
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler, preferring the latter
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler@36f0f1be
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler, preferring the latter
03:05:34.254 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler@36f0f1be
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler, preferring the latter
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.Ipv4SpecificEcHandler@36f0f1be
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler, preferring the latter
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler@4de5031f
03:05:34.255 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler, preferring the latter
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler@4de5031f
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler, preferring the latter
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.OpaqueEcHandler@4de5031f
03:05:34.256 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler, preferring the latter
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler@568bf312
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler, preferring the latter
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler@568bf312
03:05:34.257 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler, preferring the latter
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginAsTwoOctetEcHandler@568bf312
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler, preferring the latter
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler@35083305
03:05:34.258 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler, preferring the latter
03:05:34.259 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler@35083305
03:05:34.259 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler, preferring the latter
03:05:34.259 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetAsTwoOctetEcHandler@35083305
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler, preferring the latter
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler@3ec300f1
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler, preferring the latter
03:05:34.260 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler@3ec300f1
03:05:34.261 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler, preferring the latter
03:05:34.261 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.RouteOriginIpv4EcHandler@3ec300f1
03:05:34.261 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler, preferring the latter
03:05:34.262 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler@25b485ba
03:05:34.262 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler, preferring the latter
03:05:34.262 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler@25b485ba
03:05:34.263 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler, preferring the latter
03:05:34.263 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTargetIpv4EcHandler@25b485ba
03:05:34.264 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC, preferring the latter
03:05:34.264 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC@5af97850
03:05:34.264 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC, preferring the latter
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.LinkBandwidthEC@5af97850
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler, preferring the latter
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler@4034c28c
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler, preferring the latter
03:05:34.265 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler@4034c28c
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler, preferring the latter
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.Generic4OctASEcHandler@4034c28c
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler, preferring the latter
03:05:34.266 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler@4b168fa9
03:05:34.267 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler, preferring the latter
03:05:34.267 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.route.target.RouteTarget4OctectASEcHandler@4b168fa9
03:05:34.267 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler, preferring the latter
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler@55a561cf
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler, preferring the latter
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.RouteOrigin4OctectASEcHandler@55a561cf
03:05:34.268 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC, preferring the latter
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC@6295d394
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC, preferring the latter
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.EncapsulationEC@6295d394
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler, preferring the latter
03:05:34.269 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler@2aa5fe93
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler, preferring the latter
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.VrfRouteImportHandler@2aa5fe93
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler, preferring the latter
03:05:34.270 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler@3e3047e6
03:05:34.271 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler, preferring the latter
03:05:34.271 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.four.octect.as.specific.SourceAS4OctectHandler@3e3047e6
03:05:34.271 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler, preferring the latter
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler@6ab7a896
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler, preferring the latter
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.extended.communities.SourceASHandler@6ab7a896
03:05:34.272 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler, preferring the latter
03:05:34.273 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler@d83da2e
03:05:34.273 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler, preferring the latter
03:05:34.273 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.MultiProtocolCapabilityHandler@d83da2e
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler, preferring the latter
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler@4f638935
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler, preferring the latter
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.AddPathCapabilityHandler@4f638935
03:05:34.274 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler, preferring the latter
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler@7ff95560
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler, preferring the latter
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.RouteRefreshCapabilityHandler@7ff95560
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler, preferring the latter
03:05:34.275 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler@78dd667e
03:05:34.276 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler, preferring the latter
03:05:34.276 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.As4CapabilityHandler@78dd667e
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler, preferring the latter
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler@6293abcc
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler, preferring the latter
03:05:34.277 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.GracefulCapabilityHandler@6293abcc
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler, preferring the latter
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler@23986957
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler, preferring the latter
03:05:34.278 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.LlGracefulCapabilityHandler@23986957
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser, preferring the latter
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser@6b19b79
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser, preferring the latter
03:05:34.279 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.CapabilityParameterParser@6b19b79
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler, preferring the latter
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler@4fe767f3
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler, preferring the latter
03:05:34.280 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.open.BgpExtendedMessageCapabilityHandler@4fe767f3
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser, preferring the latter
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser@ec756bd
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser, preferring the latter
03:05:34.281 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.BgpPrefixSidAttributeParser@ec756bd
03:05:34.286 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser, preferring the latter
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser@5dd6264
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser, preferring the latter
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginAttributeParser@5dd6264
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser, preferring the latter
03:05:34.287 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser@6ac13091
03:05:34.288 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser, preferring the latter
03:05:34.288 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AigpAttributeParser@6ac13091
03:05:34.289 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser, preferring the latter
03:05:34.289 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser@1ed1993a
03:05:34.289 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser, preferring the latter
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AsPathAttributeParser@1ed1993a
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser, preferring the latter
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser@60d8c9b7
03:05:34.290 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser, preferring the latter
03:05:34.291 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.NextHopAttributeParser@60d8c9b7
03:05:34.291 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser, preferring the latter
03:05:34.291 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser@65466a6a
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser, preferring the latter
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MultiExitDiscriminatorAttributeParser@65466a6a
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser, preferring the latter
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser@79b06cab
03:05:34.292 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser, preferring the latter
03:05:34.293 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.LocalPreferenceAttributeParser@79b06cab
03:05:34.293 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser, preferring the latter
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser@7880cdf3
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser, preferring the latter
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AtomicAggregateAttributeParser@7880cdf3
03:05:34.294 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser, preferring the latter
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser@22a637e7
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser, preferring the latter
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AggregatorAttributeParser@22a637e7
03:05:34.295 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser, preferring the latter
03:05:34.296 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser@5ae50ce6
03:05:34.296 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser, preferring the latter
03:05:34.296 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.CommunitiesAttributeParser@5ae50ce6
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser, preferring the latter
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser@418e7838
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser, preferring the latter
03:05:34.297 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser@418e7838
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser, preferring the latter
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser@5a63f509
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser, preferring the latter
03:05:34.298 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser@5a63f509
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser, preferring the latter
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser@a9cd3b1
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser, preferring the latter
03:05:34.299 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPReachAttributeParser@a9cd3b1
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser, preferring the latter
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser@63355449
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser, preferring the latter
03:05:34.300 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.MPUnreachAttributeParser@63355449
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser, preferring the latter
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser@5c30a9b0
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser, preferring the latter
03:05:34.301 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.ExtendedCommunitiesAttributeParser@5c30a9b0
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4AggregatorAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4AggregatorAttributeParser, preferring the latter
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AS4AggregatorAttributeParser@3f197a46
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4PathAttributeParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.AS4PathAttributeParser, preferring the latter
03:05:34.302 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.AS4PathAttributeParser@6ca8564a
03:05:34.303 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.update.UnrecognizedAttributesSerializer is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.update.UnrecognizedAttributesSerializer, preferring the latter
03:05:34.303 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.update.UnrecognizedAttributesSerializer@76508ed1
03:05:34.304 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser, preferring the latter
03:05:34.304 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser@481a996b
03:05:34.305 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser, preferring the latter
03:05:34.305 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPOpenMessageParser@481a996b
03:05:34.306 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser, preferring the latter
03:05:34.306 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser@708f5957
03:05:34.312 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser, preferring the latter
03:05:34.312 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser@708f5957
03:05:34.312 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser, preferring the latter
03:05:34.313 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser@1ea9f6af
03:05:34.313 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser, preferring the latter
03:05:34.313 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPNotificationMessageParser@1ea9f6af
03:05:34.381 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser, preferring the latter
03:05:34.381 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser@62ddbd7e
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser, preferring the latter
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPKeepAliveMessageParser@62ddbd7e
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser, preferring the latter
03:05:34.382 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser@15de0b3c
03:05:34.383 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser is superclass of class org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser, preferring the latter
03:05:34.383 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bgp.parser.impl.message.BGPRouteRefreshMessageParser@15de0b3c
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler, preferring the latter
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler@c86b9e3
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler, preferring the latter
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.DescriptionTlvHandler@c86b9e3
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler, preferring the latter
03:05:34.395 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler@ed7f8b4
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler, preferring the latter
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.NameTlvHandler@ed7f8b4
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.396 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler, preferring the latter
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StringTlvHandler@6ab778a
03:05:34.397 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler, preferring the latter
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler@5c90e579
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler, preferring the latter
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.ReasonTlvHandler@5c90e579
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler, preferring the latter
03:05:34.398 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler@63070bab
03:05:34.399 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler, preferring the latter
03:05:34.399 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.MirrorInformationTlvHandler@63070bab
03:05:34.399 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler, preferring the latter
03:05:34.400 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler@762ef0ea
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler, preferring the latter
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType000TlvHandler@762ef0ea
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler, preferring the latter
03:05:34.401 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler@5f8edcc5
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler, preferring the latter
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType001TlvHandler@5f8edcc5
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler, preferring the latter
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler@15ca7889
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler, preferring the latter
03:05:34.402 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType002TlvHandler@15ca7889
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler, preferring the latter
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler@2898ac89
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler, preferring the latter
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType003TlvHandler@2898ac89
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler, preferring the latter
03:05:34.403 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler@6ff29830
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType004TlvHandler@6ff29830
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler@548e6d58
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType005TlvHandler@548e6d58
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler, preferring the latter
03:05:34.404 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler@3098cf3b
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler, preferring the latter
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType006TlvHandler@3098cf3b
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler, preferring the latter
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler@57250572
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler, preferring the latter
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType007TlvHandler@57250572
03:05:34.405 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler, preferring the latter
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler@11fc564b
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler, preferring the latter
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType008TlvHandler@11fc564b
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler, preferring the latter
03:05:34.406 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler@fa36558
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler, preferring the latter
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType009TlvHandler@fa36558
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler, preferring the latter
03:05:34.407 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler@3571b748
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler, preferring the latter
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType010TlvHandler@3571b748
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler, preferring the latter
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler@7c83dc97
03:05:34.408 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler, preferring the latter
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType011TlvHandler@7c83dc97
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler, preferring the latter
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler@55740540
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler, preferring the latter
03:05:34.409 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType012TlvHandler@55740540
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler, preferring the latter
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler@65b3f4a4
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler is superclass of class org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler, preferring the latter
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.tlv.StatType013TlvHandler@65b3f4a4
03:05:34.410 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.InitiationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.InitiationHandler, preferring the latter
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.InitiationHandler@2a266d09
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.InitiationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.InitiationHandler, preferring the latter
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.InitiationHandler@2a266d09
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.TerminationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.TerminationHandler, preferring the latter
03:05:34.411 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.TerminationHandler@757acd7b
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.TerminationHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.TerminationHandler, preferring the latter
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.TerminationHandler@757acd7b
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler, preferring the latter
03:05:34.412 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerUpHandler@343570b7
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerUpHandler, preferring the latter
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerUpHandler@343570b7
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler, preferring the latter
03:05:34.413 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerDownHandler@69fb6037
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.PeerDownHandler, preferring the latter
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.PeerDownHandler@69fb6037
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler, preferring the latter
03:05:34.414 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler@609db43b
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler, preferring the latter
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.StatisticsReportHandler@609db43b
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler, preferring the latter
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler@41c2284a
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler, preferring the latter
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMonitoringMessageHandler@41c2284a
03:05:34.415 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler, preferring the latter
03:05:34.416 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler@4f67eb2a
03:05:34.416 [main] DEBUG o.o.p.c.MultiRegistry - class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler is superclass of class org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler, preferring the latter
03:05:34.416 [main] DEBUG o.o.p.c.MultiRegistry - New best value org.opendaylight.protocol.bmp.parser.message.RouteMirroringMessageHandler@4f67eb2a
03:05:34.599 [main] INFO  o.o.p.b.m.BmpMockDispatcher - BMP client /10.30.171.194:0 &lt;--&gt; /10.30.170.38:12345 deployed
03:05:34.617 [bmp-worker-0] DEBUG o.o.p.b.m.BmpMockDispatcher - Connection AbstractBootstrap$PendingRegistrationPromise@6a5a6961(success) succeeded!
03:05:34.618 [bmp-worker-0] INFO  o.o.p.b.m.BmpMockSession - BMP session [id: 0xd080e4b2, L:/10.30.171.194:43527 - R:10.30.170.38/10.30.170.38:12345] successfully established.
03:05:34.778 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: InitiationMessage{tlvs=Tlvs{descriptionTlv=DescriptionTlv{description=OpenDaylight}, nameTlv=NameTlv{name=BMP mock}}}
03:05:34.806 [bmp-worker-0] DEBUG o.o.p.b.i.BmpMessageToByteEncoder - Message sent to output: PeerUpNotification{localAddress=IpAddressNoZone{ipv4AddressNoZone=Ipv4Address{value=10.30.171.194}}, localPort=PortNumber{value=179}, peerHeader=PeerHeader{address=IpAddressNoZone{ipv4AddressNoZone=Ipv4Address{value=1.1.1.1}}, adjRibInType=PrePolicy, as=AsNumber{value=65431}, bgpId=Ipv4Address{value=1.1.1.1}, ipv4=true, type=Global}, receivedOpen=ReceivedOpen{bgpIdentifier=Ipv4Address{value=1.1.1.1}, holdTimer=180, myAsNumber=65431, version=ProtocolVersion{value=4}}, remotePort=PortNumber{value=179}, sentOpen=SentOpen{bgpIdentifier=Ipv4Address{value=10.30.171.194}, holdTimer=180, myAsNumber=65431, version=ProtocolVersion{value=4}}}
03:05:34.807 [bmp-worker-0] DEBUG o.o.p.b.m.BmpMockSession - BMP router /10.30.171.194:43527 advertized peer Ipv4Address{value=1.1.1.1}
</msg>
<arg>${cnt}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:35.835868" elapsed="0.002677"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:35.839000" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:05:35.838839" elapsed="0.000326"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:05:35.839475" elapsed="0.001251"/>
</kw>
<doc>Download bmpmock.log and Log its contents.
Compute and Log the diff between expected and actual normalized responses.
Close both HTTP client session and SSH connection to Mininet.</doc>
<status status="PASS" start="2026-06-06T03:05:35.812132" elapsed="0.028697"/>
</kw>
<doc>Basic tests for odl-bgpcep-bmp feature

Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This is a basic suite for bgp monitoring protocol feature.
After the feature odl-bgpcep-bmp installation the port 12345 should be
bound for listening,
To test this feature bgp-bmp-mock tool is used. It is a part of the
bgpcep project. It is a java tool which simulates more peers and more
routers.
In this particular test suite it simulates 1 peer with 1 router, which
means it advertizes one peer ipv4 address towards odl. As a result one
route should appear in the rests/data/bmp-monitor:bmp-monitor?content=nonconfig.</doc>
<status status="PASS" start="2026-06-06T03:05:30.045049" elapsed="5.795836"/>
</suite>
<suite id="s1-s2" name="Pcepuser" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/pcepuser.robot">
<kw name="Set_It_Up" type="SETUP">
<kw name="Initialize_Artifact_Deployment_And_Usage" owner="NexusKeywords">
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:35.931275" level="INFO">${odl_connection} = 1</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-06-06T03:05:35.930741" elapsed="0.000568"/>
</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-06-06T03:05:35.933373" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:05:35.933506" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:35.933065" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:35.933715" elapsed="0.000465"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:05:35.935102" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:05:36.210990" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:05:28 UTC 2026

  System load:  0.91               Processes:             126
  Usage of /:   11.2% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:05:32 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:05:35.934730" elapsed="0.276453"/>
</kw>
<msg time="2026-06-06T03:05:36.211272" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:35.934347" elapsed="0.277197"/>
</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-06-06T03:05:35.932600" elapsed="0.279081"/>
</kw>
<msg time="2026-06-06T03:05:36.211738" 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-06-06T03:05:35.932034" elapsed="0.279751"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:05:35.931579" elapsed="0.280285"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-06-06T03:05:36.211919" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:05:36.212155" level="INFO">${odl} = 1</msg>
<var>${odl}</var>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:05:35.930327" elapsed="0.281855"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:05:36.218918" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:05:36.225224" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/../../tools/deployment/search.sh' -&gt; '/home/jenkins//search.sh'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/../../tools/deployment/search.sh</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:05:36.212394" elapsed="0.012915"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:05:36.225513" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="not (${tools_system_connect})">
<return>
<status status="NOT RUN" start="2026-06-06T03:05:36.226165" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:36.225982" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:36.225914" elapsed="0.000326"/>
</if>
<kw name="Open_Connection_To_Tools_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:36.230952" level="INFO">${tools_connection} = 2</msg>
<var>${tools_connection}</var>
<arg>${ip_address}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:05:36.230503" elapsed="0.000477"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:05:36.232786" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:05:36.232867" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:36.232475" elapsed="0.000416"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.233037" elapsed="0.000334"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:05:36.234252" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:05:36.610469" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:05:31 UTC 2026

  System load:  0.06               Processes:             110
  Usage of /:   19.3% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:05:31 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:05:36.233890" elapsed="0.376775"/>
</kw>
<msg time="2026-06-06T03:05:36.610752" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.233527" elapsed="0.377307"/>
</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-06-06T03:05:36.232048" elapsed="0.378905"/>
</kw>
<msg time="2026-06-06T03:05:36.611006" 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-06-06T03:05:36.231586" elapsed="0.379468"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:05:36.231251" elapsed="0.379902"/>
</kw>
<return>
<value>${tools_connection}</value>
<status status="PASS" start="2026-06-06T03:05:36.611205" elapsed="0.000042"/>
</return>
<doc>Open a connection to the tools system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:05:36.230112" elapsed="0.381262"/>
</kw>
<doc>Places search utility to ODL system, which will be needed for version detection.
By default also initialize a SSH connection to Tools system,
as following Keywords assume a working connection towards target system.</doc>
<status status="PASS" start="2026-06-06T03:05:35.926266" elapsed="0.685162"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:36.612001" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e76fe390&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:05:36.611631" elapsed="0.000554"/>
</kw>
<kw name="Deploy_Test_Tool" owner="NexusKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:36.628585" level="INFO">${name_prefix} = pcep-pcc-mock-</msg>
<var>${name_prefix}</var>
<arg>${artifact}-</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:36.628219" elapsed="0.000394"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:36.629158" level="INFO">${extension} = jar</msg>
<var>${extension}</var>
<arg>'${component}'=='odl-micro'</arg>
<arg>tar</arg>
<arg>jar</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:36.628787" elapsed="0.000399"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:36.629772" level="INFO">${name_suffix} = -executable.jar</msg>
<var>${name_suffix}</var>
<arg>"${suffix}" != ""</arg>
<arg>-${suffix}.${extension}</arg>
<arg>.${extension}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:36.629350" elapsed="0.000449"/>
</kw>
<kw name="Deploy_Artifact" owner="NexusKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${explicit_url}""" != ""</arg>
<arg>Deploy_From_Url</arg>
<arg>${explicit_url}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.631058" elapsed="0.000311"/>
</kw>
<kw name="Fetch From Left" owner="String">
<msg time="2026-06-06T03:05:36.631747" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>${BUNDLE_URL}</arg>
<arg>/org/opendaylight</arg>
<doc>Returns contents of the ``string`` before the first occurrence of ``marker``.</doc>
<status status="PASS" start="2026-06-06T03:05:36.631517" elapsed="0.000258"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:36.632312" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>'${urlbase}' != '${BUNDLE_URL}'</arg>
<arg>${urlbase}</arg>
<arg>${fallback_url}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:36.631924" elapsed="0.000414"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Magnesium" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.649106" elapsed="0.000440"/>
</kw>
<arg>magnesium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'carpeople'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:36.648698" elapsed="0.000930"/>
</kw>
<msg time="2026-06-06T03:05:36.649776" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>magnesium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.640882" elapsed="0.008959"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>carpeople</arg>
<doc>Compare magnesium to vanadium and in case vanadium is at most magnesium,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:36.640419" elapsed="0.009502"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Aluminium" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.666382" elapsed="0.000439"/>
</kw>
<arg>aluminium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'netconf'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:36.665987" elapsed="0.000904"/>
</kw>
<msg time="2026-06-06T03:05:36.666937" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>aluminium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.658313" elapsed="0.008673"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>netconf</arg>
<doc>Compare aluminium to vanadium and in case vanadium is at most aluminium,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:36.657983" elapsed="0.009079"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Silicon" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.685344" elapsed="0.000436"/>
</kw>
<arg>silicon</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'bgpcep'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:36.684927" elapsed="0.000928"/>
</kw>
<msg time="2026-06-06T03:05:36.685902" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>silicon</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.675415" elapsed="0.010538"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>bgpcep</arg>
<doc>Compare silicon to vanadium and in case vanadium is at most silicon,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:05:36.675090" elapsed="0.010939"/>
</kw>
<if>
<branch type="IF" condition="'${build_version}'=='${EMPTY}'">
<kw name="NexusKeywords__Detect_Version_To_Pull" owner="NexusKeywords">
<kw name="NexusKeywords__Get_Items_To_Look_At" owner="NexusKeywords">
<kw name="Dictionary Should Contain Key" owner="Collections">
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<arg>Component not supported by NexusKeywords version detection: ${component}</arg>
<doc>Fails if ``key`` is not found from ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:05:36.688748" elapsed="0.000281"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-06-06T03:05:36.689513" elapsed="0.000199"/>
</kw>
<msg time="2026-06-06T03:05:36.689759" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Collections.Get_From_Dictionary</arg>
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.689181" elapsed="0.000627"/>
</kw>
<msg time="2026-06-06T03:05:36.689914" level="INFO">${itemlist} = pcep-impl</msg>
<var>${itemlist}</var>
<arg>${component}</arg>
<doc>Get a list of items that might contain the version number that we are looking for.</doc>
<status status="PASS" start="2026-06-06T03:05:36.688481" elapsed="0.001458"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:36.690221" level="INFO">index=2
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:05:36.690328" level="INFO">${current_ssh_connection} = index=2
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:05:36.690082" elapsed="0.000273"/>
</kw>
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:05:36.694791" level="INFO">${odl_connection} = 3</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-06-06T03:05:36.694353" elapsed="0.000465"/>
</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-06-06T03:05:36.696379" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:05:36.696456" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:36.696099" elapsed="0.000381"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.696621" elapsed="0.000340"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:05:36.698275" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:05:37.047005" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:05:28 UTC 2026

  System load:  0.91               Processes:             126
  Usage of /:   11.2% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:05:36 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:05:36.697453" elapsed="0.349921"/>
</kw>
<msg time="2026-06-06T03:05:37.047484" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:36.697113" elapsed="0.350479"/>
</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-06-06T03:05:36.695682" elapsed="0.352084"/>
</kw>
<msg time="2026-06-06T03:05:37.047843" 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-06-06T03:05:36.695294" elapsed="0.352620"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:05:36.694981" elapsed="0.353041"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-06-06T03:05:37.048094" elapsed="0.000057"/>
</return>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:05:36.694068" elapsed="0.354262"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:37.049009" level="INFO">Executing command 'sh search.sh /tmp/karaf-0.24.0/system pcep-impl'.</msg>
<msg time="2026-06-06T03:05:37.082531" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:37.082849" level="INFO">${version} = 2.0.0
org/opendaylight/bgpcep</msg>
<msg time="2026-06-06T03:05:37.082915" level="INFO">${result} = 0</msg>
<var>${version}</var>
<var>${result}</var>
<arg>sh search.sh ${WORKSPACE}/${BUNDLEFOLDER}/system ${itemlist}</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:37.048593" elapsed="0.034358"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:05:37.083266" elapsed="0.000764"/>
</kw>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:05:37.090457" elapsed="0.000356"/>
</kw>
<msg time="2026-06-06T03:05:37.090915" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:05:37.089323" elapsed="0.001712"/>
</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="NOT RUN" start="2026-06-06T03:05:37.091412" elapsed="0.000051"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:37.091780" elapsed="0.000057"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:05:37.084619" elapsed="0.007400"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.092577" level="INFO">2.0.0
org/opendaylight/bgpcep</msg>
<arg>${version}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.092299" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${result}!=0">
<kw name="Fail" owner="BuiltIn">
<arg>Component "${component}": searching for "${itemlist}" found no version, cannot locate test tool.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:37.093134" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:37.092745" elapsed="0.000446"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.092713" elapsed="0.000508"/>
</if>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:05:37.093616" level="INFO">${version} = 2.0.0</msg>
<msg time="2026-06-06T03:05:37.093683" level="INFO">${location} = org/opendaylight/bgpcep</msg>
<var>${version}</var>
<var>${location}</var>
<arg>${version}</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:05:37.093352" elapsed="0.000356"/>
</kw>
<return>
<value>${version}</value>
<value>${location}</value>
<status status="PASS" start="2026-06-06T03:05:37.093766" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:05:37.093980" level="INFO">${version} = 2.0.0</msg>
<msg time="2026-06-06T03:05:37.094023" level="INFO">${location} = org/opendaylight/bgpcep</msg>
<var>${version}</var>
<var>${location}</var>
<arg>${component}</arg>
<doc>Determine the exact Nexus directory to be used as a source for a particular test tool
Figure out what version of the tool needs to be pulled out of the
Nexus by looking at the version directory of the subsystem from
which the tool is being pulled. This code is REALLY UGLY but there
is no way around it until the bug
https://bugs.opendaylight.org/show_bug.cgi?id=5206 gets fixed.
I also don't want to depend on maven-metadata-local.xml and other
bits and pieces of ODL distribution which are not required for ODL
to function properly.</doc>
<status status="PASS" start="2026-06-06T03:05:36.688126" elapsed="0.405920"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:36.686118" elapsed="0.407972"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${version}</var>
<var>${location}</var>
<arg>${build_version}</arg>
<arg>${build_location}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:37.094256" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:37.094117" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:36.686092" elapsed="0.408247"/>
</if>
<if>
<branch type="IF" condition="'SNAPSHOT' in '${version}'">
<kw name="Remove Values From List" owner="Collections">
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>netconf</arg>
<arg>bgpcep</arg>
<doc>Removes all occurrences of given ``values`` from ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:37.094602" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:37.094398" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.094381" elapsed="0.000321"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.095243" level="INFO">${is_staged} = "TRUE"</msg>
<var>${is_staged}</var>
<arg>"opendaylight.release" not in '${urlbase}' and "opendaylight.snapshot" not in '${urlbase}'</arg>
<arg>"TRUE"</arg>
<arg>"FALSE"</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:37.094842" elapsed="0.000431"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.095865" level="INFO">${is_mri_component} = "TRUE"</msg>
<var>${is_mri_component}</var>
<arg>'${component}' in ${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>"TRUE"</arg>
<arg>"FALSE"</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:37.095449" elapsed="0.000442"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.096582" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>${is_mri_component} == "TRUE" and ${is_staged} == "FALSE"</arg>
<arg>${NEXUS_RELEASE_BASE_URL}</arg>
<arg>${urlbase}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:37.096174" elapsed="0.000435"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.097152" level="INFO">${url} = https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0</msg>
<var>${url}</var>
<arg>${urlbase}/${location}/${artifact}/${version}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:37.096781" elapsed="0.000397"/>
</kw>
<kw name="Execute_Command_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:37.099054" level="INFO">Executing command 'curl -L https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml'.</msg>
<msg time="2026-06-06T03:05:37.183757" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:37.184193" level="INFO">${stdout} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autore...</msg>
<msg time="2026-06-06T03:05:37.184362" level="INFO">${stderr} =   % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0   ...</msg>
<msg time="2026-06-06T03:05:37.184506" 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-06-06T03:05:37.098854" elapsed="0.085731"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.187249" level="INFO">Length is 316.</msg>
<msg time="2026-06-06T03:05:37.187427" level="FAIL">'  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1098    0  1098    0     0  17031      0 --:--:-- --:--:-- --:--:-- 17156' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:05:37.186414" elapsed="0.001153">'  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1098    0  1098    0     0  17031      0 --:--:-- --:--:-- --:--:-- 17156' should be empty.</status>
</kw>
<msg time="2026-06-06T03:05:37.187796" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:05:37.187874" level="INFO">${result} = '  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0  ...</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-06-06T03:05:37.185278" elapsed="0.002639"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.188886" 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-06-06T03:05:37.188205" elapsed="0.000726"/>
</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-06-06T03:05:37.191036" level="INFO">&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8"/&gt;

    &lt;link rel="icon" type="image/png" href="https://nexus.opendaylight.org/favicon.png"&gt;
    &lt;!--[if IE]&gt;
    &lt;link rel="SHORTCUT ICON" href="https://nexus.opendaylight.org/favicon.ico"/&gt;
    &lt;![endif]--&gt;

    &lt;link rel="stylesheet" href="https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02" type="text/css" media="screen" title="no title" charset="utf-8"&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/h1&gt;
    &lt;p&gt;Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/p&gt;
  &lt;/body&gt;
&lt;/html&gt;</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.190222" elapsed="0.000906"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.191809" level="INFO">  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1098    0  1098    0     0  17031      0 --:--:-- --:--:-- --:--:-- 17156</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.191330" elapsed="0.000551"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.192386" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.192080" elapsed="0.000354"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:05:37.189701" elapsed="0.002791"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:37.189092" elapsed="0.003439"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.189043" elapsed="0.003518"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:05:37.192748" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:37.192620" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.192602" elapsed="0.000219"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:05:37.192983" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:05:37.192875" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.192859" elapsed="0.000221"/>
</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-06-06T03:05:37.193279" elapsed="0.000029"/>
</kw>
<arg>${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-06-06T03:05:37.098299" elapsed="0.095134"/>
</kw>
<msg time="2026-06-06T03:05:37.193499" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${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-06-06T03:05:37.097760" elapsed="0.095788"/>
</kw>
<msg time="2026-06-06T03:05:37.193723" level="INFO">${metadata} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autore...</msg>
<var>${metadata}</var>
<arg>curl -L ${url}/maven-metadata.xml</arg>
<doc>A wrapper for Execute_Command_Passes with return_success_only=False
Also, log_on_success defaults to True (but is customizable, unlike return_success_only)..</doc>
<status status="PASS" start="2026-06-06T03:05:37.097388" elapsed="0.096364"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Command_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:37.196029" level="INFO">Executing command 'echo "&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8"/&gt;

    &lt;link rel="icon" type="image/png" href="https://nexus.opendaylight.org/favicon.png"&gt;
    &lt;!--[if IE]&gt;
    &lt;link rel="SHORTCUT ICON" href="https://nexus.opendaylight.org/favicon.ico"/&gt;
    &lt;![endif]--&gt;

    &lt;link rel="stylesheet" href="https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02" type="text/css" media="screen" title="no title" charset="utf-8"&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/h1&gt;
    &lt;p&gt;Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/p&gt;
  &lt;/body&gt;
&lt;/html&gt;" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1'.</msg>
<msg time="2026-06-06T03:05:37.237339" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:37.237704" level="INFO">${stdout} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autore...</msg>
<msg time="2026-06-06T03:05:37.237824" level="INFO">${stderr} = bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text...</msg>
<msg time="2026-06-06T03:05:37.237924" 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-06-06T03:05:37.195835" elapsed="0.042143"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.239998" level="INFO">Length is 253.</msg>
<msg time="2026-06-06T03:05:37.240193" level="FAIL">'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:05:37.239265" elapsed="0.001083">'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory' should be empty.</status>
</kw>
<msg time="2026-06-06T03:05:37.240597" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:05:37.240734" level="INFO">${result} = 'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=tex...</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-06-06T03:05:37.238411" elapsed="0.002384"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.242163" level="INFO">${success} = False</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-06-06T03:05:37.241149" elapsed="0.001074"/>
</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-06-06T03:05:37.244770" level="INFO">&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv=Content-Type content=text/html</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.244147" elapsed="0.000739"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.245768" level="INFO">bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.245195" elapsed="0.000681"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.246912" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.246177" elapsed="0.000843"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:05:37.243199" elapsed="0.004100"/>
</kw>
<status status="PASS" start="2026-06-06T03:05:37.242411" elapsed="0.005007"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.242361" elapsed="0.005123"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:05:37.247989" elapsed="0.000036"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:37.247728" elapsed="0.000366"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.247580" elapsed="0.000568"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:05:37.248352" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:37.248258" elapsed="0.000137"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.248235" elapsed="0.000183"/>
</if>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.248943" level="FAIL">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</msg>
<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="FAIL" start="2026-06-06T03:05:37.248549" elapsed="0.000463">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<arg>${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="FAIL" start="2026-06-06T03:05:37.195247" elapsed="0.053892">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<msg time="2026-06-06T03:05:37.249202" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${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="FAIL" start="2026-06-06T03:05:37.194727" elapsed="0.054528"/>
</kw>
<arg>echo "${metadata}" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1</arg>
<arg>stderr_must_be_empty=${True}</arg>
<doc>A wrapper for Execute_Command_Passes with return_success_only=False
Also, log_on_success defaults to True (but is customizable, unlike return_success_only)..</doc>
<status status="FAIL" start="2026-06-06T03:05:37.194298" elapsed="0.055068">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<msg time="2026-06-06T03:05:37.249481" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:05:37.249528" level="INFO">${namepart} = Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonaty...</msg>
<var>${status}</var>
<var>${namepart}</var>
<arg>SSHKeywords.Execute_Command_Should_Pass</arg>
<arg>echo "${metadata}" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1</arg>
<arg>stderr_must_be_empty=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:05:37.193904" elapsed="0.055650"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.250010" level="INFO">Length is 288.</msg>
<msg time="2026-06-06T03:05:37.250088" level="INFO">${length} = 288</msg>
<var>${length}</var>
<arg>${namepart}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:05:37.249733" elapsed="0.000379"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.250699" level="INFO">${namepart} = 2.0.0</msg>
<var>${namepart}</var>
<arg>"${status}" != "PASS" or ${length} == 0</arg>
<arg>${version}</arg>
<arg>${namepart}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:37.250270" elapsed="0.000457"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.251231" level="INFO">${filename} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${filename}</var>
<arg>${name_prefix}${namepart}${name_suffix}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:37.250878" elapsed="0.000381"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.251682" level="INFO">pcep-pcc-mock-2.0.0-executable.jar</msg>
<arg>${filename}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.251401" elapsed="0.000334"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.252192" level="INFO">${url} = https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${url}</var>
<arg>${url}/${filename}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:05:37.251875" elapsed="0.000345"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:37.252555" level="INFO">Executing command 'wget -q -N 'https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar' 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:05:37.308985" level="INFO">Command exited with return code 8.</msg>
<msg time="2026-06-06T03:05:37.309372" level="INFO">${response} = </msg>
<msg time="2026-06-06T03:05:37.309484" level="INFO">${result} = 8</msg>
<var>${response}</var>
<var>${result}</var>
<arg>wget -q -N '${url}' 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:37.252377" elapsed="0.057165"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.310801" level="INFO"/>
<arg>${response}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:05:37.310049" elapsed="0.000858"/>
</kw>
<if>
<branch type="IF" condition="${result} == 0">
<return>
<value>${filename}</value>
<status status="NOT RUN" start="2026-06-06T03:05:37.311474" elapsed="0.000044"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:05:37.311093" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.311037" elapsed="0.000694"/>
</if>
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:05:37.313412" level="INFO">${release_url} = https://nexus.opendaylight.org/content/repositories//opendaylight.release/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${release_url}</var>
<arg>${url}</arg>
<arg>autorelease-[0-9]{4}</arg>
<arg>opendaylight.release</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:05:37.312222" elapsed="0.001256"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:05:37.314262" level="INFO">Executing command 'wget -q -N 'https://nexus.opendaylight.org/content/repositories//opendaylight.release/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar' 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:05:37.482907" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:05:37.483267" level="INFO">${response} = </msg>
<msg time="2026-06-06T03:05:37.483372" level="INFO">${result} = 0</msg>
<var>${response}</var>
<var>${result}</var>
<arg>wget -q -N '${release_url}' 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:05:37.313857" elapsed="0.169570"/>
</kw>
<if>
<branch type="IF" condition="${result} != 0">
<kw name="Fail" owner="BuiltIn">
<arg>Artifact "${artifact}" in component "${component}" could not be downloaded from ${release_url} nor ${url}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:37.484294" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:05:37.483720" elapsed="0.000704"/>
</branch>
<status status="PASS" start="2026-06-06T03:05:37.483606" elapsed="0.000875"/>
</if>
<return>
<value>${filename}</value>
<status status="PASS" start="2026-06-06T03:05:37.484561" elapsed="0.000076"/>
</return>
<msg time="2026-06-06T03:05:37.484966" level="INFO">${filename} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${filename}</var>
<arg>${component}</arg>
<arg>${artifact}</arg>
<arg>${name_prefix}</arg>
<arg>${name_suffix}</arg>
<arg>${fallback_url}</arg>
<arg>${explicit_url}</arg>
<arg>${build_version}</arg>
<arg>${build_location}</arg>
<doc>Deploy the specified artifact from Nexus to the cwd of the machine to which the active SSHLibrary connection points.
bgpcep is a name part of an artifact present in system/ of ODl installation with the same version as pcep-pcc-mock should have.
Must have https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/integration/karaf/0.24.0/karaf-0.24.0.zip variable set to the URL from which the
tested ODL distribution was downloaded and this place must be
inside a repository created by a standard distribution
construction job. If this is detected to ne be the case, fallback URL is used.
If  is non-empty, Deploy_From_Utrl is called instead.
TODO: Allow deploying to a specific directory, we have SSHKeywords.Execute_Command_At_Cwd_Should_Pass now.</doc>
<status status="PASS" start="2026-06-06T03:05:36.630404" elapsed="0.854619"/>
</kw>
<return>
<value>${filename}</value>
<status status="PASS" start="2026-06-06T03:05:37.485207" elapsed="0.000083"/>
</return>
<msg time="2026-06-06T03:05:37.485636" level="INFO">${name} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${name}</var>
<arg>bgpcep</arg>
<arg>pcep-pcc-mock</arg>
<doc>Deploy a test tool.
The test tools have naming convention of the form
"&lt;repository_url&gt;/some/dir/somewhere/&lt;tool-name&gt;/&lt;tool-name&gt;-&lt;version-tag&gt;-${suffix}.jar"
where "&lt;tool-name&gt;" is the name of the tool and "&lt;version-tag&gt;" is
the version tag that is digged out of the maven metadata. This
keyword calculates ${name_prefix} and ${name_suffix} for
"Deploy_Artifact" and then calls "Deploy_Artifact" to do the real
work of deploying the artifact.</doc>
<status status="PASS" start="2026-06-06T03:05:36.623001" elapsed="0.862744"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.493357" level="INFO">${filename} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<arg>${filename}</arg>
<arg>${name}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:05:37.486108" elapsed="0.007298"/>
</kw>
<kw name="Setup_Pcep_Operations" owner="PcepOperations">
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:37.494215" level="INFO">Creating Session using : alias=pcep_session, url=http://10.30.170.38:8181, headers={'Content-Type': 'application/xml'},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e762e490&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>pcep_session</arg>
<arg>url=http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:05:37.493847" elapsed="0.000555"/>
</kw>
<doc>Creates Requests session to be used by subsequent keywords.</doc>
<status status="PASS" start="2026-06-06T03:05:37.493611" elapsed="0.000860"/>
</kw>
<doc>Create SSH session to Mininet machine, prepare HTTP client session to Controller.
Figure out latest pcc-mock version and download it from Nexus to Mininet.</doc>
<status status="PASS" start="2026-06-06T03:05:35.925793" elapsed="1.568727"/>
</kw>
<test id="s1-s2-t1" name="Topology_Precondition" line="33">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:37.499964" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:37.497815" elapsed="0.002214"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:37.520410" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:37.521084" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Set-Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:05:37 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:37.521563" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:37.500181" elapsed="0.023571">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:37.524525" elapsed="0.000069"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:37.495818" elapsed="0.029118">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:38.531437" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:38.528569" elapsed="0.002908"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:38.541044" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:38.541247" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:38.541393" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:38.531707" elapsed="0.010351">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:38.542371" elapsed="0.000034"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:38.525591" elapsed="0.016949">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:39.552564" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:39.548876" elapsed="0.003730"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:39.563938" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:39.564180" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:39.564388" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:39.552835" elapsed="0.012273">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:39.565610" elapsed="0.000074"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:39.543312" elapsed="0.022538">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:40.576016" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:40.571301" elapsed="0.004781"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:40.587259" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:40.587519" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:40.587917" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:40.576397" elapsed="0.012483">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:40.589449" elapsed="0.000061"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:40.566554" elapsed="0.023216">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:41.598429" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:41.595333" elapsed="0.003141"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:41.608719" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:41.608869" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:41.608989" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:41.598720" elapsed="0.010753">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:41.609772" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:41.590534" elapsed="0.019379">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:42.619551" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:42.615669" elapsed="0.003933"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:42.630302" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:42.630534" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:42.630708" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:42.619876" elapsed="0.011317">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:42.631705" elapsed="0.000069"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:42.610721" elapsed="0.021311">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:43.639417" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:43.635584" elapsed="0.003890"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:43.651344" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:43.651736" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:43.651909" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:43.639808" elapsed="0.012793">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:43.653029" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:43.632687" elapsed="0.020547">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:44.661718" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:44.658556" elapsed="0.003217"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:44.670869" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:44.671008" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:44.671123" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:44.662025" elapsed="0.009547">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:44.671841" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:44.654083" elapsed="0.017890">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:45.682202" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:45.677508" elapsed="0.004727"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:45.692393" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:45.692576" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:45.692761" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:45.682399" elapsed="0.010978">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:45.693732" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:45.672615" elapsed="0.021293">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:46.702230" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:46.699259" elapsed="0.003015"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:46.712731" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:46.712920" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:46.713056" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:46.702684" elapsed="0.010835">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:46.713873" elapsed="0.000035"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:46.694838" elapsed="0.019180">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:47.724555" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:47.719794" elapsed="0.004828"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:47.737232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:47.737505" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:47.737761" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:47.725015" elapsed="0.013658">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:47.739238" elapsed="0.000062"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:47.714988" elapsed="0.024532">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:48.748781" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:48.745311" elapsed="0.003518"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:48.760136" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:48.760296" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:48.760423" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:48.749059" elapsed="0.011842">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:48.761165" elapsed="0.000033"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:48.740270" elapsed="0.021953">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:49.773549" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:49.768362" elapsed="0.005230"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:49.783381" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:49.783564" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:49.783762" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:49.773780" elapsed="0.010565">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:49.784753" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:49.762975" elapsed="0.021965">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:50.794609" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:50.790453" elapsed="0.004233"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:50.806105" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:50.806274" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:50.806405" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:50.794938" elapsed="0.011954">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:50.807208" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:50.785737" elapsed="0.021626">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:51.818275" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:51.812876" elapsed="0.005475"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:51.829159" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:51.829343" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:51.829567" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:51.818714" elapsed="0.011830">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:51.831171" elapsed="0.000063"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:51.808107" elapsed="0.023352">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:52.839563" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:52.836585" elapsed="0.003023"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:52.848399" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:52.848584" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:52.848753" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:52.839858" elapsed="0.009459">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:52.849674" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:52.832138" elapsed="0.017707">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:53.859020" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:53.855295" elapsed="0.003772"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:53.876755" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:53.877053" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:53.877307" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:53.859330" elapsed="0.019135">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:53.879059" elapsed="0.000061"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:53.850499" elapsed="0.028842">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:54.888980" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:54.884842" elapsed="0.004184"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:54.897709" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:54.898026" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:54.898208" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:54.889265" elapsed="0.009608">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:54.899280" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:54.880108" elapsed="0.019369">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:55.906372" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:55.903262" elapsed="0.003156"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:55.916122" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:55.916325" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:55.916488" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:55.906737" elapsed="0.010403">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:55.917504" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:55.900093" elapsed="0.017618">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:56.925635" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:56.922523" elapsed="0.003180"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:56.935255" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:56.935394" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:56.935504" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:56.925937" elapsed="0.010031">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:56.936222" elapsed="0.000083"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:56.918439" elapsed="0.017984">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:57.944087" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:57.940709" elapsed="0.003432"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:57.954272" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:57.954414" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:57.954534" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:57.944493" elapsed="0.010522">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:57.955273" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:57.937546" elapsed="0.017860">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:58.963443" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:58.960201" elapsed="0.003288"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:58.975210" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:58.975444" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:58.975621" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:58.963750" elapsed="0.012548">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:58.976757" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:58.956049" elapsed="0.020909">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:05:59.986588" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:05:59.982471" elapsed="0.004166"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:05:59.995240" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:05:59.995436" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:05:59.995592" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:05:59.986906" elapsed="0.009492">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:05:59.996828" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:05:59.977613" elapsed="0.019532">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:01.005767" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:01.002465" elapsed="0.003347"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:01.015400" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:01.015563" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:01.015733" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:01.006042" elapsed="0.010202">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:01.016553" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:00.997886" elapsed="0.018829">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:02.027632" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:02.023266" elapsed="0.004423"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:02.035368" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:02.035528" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:02.035681" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:02.027871" elapsed="0.008428">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:02.036683" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:02.018212" elapsed="0.018664">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:03.047532" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:03.042624" elapsed="0.004977"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:03.055512" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:03.055670" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:03.055890" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:03.047950" elapsed="0.008557">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:03.056889" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:03.037577" elapsed="0.019512">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:04.068980" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:04.063322" elapsed="0.005705"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:04.079244" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:04.079384" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:04.079498" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:04.069259" elapsed="0.010751">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:04.080270" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:04.057988" elapsed="0.022415">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:05.090172" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:05.086311" elapsed="0.003895"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:05.098264" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:05.098475" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:05.098669" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:05.090389" elapsed="0.008924">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:05.099706" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:05.081320" elapsed="0.018576">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:06.110300" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:06.105713" elapsed="0.004620"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:06.119011" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:06.119222" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:06.119336" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:06.110510" elapsed="0.009308">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:06.120082" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:06.100786" elapsed="0.019429">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:07.157090" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:07.126188" elapsed="0.030940"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:07.165682" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:07.165825" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:07.165948" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:07.157329" elapsed="0.009064">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:07.166720" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:07.121215" elapsed="0.045648">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:08.175113" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:08.171405" elapsed="0.003758"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:08.187405" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:08.187678" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:08.187866" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:08.175499" elapsed="0.013004">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:08.188966" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:08.167517" elapsed="0.021660">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:09.195825" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:09.192809" elapsed="0.003062"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:09.204886" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:09.205151" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:09.205285" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:09.196242" elapsed="0.009543">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:09.206156" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:09.189755" elapsed="0.016577">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:10.218827" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:10.212890" elapsed="0.005985"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:10.228518" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:10.228693" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:10.228823" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:10.219121" elapsed="0.010208">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:10.229601" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:10.207255" elapsed="0.022505">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:11.240033" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:11.235302" elapsed="0.004798"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:11.248537" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:11.248719" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:11.248841" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:11.240445" elapsed="0.008847">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:11.249586" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:11.230578" elapsed="0.019319">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:12.260550" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:12.255734" elapsed="0.004884"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:12.272285" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:12.272561" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:12.272828" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:12.261006" elapsed="0.012741">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:12.274301" elapsed="0.000060"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:12.250559" elapsed="0.024023">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:13.285259" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:13.280966" elapsed="0.004331"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:13.293803" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:13.293972" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:13.294097" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:13.285483" elapsed="0.009237">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:13.295069" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:13.275573" elapsed="0.019675">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:14.303488" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:14.299372" elapsed="0.004184"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:14.314240" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:14.314503" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:14.314889" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:14.303945" elapsed="0.011889">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:14.316421" elapsed="0.000061"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:14.295841" elapsed="0.020894">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:15.324802" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:15.321846" elapsed="0.003000"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:15.334014" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:15.334150" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:15.334262" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:15.325091" elapsed="0.009649">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:15.335008" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:15.317436" elapsed="0.017703">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:16.344486" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:16.340517" elapsed="0.004014"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:16.354173" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:16.354356" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:16.354508" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:16.344777" elapsed="0.010334">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:16.355431" elapsed="0.000035"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:16.335830" elapsed="0.019772">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:17.364843" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:17.361740" elapsed="0.003138"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:17.373228" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:17.373578" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:17.373800" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:17.365062" elapsed="0.009459">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:17.374965" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:17.356287" elapsed="0.018880">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:18.384432" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:18.380953" elapsed="0.003512"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:18.397536" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:18.397844" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:18.398062" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:18.384634" elapsed="0.014339">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:18.399523" elapsed="0.000058"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:18.375843" elapsed="0.024041">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:19.410125" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:19.406097" elapsed="0.004062"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:19.418090" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:19.418310" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:19.418519" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:19.410336" elapsed="0.008829">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:19.419508" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:19.400685" elapsed="0.019107">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:20.430605" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:20.425729" elapsed="0.004979"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:20.441047" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:20.441206" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:20.441343" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:20.431205" elapsed="0.010649">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:20.442107" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:20.420583" elapsed="0.021655">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:21.453206" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:21.447946" elapsed="0.005337"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:21.460629" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:21.460808" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:21.460934" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:21.453498" elapsed="0.007990">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:21.461922" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:21.442963" elapsed="0.019157">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:22.470779" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:22.467397" elapsed="0.003437"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:22.479174" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:22.479315" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:22.479437" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:22.471063" elapsed="0.008834">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:22.480134" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:22.462859" elapsed="0.017476">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:23.489934" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:23.485938" elapsed="0.004048"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:23.498788" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:23.499005" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:23.499175" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:23.490252" elapsed="0.009603">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:23.500299" elapsed="0.000072"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:23.481047" elapsed="0.019499">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:24.511604" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:24.506582" elapsed="0.005079"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:24.521394" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:24.521825" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:24.522133" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:24.511870" elapsed="0.011567">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:24.523981" elapsed="0.000057"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:24.501233" elapsed="0.023012">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:25.532456" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:25.528772" elapsed="0.003736"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:25.540878" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:25.541111" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:25.541427" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:25.532777" elapsed="0.009385">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:25.542538" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:25.525231" elapsed="0.017532">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:26.554234" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:26.548527" elapsed="0.005782"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:26.564015" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:26.564157" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:26.564289" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:26.554758" elapsed="0.010050">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:26.565071" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:26.543480" elapsed="0.021731">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:27.573580" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:27.570386" elapsed="0.003241"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:27.581900" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:27.582091" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:27.582247" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:27.573914" elapsed="0.008974">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:27.583247" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:27.565903" elapsed="0.017532">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:28.590791" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:28.587243" elapsed="0.003595"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:28.599335" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:28.599565" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:28.599750" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:28.591080" elapsed="0.009153">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:28.600503" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:28.584012" elapsed="0.016646">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:29.605636" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:29.603453" elapsed="0.002233"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:29.613509" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:29.613727" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:29.613881" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:29.605872" elapsed="0.008713">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:29.614951" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:29.601148" elapsed="0.013989">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:30.624727" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:30.619540" elapsed="0.005258"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:30.634120" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:30.634308" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:30.634460" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:30.625150" elapsed="0.010022">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:30.635563" elapsed="0.000051"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:30.615692" elapsed="0.020176">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:31.645984" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:31.641847" elapsed="0.004183"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:31.654165" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:31.654348" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:31.654547" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:31.646342" elapsed="0.008851">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:31.655586" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:31.636594" elapsed="0.019197">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:32.665920" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:32.661588" elapsed="0.004374"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:32.674004" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:32.674239" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:32.674404" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:32.666175" elapsed="0.008899">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:32.675446" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:32.656504" elapsed="0.019135">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:33.683216" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:33.679500" elapsed="0.003785"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:33.692948" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:33.693088" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:33.693198" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:33.683636" elapsed="0.009994">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:33.693890" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:33.676209" elapsed="0.017874">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:34.705419" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:34.699932" elapsed="0.005557"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:34.715916" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:34.716065" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:34.716192" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:34.705892" elapsed="0.010766">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:34.716924" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:34.694813" elapsed="0.022246">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:35.725787" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:35.722715" elapsed="0.003128"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:35.733953" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:35.734104" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:35.734225" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:35.726162" elapsed="0.008536">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:35.734985" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:35.717933" elapsed="0.017192">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:36.741822" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:36.738263" elapsed="0.003600"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:36.749817" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:36.749994" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:36.750193" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:36.742054" elapsed="0.008688">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:36.751031" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:36.735633" elapsed="0.015546">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:37.758734" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:37.755282" elapsed="0.003508"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:37.766855" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:37.767060" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:37.767281" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:37.759074" elapsed="0.008896">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:37.768488" elapsed="0.000063"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:37.752064" elapsed="0.016740">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:38.778195" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:38.774337" elapsed="0.003905"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:38.786685" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:38.786879" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:38.787029" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:38.778481" elapsed="0.009153">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:38.788034" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:38.769499" elapsed="0.018721">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:39.795856" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:39.792546" elapsed="0.003358"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:39.805308" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:39.805767" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:39.806006" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:39.796147" elapsed="0.010794">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:39.807525" elapsed="0.000055"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:39.788908" elapsed="0.018883">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:40.818671" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:40.813363" elapsed="0.005378"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:40.829564" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:40.829973" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:40.830242" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:40.819089" elapsed="0.012185">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:40.831824" elapsed="0.000057"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:40.808486" elapsed="0.023614">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:41.842553" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:41.837734" elapsed="0.004894"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:41.852306" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:41.852453" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:41.852574" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:41.843043" elapsed="0.009999">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:41.853340" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:41.832848" elapsed="0.020631">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:42.863988" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:42.858783" elapsed="0.005264"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:42.873161" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:42.873409" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:42.873592" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:42.864465" elapsed="0.009889">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:42.874859" elapsed="0.000046"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:42.854205" elapsed="0.020855">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:43.884191" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:43.878886" elapsed="0.005375"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:43.895028" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:43.895227" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:43.895407" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:43.884674" elapsed="0.011291">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:43.896312" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:43.875733" elapsed="0.020730">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:44.907724" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:44.902391" elapsed="0.005413"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:44.915608" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:44.915803" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:44.915936" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:44.908205" elapsed="0.008201">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:44.916816" elapsed="0.000046"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:44.897184" elapsed="0.019948">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:45.926279" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:45.923122" elapsed="0.003196"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:45.934349" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:45.934594" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:45.934804" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:45.926527" elapsed="0.008971">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:45.936027" elapsed="0.000052"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:45.917938" elapsed="0.018305">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:46.946565" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:46.942002" elapsed="0.004598"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:46.953896" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:46.954096" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:46.954270" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:46.946786" elapsed="0.008138">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:46.955290" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:46.937057" elapsed="0.018427">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:47.965747" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:47.960895" elapsed="0.004889"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:47.973232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:47.973407" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:47.973610" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:47.965972" elapsed="0.008277">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:47.974696" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:47.956150" elapsed="0.018744">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:48.985395" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:48.980371" elapsed="0.005092"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:48.993251" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:48.993389" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:48.993499" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:48.985937" elapsed="0.008093">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:48.994299" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:48.975508" elapsed="0.018927">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:50.003074" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:49.999703" elapsed="0.003417"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:50.011580" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:50.011745" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:50.011874" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:50.003354" elapsed="0.008982">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:50.012610" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:49.995150" elapsed="0.017617">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:51.023253" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:51.018440" elapsed="0.004883"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:51.031373" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:51.031589" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:51.031742" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:51.023709" elapsed="0.008483">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:51.032468" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:51.013436" elapsed="0.019168">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:52.043848" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:52.038526" elapsed="0.005395"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:52.050518" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:52.050691" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:52.050811" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:52.044111" elapsed="0.007150">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:52.051632" elapsed="0.000051"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:52.033293" elapsed="0.018506">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:53.062012" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:53.057593" elapsed="0.004455"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:53.070030" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:53.070214" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:53.070372" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:53.062230" elapsed="0.008747">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:53.071319" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:53.052559" elapsed="0.018938">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:54.081574" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:54.077191" elapsed="0.004416"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:54.089512" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:54.089726" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:54.089876" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:54.081878" elapsed="0.008583">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:54.090831" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:54.072249" elapsed="0.018762">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:55.101604" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:55.096736" elapsed="0.004972"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:55.110434" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:55.110613" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:55.110791" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:55.102077" elapsed="0.009295">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:55.111725" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:55.091921" elapsed="0.019984">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:56.122750" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:56.117438" elapsed="0.005384"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:56.132579" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:56.132737" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:56.132854" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:56.123177" elapsed="0.010114">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:56.133528" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:56.112602" elapsed="0.021132">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:57.144201" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:57.139980" elapsed="0.004266"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:57.153229" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:57.153413" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:57.153561" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:57.144473" elapsed="0.009695">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:57.154556" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:57.134536" elapsed="0.020227">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:58.161173" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:58.158721" elapsed="0.002490"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:58.169003" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:58.169191" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:58.169343" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:58.161434" elapsed="0.008585">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:58.170455" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:58.155467" elapsed="0.015202">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:06:59.181406" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:06:59.176141" elapsed="0.005335"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:06:59.192548" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:06:59.192871" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:06:59.193216" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:06:59.181866" elapsed="0.012279">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:06:59.194750" elapsed="0.000063"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:06:59.171348" elapsed="0.023692">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:00.202143" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:00.198947" elapsed="0.003245"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:00.211334" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:00.211487" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:00.211822" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:00.202557" elapsed="0.009716">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:00.212553" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:00.195699" elapsed="0.017010">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:01.224247" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:01.219100" elapsed="0.005222"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:01.234684" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:01.234877" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:01.235016" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:01.224731" elapsed="0.011032">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:01.236543" elapsed="0.000086"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:01.213500" elapsed="0.023504">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:02.246510" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:02.242962" elapsed="0.003599"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:02.256745" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:02.256964" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:02.257093" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:02.246810" elapsed="0.010738">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:02.257815" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:02.237953" elapsed="0.019996">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:03.267974" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:03.263376" elapsed="0.004631"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:03.275776" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:03.275917" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:03.276030" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:03.268175" elapsed="0.008289">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:03.276724" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:03.258702" elapsed="0.018154">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:04.287349" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:04.282337" elapsed="0.005082"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:04.297455" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:04.297611" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:04.297815" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:04.287762" elapsed="0.011047">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:04.299466" elapsed="0.000067"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:04.277550" elapsed="0.022254">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:05.310719" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:05.305431" elapsed="0.005488"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:05.319079" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:05.319217" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:05.319337" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:05.311415" elapsed="0.008385">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:05.320038" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:05.300541" elapsed="0.019625">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:06.329685" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:06.325729" elapsed="0.004002"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:06.339953" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:06.340141" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:06.340292" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:06.329959" elapsed="0.011012">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:06.341319" elapsed="0.000047"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:06.320904" elapsed="0.020653">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:07.352091" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:07.347263" elapsed="0.004867"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:07.359535" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:07.359728" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:07.359863" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:07.352345" elapsed="0.008002">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:07.360695" elapsed="0.000033"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:07.342240" elapsed="0.018670">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:08.372396" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:08.367250" elapsed="0.005181"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:08.379541" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:08.379711" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:08.379838" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:08.372599" elapsed="0.007808">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:08.380768" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:08.361583" elapsed="0.019369">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:09.392070" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:09.386956" elapsed="0.005150"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:09.400000" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:09.400197" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:09.400375" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:09.392290" elapsed="0.008658">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:09.401247" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:09.381633" elapsed="0.019751">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:10.411969" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:10.406979" elapsed="0.005063"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:10.419707" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:10.419848" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:10.420019" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:10.412226" elapsed="0.008375">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:10.420963" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:10.402131" elapsed="0.019015">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:11.432251" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:11.426894" elapsed="0.005429"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:11.440880" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:11.441230" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:11.441541" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:11.432721" elapsed="0.009898">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:11.443381" elapsed="0.000074"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:11.421954" elapsed="0.021857">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:12.452268" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:12.449246" elapsed="0.003067"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:12.460328" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:12.460512" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:12.460714" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:12.452536" elapsed="0.008888">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:12.461848" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:12.444566" elapsed="0.017488">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:13.468804" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:13.465733" elapsed="0.003116"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:13.477900" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:13.478122" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:13.478233" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:13.469075" elapsed="0.009627">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:13.478948" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:13.462627" elapsed="0.016449">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:14.485952" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:14.482688" elapsed="0.003307"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:14.493362" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:14.493535" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:14.493711" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:14.486206" elapsed="0.008090">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:14.494607" elapsed="0.000055"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:14.479594" elapsed="0.015205">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:15.505453" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:15.500600" elapsed="0.004887"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:15.512164" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:15.512306" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:15.512421" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:15.505692" elapsed="0.007274">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:15.513244" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:15.495506" elapsed="0.017894">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:16.523687" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:16.518905" elapsed="0.004853"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:16.533815" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:16.533966" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:16.534090" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:16.524260" elapsed="0.010288">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:16.534847" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:16.514107" elapsed="0.020884">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:17.544588" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:17.541182" elapsed="0.003450"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:17.552546" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:17.552768" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:17.552994" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:17.544872" elapsed="0.008724">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:17.553943" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:17.535936" elapsed="0.018187">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:18.563463" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:18.559706" elapsed="0.003802"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:18.572058" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:18.572237" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:18.572384" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:18.563783" elapsed="0.009197">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:18.573366" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:18.554833" elapsed="0.018860">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:19.582116" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:19.579029" elapsed="0.003144"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:19.590855" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:19.591053" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:19.591207" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:19.582407" elapsed="0.009411">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:19.592147" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:19.574418" elapsed="0.017917">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:20.604471" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:20.598981" elapsed="0.005524"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:20.612147" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:20.612337" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:20.612498" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:20.604700" elapsed="0.008425">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:20.613478" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:20.593562" elapsed="0.020158">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:21.622556" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:21.619421" elapsed="0.003183"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:21.630533" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:21.630804" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:21.631090" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:21.622888" elapsed="0.009012">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:21.632302" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:21.614785" elapsed="0.017700">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:22.646948" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:22.639548" elapsed="0.007446"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:22.657081" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:22.657222" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:22.657331" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:22.647230" elapsed="0.010573">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:22.658058" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:22.633521" elapsed="0.024691">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:23.668247" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:23.664056" elapsed="0.004225"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:23.677475" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:23.677624" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:23.677781" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:23.668449" elapsed="0.009946">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:23.678858" elapsed="0.000046"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:23.658971" elapsed="0.020095">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:24.688877" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:24.684964" elapsed="0.003947"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:24.697367" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:24.697631" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:24.697809" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:24.689081" elapsed="0.009309">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:24.698804" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:24.679901" elapsed="0.019096">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:25.708278" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:25.704948" elapsed="0.003389"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:25.718396" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:25.718575" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:25.718740" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:25.708584" elapsed="0.010784">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:25.719747" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:25.699780" elapsed="0.020123">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:26.731153" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:26.727034" elapsed="0.004166"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:26.740404" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:26.740588" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:26.740780" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:26.731461" elapsed="0.009930">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:26.741752" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:26.720757" elapsed="0.021177">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:27.752611" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:27.748179" elapsed="0.004480"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:27.761557" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:27.761790" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:27.761971" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:27.752942" elapsed="0.009802">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:27.763160" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:27.742721" elapsed="0.020659">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:28.774156" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:28.769903" elapsed="0.004289"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:28.782288" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:28.782489" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:28.782671" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:28.774364" elapsed="0.008904">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:28.783660" elapsed="0.000046"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:28.764255" elapsed="0.019602">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:29.793080" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:29.789351" elapsed="0.003788"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:29.801154" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:29.801305" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:29.801433" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:29.793408" elapsed="0.008517">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:29.802187" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:29.784549" elapsed="0.017860">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:30.813269" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:30.808192" elapsed="0.005146"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:30.822275" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:30.822412" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:30.822519" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:30.813722" elapsed="0.009252">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:30.823227" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:30.803158" elapsed="0.020207">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:31.832263" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:31.829063" elapsed="0.003244"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:31.840497" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:31.840753" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:31.840908" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:31.832535" elapsed="0.009000">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:31.841925" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:31.824083" elapsed="0.018027">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:32.852917" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:32.847612" elapsed="0.005374"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:32.860589" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:32.860762" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:32.860962" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:32.853393" elapsed="0.008061">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:32.861755" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:32.842848" elapsed="0.019049">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:33.872090" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:33.867343" elapsed="0.004814"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:33.881678" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:33.881821" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:33.881935" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:33.872505" elapsed="0.009870">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:33.882834" elapsed="0.000062"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:33.862511" elapsed="0.020602">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:34.893374" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:34.888621" elapsed="0.004821"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:34.900886" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:34.901028" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:34.901137" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:34.893816" elapsed="0.007802">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:34.901874" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:34.883858" elapsed="0.018184">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:35.909844" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:35.906168" elapsed="0.003726"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:35.920384" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:35.920690" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:35.920869" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:35.910139" elapsed="0.011389">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:35.921914" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:35.902639" elapsed="0.019477">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:36.932349" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:36.928288" elapsed="0.004096"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:36.940511" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:36.940743" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:36.940898" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:36.932552" elapsed="0.008942">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:36.941872" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:36.922977" elapsed="0.019080">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:37.952161" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:37.947683" elapsed="0.004522"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:37.960828" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:37.961010" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:37.961156" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:37.952426" elapsed="0.009334">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:37.962112" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:37.942800" elapsed="0.019490">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:38.973634" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:38.968044" elapsed="0.005714"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:38.985251" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:38.985459" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:38.985663" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:38.974316" elapsed="0.012012">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:38.986807" elapsed="0.000049"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:38.963058" elapsed="0.023951">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:39.993685" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:39.990662" elapsed="0.003069"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:40.001613" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:40.001851" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:40.002017" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:39.993956" elapsed="0.008664">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:40.003055" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:39.987564" elapsed="0.015679">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:41.014091" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:41.009880" elapsed="0.004254"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:41.024261" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:41.024477" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:41.024688" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:41.014356" elapsed="0.010980">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:41.025796" elapsed="0.000047"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:41.004029" elapsed="0.022054">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:42.037065" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:42.031898" elapsed="0.005202"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:42.044473" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:42.044806" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:42.045062" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:42.037274" elapsed="0.008671">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:42.046487" elapsed="0.000057"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:42.026819" elapsed="0.019961">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:43.057199" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:43.053806" elapsed="0.003440"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:43.066868" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:43.067027" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:43.067146" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:43.057474" elapsed="0.010156">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:43.067915" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:43.047586" elapsed="0.020465">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:44.078204" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:44.073552" elapsed="0.004696"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:44.086761" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:44.086941" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:44.087169" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:44.078466" elapsed="0.009308">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:44.088102" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:44.068787" elapsed="0.019488">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:45.098385" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:45.094122" elapsed="0.004313"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:45.110237" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:45.110379" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:45.110519" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:45.098728" elapsed="0.012341">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:45.111337" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:45.089048" elapsed="0.022427">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:46.121216" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:46.117463" elapsed="0.003799"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:46.130293" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:46.130485" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:46.130668" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:46.121485" elapsed="0.009824">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:46.131697" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:46.112226" elapsed="0.019656">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:47.141943" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:47.137245" elapsed="0.004763"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:47.151959" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:47.152210" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:47.152446" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:47.142344" elapsed="0.011045">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:47.154021" elapsed="0.000069"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:47.132536" elapsed="0.021781">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:48.164299" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:48.160041" elapsed="0.004293"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:48.171344" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:48.171519" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:48.171734" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:48.164501" elapsed="0.007764">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:48.172597" elapsed="0.000034"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:48.155107" elapsed="0.017661">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:49.179355" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:49.176361" elapsed="0.003043"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:49.187512" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:49.187759" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:49.187918" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:49.179634" elapsed="0.008835">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:49.188892" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:49.173378" elapsed="0.015698">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:50.198986" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:50.195314" elapsed="0.003717"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:50.208317" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:50.208503" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:50.208677" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:50.199337" elapsed="0.009925">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:50.209597" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:50.189874" elapsed="0.019930">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:51.215767" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:51.212970" elapsed="0.002835"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:51.223058" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:51.223251" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:51.223410" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:51.215987" elapsed="0.007956">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:51.224351" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:51.210315" elapsed="0.014206">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:52.235254" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:52.230336" elapsed="0.004993"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:52.243415" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:52.243564" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:52.243714" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:52.235717" elapsed="0.008464">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:52.244509" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:52.225371" elapsed="0.019396">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:53.256040" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:53.250866" elapsed="0.005250"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:53.263845" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:53.263985" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:53.264097" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:53.256499" elapsed="0.008046">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:53.264833" elapsed="0.000071"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:53.245497" elapsed="0.019521">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:54.272466" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:54.268908" elapsed="0.003607"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:54.280375" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:54.280570" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:54.280775" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:54.272776" elapsed="0.008682">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:54.281856" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:54.265627" elapsed="0.016423">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:55.292202" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:55.287485" elapsed="0.004783"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:55.301763" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:55.301903" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:55.302078" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:55.292604" elapsed="0.009905">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:55.302855" elapsed="0.000056"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:55.282754" elapsed="0.020371">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:56.310537" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:56.307441" elapsed="0.003141"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:56.318520" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:56.318717" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:56.318858" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:56.310836" elapsed="0.008575">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:56.319715" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:56.303983" elapsed="0.015864">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:57.328677" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:57.323694" elapsed="0.005033"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:57.337861" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:57.338027" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:57.338170" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:57.328968" elapsed="0.009734">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:57.339005" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:57.320391" elapsed="0.018751">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:58.345693" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:58.342712" elapsed="0.003024"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:58.354166" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:58.354508" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:58.354708" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:58.345964" elapsed="0.009456">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:58.355901" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:58.339717" elapsed="0.016380">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:07:59.367295" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:07:59.362046" elapsed="0.005385"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:07:59.376540" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:07:59.376898" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:07:59.377217" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:07:59.367914" elapsed="0.010324">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:07:59.378909" elapsed="0.000072"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:07:59.356913" elapsed="0.022314">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:00.389955" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:00.384871" elapsed="0.005141"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:00.399211" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:00.399449" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:00.399630" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:00.390257" elapsed="0.010066">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:00.400777" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:00.380081" elapsed="0.020912">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:01.410062" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:01.406462" elapsed="0.003654"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:01.419054" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:01.419211" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:01.419334" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:01.410461" elapsed="0.009358">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:01.420118" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:01.401723" elapsed="0.018563">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:02.426924" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:02.423900" elapsed="0.003068"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:02.435929" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:02.436282" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:02.436558" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:02.427192" elapsed="0.010579">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:02.438515" elapsed="0.000075"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:02.420865" elapsed="0.018014">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:03.445950" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:03.442718" elapsed="0.003274"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:03.454181" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:03.454365" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:03.454523" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:03.446204" elapsed="0.008920">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:03.455456" elapsed="0.000035"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:03.439676" elapsed="0.016071">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:04.463575" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:04.460024" elapsed="0.003605"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:04.471921" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:04.472068" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:04.472186" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:04.463890" elapsed="0.008803">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:04.472958" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:04.456303" elapsed="0.016798">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:05.483331" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:05.478695" elapsed="0.004679"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:05.489884" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:05.490077" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:05.490195" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:05.483546" elapsed="0.007279">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:05.491238" elapsed="0.000054"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:05.473612" elapsed="0.017880">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:06.502994" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:06.497548" elapsed="0.005517"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:06.510583" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:06.510775" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:06.510994" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:06.503392" elapsed="0.008083">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:06.511841" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:06.492246" elapsed="0.019775">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:07.521979" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:07.518536" elapsed="0.003489"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:07.530373" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:07.530561" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:07.530745" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:07.522252" elapsed="0.009167">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:07.531787" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:07.513081" elapsed="0.018889">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:08.542862" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:08.538860" elapsed="0.004079"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:08.554054" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:08.554359" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:08.554590" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:08.543388" elapsed="0.012001">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:08.555888" elapsed="0.000051"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:08.532900" elapsed="0.023176">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:09.565206" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:09.560670" elapsed="0.004627"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:09.575071" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:09.575294" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:09.575423" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:09.565692" elapsed="0.010255">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:09.576226" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:09.556801" elapsed="0.019564">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:10.587475" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:10.582020" elapsed="0.005534"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:10.596433" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:10.596606" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:10.596806" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:10.588056" elapsed="0.009360">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:10.597839" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:10.577077" elapsed="0.020954">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:11.608301" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:11.603512" elapsed="0.004858"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:11.615671" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:11.615815" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:11.615923" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:11.608798" elapsed="0.007573">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:11.616610" elapsed="0.000088"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:11.598762" elapsed="0.018044">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:12.627299" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:12.622453" elapsed="0.004893"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:12.635868" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:12.636100" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:12.636267" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:12.627691" elapsed="0.009228">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:12.637345" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:12.617592" elapsed="0.019958">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:13.645897" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:13.642708" elapsed="0.003235"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:13.653692" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:13.653838" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:13.653949" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:13.646177" elapsed="0.008203">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:13.654621" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:13.638201" elapsed="0.016567">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:14.665541" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:14.660392" elapsed="0.005217"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:14.674048" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:14.674201" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:14.674323" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:14.666061" elapsed="0.008737">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:14.675177" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:14.655390" elapsed="0.020059">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:15.686812" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:15.681099" elapsed="0.005785"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:15.694093" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:15.694245" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:15.694400" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:15.687060" elapsed="0.007885">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:15.695294" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:15.676195" elapsed="0.019281">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:16.705906" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:16.700956" elapsed="0.005021"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:16.713231" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:16.713372" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:16.713487" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:16.706329" elapsed="0.007623">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:16.714195" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:16.696173" elapsed="0.018151">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:17.723136" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:17.720163" elapsed="0.003018"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:17.731234" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:17.731448" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:17.731710" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:17.723435" elapsed="0.008859">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:17.732681" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:17.715149" elapsed="0.017719">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:18.743444" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:18.738246" elapsed="0.005263"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:18.752383" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:18.752526" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:18.752662" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:18.743926" elapsed="0.009169">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:18.753341" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:18.733529" elapsed="0.019941">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:19.763701" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:19.758956" elapsed="0.004816"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:19.771139" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:19.771274" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:19.771380" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:19.764122" elapsed="0.007709">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:19.772065" elapsed="0.000025"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:19.754172" elapsed="0.018017">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:20.780703" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:20.777718" elapsed="0.003051"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:20.788928" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:20.789151" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:20.789274" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:20.781045" elapsed="0.008700">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:20.790016" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:20.772980" elapsed="0.017169">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:21.798617" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:21.795272" elapsed="0.003411"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:21.806875" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:21.807020" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:21.807143" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:21.798914" elapsed="0.008673">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:21.807874" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:21.790879" elapsed="0.017131">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:22.820491" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:22.814606" elapsed="0.005947"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:22.828579" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:22.828749" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:22.828865" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:22.820915" elapsed="0.008390">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:22.829578" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:22.808717" elapsed="0.021053">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:23.840162" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:23.835337" elapsed="0.004894"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:23.848982" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:23.849120" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:23.849230" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:23.840751" elapsed="0.008932">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:23.849929" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:23.830515" elapsed="0.019543">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:24.860441" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:24.855468" elapsed="0.005019"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:24.867908" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:24.868089" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:24.868249" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:24.860747" elapsed="0.008107">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:24.869213" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:24.850783" elapsed="0.018613">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:25.880396" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:25.875526" elapsed="0.004940"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:25.890216" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:25.890379" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:25.890499" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:25.880854" elapsed="0.010107">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:25.891248" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:25.870195" elapsed="0.021250">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:26.901444" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:26.897433" elapsed="0.004047"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:26.910364" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:26.910506" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:26.910622" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:26.901666" elapsed="0.009416">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:26.911345" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:26.892194" elapsed="0.019286">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:27.920386" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:27.917016" elapsed="0.003415"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:27.928120" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:27.928303" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:27.928461" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:27.920680" elapsed="0.008423">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:27.929447" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:27.912215" elapsed="0.017418">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:28.940812" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:28.935558" elapsed="0.005327"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:28.950247" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:28.950410" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:28.950600" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:28.941258" elapsed="0.010324">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:28.952292" elapsed="0.000084"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:28.930374" elapsed="0.022357">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:29.961202" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:29.958212" elapsed="0.003035"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:29.969078" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:29.969257" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:29.969399" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:29.961472" elapsed="0.008523">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:29.970322" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:29.953485" elapsed="0.017010">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:30.981612" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:30.976141" elapsed="0.005572"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:30.991376" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:30.991558" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:30.991738" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:30.982088" elapsed="0.010112">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:30.992546" elapsed="0.000035"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:30.971173" elapsed="0.021540">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:32.003412" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:31.998515" elapsed="0.004932"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:32.010561" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:32.010849" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:32.011049" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:32.003657" elapsed="0.008214">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:32.012327" elapsed="0.000052"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:31.993391" elapsed="0.019180">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:33.019664" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:33.016423" elapsed="0.003292"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:33.028240" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:33.028457" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:33.028628" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:33.019959" elapsed="0.009341">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:33.029736" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:33.013182" elapsed="0.016752">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:34.042341" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:34.035484" elapsed="0.006927"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:34.049882" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:34.050019" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:34.050133" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:34.042858" elapsed="0.007705">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:34.051292" elapsed="0.000034"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:34.030701" elapsed="0.020732">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:35.061524" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:35.057299" elapsed="0.004271"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:35.070337" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:35.070563" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:35.070758" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:35.061923" elapsed="0.009501">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:35.071853" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:35.052222" elapsed="0.019822">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:36.082139" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:36.077418" elapsed="0.004789"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:36.093111" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:36.093381" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:36.093607" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:36.082555" elapsed="0.011970">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:36.095073" elapsed="0.000057"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:36.072740" elapsed="0.022605">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:37.106080" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:37.101370" elapsed="0.004744"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:37.114013" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:37.114202" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:37.114363" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:37.106282" elapsed="0.008685">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:37.115311" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:37.096090" elapsed="0.019472">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:38.128899" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:38.122025" elapsed="0.006977"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:38.138860" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:38.139006" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:38.139121" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:38.129344" elapsed="0.010217">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:38.139844" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:38.116263" elapsed="0.023717">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:39.148790" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:39.145575" elapsed="0.003258"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:39.157681" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:39.157864" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:39.158007" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:39.149056" elapsed="0.009532">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:39.158947" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:39.140704" elapsed="0.018421">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:40.170291" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:40.164828" elapsed="0.005533"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:40.178108" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:40.178243" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:40.178541" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:40.170526" elapsed="0.008943">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:40.180054" elapsed="0.000068"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:40.159881" elapsed="0.020473">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:41.191874" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:41.186474" elapsed="0.005436"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:41.200857" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:41.201082" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:41.201253" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:41.192094" elapsed="0.009817">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:41.202405" elapsed="0.000050"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:41.181188" elapsed="0.021430">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:42.209375" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:42.206299" elapsed="0.003122"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:42.217280" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:42.217464" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:42.217610" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:42.209662" elapsed="0.008586">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:42.218589" elapsed="0.000096"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:42.203183" elapsed="0.015648">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:43.228818" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:43.224255" elapsed="0.004607"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:43.238024" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:43.238311" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:43.238470" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:43.229089" elapsed="0.009983">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:43.239441" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:43.219510" elapsed="0.020114">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:44.248344" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:44.245147" elapsed="0.003254"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:44.256591" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:44.256766" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:44.256885" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:44.248674" elapsed="0.008680">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:44.257685" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:44.240384" elapsed="0.017464">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:45.268103" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:45.263278" elapsed="0.004897"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:45.276162" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:45.276300" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:45.276410" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:45.268527" elapsed="0.008474">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:45.277336" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:45.258522" elapsed="0.018993">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:46.288207" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:46.282958" elapsed="0.005316"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:46.298020" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:46.298154" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:46.298268" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:46.288933" elapsed="0.009911">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:46.299353" elapsed="0.000058"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:46.278211" elapsed="0.021413">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:47.310192" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:47.305499" elapsed="0.004743"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:47.318483" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:47.318621" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:47.318791" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:47.310427" elapsed="0.008976">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:47.319763" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:47.300449" elapsed="0.019491">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:48.328674" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:48.325298" elapsed="0.003424"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:48.337412" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:48.337677" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:48.337842" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:48.328965" elapsed="0.009488">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:48.338880" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:48.320578" elapsed="0.018579">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:49.351874" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:49.346126" elapsed="0.005789"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:49.361065" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:49.361254" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:49.361415" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:49.352114" elapsed="0.009948">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:49.362404" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:49.339989" elapsed="0.022593">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:50.367486" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:50.365334" elapsed="0.002185"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:50.375636" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:50.375814" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:50.375938" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:50.367697" elapsed="0.008687">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:50.376687" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:50.363097" elapsed="0.013727">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:51.388558" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:51.383827" elapsed="0.004771"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:51.396742" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:51.396903" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:51.397184" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:51.388781" elapsed="0.009079">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:51.398209" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:51.378166" elapsed="0.020226">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:52.409946" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:52.404594" elapsed="0.005423"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:52.417742" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:52.417880" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:52.417996" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:52.410379" elapsed="0.008059">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:52.418688" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:52.399600" elapsed="0.019216">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:53.427498" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:53.424279" elapsed="0.003262"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:53.435600" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:53.435806" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:53.435968" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:53.427781" elapsed="0.008757">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:53.436885" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:53.419469" elapsed="0.017589">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:54.446261" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:54.442749" elapsed="0.003546"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:54.452966" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:54.453178" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:54.453285" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:54.446460" elapsed="0.007273">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:54.453971" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:54.437799" elapsed="0.016304">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:55.465429" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:55.459789" elapsed="0.005691"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:55.472325" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:55.472462" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:55.472577" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:55.465684" elapsed="0.007413">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:55.473412" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:55.454826" elapsed="0.018761">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:56.483729" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:56.480456" elapsed="0.003311"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:56.490232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:56.490415" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:56.490560" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:56.483938" elapsed="0.007270">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:56.491539" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:56.475007" elapsed="0.016732">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:57.502173" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:57.497283" elapsed="0.004955"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:57.509691" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:57.509921" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:57.510043" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:57.502527" elapsed="0.008060">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:57.510943" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:57.492447" elapsed="0.018674">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:58.519573" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:58.516270" elapsed="0.003348"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:58.526317" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:58.526457" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:58.526574" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:58.519863" elapsed="0.007161">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:58.527259" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:58.511874" elapsed="0.015510">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:08:59.537378" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:08:59.533541" elapsed="0.003883"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:08:59.545366" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:08:59.545567" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:08:59.545759" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:08:59.537672" elapsed="0.008703">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:08:59.546819" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:08:59.528160" elapsed="0.018945">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:00.557163" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:00.553206" elapsed="0.003991"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:00.563475" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:00.563621" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:00.563776" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:00.557363" elapsed="0.006879">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:00.564533" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:00.548245" elapsed="0.016489">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:01.573267" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:01.569764" elapsed="0.003564"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:01.580414" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:01.580556" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:01.580695" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:01.573559" elapsed="0.007583">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:01.581386" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:01.565476" elapsed="0.016040">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:02.589384" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:02.586259" elapsed="0.003170"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:02.597185" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:02.597333" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:02.597518" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:02.589695" elapsed="0.008332">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:02.598292" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:02.582184" elapsed="0.016247">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:03.607759" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:03.604053" elapsed="0.003754"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:03.615232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:03.615423" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:03.615574" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:03.608046" elapsed="0.008170">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:03.616574" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:03.599185" elapsed="0.017646">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:04.626896" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:04.622584" elapsed="0.004347"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:04.634556" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:04.634823" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:04.635038" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:04.627096" elapsed="0.008566">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:04.636002" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:04.617757" elapsed="0.018433">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:05.646155" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:05.641806" elapsed="0.004382"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:05.654299" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:05.654510" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:05.654617" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:05.646354" elapsed="0.008893">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:05.655577" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:05.636996" elapsed="0.018779">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:06.663367" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:06.660049" elapsed="0.003367"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:06.671197" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:06.671344" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:06.671458" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:06.663693" elapsed="0.008262">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:06.672243" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:06.656498" elapsed="0.015884">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:07.683360" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:07.677849" elapsed="0.005592"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:07.690495" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:07.690634" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:07.690773" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:07.683813" elapsed="0.007422">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:07.691480" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:07.673061" elapsed="0.018546">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:08.701880" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:08.697195" elapsed="0.004756"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:08.709000" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:08.709135" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:08.709241" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:08.702489" elapsed="0.007227">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:08.709978" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:08.692460" elapsed="0.017647">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:09.720722" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:09.715588" elapsed="0.005212"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:09.727488" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:09.727626" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:09.727782" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:09.721062" elapsed="0.007193">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:09.728552" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:09.710806" elapsed="0.017959">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:10.739921" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:10.734720" elapsed="0.005237"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:10.746704" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:10.746845" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:10.746970" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:10.740123" elapsed="0.007428">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:10.747905" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:10.729474" elapsed="0.018669">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:11.757262" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:11.753960" elapsed="0.003378"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:11.764988" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:11.765216" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:11.765419" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:11.757615" elapsed="0.008741">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:11.766969" elapsed="0.000070"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:11.748981" elapsed="0.018276">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:12.777532" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:12.772759" elapsed="0.004843"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:12.784821" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:12.784957" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:12.785066" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:12.777988" elapsed="0.007507">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:12.785761" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:12.767990" elapsed="0.017917">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:13.794204" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:13.790868" elapsed="0.003381"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:13.801749" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:13.801928" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:13.802199" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:13.794474" elapsed="0.008380">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:13.803194" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:13.786497" elapsed="0.016875">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:14.815216" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:14.809278" elapsed="0.005971"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:14.822453" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:14.822596" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:14.822727" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:14.815422" elapsed="0.007754">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:14.823421" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:14.804104" elapsed="0.019447">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:15.833948" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:15.830095" elapsed="0.003886"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:15.841448" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:15.841587" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:15.841713" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:15.834144" elapsed="0.008006">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:15.842473" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:15.824187" elapsed="0.018490">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:16.851762" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:16.848437" elapsed="0.003371"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:16.859810" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:16.860084" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:16.860244" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:16.852032" elapsed="0.008826">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:16.861190" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:16.843357" elapsed="0.018011">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:17.871712" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:17.866719" elapsed="0.005062"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:17.879522" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:17.879704" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:17.879830" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:17.872191" elapsed="0.008126">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:17.880630" elapsed="0.000051"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:17.862026" elapsed="0.018766">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:18.887338" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:18.884350" elapsed="0.003035"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:18.895042" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:18.895229" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:18.895382" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:18.887620" elapsed="0.008384">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:18.896363" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:18.881317" elapsed="0.015231">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:19.907594" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:19.902094" elapsed="0.005647"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:19.915841" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:19.916103" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:19.916387" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:19.908312" elapsed="0.008833">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:19.917610" elapsed="0.000071"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:19.897211" elapsed="0.020651">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:20.925632" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:20.922610" elapsed="0.003099"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:20.933954" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:20.934413" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:20.936001" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:20.925955" elapsed="0.011243">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:20.937972" elapsed="0.000077"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:20.918577" elapsed="0.019727">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:21.947508" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:21.943892" elapsed="0.003650"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:21.954869" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:21.955076" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:21.955240" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:21.947732" elapsed="0.008157">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:21.956286" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:21.939070" elapsed="0.017493">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:22.967950" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:22.962857" elapsed="0.005152"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:22.975279" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:22.975490" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:22.975688" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:22.968260" elapsed="0.008048">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:22.976782" elapsed="0.000051"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:22.957323" elapsed="0.019695">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:23.986971" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:23.982449" elapsed="0.004556"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:23.993297" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:23.993465" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:23.993573" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:23.987171" elapsed="0.006885">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:23.994321" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:23.977714" elapsed="0.016752">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:25.003285" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:25.000039" elapsed="0.003304"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:25.011221" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:25.011421" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:25.011851" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:25.003666" elapsed="0.008791">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:25.012929" elapsed="0.000050"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:24.995225" elapsed="0.017914">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:26.022856" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:26.019462" elapsed="0.003436"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:26.029532" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:26.029736" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:26.029935" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:26.023110" elapsed="0.007484">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:26.030965" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:26.013937" elapsed="0.017209">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:27.038117" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:27.034902" elapsed="0.003263"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:27.046490" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:27.046817" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:27.046996" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:27.038402" elapsed="0.009335">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:27.048155" elapsed="0.000066"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:27.031681" elapsed="0.016712">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:28.057177" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:28.053152" elapsed="0.004088"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:28.065402" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:28.065632" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:28.065771" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:28.057574" elapsed="0.008649">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:28.066516" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:28.048984" elapsed="0.017689">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:29.078058" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:29.072325" elapsed="0.005803"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:29.087227" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:29.087390" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:29.087531" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:29.078502" elapsed="0.009534">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:29.088342" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:29.067351" elapsed="0.021131">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:30.095466" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:30.092424" elapsed="0.003087"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:30.103283" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:30.103503" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:30.103731" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:30.095796" elapsed="0.008548">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:30.104780" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:30.089055" elapsed="0.015919">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:31.114385" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:31.110666" elapsed="0.003773"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:31.124096" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:31.124306" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:31.124464" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:31.114874" elapsed="0.010222">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:31.125478" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:31.105875" elapsed="0.019815">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:32.136567" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:32.131952" elapsed="0.004665"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:32.144342" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:32.144540" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:32.144714" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:32.136897" elapsed="0.008271">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:32.145524" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:32.126342" elapsed="0.019366">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:33.156942" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:33.151759" elapsed="0.005228"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:33.170528" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:33.170785" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:33.170944" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:33.157219" elapsed="0.014342">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:33.171928" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:33.146503" elapsed="0.025704">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:34.182355" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:34.177591" elapsed="0.004798"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:34.191238" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:34.191511" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:34.191772" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:34.182554" elapsed="0.010133">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:34.193216" elapsed="0.000058"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:34.172917" elapsed="0.020577">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:35.204814" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:35.199463" elapsed="0.005422"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:35.212095" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:35.212233" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:35.212351" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:35.205245" elapsed="0.007639">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:35.213123" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:35.194267" elapsed="0.018985">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:36.224387" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:36.219171" elapsed="0.005249"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:36.231342" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:36.231484" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:36.231723" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:36.224592" elapsed="0.007582">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:36.232415" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:36.213921" elapsed="0.018627">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:37.243421" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:37.238458" elapsed="0.005036"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:37.251708" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:37.251905" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:37.252087" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:37.243914" elapsed="0.008664">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:37.252949" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:37.233305" elapsed="0.019798">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:38.265552" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:38.259730" elapsed="0.005895"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:38.273959" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:38.274102" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:38.274223" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:38.266033" elapsed="0.008729">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:38.275035" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:38.254077" elapsed="0.021095">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:39.286336" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:39.281214" elapsed="0.005176"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:39.294814" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:39.295189" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:39.295371" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:39.286686" elapsed="0.009309">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:39.296677" elapsed="0.000049"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:39.275942" elapsed="0.020919">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:40.306032" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:40.302617" elapsed="0.003462"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:40.312045" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:40.312197" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:40.312317" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:40.306313" elapsed="0.006513">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:40.313124" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:40.297729" elapsed="0.015585">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:41.322786" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:41.319292" elapsed="0.003541"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:41.330167" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:41.330347" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:41.330508" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:41.323123" elapsed="0.008058">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:41.331545" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:41.314263" elapsed="0.017488">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:42.342234" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:42.338208" elapsed="0.004079"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:42.353111" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:42.353414" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:42.353667" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:42.343817" elapsed="0.010546">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:42.354997" elapsed="0.000064"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:42.332766" elapsed="0.022483">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:43.366401" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:43.361625" elapsed="0.004853"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:43.372589" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:43.372751" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:43.372863" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:43.366774" elapsed="0.006521">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:43.373541" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:43.355988" elapsed="0.017711">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:44.380579" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:44.377270" elapsed="0.003354"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:44.387830" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:44.388015" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:44.388175" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:44.380870" elapsed="0.007948">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:44.389178" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:44.374229" elapsed="0.015232">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:45.398347" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:45.395133" elapsed="0.003258"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:45.405396" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:45.405578" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:45.405750" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:45.398616" elapsed="0.007712">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:45.406675" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:45.390289" elapsed="0.016561">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:46.416818" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:46.412758" elapsed="0.004103"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:46.423991" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:46.424192" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:46.424329" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:46.417068" elapsed="0.007771">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:46.425309" elapsed="0.000047"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:46.407616" elapsed="0.017899">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:47.440159" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:47.431875" elapsed="0.008322"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:47.446552" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:47.446737" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:47.446973" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:47.440389" elapsed="0.007093">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:47.447771" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:47.426368" elapsed="0.021540">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:48.457744" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:48.453446" elapsed="0.004342"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:48.465012" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:48.465193" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:48.465336" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:48.458012" elapsed="0.007983">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:48.466321" elapsed="0.000035"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:48.448589" elapsed="0.017905">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:49.476232" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:49.472688" elapsed="0.003590"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:49.484214" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:49.484399" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:49.484546" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:49.476505" elapsed="0.008675">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:49.485532" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:49.467200" elapsed="0.018537">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:50.494204" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:50.491602" elapsed="0.002636"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:50.502047" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:50.502320" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:50.502444" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:50.494683" elapsed="0.008228">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:50.503252" elapsed="0.000032"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:50.486583" elapsed="0.016810">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:51.513937" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:51.509722" elapsed="0.004258"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:51.522626" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:51.522790" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:51.522904" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:51.514198" elapsed="0.009194">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:51.523660" elapsed="0.000031"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:51.504091" elapsed="0.019707">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:52.534946" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:52.530400" elapsed="0.004593"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:52.546438" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:52.547094" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:52.547463" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:52.535219" elapsed="0.013492">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:52.549580" elapsed="0.000173"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:52.524816" elapsed="0.025217">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:53.561309" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:53.556476" elapsed="0.004875"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:53.569786" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:53.569966" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:53.570156" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:53.562655" elapsed="0.008202">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:53.571346" elapsed="0.000050"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:53.550982" elapsed="0.020593">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:54.581979" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:54.577190" elapsed="0.004914"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:54.591869" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:54.592014" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:54.592130" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:54.582433" elapsed="0.010478">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:54.593436" elapsed="0.000060"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:54.572301" elapsed="0.021451">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:55.604026" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:55.600589" elapsed="0.003490"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:55.613090" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:55.613276" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:55.613431" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:55.604311" elapsed="0.009756">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:55.614419" elapsed="0.000038"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:55.595241" elapsed="0.019497">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:56.624869" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:56.620853" elapsed="0.004057"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:56.635340" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:56.635582" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:56.635805" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:56.625096" elapsed="0.011437">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:56.636896" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:56.615704" elapsed="0.021390">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:57.645821" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:57.642629" elapsed="0.003239"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:57.654136" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:57.654353" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:57.654518" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:57.646102" elapsed="0.009217">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:57.655725" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:57.637839" elapsed="0.018127">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:58.665881" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:58.661450" elapsed="0.004466"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:58.676524" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:58.676742" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:58.677018" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:58.666078" elapsed="0.011696">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:58.678109" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:58.656731" elapsed="0.021553">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:09:59.689545" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:09:59.684122" elapsed="0.005493"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:09:59.698804" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:09:59.698959" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:09:59.699097" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:09:59.690027" elapsed="0.009593">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:09:59.699988" elapsed="0.000064"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:09:59.678966" elapsed="0.021207">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:00.710523" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:00.705699" elapsed="0.004894"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:00.717075" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:00.717211" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:00.717318" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:00.710834" elapsed="0.006938">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:00.718010" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:00.700915" elapsed="0.017222">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:01.728503" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:01.723616" elapsed="0.004956"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:01.739169" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:01.739404" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:01.739535" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:01.728970" elapsed="0.011043">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:01.740331" elapsed="0.000033"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:01.718820" elapsed="0.021652">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:02.750183" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:02.746369" elapsed="0.003846"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:02.757433" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:02.757686" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:02.757872" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:02.750380" elapsed="0.008109">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:02.758920" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:02.741295" elapsed="0.017812">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:03.767586" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:03.764579" elapsed="0.003086"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:03.776963" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:03.777153" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:03.777304" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:03.767890" elapsed="0.010025">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:03.778278" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:03.759829" elapsed="0.018631">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:04.788939" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:04.785144" elapsed="0.003840"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:04.797915" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:04.798064" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:04.798178" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:04.789346" elapsed="0.009273">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:04.798901" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:04.779280" elapsed="0.019750">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:05.808315" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:05.804546" elapsed="0.003803"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:05.817089" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:05.817231" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:05.817347" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:05.808512" elapsed="0.009291">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:05.818072" elapsed="0.000028"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:05.799752" elapsed="0.018451">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:06.829274" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:06.824275" elapsed="0.005150"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:06.838239" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:06.838478" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:06.838692" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:06.829814" elapsed="0.009598">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:06.839817" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:06.819243" elapsed="0.020909">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:07.849200" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:07.845972" elapsed="0.003278"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:07.858790" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:07.859026" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:07.859375" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:07.849506" elapsed="0.010559">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:07.860508" elapsed="0.000046"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:07.840947" elapsed="0.019847">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:08.871076" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:08.865576" elapsed="0.005534"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:08.878984" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:08.879202" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:08.879446" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:08.871282" elapsed="0.009128">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:08.880981" elapsed="0.000062"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:08.861354" elapsed="0.019909">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:09.891088" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:09.887519" elapsed="0.003614"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:09.899779" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:09.900036" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:09.900309" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:09.891323" elapsed="0.009775">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:09.901589" elapsed="0.000049"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:09.882116" elapsed="0.019709">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:10.912389" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:10.907759" elapsed="0.004664"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:10.920725" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:10.920878" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:10.921001" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:10.912609" elapsed="0.008944">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:10.921945" elapsed="0.000041"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:10.902766" elapsed="0.019366">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:11.931366" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:11.927788" elapsed="0.003627"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:11.940869" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:11.941029" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:11.941162" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:11.931805" elapsed="0.009814">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:11.941909" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:11.923046" elapsed="0.019001">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:12.952978" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:12.947965" elapsed="0.005051"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:12.961328" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:12.961799" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:12.962050" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:12.953227" elapsed="0.009925">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:12.963827" elapsed="0.000067"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:12.942902" elapsed="0.021236">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:13.974015" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:13.970687" elapsed="0.003377"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:13.985231" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:13.985436" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:13.985881" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:13.974313" elapsed="0.012258">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:13.987057" elapsed="0.000048"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:13.964952" elapsed="0.022313">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:14.996578" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:14.993284" elapsed="0.003338"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:15.005950" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:15.006176" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:15.006366" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:14.996870" elapsed="0.010131">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:15.007399" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:14.988048" elapsed="0.019543">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:16.018583" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:16.013564" elapsed="0.005126"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:16.031617" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:16.031902" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:16.032086" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:16.019487" elapsed="0.013265">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:16.033178" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:16.008647" elapsed="0.024736">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:17.042906" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:17.039240" elapsed="0.003712"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:17.051726" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:17.051936" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:17.052096" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:17.043185" elapsed="0.009535">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:17.053128" elapsed="0.000042"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:17.034158" elapsed="0.019161">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:18.063724" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:18.059491" elapsed="0.004268"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:18.070782" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:18.070992" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:18.071169" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:18.063927" elapsed="0.007875">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:18.072205" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:18.054310" elapsed="0.018198">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:19.082081" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:19.078920" elapsed="0.003206"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:19.091153" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:19.091419" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:19.091680" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:19.082353" elapsed="0.010070">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:19.092905" elapsed="0.000047"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:19.073434" elapsed="0.019685">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:20.101335" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:20.098296" elapsed="0.003084"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:20.108630" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:20.108801" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:20.108913" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:20.101607" elapsed="0.007761">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:20.109622" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:20.093895" elapsed="0.015876">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:21.120040" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:21.115190" elapsed="0.004884"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:21.128068" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:21.128339" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:21.128754" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:21.120238" elapsed="0.009402">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:21.130245" elapsed="0.000078"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:21.110453" elapsed="0.020164">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:22.139469" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:22.136131" elapsed="0.003390"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:22.148317" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:22.148541" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:22.148756" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:22.139802" elapsed="0.009697">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:22.149985" elapsed="0.000043"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:22.131608" elapsed="0.018585">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:23.159360" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:23.156008" elapsed="0.003426"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:23.168069" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:23.168252" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:23.168383" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:23.159728" elapsed="0.009188">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:23.169267" elapsed="0.000035"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:23.150954" elapsed="0.018459">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:24.179383" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:24.174690" elapsed="0.004750"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:24.188268" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:24.188596" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:24.188782" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:24.179709" elapsed="0.010103">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:24.190465" elapsed="0.000069"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:24.170421" elapsed="0.020391">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:25.200387" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:25.197092" elapsed="0.003345"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:25.209918" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:25.210243" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:25.210462" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:25.200704" elapsed="0.010716">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:25.211990" elapsed="0.000052"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:25.191831" elapsed="0.020384">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:26.221873" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:26.218338" elapsed="0.003591"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:26.230726" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:26.230938" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:26.231093" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:26.222263" elapsed="0.009448">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:26.231966" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:26.213245" elapsed="0.018873">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:27.240999" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:27.237527" elapsed="0.003518"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:27.250634" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:27.250848" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:27.251020" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:27.241369" elapsed="0.010298">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:27.252031" elapsed="0.000040"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:27.232976" elapsed="0.019241">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:28.260169" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:28.257201" elapsed="0.003012"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:28.269696" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:28.269929" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:28.270117" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:28.260438" elapsed="0.010376">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:28.271254" elapsed="0.000048"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:28.253001" elapsed="0.018465">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:29.281488" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:29.276838" elapsed="0.004716"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:29.291230" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:29.291371" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:29.291479" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:29.281932" elapsed="0.010004">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:29.292169" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:29.272124" elapsed="0.020236">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:30.301568" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:30.298091" elapsed="0.003524"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:30.312086" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:30.312279" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:30.312445" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:30.301872" elapsed="0.011202">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:30.313455" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:30.293055" elapsed="0.020613">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:31.324488" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:31.319419" elapsed="0.005106"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:31.334305" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:31.334543" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:31.334789" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:31.324745" elapsed="0.011149">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:31.336417" elapsed="0.000055"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:31.314342" elapsed="0.022334">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:32.345503" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:32.342275" elapsed="0.003334"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:32.354144" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:32.354329" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:32.354551" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:32.345862" elapsed="0.009295">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:32.355488" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:32.337396" elapsed="0.018289">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:33.365849" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:33.362051" elapsed="0.003838"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:33.375756" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:33.375987" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:33.376174" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:33.366076" elapsed="0.010815">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:33.377239" elapsed="0.000037"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:33.356598" elapsed="0.020829">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:34.385920" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:34.382737" elapsed="0.003231"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:34.393201" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:34.393390" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:34.393539" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:34.386206" elapsed="0.008019">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:34.394612" elapsed="0.000066"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:34.378139" elapsed="0.016691">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:35.403236" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:35.398794" elapsed="0.004532"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:35.411753" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:35.412071" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:35.412280" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:35.403548" elapsed="0.009461">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:35.413459" elapsed="0.000046"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:35.395467" elapsed="0.018232">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:36.424443" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:36.419165" elapsed="0.005312"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:36.432785" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:36.433075" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:36.433330" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:36.424664" elapsed="0.009595">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:36.434869" elapsed="0.000062"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:36.414368" elapsed="0.020785">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:37.446241" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:37.441203" elapsed="0.005111"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:37.452621" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:37.452782" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:37.452893" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:37.446607" elapsed="0.006726">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:37.453619" elapsed="0.000044"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:37.435964" elapsed="0.017804">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:38.464292" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:38.459465" elapsed="0.004895"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:38.474087" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:38.474239" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:38.474353" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:38.465005" elapsed="0.009913">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.475197" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:38.454439" elapsed="0.020893">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:10:38.475424" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 5 minutes. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<arg>300s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${off_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:05:37.495300" elapsed="300.980239">Keyword 'Compare_Topology' failed after retrying for 5 minutes. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare current pcep-topology to off_json variable.
Timeout is long enough to ODL boot, to see that pcep is ready, with no PCC is connected.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:05:37.494595" elapsed="300.981394">Keyword 'Compare_Topology' failed after retrying for 5 minutes. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t2" name="Start_Pcc_Mock" line="39">
<kw name="Compose_Full_Java_Command" owner="NexusKeywords">
<kw name="Compose_Base_Java_Command" owner="NexusKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${openjdk}""" == "openjdk8"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_8_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_8_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:10:38.480254" elapsed="0.000896"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${openjdk}""" == "openjdk11"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_11_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_11_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:10:38.481493" elapsed="0.000725"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${openjdk}""" == "openjdk17"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_17_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_17_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:10:38.482547" elapsed="0.000827"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Compose_Dilemma_Filepath" owner="NexusKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:10:38.484991" level="INFO">Executing command 'ls -lA /usr/lib/jvm/java-21-openjdk-amd64/bin/java 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:10:38.499345" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:10:38.499515" level="INFO">${out} = -rwxr-xr-x 1 root root 14456 Jul 16  2025 /usr/lib/jvm/java-21-openjdk-amd64/bin/java</msg>
<msg time="2026-06-06T03:10:38.499613" level="INFO">${rc} = 0</msg>
<var>${out}</var>
<var>${rc}</var>
<arg>ls -lA ${specific_path} 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:10:38.484777" elapsed="0.014930"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>${specific_path}</value>
<status status="PASS" start="2026-06-06T03:10:38.500190" elapsed="0.000079"/>
</return>
<status status="PASS" start="2026-06-06T03:10:38.499917" elapsed="0.000438"/>
</branch>
<status status="PASS" start="2026-06-06T03:10:38.499858" elapsed="0.000555"/>
</if>
<return>
<value>${default_path}</value>
<status status="NOT RUN" start="2026-06-06T03:10:38.500492" elapsed="0.000033"/>
</return>
<arg>${JAVA_21_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_21_HOME_UBUNTU}/bin/java</arg>
<doc>Query active SSH connection, return specific path if it exists else default path.</doc>
<status status="PASS" start="2026-06-06T03:10:38.484376" elapsed="0.016552"/>
</kw>
<msg time="2026-06-06T03:10:38.501036" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>"""${openjdk}""" == "openjdk21"</arg>
<arg>Compose_Dilemma_Filepath</arg>
<arg>${JAVA_21_HOME_CENTOS}/bin/java</arg>
<arg>${JAVA_21_HOME_UBUNTU}/bin/java</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:10:38.483608" elapsed="0.017534"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${out}</var>
<var>${rc}</var>
<arg>java -version 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.501531" elapsed="0.000057"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>java</value>
<status status="NOT RUN" start="2026-06-06T03:10:38.501878" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:10:38.501796" elapsed="0.000175"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:38.501754" elapsed="0.000267"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${java}</var>
<arg>echo $JAVA_HOME/bin/java 2&gt;&amp;1</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.502312" elapsed="0.000047"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${out}</var>
<var>${rc}</var>
<arg>${java} -version 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.502921" elapsed="0.000058"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>${java}</value>
<status status="NOT RUN" start="2026-06-06T03:10:38.503237" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:10:38.503154" elapsed="0.000177"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:38.503113" elapsed="0.000269"/>
</if>
<kw name="Get Environment Variable" owner="OperatingSystem">
<var>${JAVA_HOME}</var>
<arg>JAVA_HOME</arg>
<arg>${EMPTY}</arg>
<doc>Returns the value of an environment variable with the given name.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.503719" elapsed="0.000178"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${java}</var>
<arg>"""${JAVA_HOME}"""!=""</arg>
<arg>${JAVA_HOME}/bin/java</arg>
<arg>false</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.504264" elapsed="0.000055"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${out}</var>
<var>${rc}</var>
<arg>${java} -version 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.504693" elapsed="0.000064"/>
</kw>
<if>
<branch type="IF" condition="${rc} == 0">
<return>
<value>${java}</value>
<status status="NOT RUN" start="2026-06-06T03:10:38.505092" elapsed="0.000047"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:10:38.504973" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:38.504928" elapsed="0.000357"/>
</if>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to find Java; specify \${JDKVERSION}, put it to your PATH or set JAVA_HOME environment variable.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:38.505602" elapsed="0.000085"/>
</kw>
<msg time="2026-06-06T03:10:38.505944" level="INFO">${base_command} = /usr/lib/jvm/java-21-openjdk-amd64/bin/java</msg>
<var>${base_command}</var>
<arg>openjdk=${openjdk}</arg>
<doc>Return string suitable for launching Java programs over SSHLibrary, depending on JRE version needed.
This requires that the SSH connection on which the command is going to be used is active as it is needed for querying files.
Commands composed for one SSH connection shall not be reused on other SSH connections as the two connections may have different Java setups.
Not directly related to Nexus, but versioned Java tools may need this.</doc>
<status status="PASS" start="2026-06-06T03:10:38.479422" elapsed="0.026582"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:10:38.507337" level="INFO">${full_command} = /usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar pcep-pcc-mock-2.0.0-executable.jar --reconnect 1 --local-address 10.30.171.194 --remote-address 10.30.170.38 2&gt;&amp;1 | tee pccmock.log</msg>
<var>${full_command}</var>
<arg>${base_command} ${options}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:10:38.506342" elapsed="0.001065"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:38.507888" level="INFO">/usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar pcep-pcc-mock-2.0.0-executable.jar --reconnect 1 --local-address 10.30.171.194 --remote-address 10.30.170.38 2&gt;&amp;1 | tee pccmock.log</msg>
<arg>${full_command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:38.507621" elapsed="0.000314"/>
</kw>
<return>
<value>${full_command}</value>
<status status="PASS" start="2026-06-06T03:10:38.507977" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:10:38.508131" level="INFO">${command} = /usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar pcep-pcc-mock-2.0.0-executable.jar --reconnect 1 --local-address 10.30.171.194 --remote-address 10.30.170.38 2&gt;&amp;1 | tee pccmock.log</msg>
<var>${command}</var>
<arg>-jar ${filename} --reconnect 1 --local-address ${TOOLS_SYSTEM_IP} --remote-address ${ODL_SYSTEM_IP} 2&gt;&amp;1 | tee pccmock.log</arg>
<doc>Return full Bash command to run Java with given options.
This requires that the SSH connection on which the command is going to be used is active as it is needed for querying files.
The options may include JVM options, application command line arguments, Bash redirects and other constructs.</doc>
<status status="PASS" start="2026-06-06T03:10:38.477902" elapsed="0.030256"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:38.508564" level="INFO">/usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar pcep-pcc-mock-2.0.0-executable.jar --reconnect 1 --local-address 10.30.171.194 --remote-address 10.30.170.38 2&gt;&amp;1 | tee pccmock.log</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:38.508322" elapsed="0.000289"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:10:38.541230" level="INFO">/usr/lib/jvm/java-21-openjdk-amd64/bin/java -jar pcep-pcc-mock-2.0.0-executable.jar --reconnect 1 --local-address 10.30.171.194 --remote-address 10.30.170.38 2&gt;&amp;1 | tee pccmock.log</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:10:38.508771" elapsed="0.032558"/>
</kw>
<kw name="Read Until" owner="SSHLibrary">
<msg time="2026-06-06T03:10:48.542311" level="FAIL">No match found for 'started, sent proposal Open' in 10 seconds
Output:
[?2004l.</msg>
<arg>started, sent proposal Open</arg>
<doc>Consumes and returns the server output until ``expected`` is encountered.</doc>
<status status="FAIL" start="2026-06-06T03:10:38.541550" elapsed="10.003065">No match found for 'started, sent proposal Open' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Sleep" owner="BuiltIn">
<arg>1s</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.544969" elapsed="0.000034"/>
</kw>
<doc>Execute pcc-mock on Mininet, fail is Open is not sent, keep it running for next tests.</doc>
<status status="FAIL" start="2026-06-06T03:10:38.476479" elapsed="10.068726">No match found for 'started, sent proposal Open' in 10 seconds
Output:
[?2004l.</status>
</test>
<test id="s1-s2-t3" name="Configure_Speaker_Entity_Identifier" line="49">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.546792" level="INFO">&amp;{mapping} = { IP=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:10:48.546231" elapsed="0.000593"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.569148" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:10:48.568754" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:10:48.570012" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.569699" elapsed="0.000952">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:10:48.570756" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:10:48.569333" elapsed="0.001448"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.571327" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:48.570931" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:10:48.571664" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:10:48.571839" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology/node=$IP
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:10:48.571499" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.572258" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology/node=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.572006" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.573258" level="INFO">mapping: {'IP': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.572995" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.573777" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:10:48.573460" elapsed="0.000343"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.574505" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:10:48.574193" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:10:48.575305" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:10:48.575066" elapsed="0.000271"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:10:48.575394" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:10:48.575561" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:10:48.574724" elapsed="0.000862"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:10:48.575741" elapsed="0.000265"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:10:48.574067" elapsed="0.001982"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:10:48.573869" elapsed="0.002218"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:10:48.576132" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:10:48.576312" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:10:48.572687" elapsed="0.003651"/>
</kw>
<status status="PASS" start="2026-06-06T03:10:48.572380" elapsed="0.003990"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.576533" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.576396" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:10:48.572356" elapsed="0.004255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.577401" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:10:48.576763" elapsed="0.000671"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:10:48.577486" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:10:48.568137" elapsed="0.009478"/>
</kw>
<msg time="2026-06-06T03:10:48.577738" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:10:48.567223" elapsed="0.010569"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.578297" elapsed="0.000061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.578885" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.579398" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.579575" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.579759" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.580345" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.580208" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:48.580192" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.580559" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.580729" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.580884" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:10:48.580159" elapsed="0.000780"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.579869" elapsed="0.001097"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.581099" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.581176" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:10:48.581315" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:10:48.562603" elapsed="0.018740"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.595664" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:10:48.595254" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:10:48.596460" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.596215" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:10:48.596717" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:10:48.595875" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.597331" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:48.596901" elapsed="0.000459"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:10:48.597687" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:10:48.597863" level="INFO">${template} = &lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;$IP&lt;/node-id&gt;
    &lt;session-config xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
        &lt;speaker-entity-id-value xm...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:10:48.597512" elapsed="0.000391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.598328" level="INFO">&lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;$IP&lt;/node-id&gt;
    &lt;session-config xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
        &lt;speaker-entity-id-value xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep:sync:optimizations:config"&gt;
            AQIDBA==
        &lt;/speaker-entity-id-value&gt;
    &lt;/session-config&gt;
&lt;/node&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.598065" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:10:48.598822" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.598462" elapsed="0.000423"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.599350" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:10:48.599046" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:10:48.598910" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:10:48.598436" elapsed="0.001005"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.600222" level="INFO">${final_text} = &lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.170.38&lt;/node-id&gt;
    &lt;session-config xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
        &lt;speaker-entity-id...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:10:48.599609" elapsed="0.000644"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:10:48.600306" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:10:48.594626" elapsed="0.005820"/>
</kw>
<msg time="2026-06-06T03:10:48.600510" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:10:48.593674" elapsed="0.006886"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.601108" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.601605" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.602124" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.602394" elapsed="0.000033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.602588" elapsed="0.000030"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.603036" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.602871" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:48.602854" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.603260" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.603421" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.603574" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:10:48.602823" elapsed="0.000804"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.602709" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.603805" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.603883" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:10:48.604015" level="INFO">${data} = &lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.170.38&lt;/node-id&gt;
    &lt;session-config xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
        &lt;speaker-entity-id...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:10:48.591034" elapsed="0.013019"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:10:48.605543" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.605284" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/pcepuser/vanadium/node_speaker_entity_identifier/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:10:48.605728" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:10:48.604761" elapsed="0.000992"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.606057" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.605825" elapsed="0.000288"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.606580" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:10:48.606287" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:10:48.606138" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:10:48.605806" elapsed="0.000875"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.608910" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:48.606818" elapsed="0.002119"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:10:48.608999" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:10:48.609161" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/pcepuser/../../../variables/pcepuser/vanadium/node_speaker_entity_identifier/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:10:48.604427" elapsed="0.004759"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.610579" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.610326" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.611062" level="INFO">&lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.170.38&lt;/node-id&gt;
    &lt;session-config xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
        &lt;speaker-entity-id-value xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep:sync:optimizations:config"&gt;
            AQIDBA==
        &lt;/speaker-entity-id-value&gt;
    &lt;/session-config&gt;
&lt;/node&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.610810" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.611502" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.611249" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.612028" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.611744" elapsed="0.000333"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:10:48.613068" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:10:48.612767" elapsed="0.000331"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:10:48.613433" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:10:48.613238" elapsed="0.000223"/>
</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-06-06T03:10:48.613597" elapsed="0.000233"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.614223" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:48.613971" elapsed="0.000297"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:10:48.614311" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:10:48.614469" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:10:48.612286" elapsed="0.002208"/>
</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-06-06T03:10:48.661484" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Content-Length': '377', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.170.38&lt;/node-id&gt;
    &lt;session-config xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
        &lt;speaker-entity-id-value xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep:sync:optimizations:config"&gt;
            AQIDBA==
        &lt;/speaker-entity-id-value&gt;
    &lt;/session-config&gt;
&lt;/node&gt; 
 </msg>
<msg time="2026-06-06T03:10:48.667789" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38 
 status=400, reason=Bad Request 
 headers={'Content-Type': 'application/xml', 'Content-Length': '581'} 
 body=&lt;?xml version='1.0' encoding='UTF-8'?&gt;&lt;errors xmlns="urn:ietf:params:xml:ns:yang:ietf-restconf"&gt;&lt;error&gt;&lt;error-type&gt;protocol&lt;/error-type&gt;&lt;error-message&gt;Error parsing input: ParseError at [row,col]:[-1,-1]
Message: Schema for node with name speaker-entity-id-value and namespace urn:opendaylight:params:xml:ns:yang:topology:pcep:sync:optimizations:config does not exist in parent RegularContainerEffectiveStatement{argument=(urn:opendaylight:params:xml:ns:yang:topology:pcep?revision=2026-05-28)session-config}&lt;/error-message&gt;&lt;error-tag&gt;malformed-message&lt;/error-tag&gt;&lt;/error&gt;&lt;/errors&gt; 
 </msg>
<msg time="2026-06-06T03:10:48.668178" level="FAIL">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</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="FAIL" start="2026-06-06T03:10:48.616506" elapsed="0.053075">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</kw>
<status status="FAIL" start="2026-06-06T03:10:48.614565" elapsed="0.055262">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</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-06-06T03:10:48.670279" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.669912" elapsed="0.000542"/>
</branch>
<status status="FAIL" start="2026-06-06T03:10:48.614547" elapsed="0.055982">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:10:48.671528" elapsed="0.000065"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.671906" elapsed="0.000036"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:10:48.671816" elapsed="0.000190"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:48.671753" elapsed="0.000295"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:10:48.672188" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.672256" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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="FAIL" start="2026-06-06T03:10:48.609519" elapsed="0.062850">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.672446" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.551424" elapsed="0.121172">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.672902" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:10:48.672727" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:10:48.672709" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:10:48.673030" elapsed="0.000015"/>
</return>
<arg>${PCEP_VARIABLES_FOLDER}${/}node_speaker_entity_identifier</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.547142" elapsed="0.125992">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</kw>
<doc>Additional PCEP Speaker configuration for at least oxygen streams.
Allows PCEP speaker to determine if state synchronization can be skipped when a PCEP session is restarted.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.545462" elapsed="0.127851">HTTPError: 400 Client Error: Bad Request for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.170.38</status>
</test>
<test id="s1-s2-t4" name="Topology_Default" line="58">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:48.677818" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:48.675597" elapsed="0.002252"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:48.687243" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:48.687390" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:48.687505" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.678005" elapsed="0.009993">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:48.688312" elapsed="0.000040"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.675173" elapsed="0.013323">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:49.695495" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:49.690303" elapsed="0.005264"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:49.705109" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:49.705463" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:49.705699" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:49.695954" elapsed="0.010204">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:49.706490" elapsed="0.000038"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:49.689181" elapsed="0.017506">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:50.714589" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:50.708502" elapsed="0.006241"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:50.724964" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:50.725102" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:50.725254" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:50.715283" elapsed="0.010612">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:50.726260" elapsed="0.000040"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:50.707363" elapsed="0.019086">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:51.733974" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:51.728285" elapsed="0.005765"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:51.745546" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:51.745727" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:51.745865" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:51.734528" elapsed="0.011844">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:51.746636" elapsed="0.000055"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:51.727167" elapsed="0.019724">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:52.753588" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:52.748675" elapsed="0.005019"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:52.765417" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:52.765554" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:52.765685" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:52.754057" elapsed="0.012058">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:52.766361" elapsed="0.000027"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:52.747539" elapsed="0.018952">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:53.773622" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:53.768407" elapsed="0.005316"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:53.786899" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:53.787043" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:53.787158" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:53.774079" elapsed="0.013581">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:53.787907" elapsed="0.000027"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:53.767264" elapsed="0.020772">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:54.791595" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:54.789133" elapsed="0.002497"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:54.799070" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:54.799206" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:54.799322" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:54.791868" elapsed="0.007912">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:54.800020" elapsed="0.000026"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:54.788522" elapsed="0.011628">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:55.804751" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:55.801545" elapsed="0.003254"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:55.812586" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:55.812807" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:55.812954" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:55.805021" elapsed="0.008518">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:55.813888" elapsed="0.000036"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:55.800791" elapsed="0.013272">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:56.821088" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:56.815959" elapsed="0.005214"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:56.828596" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:56.828809" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:56.829052" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:56.821503" elapsed="0.008165">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:56.830000" elapsed="0.000037"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:56.814790" elapsed="0.015385">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:57.839573" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:57.831955" elapsed="0.007652"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:57.848406" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:57.848598" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:57.848883" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:57.839786" elapsed="0.010012">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:57.850369" elapsed="0.000061"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:57.830889" elapsed="0.019797">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:58.857722" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:58.852715" elapsed="0.005077"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:58.870352" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:58.870708" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:58.870948" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.858136" elapsed="0.013588">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:58.872294" elapsed="0.000054"/>
</kw>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.851397" elapsed="0.021308">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:10:58.872864" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:10:48.674346" elapsed="10.198660">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare pcep-topology to default_json, which includes a tunnel from pcc-mock.
Timeout is lower than in Precondition, as state from pcc-mock should be updated quickly.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:10:48.673550" elapsed="10.199776">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t5" name="Update_Delegated" line="64">
<kw name="Update_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Operate_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:10:58.876984" level="INFO">${uri_path} = /rests/operations/network-topology-pcep:update-lsp</msg>
<var>${uri_path}</var>
<arg>/rests/operations/${uri_part}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:10:58.876323" elapsed="0.000703"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:58.898139" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:update-lsp 
 path_url=/rests/operations/network-topology-pcep:update-lsp 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '752', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;pcc_10.30.171.194_tunnel_1&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
 &lt;arguments&gt;
  &lt;lsp xmlns="urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful"&gt;
   &lt;delegate&gt;true&lt;/delegate&gt;
   &lt;administrative&gt;true&lt;/administrative&gt;
  &lt;/lsp&gt;
  &lt;ero&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;2.2.2.2/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;1.1.1.1/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
  &lt;/ero&gt;
 &lt;/arguments&gt;
&lt;/input&gt;
 
 </msg>
<msg time="2026-06-06T03:10:58.899303" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:update-lsp 
 status=400, reason=Bad Request 
 headers={'Set-Cookie': 'JSESSIONID=node0t62w9z8u4jnd165f7zq7eiibp2.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:10:58 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Type': 'application/yang-data+json', 'Content-Length': '462'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "malformed-message",
        "error-message": "Invalid XML: ParseError at [row,col]:[6,3]\nMessage: Schema for node with name lsp and namespace urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful does not exist in parent EmptyContainerEffectiveStatement{argument=(urn:opendaylight:params:xml:ns:yang:topology:pcep?revision=2026-05-28)arguments}",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:58.899690" level="INFO">${response} = &lt;Response [400]&gt;</msg>
<var>${response}</var>
<arg>pcep_session</arg>
<arg>url=${uri_path}</arg>
<arg>data=${xml_data}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:10:58.877239" elapsed="0.022523"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:10:58.901348" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;pcc_10.30.171.194_tunnel_1&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
 &lt;arguments&gt;
  &lt;lsp xmlns="urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful"&gt;
   &lt;delegate&gt;true&lt;/delegate&gt;
   &lt;administrative&gt;true&lt;/administrative&gt;
  &lt;/lsp&gt;
  &lt;ero&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;2.2.2.2/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;1.1.1.1/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
  &lt;/ero&gt;
 &lt;/arguments&gt;
&lt;/input&gt;
</msg>
<arg>${xml_data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:10:58.900431" elapsed="0.001050"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:10:58.909484" level="FAIL">'[200, 201, 204]' does not contain '400'</msg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.901850" elapsed="0.007870">'[200, 201, 204]' does not contain '400'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:10:58.909908" elapsed="0.000065"/>
</return>
<var>${response}</var>
<arg>network-topology-pcep:update-lsp</arg>
<arg>${xml_data}</arg>
<doc>Post XML data to given pcep-operations URI, check status_code is 200 and return response text (JSON).</doc>
<status status="FAIL" start="2026-06-06T03:10:58.875340" elapsed="0.034884">'[200, 201, 204]' does not contain '400'</status>
</kw>
<return>
<value>${response}</value>
<status status="NOT RUN" start="2026-06-06T03:10:58.910369" elapsed="0.000046"/>
</return>
<var>${text}</var>
<arg>${update_delegated_xml}</arg>
<doc>Update LSP according to XML data and return response (json) text.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.874751" elapsed="0.035854">'[200, 201, 204]' does not contain '400'</status>
</kw>
<doc>Perform update-lsp on the mocked tunnel, check response is success.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:10:58.873742" elapsed="0.037181">'[200, 201, 204]' does not contain '400'</status>
</test>
<test id="s1-s2-t6" name="Topology_Updated" line="69">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:58.917996" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:58.914490" elapsed="0.003546"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:58.927446" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:58.927781" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:58.928011" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.918219" elapsed="0.010566">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:58.929380" elapsed="0.000062"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.913744" elapsed="0.015883">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:10:59.936106" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:10:59.931393" elapsed="0.004760"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:10:59.947439" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:10:59.947698" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:10:59.947925" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:10:59.936393" elapsed="0.012462">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:10:59.949381" elapsed="0.000060"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:10:59.930284" elapsed="0.019411">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:00.957561" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:00.951806" elapsed="0.005826"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:00.965134" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:00.965333" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:00.965453" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:00.958025" elapsed="0.007885">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:00.966156" elapsed="0.000027"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:00.950490" elapsed="0.015797">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:01.973128" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:01.968172" elapsed="0.005028"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:01.983724" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:01.984044" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:01.984284" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:01.973573" elapsed="0.011670">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:01.985889" elapsed="0.000070"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:01.967066" elapsed="0.019131">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:02.993944" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:02.988221" elapsed="0.005829"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:03.002199" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:03.002367" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:03.002497" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:02.994696" elapsed="0.008300">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:03.003507" elapsed="0.000035"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:02.986992" elapsed="0.016695">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:04.010318" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:04.005465" elapsed="0.004900"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:04.017778" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:04.017964" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:04.018120" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:04.010594" elapsed="0.008126">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:04.019052" elapsed="0.000038"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:04.004369" elapsed="0.014863">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:05.025907" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:05.020968" elapsed="0.004988"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:05.033437" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:05.033624" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:05.033803" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:05.026195" elapsed="0.008217">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:05.034781" elapsed="0.000040"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:05.019914" elapsed="0.015055">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:06.042102" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:06.036897" elapsed="0.005276"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:06.051635" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:06.051833" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:06.051959" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:06.042536" elapsed="0.009876">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:06.052748" elapsed="0.000039"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:06.035792" elapsed="0.017109">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:07.060561" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:07.054747" elapsed="0.005887"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:07.070084" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:07.070226" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:07.070344" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:07.061066" elapsed="0.009745">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:07.071052" elapsed="0.000026"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:07.053554" elapsed="0.017625">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:08.077223" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:08.073484" elapsed="0.003784"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:08.085570" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:08.085866" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:08.086017" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:08.077504" elapsed="0.009098">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:08.087000" elapsed="0.000037"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:08.072227" elapsed="0.014951">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:09.094713" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:09.089167" elapsed="0.005626"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:09.103092" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:09.103238" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:09.103355" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.095189" elapsed="0.008653">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:09.104127" elapsed="0.000029"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.087936" elapsed="0.016327">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:11:09.104357" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:10:58.912698" elapsed="10.191754">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare pcep-topology to default_json, which includes the updated tunnel.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:10:58.911372" elapsed="10.193257">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t7" name="Refuse_Remove_Delegated" line="74">
<kw name="Remove_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Operate_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:11:09.106516" level="INFO">${uri_path} = /rests/operations/network-topology-pcep:remove-lsp</msg>
<var>${uri_path}</var>
<arg>/rests/operations/${uri_part}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:11:09.106177" elapsed="0.000367"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:09.115408" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:remove-lsp 
 path_url=/rests/operations/network-topology-pcep:remove-lsp 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0t62w9z8u4jnd165f7zq7eiibp2.node0', 'Content-Length': '324', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;pcc_10.30.171.194_tunnel_1&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
&lt;/input&gt;
 
 </msg>
<msg time="2026-06-06T03:11:09.115881" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:remove-lsp 
 status=500, reason=Internal Server Error 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '272'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "operation-failed",
        "error-message": "No implementation of RPC (urn:opendaylight:params:xml:ns:yang:topology:pcep?revision=2026-05-28)remove-lsp available",
        "error-type": "rpc"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:09.116019" level="INFO">${response} = &lt;Response [500]&gt;</msg>
<var>${response}</var>
<arg>pcep_session</arg>
<arg>url=${uri_path}</arg>
<arg>data=${xml_data}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:11:09.106703" elapsed="0.009352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:11:09.116683" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;pcc_10.30.171.194_tunnel_1&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
&lt;/input&gt;
</msg>
<arg>${xml_data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:11:09.116297" elapsed="0.000460"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:11:09.122521" level="FAIL">'[200, 201, 204]' does not contain '500'</msg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.117008" elapsed="0.005689">'[200, 201, 204]' does not contain '500'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:11:09.122837" elapsed="0.000045"/>
</return>
<var>${response}</var>
<arg>network-topology-pcep:remove-lsp</arg>
<arg>${xml_data}</arg>
<doc>Post XML data to given pcep-operations URI, check status_code is 200 and return response text (JSON).</doc>
<status status="FAIL" start="2026-06-06T03:11:09.105840" elapsed="0.017239">'[200, 201, 204]' does not contain '500'</status>
</kw>
<return>
<value>${response}</value>
<status status="NOT RUN" start="2026-06-06T03:11:09.123211" elapsed="0.000036"/>
</return>
<var>${text}</var>
<arg>${remove_delegated_xml}</arg>
<doc>Remove LSP according to XML data and return response (json) text.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.105438" elapsed="0.017980">'[200, 201, 204]' does not contain '500'</status>
</kw>
<kw name="Pcep_Json_Is_Refused" owner="PcepOperations">
<arg>${text}</arg>
<doc>Given text should be equal to json response when device refuses tunnel removal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:09.123875" elapsed="0.000056"/>
</kw>
<doc>Perform remove-lsp on the mocked tunnel, check that mock-pcc has refused to remove it.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:09.104892" elapsed="0.019320">'[200, 201, 204]' does not contain '500'</status>
</test>
<test id="s1-s2-t8" name="Topology_Still_Updated" line="80">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:09.130797" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:09.128117" elapsed="0.002709"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:09.135976" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:09.136118" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:09.136229" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.130972" elapsed="0.005713">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:09.136976" elapsed="0.000029"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.127231" elapsed="0.009875">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:10.144405" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:10.139360" elapsed="0.005093"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:10.150947" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:10.151283" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:10.151452" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:10.144708" elapsed="0.007454">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:10.152565" elapsed="0.000043"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:10.138022" elapsed="0.014759">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:11.160092" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:11.154630" elapsed="0.005538"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:11.168480" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:11.168694" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:11.168874" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:11.160548" elapsed="0.008914">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:11.169863" elapsed="0.000039"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:11.153467" elapsed="0.016582">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:12.177828" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:12.172163" elapsed="0.005735"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:12.186714" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:12.186873" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:12.186999" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:12.178282" elapsed="0.009183">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:12.187857" elapsed="0.000032"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:12.170822" elapsed="0.017204">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:13.195786" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:13.190070" elapsed="0.005793"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:13.205281" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:13.205421" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:13.205530" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:13.196266" elapsed="0.009727">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:13.206237" elapsed="0.000026"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:13.188852" elapsed="0.017516">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:14.213802" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:14.208358" elapsed="0.005513"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:14.219813" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:14.219952" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:14.220068" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:14.214218" elapsed="0.006302">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:14.220777" elapsed="0.000027"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:14.207250" elapsed="0.013655">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:15.227868" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:15.222929" elapsed="0.005010"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:15.235765" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:15.235952" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:15.236099" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:15.228455" elapsed="0.008248">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:15.237030" elapsed="0.000037"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:15.221814" elapsed="0.015392">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:16.243963" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:16.239119" elapsed="0.004893"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:16.252417" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:16.252712" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:16.252926" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:16.244286" elapsed="0.009424">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:16.254156" elapsed="0.000051"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:16.237945" elapsed="0.016445">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:17.262102" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:17.256342" elapsed="0.005834"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:17.270356" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:17.270559" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:17.270710" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:17.262547" elapsed="0.008608">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:17.271460" elapsed="0.000030"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:17.255139" elapsed="0.016455">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:18.278784" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:18.273878" elapsed="0.004991"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:18.287664" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:18.287807" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:18.287916" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:18.279226" elapsed="0.009116">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:18.288597" elapsed="0.000028"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:18.272592" elapsed="0.016154">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:19.295276" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:19.290440" elapsed="0.004904"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:19.304416" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:19.304682" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:19.304842" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.295721" elapsed="0.009724">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:19.305935" elapsed="0.000041"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.289364" elapsed="0.016758">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:11:19.306256" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:11:09.126070" elapsed="10.180324">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare pcep-topology to default_json, which includes the updated tunnel, to verify that refusal did not break topology.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:09.124844" elapsed="10.181827">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t9" name="Add_Instantiated" line="85">
<kw name="Add_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Operate_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:11:19.309520" level="INFO">${uri_path} = /rests/operations/network-topology-pcep:add-lsp</msg>
<var>${uri_path}</var>
<arg>/rests/operations/${uri_part}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:11:19.309044" elapsed="0.000517"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:19.317822" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:add-lsp 
 path_url=/rests/operations/network-topology-pcep:add-lsp 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0t62w9z8u4jnd165f7zq7eiibp2.node0', 'Content-Length': '812', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;Instantiated tunnel&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
 &lt;arguments&gt;
  &lt;lsp xmlns="urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful"&gt;
   &lt;delegate&gt;true&lt;/delegate&gt;
   &lt;administrative&gt;true&lt;/administrative&gt;
  &lt;/lsp&gt;
  &lt;endpoints-obj&gt;
   &lt;ipv4&gt;
    &lt;source-ipv4-address&gt;10.30.171.194&lt;/source-ipv4-address&gt;
    &lt;destination-ipv4-address&gt;1.1.1.1&lt;/destination-ipv4-address&gt;
   &lt;/ipv4&gt;
  &lt;/endpoints-obj&gt;
  &lt;ero&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;1.1.1.1/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
  &lt;/ero&gt;
 &lt;/arguments&gt;
&lt;/input&gt;
 
 </msg>
<msg time="2026-06-06T03:11:19.317950" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:add-lsp 
 status=400, reason=Bad Request 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '462'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "malformed-message",
        "error-message": "Invalid XML: ParseError at [row,col]:[6,3]\nMessage: Schema for node with name lsp and namespace urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful does not exist in parent EmptyContainerEffectiveStatement{argument=(urn:opendaylight:params:xml:ns:yang:topology:pcep?revision=2026-05-28)arguments}",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:19.318046" level="INFO">${response} = &lt;Response [400]&gt;</msg>
<var>${response}</var>
<arg>pcep_session</arg>
<arg>url=${uri_path}</arg>
<arg>data=${xml_data}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:11:19.309796" elapsed="0.008276"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:11:19.318506" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;Instantiated tunnel&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
 &lt;arguments&gt;
  &lt;lsp xmlns="urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful"&gt;
   &lt;delegate&gt;true&lt;/delegate&gt;
   &lt;administrative&gt;true&lt;/administrative&gt;
  &lt;/lsp&gt;
  &lt;endpoints-obj&gt;
   &lt;ipv4&gt;
    &lt;source-ipv4-address&gt;10.30.171.194&lt;/source-ipv4-address&gt;
    &lt;destination-ipv4-address&gt;1.1.1.1&lt;/destination-ipv4-address&gt;
   &lt;/ipv4&gt;
  &lt;/endpoints-obj&gt;
  &lt;ero&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;1.1.1.1/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
  &lt;/ero&gt;
 &lt;/arguments&gt;
&lt;/input&gt;
</msg>
<arg>${xml_data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:11:19.318245" elapsed="0.000318"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:11:19.320982" level="FAIL">'[200, 201, 204]' does not contain '400'</msg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.318728" elapsed="0.002317">'[200, 201, 204]' does not contain '400'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:11:19.321106" elapsed="0.000021"/>
</return>
<var>${response}</var>
<arg>network-topology-pcep:add-lsp</arg>
<arg>${xml_data}</arg>
<doc>Post XML data to given pcep-operations URI, check status_code is 200 and return response text (JSON).</doc>
<status status="FAIL" start="2026-06-06T03:11:19.308515" elapsed="0.012699">'[200, 201, 204]' does not contain '400'</status>
</kw>
<return>
<value>${response}</value>
<status status="NOT RUN" start="2026-06-06T03:11:19.321270" elapsed="0.000015"/>
</return>
<var>${text}</var>
<arg>${add_instantiated_xml}</arg>
<doc>Instantiate LSP according to XML data and return response (json) text.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.307959" elapsed="0.013443">'[200, 201, 204]' does not contain '400'</status>
</kw>
<doc>Perform add-lsp to create new tunnel, check that response is success.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:19.307145" elapsed="0.014394">'[200, 201, 204]' does not contain '400'</status>
</test>
<test id="s1-s2-t10" name="Topology_Second_Default" line="90">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:19.325815" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:19.323290" elapsed="0.002567"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:19.332043" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:19.332204" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:19.332338" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.326074" elapsed="0.006843">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:19.333249" elapsed="0.000036"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.322905" elapsed="0.010515">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:20.340879" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:20.335462" elapsed="0.005490"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:20.349695" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:20.349859" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:20.350008" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:20.341309" elapsed="0.009190">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:20.350766" elapsed="0.000027"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:20.334238" elapsed="0.016661">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:21.357888" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:21.352724" elapsed="0.005210"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:21.365881" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:21.366101" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:21.366269" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:21.358242" elapsed="0.008655">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:21.367265" elapsed="0.000038"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:21.351549" elapsed="0.015895">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:22.374355" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:22.369267" elapsed="0.005158"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:22.384977" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:22.385118" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:22.385228" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:22.374821" elapsed="0.010853">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:22.385915" elapsed="0.000027"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:22.368173" elapsed="0.017869">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:23.393806" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:23.388127" elapsed="0.005755"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:23.403897" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:23.404043" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:23.404249" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:23.394266" elapsed="0.010523">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:23.405092" elapsed="0.000032"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:23.386827" elapsed="0.018405">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:24.412606" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:24.407071" elapsed="0.005643"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:24.419683" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:24.419832" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:24.419951" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:24.412928" elapsed="0.007492">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:24.420683" elapsed="0.000028"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:24.405955" elapsed="0.014865">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:25.428133" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:25.423065" elapsed="0.005145"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:25.435929" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:25.436110" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:25.436251" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:25.428582" elapsed="0.008218">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:25.437139" elapsed="0.000026"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:25.421725" elapsed="0.015553">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:26.443306" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:26.439152" elapsed="0.004201"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:26.451836" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:26.452022" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:26.452169" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:26.443581" elapsed="0.009214">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:26.453123" elapsed="0.000037"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:26.438032" elapsed="0.015274">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:27.462607" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:27.455939" elapsed="0.006738"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:27.472518" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:27.472734" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:27.472893" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:27.462918" elapsed="0.010596">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:27.473899" elapsed="0.000040"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:27.454303" elapsed="0.019780">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:28.480822" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:28.476015" elapsed="0.004877"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:28.489608" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:28.489779" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:28.489888" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:28.481238" elapsed="0.009085">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:28.490553" elapsed="0.000026"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:28.474900" elapsed="0.015795">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:29.497712" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:29.492586" elapsed="0.005200"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:29.506694" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:29.506896" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:29.507048" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.498218" elapsed="0.009446">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:29.508005" elapsed="0.000042"/>
</kw>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.491369" elapsed="0.016821">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:11:29.508315" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${updated_default_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:11:19.322405" elapsed="10.186037">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare pcep-topology to default_json, which includes the updated delegated and default instantiated tunnel.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:19.321839" elapsed="10.186848">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t11" name="Update_Instantiated" line="95">
<kw name="Update_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Operate_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:11:29.511697" level="INFO">${uri_path} = /rests/operations/network-topology-pcep:update-lsp</msg>
<var>${uri_path}</var>
<arg>/rests/operations/${uri_part}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:11:29.511227" elapsed="0.000510"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:29.519684" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:update-lsp 
 path_url=/rests/operations/network-topology-pcep:update-lsp 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0t62w9z8u4jnd165f7zq7eiibp2.node0', 'Content-Length': '745', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;Instantiated tunnel&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
 &lt;arguments&gt;
  &lt;lsp xmlns="urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful"&gt;
   &lt;delegate&gt;true&lt;/delegate&gt;
   &lt;administrative&gt;true&lt;/administrative&gt;
  &lt;/lsp&gt;
  &lt;ero&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;2.2.2.2/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;1.1.1.1/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
  &lt;/ero&gt;
 &lt;/arguments&gt;
&lt;/input&gt;
 
 </msg>
<msg time="2026-06-06T03:11:29.519885" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:update-lsp 
 status=400, reason=Bad Request 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '462'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "malformed-message",
        "error-message": "Invalid XML: ParseError at [row,col]:[6,3]\nMessage: Schema for node with name lsp and namespace urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful does not exist in parent EmptyContainerEffectiveStatement{argument=(urn:opendaylight:params:xml:ns:yang:topology:pcep?revision=2026-05-28)arguments}",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:29.520026" level="INFO">${response} = &lt;Response [400]&gt;</msg>
<var>${response}</var>
<arg>pcep_session</arg>
<arg>url=${uri_path}</arg>
<arg>data=${xml_data}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:11:29.511930" elapsed="0.008133"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:11:29.520716" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;Instantiated tunnel&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
 &lt;arguments&gt;
  &lt;lsp xmlns="urn:opendaylight:params:xml:ns:yang:pcep:ietf:stateful"&gt;
   &lt;delegate&gt;true&lt;/delegate&gt;
   &lt;administrative&gt;true&lt;/administrative&gt;
  &lt;/lsp&gt;
  &lt;ero&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;2.2.2.2/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
   &lt;subobject&gt;
    &lt;loose&gt;false&lt;/loose&gt;
    &lt;ip-prefix&gt;&lt;ip-prefix&gt;1.1.1.1/32&lt;/ip-prefix&gt;&lt;/ip-prefix&gt;
   &lt;/subobject&gt;
  &lt;/ero&gt;
 &lt;/arguments&gt;
&lt;/input&gt;
</msg>
<arg>${xml_data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:11:29.520317" elapsed="0.000479"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:11:29.524517" level="FAIL">'[200, 201, 204]' does not contain '400'</msg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.521004" elapsed="0.003605">'[200, 201, 204]' does not contain '400'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:11:29.524718" elapsed="0.000030"/>
</return>
<var>${response}</var>
<arg>network-topology-pcep:update-lsp</arg>
<arg>${xml_data}</arg>
<doc>Post XML data to given pcep-operations URI, check status_code is 200 and return response text (JSON).</doc>
<status status="FAIL" start="2026-06-06T03:11:29.510774" elapsed="0.014105">'[200, 201, 204]' does not contain '400'</status>
</kw>
<return>
<value>${response}</value>
<status status="NOT RUN" start="2026-06-06T03:11:29.524957" elapsed="0.000021"/>
</return>
<var>${text}</var>
<arg>${update_instantiated_xml}</arg>
<doc>Update LSP according to XML data and return response (json) text.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.510238" elapsed="0.014843">'[200, 201, 204]' does not contain '400'</status>
</kw>
<doc>Perform update-lsp on the newly instantiated tunnel, check that response is success.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:29.509326" elapsed="0.015945">'[200, 201, 204]' does not contain '400'</status>
</test>
<test id="s1-s2-t12" name="Topology_Second_Updated" line="100">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:29.530846" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:29.528067" elapsed="0.002810"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:29.538554" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:29.538728" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:29.538900" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.531030" elapsed="0.008303">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:29.539592" elapsed="0.000028"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.527495" elapsed="0.012259">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:30.545960" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:30.541522" elapsed="0.004484"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:30.553884" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:30.554076" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:30.554230" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:30.546232" elapsed="0.008612">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:30.555212" elapsed="0.000039"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:30.540425" elapsed="0.014965">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:31.563224" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:31.557304" elapsed="0.005995"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:31.573612" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:31.573835" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:31.574003" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:31.563788" elapsed="0.011065">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:31.575389" elapsed="0.000057"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:31.556149" elapsed="0.019692">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:32.583285" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:32.577766" elapsed="0.005592"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:32.592899" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:32.593055" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:32.593174" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:32.583745" elapsed="0.009890">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:32.593902" elapsed="0.000028"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:32.576597" elapsed="0.017440">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:33.600806" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:33.595870" elapsed="0.005006"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:33.609446" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:33.609584" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:33.610578" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:33.601223" elapsed="0.009839">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:33.611320" elapsed="0.000028"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:33.594765" elapsed="0.016686">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:34.616572" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:34.612911" elapsed="0.003708"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:34.624814" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:34.625018" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:34.625233" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:34.616994" elapsed="0.008912">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:34.626310" elapsed="0.000044"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:34.612085" elapsed="0.014423">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:35.632933" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:35.628359" elapsed="0.004618"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:35.640275" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:35.640453" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:35.640597" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:35.633197" elapsed="0.007995">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:35.641515" elapsed="0.000036"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:35.627227" elapsed="0.014482">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:36.648458" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:36.643614" elapsed="0.004915"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:36.656080" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:36.656221" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:36.656391" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:36.648910" elapsed="0.007937">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:36.657085" elapsed="0.000027"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:36.642429" elapsed="0.014784">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:37.664460" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:37.659115" elapsed="0.005412"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:37.671954" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:37.672095" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:37.672214" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:37.664910" elapsed="0.007752">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:37.672900" elapsed="0.000027"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:37.657946" elapsed="0.015079">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:38.679965" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:38.675098" elapsed="0.004935"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:38.687290" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:38.687432" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:38.687555" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:38.680378" elapsed="0.007847">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:38.688485" elapsed="0.000027"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:38.673770" elapsed="0.014936">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:39.694729" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:39.690438" elapsed="0.004337"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:39.702307" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:39.702516" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:39.702692" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.694998" elapsed="0.008265">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:39.703587" elapsed="0.000035"/>
</kw>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.689351" elapsed="0.014432">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:11:39.703909" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${updated_updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:11:29.526814" elapsed="10.177224">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare pcep-topology to default_json, which includes the updated delegated and updated instantiated tunnel.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:29.525852" elapsed="10.178406">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t13" name="Remove_Instantiated" line="105">
<kw name="Remove_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Operate_Xml_Lsp_Return_Json" owner="PcepOperations">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:11:39.706966" level="INFO">${uri_path} = /rests/operations/network-topology-pcep:remove-lsp</msg>
<var>${uri_path}</var>
<arg>/rests/operations/${uri_part}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:11:39.706503" elapsed="0.000502"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:39.715985" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:remove-lsp 
 path_url=/rests/operations/network-topology-pcep:remove-lsp 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0t62w9z8u4jnd165f7zq7eiibp2.node0', 'Content-Length': '317', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;Instantiated tunnel&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
&lt;/input&gt;
 
 </msg>
<msg time="2026-06-06T03:11:39.716104" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/operations/network-topology-pcep:remove-lsp 
 status=500, reason=Internal Server Error 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '272'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "operation-failed",
        "error-message": "No implementation of RPC (urn:opendaylight:params:xml:ns:yang:topology:pcep?revision=2026-05-28)remove-lsp available",
        "error-type": "rpc"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:39.716199" level="INFO">${response} = &lt;Response [500]&gt;</msg>
<var>${response}</var>
<arg>pcep_session</arg>
<arg>url=${uri_path}</arg>
<arg>data=${xml_data}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:11:39.707200" elapsed="0.009025"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:11:39.716703" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:topology:pcep"&gt;
 &lt;node&gt;pcc://10.30.171.194&lt;/node&gt;
 &lt;name&gt;Instantiated tunnel&lt;/name&gt;
 &lt;network-topology-ref xmlns:topo="urn:TBD:params:xml:ns:yang:network-topology"&gt;/topo:network-topology/topo:topology[topo:topology-id="pcep-topology"]&lt;/network-topology-ref&gt;
&lt;/input&gt;
</msg>
<arg>${xml_data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:11:39.716419" elapsed="0.000391"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:11:39.719434" level="FAIL">'[200, 201, 204]' does not contain '500'</msg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.716961" elapsed="0.002538">'[200, 201, 204]' does not contain '500'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:11:39.719565" elapsed="0.000022"/>
</return>
<var>${response}</var>
<arg>network-topology-pcep:remove-lsp</arg>
<arg>${xml_data}</arg>
<doc>Post XML data to given pcep-operations URI, check status_code is 200 and return response text (JSON).</doc>
<status status="FAIL" start="2026-06-06T03:11:39.706055" elapsed="0.013636">'[200, 201, 204]' does not contain '500'</status>
</kw>
<return>
<value>${response}</value>
<status status="NOT RUN" start="2026-06-06T03:11:39.719750" elapsed="0.000016"/>
</return>
<var>${text}</var>
<arg>${remove_instantiated_xml}</arg>
<doc>Remove LSP according to XML data and return response (json) text.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.705528" elapsed="0.014315">'[200, 201, 204]' does not contain '500'</status>
</kw>
<doc>Perform remove-lsp on the instantiated tunnel, check that response is success.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:39.704766" elapsed="0.015211">'[200, 201, 204]' does not contain '500'</status>
</test>
<test id="s1-s2-t14" name="Topology_Again_Updated" line="110">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:39.724850" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:39.721856" elapsed="0.003035"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:39.732130" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:39.732281" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:39.732429" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.725101" elapsed="0.007884">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:39.733301" elapsed="0.000035"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.721353" elapsed="0.012113">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:40.740272" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:40.735232" elapsed="0.005112"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:40.750282" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:40.750427" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:40.750539" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:40.740732" elapsed="0.010274">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:40.751363" elapsed="0.000031"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:40.734150" elapsed="0.017352">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:41.759167" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:41.753368" elapsed="0.005877"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:41.768585" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:41.769127" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:41.769406" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:41.759709" elapsed="0.010641">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:41.771105" elapsed="0.000068"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:41.752177" elapsed="0.019227">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:42.778141" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:42.773251" elapsed="0.004958"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:42.788978" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:42.789112" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:42.789220" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:42.778549" elapsed="0.011115">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:42.789905" elapsed="0.000026"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:42.772174" elapsed="0.017860">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:43.795967" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:43.791986" elapsed="0.004111"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:43.804119" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:43.804441" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:43.804722" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:43.796326" elapsed="0.009496">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:43.806449" elapsed="0.000063"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:43.790817" elapsed="0.015953">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:44.814504" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:44.808675" elapsed="0.005899"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:44.824966" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:44.825104" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:44.825222" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:44.815014" elapsed="0.010650">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:44.825896" elapsed="0.000026"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:44.807525" elapsed="0.018496">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:45.833232" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:45.827860" elapsed="0.005444"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:45.843374" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:45.843588" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:45.843723" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:45.833680" elapsed="0.010514">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:45.844427" elapsed="0.000026"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:45.826728" elapsed="0.017824">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:46.851313" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:46.846365" elapsed="0.005021"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:46.862253" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:46.862402" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:46.862511" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:46.851763" elapsed="0.011215">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:46.863239" elapsed="0.000027"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:46.845276" elapsed="0.018093">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:47.870788" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:47.865241" elapsed="0.005619"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:47.880683" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:47.880880" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:47.881096" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:47.871121" elapsed="0.010903">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:47.882792" elapsed="0.000066"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:47.864134" elapsed="0.018963">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:48.890403" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:48.885285" elapsed="0.005189"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:48.901735" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:48.901915" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:48.902043" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:48.890860" elapsed="0.011633">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:48.902754" elapsed="0.000027"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:48.883909" elapsed="0.018978">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:49.909670" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:49.904638" elapsed="0.005109"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:49.921611" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:49.921782" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:49.921908" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:49.910125" elapsed="0.012231">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:49.922615" elapsed="0.000043"/>
</kw>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:49.903543" elapsed="0.019222">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:11:49.922932" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${updated_json}</arg>
<arg>${PATH_SESSION_URI}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:11:39.720877" elapsed="10.202157">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare pcep-topology to default_json, which includes the updated tunnel, to verify that instantiated tunnel was removed.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:39.720251" elapsed="10.202960">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=pcc:%2F%2F10.30.171.194/network-topology-pcep:path-computation-client?content=nonconfig Expected status: 409 != 200</status>
</test>
<test id="s1-s2-t15" name="Stop_Pcc_Mock" line="115">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:11:49.924851" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:11:49.924466" elapsed="0.000414"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:11:49.925023" elapsed="0.000338"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:11:49.924183" elapsed="0.001244"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:11:50.259106" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:11:50.259311" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:11:49.925577" elapsed="0.333775"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:11:50.259976" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:11:50.259593" elapsed="0.000432"/>
</kw>
<doc>Send ctrl+c to pcc-mock, fails if no prompt is seen
after 3 seconds (the default for SSHLibrary)</doc>
<status status="PASS" start="2026-06-06T03:11:49.923581" elapsed="0.336565"/>
</test>
<test id="s1-s2-t16" name="Topology_Postcondition" line="122">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:50.266035" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:50.263947" elapsed="0.002116"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:50.273468" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:50.273618" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:50.273756" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:50.266214" elapsed="0.007990">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:50.274464" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:50.261558" elapsed="0.013037">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:51.284785" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:51.280026" elapsed="0.004827"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:51.293535" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:51.293701" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:51.293892" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:51.285199" elapsed="0.009128">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:51.294608" elapsed="0.000029"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:51.275249" elapsed="0.019514">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:52.304930" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:52.300198" elapsed="0.004796"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:52.314918" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:52.315065" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:52.315181" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:52.305343" elapsed="0.010281">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:52.316007" elapsed="0.000033"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:52.295404" elapsed="0.020795">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:53.327293" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:53.322541" elapsed="0.004821"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:53.334704" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:53.334855" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:53.334980" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:53.327740" elapsed="0.007726">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:53.335763" elapsed="0.000030"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:53.316994" elapsed="0.018905">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:54.346307" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:54.341587" elapsed="0.004788"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:54.355229" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:54.355466" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:54.355575" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:54.346812" elapsed="0.009228">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:54.356279" elapsed="0.000026"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:54.336775" elapsed="0.019631">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:55.365175" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:55.362021" elapsed="0.003199"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:55.373048" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:55.373226" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:55.373373" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:55.365445" elapsed="0.008541">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:55.374314" elapsed="0.000036"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:55.357107" elapsed="0.017381">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:56.384407" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:56.379959" elapsed="0.004501"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:56.394438" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:56.394701" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:56.394897" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:56.384765" elapsed="0.010768">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:56.395982" elapsed="0.000045"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:56.375156" elapsed="0.021023">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:57.406445" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:57.401695" elapsed="0.004819"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:57.415972" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:57.416112" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:57.416222" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:57.407008" elapsed="0.009663">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:57.416950" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:57.396970" elapsed="0.020108">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:58.427401" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:58.422596" elapsed="0.004877"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:58.437756" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:58.437905" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:58.438016" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:58.427915" elapsed="0.010593">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:58.439111" elapsed="0.000065"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:58.417801" elapsed="0.021607">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:11:59.450012" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:11:59.444842" elapsed="0.005216"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:11:59.457447" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:11:59.457580" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:11:59.457713" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:11:59.450293" elapsed="0.007851">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:11:59.458384" elapsed="0.000027"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:11:59.440210" elapsed="0.018358">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Compare_Topology">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.466902" level="INFO">${topology_uri} = /rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${topology_uri}</var>
<arg>'${uri}'=='${EMPTY}'</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology?content=nonconfig</arg>
<arg>${REST_API}/${TOPOLOGY_URL}=pcep-topology/${uri}?content=nonconfig</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:00.463935" elapsed="0.003012"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:00.476636" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01qn1aw1cugrll1i5x2ju274pfc1.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:00.476867" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:00.477022" level="FAIL">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${topology_uri}</arg>
<arg>expected_status=200</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:12:00.467193" elapsed="0.010431">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp}</arg>
<arg>${response.text}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:00.477991" elapsed="0.000039"/>
</kw>
<arg>${off_json}</arg>
<doc>Get current pcep-topology as json, compare both expected and actual json.
Error codes and normalized jsons should match exactly.</doc>
<status status="FAIL" start="2026-06-06T03:12:00.459290" elapsed="0.018880">Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<msg time="2026-06-06T03:12:00.478297" level="FAIL">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>${off_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:11:50.261044" elapsed="10.217383">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</kw>
<doc>Compare curent pcep-topology to "off_json" again.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:11:50.260468" elapsed="10.218230">Keyword 'Compare_Topology' failed after retrying for 10 seconds. The last error was: Url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig Expected status: 409 != 200</status>
</test>
<kw name="Tear_It_Down" type="TEARDOWN">
<kw name="Get File" owner="SSHLibrary">
<msg time="2026-06-06T03:12:00.492138" level="INFO">[chan 6] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:12:00.498693" level="INFO">'pccmock.log' -&gt; '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/pccmock.log'</msg>
<arg>pccmock.log</arg>
<doc>Downloads file(s) from the remote machine to the local machine.</doc>
<status status="PASS" start="2026-06-06T03:12:00.480171" elapsed="0.018687"/>
</kw>
<kw name="Run" owner="OperatingSystem">
<msg time="2026-06-06T03:12:00.500578" level="INFO">Running command 'cat pccmock.log 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:12:00.503852" level="INFO">${pccmocklog} = </msg>
<var>${pccmocklog}</var>
<arg>cat pccmock.log</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="PASS" start="2026-06-06T03:12:00.499350" elapsed="0.004545"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.504540" level="INFO"/>
<arg>${pccmocklog}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:00.504120" elapsed="0.000483"/>
</kw>
<kw name="Teardown_Pcep_Operations" owner="PcepOperations">
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:00.505328" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:12:00.505220" elapsed="0.000368"/>
</kw>
<doc>Teardown to pair with Setup (otherwise no-op).</doc>
<status status="PASS" start="2026-06-06T03:12:00.504909" elapsed="0.000790"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:00.506035" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:12:00.505929" elapsed="0.000175"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:12:00.506308" elapsed="0.000477"/>
</kw>
<doc>Download pccmock.log and Log its contents.
Compute and Log the diff between expected and actual normalized responses.
Close both HTTP client session and SSH connection to Mininet.</doc>
<status status="PASS" start="2026-06-06T03:12:00.479859" elapsed="0.027015"/>
</kw>
<doc>Basic tests for odl-bgpcep-pcep-all feature.

Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html</doc>
<status status="FAIL" start="2026-06-06T03:05:35.842143" elapsed="384.664782"/>
</suite>
<suite id="s1-s3" name="Bgp Functional Md5" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/bgp_functional_md5.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.731993" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:12:00.727470" elapsed="0.004593"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:12:00.727160" elapsed="0.005084"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.737471" 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-06-06T03:12:00.733690" elapsed="0.003812"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:12:00.737748" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:00.737602" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:00.737574" elapsed="0.000247"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.738347" 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-06-06T03:12:00.737982" elapsed="0.000411"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.738897" 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-06-06T03:12:00.738561" elapsed="0.000381"/>
</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-06-06T03:12:00.739480" elapsed="0.000313"/>
</kw>
<msg time="2026-06-06T03:12:00.739893" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:00.739942" 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-06-06T03:12:00.739120" elapsed="0.000845"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.740518" 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-06-06T03:12:00.740141" elapsed="0.000409"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.741671" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:12:00.741381" elapsed="0.000319"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.742138" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:12:00.741854" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.742630" 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-06-06T03:12:00.742328" elapsed="0.000346"/>
</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-06-06T03:12:00.745995" elapsed="0.000245"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.746786" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:12:00.746429" elapsed="0.000385"/>
</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-06-06T03:12:00.747013" elapsed="0.000242"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.748075" 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-06-06T03:12:00.747773" elapsed="0.000329"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:12:00.748148" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:12:00.748311" 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-06-06T03:12:00.747455" elapsed="0.000881"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:00.748973" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e76a1610&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-06-06T03:12:00.748499" elapsed="0.000632"/>
</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-06-06T03:12:00.749302" elapsed="0.000202"/>
</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-06-06T03:12:00.745385" elapsed="0.004203"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:00.745179" elapsed="0.004457"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:12:00.742735" elapsed="0.006955"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.750276" 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-06-06T03:12:00.749866" elapsed="0.000454"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.750927" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:12:00.750488" elapsed="0.000485"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.751579" 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-06-06T03:12:00.751184" elapsed="0.000438"/>
</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-06-06T03:12:00.740919" elapsed="0.010799"/>
</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-06-06T03:12:00.733310" elapsed="0.018496"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:00.752029" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:00.751906" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:00.751878" elapsed="0.000236"/>
</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-06-06T03:12:00.755213" 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-06-06T03:12:00.754809" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.755724" 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-06-06T03:12:00.755406" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:00.755797" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:00.755952" 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-06-06T03:12:00.754462" elapsed="0.001515"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:00.756989" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:12:00.756722" elapsed="0.000294"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:00.757797" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:12:00.757903" 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-06-06T03:12:00.757594" elapsed="0.000335"/>
</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-06-06T03:12:00.761561" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:00.760940" elapsed="0.000725"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:00.760919" elapsed="0.000787"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:00.762377" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:12:00.761908" elapsed="0.000785"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.763687" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:00.762997" elapsed="0.000800"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:00.764989" 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-06-06T03:12:00.764081" elapsed="0.000960"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:12:00.766820" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:12:00.767019" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:00.766426" elapsed="0.000639"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:00.767413" elapsed="0.000479"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:12:00.769072" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:12:01.445917" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:12:00 UTC 2026

  System load:  0.01               Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:05:37 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:12:00.768742" elapsed="0.677451"/>
</kw>
<msg time="2026-06-06T03:12:01.446281" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:00.768263" elapsed="0.678180"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:12:00.765482" elapsed="0.681133"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:01.447523" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:12:01.460821" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:12:01.461073" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:12:01.461218" 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-06-06T03:12:01.447021" elapsed="0.014268"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:01.461902" elapsed="0.001235"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:01.465729" 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-06-06T03:12:01.464436" elapsed="0.001529"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:12:01.466950" elapsed="0.000114"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:01.466329" elapsed="0.000900"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:01.466273" elapsed="0.001041"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:01.468117" elapsed="0.000135"/>
</return>
<status status="PASS" start="2026-06-06T03:12:01.467494" elapsed="0.000934"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:01.467455" elapsed="0.001061"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:12:01.468678" elapsed="0.000040"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:01.473724" elapsed="0.000463"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:01.474466" elapsed="0.000339"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:01.475068" elapsed="0.000225"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:01.469769" elapsed="0.005595"/>
</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-06-06T03:12:00.759981" elapsed="0.715557"/>
</kw>
<msg time="2026-06-06T03:12:01.475595" 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-06-06T03:12:00.759303" elapsed="0.716410"/>
</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-06-06T03:12:00.758607" elapsed="0.717190"/>
</kw>
<msg time="2026-06-06T03:12:01.475838" 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-06-06T03:12:00.758091" elapsed="0.717792"/>
</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-06-06T03:12:01.478476" elapsed="0.000366"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:01.479010" elapsed="0.000149"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:01.479310" elapsed="0.000097"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:01.476180" elapsed="0.003278"/>
</kw>
<msg time="2026-06-06T03:12:01.479549" 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-06-06T03:12:00.757234" elapsed="0.722340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:01.480058" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:01.479809" elapsed="0.000291"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:12:01.480143" elapsed="0.000029"/>
</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-06-06T03:12:00.756339" elapsed="0.723928"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:00.756161" elapsed="0.724196"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:00.756030" elapsed="0.724364"/>
</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-06-06T03:12:00.752343" elapsed="0.728110"/>
</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-06-06T03:12:01.480619" elapsed="0.000230"/>
</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-06-06T03:12:01.494344" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:01.494218" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:01.494195" elapsed="0.000224"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:01.494805" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:12:01.494918" 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-06-06T03:12:01.494622" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:01.495376" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:01.495103" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:01.495884" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:01.495608" elapsed="0.000321"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:01.496730" 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-06-06T03:12:01.496479" elapsed="0.000365">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:12:01.496952" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:12:01.496998" 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-06-06T03:12:01.496094" elapsed="0.000927"/>
</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-06-06T03:12:01.497327" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:01.497097" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:01.497078" elapsed="0.000348"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:01.498191" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:12:01.497928" elapsed="0.000289"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:12:01.498264" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:01.498415" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:12:01.497636" elapsed="0.000803"/>
</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-06-06T03:12:01.498617" elapsed="0.000428"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:01.499341" level="INFO">index=4
host=10.30.170.38
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-06-06T03:12:01.499441" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:12:01.499231" elapsed="0.000237"/>
</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-06-06T03:12:01.499624" elapsed="0.002349"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:12:01.502408" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:12:02.272011" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:12:01.502142" elapsed="0.770079"/>
</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-06-06T03:12:02.275996" elapsed="0.000405"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:02.276585" elapsed="0.000213"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:02.276955" elapsed="0.000110"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:02.273558" elapsed="0.003562"/>
</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-06-06T03:12:02.272823" elapsed="0.004347"/>
</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-06-06T03:12:01.493892" elapsed="0.783333"/>
</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-06-06T03:12:01.481665" elapsed="0.795609"/>
</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-06-06T03:12:01.481207" elapsed="0.796120"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:01.481063" elapsed="0.796306"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:12:01.480910" elapsed="0.796498"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:12:00.732684" elapsed="1.544789"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:02.280224" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:02.280102" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.280077" elapsed="0.000225"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:02.285107" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:02.284998" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.284980" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:02.286207" 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-06-06T03:12:02.285783" elapsed="0.000453"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:02.286727" 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-06-06T03:12:02.286404" elapsed="0.000350"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:02.286799" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:12:02.286966" 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-06-06T03:12:02.285411" elapsed="0.001580"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:02.292573" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:02.292462" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.292442" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:02.293900" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:02.293769" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.293750" elapsed="0.000220"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:02.294514" 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-06-06T03:12:02.294162" elapsed="0.000379"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:02.294970" 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-06-06T03:12:02.294733" elapsed="0.000265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:02.398587" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:02.295695" elapsed="0.103097"/>
</kw>
<msg time="2026-06-06T03:12:02.398965" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:02.399012" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:12:02.295163" elapsed="0.103887"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:02.514464" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "f "u "[78Cn "[A[78Cc
 "t "i "o "n "a "l "_ "m "d "5 ". "r "o "b "o "t "[K"
[?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-06-06T03:12:02.399972" elapsed="0.114759"/>
</kw>
<msg time="2026-06-06T03:12:02.514933" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:02.514982" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:12:02.399367" elapsed="0.115654"/>
</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-06-06T03:12:02.515492" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:02.515135" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.515100" elapsed="0.000594"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:02.516288" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "f "u "[78Cn "[A[78Cc
 "t "i "o "n "a "l "_ "m "d "5 ". "r "o "b "o "t "[K"
[?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-06-06T03:12:02.515848" elapsed="0.000527"/>
</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-06-06T03:12:02.516703" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:02.516444" elapsed="0.000409"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.516425" elapsed="0.000455"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:02.516920" elapsed="0.000041"/>
</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-06-06T03:12:02.519061" elapsed="0.000456"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:02.519883" elapsed="0.000319"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:02.520537" elapsed="0.000259"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:02.518243" elapsed="0.002645"/>
</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-06-06T03:12:02.517262" elapsed="0.003764"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:02.293453" elapsed="0.227678"/>
</kw>
<msg time="2026-06-06T03:12:02.521230" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:02.521275" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:02.292817" elapsed="0.228496"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:02.521501" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:02.521392" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.521372" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:02.522446" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:02.522816" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:02.522890" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:02.292158" elapsed="0.230842"/>
</kw>
<msg time="2026-06-06T03:12:02.523098" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:02.523142" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:02.287386" elapsed="0.235796"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:02.523522" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:02.523259" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:02.523241" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:02.287232" elapsed="0.236465"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:02.287050" elapsed="0.236686"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:02.284697" elapsed="0.239100"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:12:02.278182" elapsed="0.245674"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:02.277657" elapsed="0.246244"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:12:00.726674" elapsed="1.797282"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:02.524486" level="INFO">${tools_system_conn_id} = 7</msg>
<var>${tools_system_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:02.524122" elapsed="0.000391"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:02.525041" level="INFO">${tools_system_conn_id} = 7</msg>
<arg>${tools_system_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:12:02.524704" elapsed="0.000380"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:12:02.526970" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:12:02.527047" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:02.526679" elapsed="0.000393"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:02.527235" elapsed="0.000562"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:12:02.528685" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:12:03.119683" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:12:02 UTC 2026

  System load:  0.0                Processes:             105
  Usage of /:   19.5% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:05:36 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:12:02.528344" elapsed="0.591495"/>
</kw>
<msg time="2026-06-06T03:12:03.119928" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:02.527974" elapsed="0.592037"/>
</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-06-06T03:12:02.526222" elapsed="0.593904"/>
</kw>
<msg time="2026-06-06T03:12:03.120180" 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-06-06T03:12:02.525775" elapsed="0.594450"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:12:02.525287" elapsed="0.595016"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:12:03.126380" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:12:03.126040" elapsed="0.000368"/>
</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-06-06T03:12:03.127891" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:12:03.667420" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:03.667845" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 302ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:12:03.667958" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:12:03.668052" 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-06-06T03:12:03.127702" elapsed="0.540403"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:03.670223" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:12:03.669560" elapsed="0.000772"/>
</kw>
<msg time="2026-06-06T03:12:03.670547" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:12:03.670682" 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-06-06T03:12:03.668608" elapsed="0.002130"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:03.672258" 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-06-06T03:12:03.671247" elapsed="0.001071"/>
</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-06-06T03:12:03.674693" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 302ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:03.674320" elapsed="0.000443"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:03.675320" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:03.674980" elapsed="0.000396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:03.675940" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:03.675588" elapsed="0.000413"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:12:03.673409" elapsed="0.002670"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:03.672511" elapsed="0.003620"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:03.672459" elapsed="0.003708"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:12:03.676390" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:03.676246" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:03.676222" elapsed="0.000267"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:03.676706" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:12:03.676561" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:03.676539" elapsed="0.000290"/>
</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-06-06T03:12:03.677037" elapsed="0.000030"/>
</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-06-06T03:12:03.127137" elapsed="0.550065"/>
</kw>
<msg time="2026-06-06T03:12:03.677279" 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-06-06T03:12:03.126572" elapsed="0.550788"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:12:03.125386" elapsed="0.552128"/>
</kw>
<msg time="2026-06-06T03:12:03.677591" 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-06-06T03:12:03.121570" elapsed="0.556100"/>
</kw>
<arg>virtualenv ${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-06-06T03:12:03.121189" elapsed="0.556627"/>
</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-06-06T03:12:03.686624" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/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-06-06T03:12:03.686299" elapsed="0.000368"/>
</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-06-06T03:12:03.688481" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-06-06T03:12:05.976183" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:05.976630" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Downloading pip-26.1.2-py3-none-any.whl (1.8 MB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━...</msg>
<msg time="2026-06-06T03:12:05.976891" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:12:05.977049" 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-06-06T03:12:03.688130" elapsed="2.289006"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:05.982334" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:12:05.981318" elapsed="0.001269"/>
</kw>
<msg time="2026-06-06T03:12:05.982960" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:12:05.983238" 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-06-06T03:12:05.977975" elapsed="0.005350"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:05.985547" 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-06-06T03:12:05.983948" elapsed="0.001641"/>
</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-06-06T03:12:05.988100" level="INFO">Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Downloading pip-26.1.2-py3-none-any.whl (1.8 MB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 1.8/1.8 MB 23.3 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.1.2</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:05.987705" elapsed="0.000528"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:05.989050" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:05.988619" elapsed="0.000531"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:05.989954" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:05.989528" elapsed="0.000528"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:12:05.986762" elapsed="0.003392"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:05.985816" elapsed="0.004445"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:05.985786" elapsed="0.004507"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:12:05.990546" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:05.990357" elapsed="0.000364"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:05.990338" elapsed="0.000413"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:05.990977" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:12:05.990809" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:05.990792" elapsed="0.000354"/>
</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-06-06T03:12:05.991301" 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-06-06T03:12:03.687461" elapsed="2.304027"/>
</kw>
<msg time="2026-06-06T03:12:05.991548" 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-06-06T03:12:03.686831" elapsed="2.304770"/>
</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/defaultvenv/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-06-06T03:12:03.685699" elapsed="2.306049"/>
</kw>
<msg time="2026-06-06T03:12:05.991805" 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-06-06T03:12:03.680473" elapsed="2.311378"/>
</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-06-06T03:12:03.679706" elapsed="2.312231"/>
</kw>
<msg time="2026-06-06T03:12:05.991987" 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-06-06T03:12:03.679155" elapsed="2.312876"/>
</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-06-06T03:12:03.678676" elapsed="2.313694"/>
</kw>
<msg time="2026-06-06T03:12:05.992419" 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-06-06T03:12:03.678039" elapsed="2.314425"/>
</kw>
<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-06-06T03:12:03.120629" elapsed="2.871910"/>
</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-06-06T03:12:05.999995" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:12:05.999551" elapsed="0.000474"/>
</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-06-06T03:12:06.001927" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; deactivate'.</msg>
<msg time="2026-06-06T03:12:07.143348" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:07.143795" level="INFO">${stdout} = Collecting setuptools==44.0.0
  Downloading setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Downloading setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━...</msg>
<msg time="2026-06-06T03:12:07.143869" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:12:07.143929" 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-06-06T03:12:06.001520" elapsed="1.142443"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:07.147792" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:12:07.146695" elapsed="0.001287"/>
</kw>
<msg time="2026-06-06T03:12:07.148204" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:12:07.148266" 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-06-06T03:12:07.144413" elapsed="0.003884"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:07.149839" 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-06-06T03:12:07.148618" elapsed="0.001259"/>
</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-06-06T03:12:07.153007" level="INFO">Collecting setuptools==44.0.0
  Downloading setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Downloading setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 583.2/583.2 kB 10.5 MB/s  0:00:00
Installing collected packages: setuptools
  Attempting uninstall: setuptools
    Found existing installation: setuptools 59.6.0
    Uninstalling setuptools-59.6.0:
      Successfully uninstalled setuptools-59.6.0
Successfully installed setuptools-44.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:07.152464" elapsed="0.000648"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:07.153992" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:07.153526" elapsed="0.000555"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:07.154953" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:07.154491" elapsed="0.000554"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:12:07.151178" elapsed="0.003967"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:07.150075" elapsed="0.005199"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:07.150039" elapsed="0.005275"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:12:07.155627" elapsed="0.000044"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:07.155395" elapsed="0.000386"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:07.155370" elapsed="0.000447"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:07.156082" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:12:07.155899" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:07.155876" elapsed="0.000403"/>
</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-06-06T03:12:07.156491" elapsed="0.000030"/>
</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-06-06T03:12:06.000894" elapsed="1.155943"/>
</kw>
<msg time="2026-06-06T03:12:07.156921" 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-06-06T03:12:06.000231" elapsed="1.156765"/>
</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/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:12:05.998892" elapsed="1.158238"/>
</kw>
<msg time="2026-06-06T03:12:07.157208" 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-06-06T03:12:05.994949" elapsed="1.162322"/>
</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-06-06T03:12:05.994346" elapsed="1.163050"/>
</kw>
<msg time="2026-06-06T03:12:07.157576" 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-06-06T03:12:05.993957" elapsed="1.163709"/>
</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-06-06T03:12:05.993447" elapsed="1.164350"/>
</kw>
<msg time="2026-06-06T03:12:07.157861" 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-06-06T03:12:05.993056" elapsed="1.164865"/>
</kw>
<arg>setuptools==44.0.0</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-06-06T03:12:05.992780" elapsed="1.165255"/>
</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-06-06T03:12:07.166004" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.17; 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-06-06T03:12:07.165671" elapsed="0.000361"/>
</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-06-06T03:12:07.167849" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.17; deactivate'.</msg>
<msg time="2026-06-06T03:12:09.081097" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:09.081717" level="INFO">${stdout} = Collecting exabgp==3.4.17
  Downloading exabgp-3.4.17.tar.gz (240 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to bu...</msg>
<msg time="2026-06-06T03:12:09.081862" level="INFO">${stderr} =   error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        ...</msg>
<msg time="2026-06-06T03:12:09.081994" 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-06-06T03:12:07.167437" elapsed="1.914617"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.087171" level="INFO">Length is 1821.</msg>
<msg time="2026-06-06T03:12:09.087874" level="FAIL">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:12:09.085912" elapsed="0.002366">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</status>
</kw>
<msg time="2026-06-06T03:12:09.088613" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:12:09.088724" level="INFO">${result} = '  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
       ...</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-06-06T03:12:09.082821" elapsed="0.006027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.090571" 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-06-06T03:12:09.089205" elapsed="0.001410"/>
</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-06-06T03:12:09.094012" level="INFO">Collecting exabgp==3.4.17
  Downloading exabgp-3.4.17.tar.gz (240 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 'error'</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.093469" elapsed="0.000649"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.095239" level="INFO">  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-x72h_kcb/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.094584" elapsed="0.000790"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.096297" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.095835" elapsed="0.000559"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:12:09.092120" elapsed="0.004379"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.090927" elapsed="0.005712"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.090887" elapsed="0.005818"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:12:09.097009" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:09.096793" elapsed="0.000363"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.096767" elapsed="0.000438"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:09.097485" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:12:09.097288" elapsed="0.000379"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.097264" elapsed="0.000446"/>
</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-06-06T03:12:09.097933" elapsed="0.000033"/>
</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-06-06T03:12:07.166830" elapsed="1.931310"/>
</kw>
<msg time="2026-06-06T03:12:09.098222" 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-06-06T03:12:07.166196" elapsed="1.932101"/>
</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/defaultvenv/bin/activate; pip install exabgp==3.4.17; 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-06-06T03:12:07.165051" elapsed="1.933381"/>
</kw>
<msg time="2026-06-06T03:12:09.098566" 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-06-06T03:12:07.161215" elapsed="1.937421"/>
</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-06-06T03:12:07.160662" elapsed="1.938189"/>
</kw>
<msg time="2026-06-06T03:12:09.098914" 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-06-06T03:12:07.160231" elapsed="1.938728"/>
</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-06-06T03:12:07.159839" elapsed="1.939300"/>
</kw>
<msg time="2026-06-06T03:12:09.099189" 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-06-06T03:12:07.159021" elapsed="1.940213"/>
</kw>
<arg>exabgp==3.4.17</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-06-06T03:12:07.158323" elapsed="1.940992"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:09.099797" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5a7bc90&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:12:09.099481" elapsed="0.000503"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.129835" level="INFO">[chan 5] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:12:09.139213" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/exa-md5.cfg' -&gt; '/home/jenkins//exa-md5.cfg'</msg>
<arg>${BGP_VAR_FOLDER}${/}exa-md5.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:12:09.100724" elapsed="0.038635"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.148205" level="INFO">1 file:
exa-md5.cfg</msg>
<msg time="2026-06-06T03:12:09.148452" level="INFO">@{cfgfiles} = [ exa-md5.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:12:09.139752" elapsed="0.008742"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.149499" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:12:09.162055" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:09.149215" elapsed="0.013034"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.163352" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:12:09.212013" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:09.162894" elapsed="0.049317"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.213122" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:12:09.260058" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:09.212734" elapsed="0.047523"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.261153" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:12:09.308448" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:09.260770" elapsed="0.047918"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.309667" level="INFO">Executing command 'sed -i -e 's/PASSWORD/topsecret/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:12:09.359992" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/PASSWORD/${MD5_SAME_PASSWD}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:09.309183" elapsed="0.051039"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.361144" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:12:09.412521" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:09.412870" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:09.360760" elapsed="0.052171"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.414141" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.413456" elapsed="0.000791"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:12:09.148948" elapsed="0.265377"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:12:09.148617" elapsed="0.265820"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:12:09.100442" elapsed="0.314134"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:00.726205" elapsed="8.688517"/>
</kw>
<test id="s1-s3-t1" name="Verify Exabgp Connected" line="43">
<kw name="Reconfigure_ODL_To_Accept_Connection" type="SETUP">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.418246" level="INFO">&amp;{mapping} = { BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PASSWORD=topsecret | PASSIVE_MODE=true }</msg>
<var>&amp;{mapping}</var>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSWORD=${password}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.416767" elapsed="0.001543"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.463981" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:09.463501" elapsed="0.000600"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:09.464996" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:09.464694" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:09.465174" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:09.464292" elapsed="0.000907"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.465796" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:09.465372" elapsed="0.000454"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:09.466147" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:09.466347" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:09.465995" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.466821" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.466542" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.468030" level="INFO">mapping: {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSWORD': 'topsecret', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.467722" elapsed="0.000359"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.468524" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.468249" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.469324" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:09.469000" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:09.470446" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.469917" elapsed="0.000556"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:09.470532" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:12:09.470757" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:09.469546" elapsed="0.001242"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.470958" elapsed="0.000250"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:09.468840" elapsed="0.002409"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.471870" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:09.471501" elapsed="0.000397"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:09.472935" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.472446" elapsed="0.000516"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:09.473014" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:09.473170" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:09.472098" elapsed="0.001096"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.473363" elapsed="0.000226"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:09.471365" elapsed="0.002266"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.474297" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:09.473942" elapsed="0.000422"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:09.477146" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.476619" elapsed="0.000555"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:09.477228" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:12:09.477451" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:09.474597" elapsed="0.002880"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.477662" elapsed="0.000240"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:09.473773" elapsed="0.004171"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.478575" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:09.478233" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:09.479682" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.479193" elapsed="0.000516"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:09.479761" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:09.479926" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:09.478868" elapsed="0.001082"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.480114" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:09.478073" elapsed="0.002305"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.480945" level="INFO">${value} = topsecret</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:09.480626" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:09.481997" level="INFO">${encoded} = topsecret</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.481497" elapsed="0.000527"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:09.482077" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:09.482235" level="INFO">${encoded_value} = topsecret</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:09.481171" elapsed="0.001090"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.482441" elapsed="0.000260"/>
</kw>
<var name="${key}">PASSWORD</var>
<var name="${value}">topsecret</var>
<status status="PASS" start="2026-06-06T03:12:09.480491" elapsed="0.002254"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.483355" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:09.483024" elapsed="0.000357"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:09.484402" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.483964" elapsed="0.000465"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:09.484480" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:09.484635" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:09.483589" elapsed="0.001089"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:09.484836" elapsed="0.000239"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:12:09.482880" elapsed="0.002237"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:09.468607" elapsed="0.016546"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:09.485200" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:12:09.485374" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSWORD': 'topsecret', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:09.467334" elapsed="0.018079"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.466958" elapsed="0.018490"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.485667" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.485479" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.466931" elapsed="0.018817"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.486728" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:09.485904" elapsed="0.000855"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:09.486811" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:09.462695" elapsed="0.024251"/>
</kw>
<msg time="2026-06-06T03:12:09.487068" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:09.447538" elapsed="0.039589"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.545703" elapsed="0.000073"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.558231" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.570402" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.570623" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.570830" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.571257" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.571101" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:09.571081" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.571487" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.571671" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.571843" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:09.571040" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:09.570916" elapsed="0.001007"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.572073" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:09.572152" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:12:09.572317" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:09.442600" elapsed="0.129747"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.598403" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:09.597971" elapsed="0.000461"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:09.599220" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:09.598963" elapsed="0.000399">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:09.599459" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:09.598601" elapsed="0.000883"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.600055" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:09.599665" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:09.600386" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:09.600549" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:09.600245" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.601005" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
        &lt;auth-password&gt;$PASSWORD&lt;/auth-password&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.600755" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:09.601432" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.601131" elapsed="0.000360"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.601979" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSWORD': 'topsecret', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:09.601679" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.601516" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.601112" elapsed="0.000951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.602979" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:09.602212" elapsed="0.000797"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:09.603060" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:09.597339" elapsed="0.005850"/>
</kw>
<msg time="2026-06-06T03:12:09.603247" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:09.584918" elapsed="0.018376"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.615577" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.627725" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.640266" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.640472" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.640665" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.641057" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.640903" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:09.640887" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.641283" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.641592" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.641789" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:09.640856" elapsed="0.000988"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:09.640745" elapsed="0.001126"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.642019" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:09.642096" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:09.642254" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:09.582208" elapsed="0.060076"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:09.643597" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:09.643333" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:09.643778" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:09.642975" elapsed="0.000828"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.644130" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.643874" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.644704" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:09.644390" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.644212" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.643855" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.647111" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:09.644941" elapsed="0.002196"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:09.647190" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:09.647344" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:09.642619" elapsed="0.004749"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.648774" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.648507" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.649262" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
        &lt;auth-password&gt;topsecret&lt;/auth-password&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.649022" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.649734" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.649472" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.650174" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.649932" elapsed="0.000316"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:09.651080" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:09.650880" elapsed="0.000226"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:09.651441" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:09.651263" elapsed="0.000204"/>
</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-06-06T03:12:09.651619" elapsed="0.000227"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.652256" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.652010" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:09.652343" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:09.652498" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:09.650458" elapsed="0.002065"/>
</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-06-06T03:12:09.681241" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '847', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
        &lt;auth-password&gt;topsecret&lt;/auth-password&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:12:09.681411" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:12:09 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:09.681893" 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-06-06T03:12:09.654823" elapsed="0.027134"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.652594" elapsed="0.029475"/>
</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-06-06T03:12:09.682721" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.682139" elapsed="0.000743"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.652576" elapsed="0.030355"/>
</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-06-06T03:12:09.690686" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.685213" elapsed="0.005574"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.684696" elapsed="0.006169"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.684622" elapsed="0.006299"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.693554" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.691282" elapsed="0.002318"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.691052" elapsed="0.002582"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.691034" elapsed="0.002640"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.694320" 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-06-06T03:12:09.693868" elapsed="0.000480"/>
</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-06-06T03:12:09.694684" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.694421" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.695240" 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-06-06T03:12:09.694937" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.694768" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.694402" elapsed="0.000921"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.695863" 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-06-06T03:12:09.695485" elapsed="0.000405"/>
</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-06-06T03:12:09.696195" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.695961" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.696748" 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-06-06T03:12:09.696438" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.696276" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.695942" elapsed="0.000889"/>
</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-06-06T03:12:09.696991" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:09.697845" 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-06-06T03:12:09.697510" elapsed="0.000361"/>
</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-06-06T03:12:09.698035" elapsed="0.002288"/>
</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-06-06T03:12:09.683823" elapsed="0.016568"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:09.700576" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:12:09.700462" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.700443" elapsed="0.000250"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:09.700849" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:09.700918" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:09.703182" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:12:09.647716" elapsed="0.055494"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:09.703278" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:09.703433" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:09.426941" elapsed="0.276517"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:09.703836" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:09.703560" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.703541" elapsed="0.000389"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:09.703963" elapsed="0.000026"/>
</return>
<arg>${BGP_PEER_FOLDER}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:09.419011" elapsed="0.285078"/>
</kw>
<arg>${MD5_SAME_PASSWD}</arg>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:12:09.415913" elapsed="0.288296"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.707586" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:09.707259" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.708047" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.707801" elapsed="0.000292"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.710785" level="INFO">source /tmp/defaultvenv/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-06-06T03:12:09.708713" elapsed="0.002129"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.715726" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:12:09.715818" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:09.711009" elapsed="0.004837"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.716632" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.716169" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:09.715915" elapsed="0.000818"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:09.715896" elapsed="0.000864"/>
</if>
<arg>log_output=${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-06-06T03:12:09.708335" elapsed="0.008470"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:09.718460" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg</msg>
<msg time="2026-06-06T03:12:09.718547" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:09.716960" elapsed="0.001613"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.719009" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.718756" elapsed="0.000298"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:09.706937" elapsed="0.012172"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.721022" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:09.720674" elapsed="0.000375"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.723118" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:09.721216" elapsed="0.001930"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:09.729062" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:09.729216" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:09.729311" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:09.723312" elapsed="0.006026"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.731887" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:09.729507" elapsed="0.002428"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:09.734576" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:09.732093" elapsed="0.002571">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:09.720201" elapsed="0.014575">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.738085" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:12.737056" elapsed="0.001129"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.743181" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:12.738600" elapsed="0.004646"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:12.754488" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:12.755052" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '611'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:12:12.755248" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:12.743775" elapsed="0.011533"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.764521" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.755727" elapsed="0.009081"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:12:12.765225" elapsed="0.003312"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:12:12.735627" elapsed="0.032983"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:12:09.719690" elapsed="3.049017"/>
</kw>
<msg time="2026-06-06T03:12:12.768825" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:12.768869" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:09.719277" elapsed="3.049615"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.769332" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:12.769004" elapsed="0.000386"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:12.768974" elapsed="0.000445"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:12:12.769587" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:12:12.769475" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:12.769459" elapsed="0.000238"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:12:09.706753" elapsed="3.062972"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:12:09.706504" elapsed="3.063260"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.769925" elapsed="0.000021"/>
</kw>
<arg>${BGP_EXAMD5_CFG}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>connection_retries=${3}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:12:09.704558" elapsed="3.065448"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:12:12.770685" level="INFO">[?2004l03:12:09 | 2187   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:12:09 | 2187   | [01;34mversion      [0m | [1m4.2.17  [0m
03:12:09 | 2187   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:12:09 | 2187   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:12:09 | 2187   | [01;34minstallation [0m | [1m        [0m
03:12:09 | 2187   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:12:09 | 2187   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:12:09 | 2187   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:12:09 | 2187   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:12:09 | 2187   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:12:09 | 2187   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:12:09 | 2187   | configuration[0m | . local-as         | '64496'[0m
03:12:09 | 2187   | configuration[0m | . peer-as          | '64496'[0m
03:12:09 | 2187   | configuration[0m | . md5-password     | 'topsecret'[0m
03:12:09 | 2187   | configuration[0m | &gt; capability       | [0m
03:12:09 | 2187   | configuration[0m | . route-refresh    | 'disable'[0m
03:12:09 | 2187   | configuration[0m | . add-path         | 'disable'[0m
03:12:09 | 2187   | configuration[0m | &lt; capability       | [0m
03:12:09 | 2187   | configuration[0m | &gt; family           | [0m
03:12:09 | 2187   | configuration[0m | . ipv4             | 'unicast'[0m
03:12:09 | 2187   | configuration[0m | &lt; family           | [0m
03:12:09 | 2187   | configuration[0m | &lt; neighbor         | [0m
03:12:09 | 2187   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:12:09 | 2187   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:12:09 | 2187   | reactor      [0m | initialising connection to peer-1[0m
03:12:09 | 2187   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:12:10 | 2187   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00[0m
03:12:10 | 2187   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)][0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0035 01[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  34) 04FB F000 B4C0 0002 0218 0216 4104 0000 FBF0 0600 0200 0104 0001 0001 4002 00B4 4700[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71][0m
03:12:10 | 2187   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:12:10 | 2187   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:12:10 | 2187   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:12:10 | 2187   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:12:10 | 2187   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:12:10 | 2187   | outgoing-1   [0m | sending TCP payload (  23) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 0200 0000 00[0m
03:12:10 | 2187   | outgoing-1   [0m | &gt;&gt; EOR ipv4 unicast[0m
03:12:10 | 2187   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:12:10 | 2187   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:12:10 | 2187   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:12:10 | 2187   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:12:11 | 2187   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:12:11 | 2187   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:12:12 | 2187   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:12:12 | 2187   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m</msg>
<msg time="2026-06-06T03:12:12.770941" level="INFO">${output} = [?2004l03:12:09 | 2187   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:12:09 | 2187   | [01;34mversion      [0m | [1m4.2.17  [0m
03:12:09 | 2187   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:12:12.770530" elapsed="0.000441"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.771384" level="INFO">[?2004l03:12:09 | 2187   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:12:09 | 2187   | [01;34mversion      [0m | [1m4.2.17  [0m
03:12:09 | 2187   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:12:09 | 2187   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:12:09 | 2187   | [01;34minstallation [0m | [1m        [0m
03:12:09 | 2187   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:12:09 | 2187   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:12:09 | 2187   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:12:09 | 2187   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:12:09 | 2187   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:12:09 | 2187   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:12:09 | 2187   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:12:09 | 2187   | configuration[0m | . local-as         | '64496'[0m
03:12:09 | 2187   | configuration[0m | . peer-as          | '64496'[0m
03:12:09 | 2187   | configuration[0m | . md5-password     | 'topsecret'[0m
03:12:09 | 2187   | configuration[0m | &gt; capability       | [0m
03:12:09 | 2187   | configuration[0m | . route-refresh    | 'disable'[0m
03:12:09 | 2187   | configuration[0m | . add-path         | 'disable'[0m
03:12:09 | 2187   | configuration[0m | &lt; capability       | [0m
03:12:09 | 2187   | configuration[0m | &gt; family           | [0m
03:12:09 | 2187   | configuration[0m | . ipv4             | 'unicast'[0m
03:12:09 | 2187   | configuration[0m | &lt; family           | [0m
03:12:09 | 2187   | configuration[0m | &lt; neighbor         | [0m
03:12:09 | 2187   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:12:09 | 2187   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:12:09 | 2187   | reactor      [0m | initialising connection to peer-1[0m
03:12:09 | 2187   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:12:10 | 2187   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00[0m
03:12:10 | 2187   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)][0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0035 01[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  34) 04FB F000 B4C0 0002 0218 0216 4104 0000 FBF0 0600 0200 0104 0001 0001 4002 00B4 4700[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71][0m
03:12:10 | 2187   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:12:10 | 2187   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:12:10 | 2187   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:12:10 | 2187   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:12:10 | 2187   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:12:10 | 2187   | outgoing-1   [0m | sending TCP payload (  23) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 0200 0000 00[0m
03:12:10 | 2187   | outgoing-1   [0m | &gt;&gt; EOR ipv4 unicast[0m
03:12:10 | 2187   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:12:10 | 2187   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:12:10 | 2187   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:12:10 | 2187   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:12:10 | 2187   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:12:10 | 2187   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:12:11 | 2187   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:12:11 | 2187   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:12:12 | 2187   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:12:12 | 2187   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.771130" elapsed="0.000394"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.772342" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:12.772023" elapsed="0.000347"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:12.772527" elapsed="0.000324"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:12:12.771744" elapsed="0.001175"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:12.899158" level="INFO">^C03:12:12 | 2187   | [00;31mreactor      [0m | [1m^C received[0m
03:12:12 | 2187   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:12:12 | 2187   | outgoing-1   [0m | stop, message [shutting down][0m
03:12:12 | 2187   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:12:12.899516" level="INFO">${output} = ^C03:12:12 | 2187   | [00;31mreactor      [0m | [1m^C received[0m
03:12:12 | 2187   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:12:12 | 2187   | outgoing-1   [0m | stop, messag...</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:12.773088" elapsed="0.126465"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.900183" level="INFO">^C03:12:12 | 2187   | [00;31mreactor      [0m | [1m^C received[0m
03:12:12 | 2187   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:12:12 | 2187   | outgoing-1   [0m | stop, message [shutting down][0m
03:12:12 | 2187   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.899829" elapsed="0.000429"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:12.902151" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:12.901034" elapsed="0.001173"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:12.903132" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:12:12.903224" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:12.902373" elapsed="0.000879"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.903883" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.903612" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:12.903332" elapsed="0.000633"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:12.903307" elapsed="0.000686"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:12:12.900600" elapsed="0.003442"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:12:12.770239" elapsed="0.133856"/>
</kw>
<kw name="Delete_Bgp_Peer_Configuration" type="TEARDOWN">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.905156" level="INFO">&amp;{mapping} = { BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.171.194 }</msg>
<var>&amp;{mapping}</var>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:12.904684" elapsed="0.000502"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.947583" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:12.947201" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:12.948420" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:12.948144" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:12.948602" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:12.947801" elapsed="0.000826"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.949201" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:12.948812" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:12.949529" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:12.949757" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:12.949391" elapsed="0.000395"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.950200" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.949948" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.951249" level="INFO">mapping: {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.950989" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.951741" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:12.951457" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.952442" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:12.952143" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:12.953344" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:12.953058" elapsed="0.000313"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:12.953426" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:12.953588" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:12.952701" elapsed="0.000912"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:12.953790" elapsed="0.000241"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:12.952003" elapsed="0.002070"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.954634" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:12.954331" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:12.955435" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:12.955220" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:12.955515" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:12.955684" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:12.954869" elapsed="0.000842"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:12.955868" elapsed="0.000225"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:12.954195" elapsed="0.001943"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:12.951824" elapsed="0.004350"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:12.956219" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:12.956378" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:12.950617" elapsed="0.005787"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:12.950316" elapsed="0.006121"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.956668" elapsed="0.000194"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:12.956462" elapsed="0.000442"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:12.950295" elapsed="0.006631"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.957683" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:12.957077" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:12.957765" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:12.946543" elapsed="0.011351"/>
</kw>
<msg time="2026-06-06T03:12:12.957949" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:12.933961" elapsed="0.024049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.970677" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.983074" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.995454" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.995740" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.995928" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.996328" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:12.996174" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:12.996157" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.996576" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.996771" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.996944" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:12.996123" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:12.996011" elapsed="0.001015"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:12.997177" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:12.997256" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:12.997394" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:12.929631" elapsed="0.067791"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:12.998602" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:12.998329" elapsed="0.000339"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:13.020231" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:13.020279" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:13.020371" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:13.000881" elapsed="0.019516"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:12.998737" elapsed="0.021701"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.020668" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.020464" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:12.998719" elapsed="0.022035"/>
</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-06-06T03:12:13.024356" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.021820" elapsed="0.002581"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.021571" elapsed="0.002866"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.021552" elapsed="0.002910"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.027173" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.024797" elapsed="0.002423"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.024540" elapsed="0.002716"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.024502" elapsed="0.002781"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.027909" 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-06-06T03:12:13.027487" elapsed="0.000450"/>
</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-06-06T03:12:13.028259" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.028010" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.028872" 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-06-06T03:12:13.028543" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.028342" elapsed="0.000594"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.027991" elapsed="0.000967"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.029493" 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-06-06T03:12:13.029123" elapsed="0.000397"/>
</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-06-06T03:12:13.029847" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.029591" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.030401" 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-06-06T03:12:13.030096" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.029930" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.029571" elapsed="0.000915"/>
</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-06-06T03:12:13.030654" elapsed="0.000356"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:13.031474" 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-06-06T03:12:13.031180" elapsed="0.000330"/>
</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-06-06T03:12:13.031696" elapsed="0.002321"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:12:13.021125" elapsed="0.012956"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:13.034129" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:12:13.036399" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:12:12.997706" elapsed="0.038721"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:13.036482" elapsed="0.000048"/>
</return>
<arg>${BGP_PEER_FOLDER}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:12:12.905412" elapsed="0.131220"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:12:12.904308" elapsed="0.132399"/>
</kw>
<doc>Verifies exabgp connected with md5 settings</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:09.414858" elapsed="3.621894"/>
</test>
<test id="s1-s3-t2" name="Verify Exabgp Not Connected" line="54">
<kw name="Reconfigure_ODL_To_Accept_Connection" type="SETUP">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.038389" level="INFO">&amp;{mapping} = { BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PASSWORD=different | PASSIVE_MODE=true }</msg>
<var>&amp;{mapping}</var>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSWORD=${password}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.037756" elapsed="0.000662"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.071837" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:13.071437" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:13.072794" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:13.072537" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:13.073005" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:13.072034" elapsed="0.000997"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.073597" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:13.073204" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:13.073950" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:13.074097" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:13.073810" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.074558" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.074305" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.075624" level="INFO">mapping: {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSWORD': 'different', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.075354" elapsed="0.000336"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.076134" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.075858" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.076920" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.076590" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:13.077971" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.077480" elapsed="0.000518"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:13.078050" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:13.078201" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:13.077156" elapsed="0.001069"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.078380" elapsed="0.000229"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:13.076414" elapsed="0.002251"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.079211" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.078913" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:13.080193" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.079758" elapsed="0.000462"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:13.080272" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:13.080423" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:13.079423" elapsed="0.001025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.080627" elapsed="0.000240"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:13.078777" elapsed="0.002132"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.081453" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.081155" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:13.082441" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.082003" elapsed="0.000465"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:13.082520" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:13.082859" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:13.081684" elapsed="0.001200"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.083039" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:13.081020" elapsed="0.002284"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.083868" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.083550" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:13.084927" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.084442" elapsed="0.000513"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:13.085007" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:13.085187" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:13.084122" elapsed="0.001100"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.085386" elapsed="0.000227"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:13.083415" elapsed="0.002259"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.086244" level="INFO">${value} = different</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.085928" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:13.087244" level="INFO">${encoded} = different</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.086810" elapsed="0.000461"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:13.087322" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:13.087474" level="INFO">${encoded_value} = different</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:13.086461" elapsed="0.001037"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.087667" elapsed="0.000225"/>
</kw>
<var name="${key}">PASSWORD</var>
<var name="${value}">different</var>
<status status="PASS" start="2026-06-06T03:12:13.085791" elapsed="0.002142"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.088521" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.088185" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:13.089523" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.089082" elapsed="0.000469"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:13.089603" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:13.089773" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:13.088757" elapsed="0.001041"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:13.089954" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:12:13.088045" elapsed="0.002174"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:13.076228" elapsed="0.014028"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:13.090299" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:13.090458" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSWORD': 'different', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:13.075000" elapsed="0.015485"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.074697" elapsed="0.015820"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.090756" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.090543" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.074675" elapsed="0.016160"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.091654" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:13.090985" elapsed="0.000699"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:13.091735" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:13.070811" elapsed="0.021051"/>
</kw>
<msg time="2026-06-06T03:12:13.091919" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:13.058154" elapsed="0.033816"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.104778" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.117263" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.129506" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.129726" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.129911" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.130300" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.130151" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:13.130135" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.130525" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.130718" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.130888" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:13.130101" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:13.129992" elapsed="0.000976"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.131116" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:13.131197" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:13.131330" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:13.053883" elapsed="0.077475"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.157483" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:13.157100" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:13.158278" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:13.158031" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:13.158448" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:13.157692" elapsed="0.000781"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.159149" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:13.158750" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:13.159484" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:13.159657" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:13.159345" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.160107" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
        &lt;auth-password&gt;$PASSWORD&lt;/auth-password&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.159850" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:13.160575" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.160235" elapsed="0.000401"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.161130" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSWORD': 'different', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:13.160830" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.160678" elapsed="0.000516"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.160216" elapsed="0.001000"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.162083" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:13.161368" elapsed="0.000746"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:13.162165" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:13.156462" elapsed="0.005830"/>
</kw>
<msg time="2026-06-06T03:12:13.162350" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:13.143972" elapsed="0.018426"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.174791" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.187036" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.199393" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.199660" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.199846" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.200234" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.200084" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:13.200067" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.200474" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.200658" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.200830" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:13.200033" elapsed="0.000850"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:13.199924" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.201061" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:13.201136" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:13.201279" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:13.141303" elapsed="0.060006"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:13.202630" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:13.202371" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:13.202817" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:13.202000" elapsed="0.000842"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.203171" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.202913" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.203744" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:13.203433" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.203253" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.202893" elapsed="0.000934"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.206160" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:13.203980" elapsed="0.002206"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:13.206237" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:13.206393" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:13.201658" elapsed="0.004759"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.207826" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.207554" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.208266" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
        &lt;auth-password&gt;different&lt;/auth-password&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.208030" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.208854" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.208580" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.209300" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.209055" elapsed="0.000290"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:13.210173" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:13.209976" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:13.210531" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:13.210355" elapsed="0.000202"/>
</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-06-06T03:12:13.210727" elapsed="0.000208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.211342" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.211093" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:13.211429" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:13.211585" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:13.209549" elapsed="0.002062"/>
</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-06-06T03:12:13.230377" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Content-Length': '847', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
        &lt;auth-password&gt;different&lt;/auth-password&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:12:13.230441" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:13.230543" 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-06-06T03:12:13.215142" elapsed="0.015427"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.211698" elapsed="0.018917"/>
</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-06-06T03:12:13.230822" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.230660" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.211679" elapsed="0.019233"/>
</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-06-06T03:12:13.234261" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.231894" elapsed="0.002411"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.231666" elapsed="0.002674"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.231631" elapsed="0.002734"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.236976" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.234664" elapsed="0.002358"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.234422" elapsed="0.002634"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.234405" elapsed="0.002676"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.237658" 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-06-06T03:12:13.237257" elapsed="0.000431"/>
</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-06-06T03:12:13.238011" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.237760" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.238562" 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-06-06T03:12:13.238260" elapsed="0.000368"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.238094" elapsed="0.000587"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.237740" elapsed="0.000963"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.239239" 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-06-06T03:12:13.238871" elapsed="0.000395"/>
</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-06-06T03:12:13.239574" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.239337" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.240131" 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-06-06T03:12:13.239836" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.239671" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.239318" elapsed="0.000895"/>
</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-06-06T03:12:13.240367" elapsed="0.000384"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:13.241204" 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-06-06T03:12:13.240920" elapsed="0.000310"/>
</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-06-06T03:12:13.241388" elapsed="0.002292"/>
</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-06-06T03:12:13.231285" elapsed="0.012459"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:13.243921" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:12:13.243812" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.243793" elapsed="0.000217"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:13.244162" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:13.244231" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:13.246498" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:12:13.206765" elapsed="0.039761"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:13.246591" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:13.246761" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:13.043039" elapsed="0.203750"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:13.247136" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:13.246894" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.246876" elapsed="0.000353"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:13.247262" elapsed="0.000026"/>
</return>
<arg>${BGP_PEER_FOLDER}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:13.038707" elapsed="0.208677"/>
</kw>
<arg>${MD5_DIFF_PASSWD}</arg>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:12:13.037400" elapsed="0.210045"/>
</kw>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.248353" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:13.248025" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.248836" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.248572" elapsed="0.000309"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:13.251542" level="INFO">source /tmp/defaultvenv/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-06-06T03:12:13.249490" elapsed="0.002109"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:13.255654" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:12:13.255784" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:13.251778" elapsed="0.004035"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.256411" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.256141" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:13.255882" elapsed="0.000614"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:13.255863" elapsed="0.000659"/>
</if>
<arg>log_output=${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-06-06T03:12:13.249126" elapsed="0.007444"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:13.258563" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg</msg>
<msg time="2026-06-06T03:12:13.258673" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:13.256741" elapsed="0.001959"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.259128" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa-md5.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.258877" elapsed="0.000297"/>
</kw>
<arg>${BGP_EXAMD5_CFG}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:13.247695" elapsed="0.011535"/>
</kw>
<kw name="Verify_Keyword_Never_Passes_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.262610" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:13.262264" elapsed="0.000373"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.264822" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:13.262820" elapsed="0.002029"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:13.270732" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:13.270873" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:13.270966" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:13.265015" elapsed="0.005976"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.273512" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:13.271167" elapsed="0.002393"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:13.276191" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:13.273736" elapsed="0.002523">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:13.261888" elapsed="0.014483">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:15.279264" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:15.278348" elapsed="0.000985"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:15.284222" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:15.279792" elapsed="0.004504"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:15.294041" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:15.294353" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:15.294612" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:15.284749" elapsed="0.009964"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:15.300785" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:15.295292" elapsed="0.005570"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:15.305307" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:15.301112" elapsed="0.004302">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:15.277314" elapsed="0.028278">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:17.308528" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:17.307624" elapsed="0.000972"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:17.312716" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:17.309020" elapsed="0.003738"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:17.321799" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:17.321992" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:17.322144" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:17.313002" elapsed="0.009181"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:17.325927" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:17.322487" elapsed="0.003507"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:17.329829" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:17.326218" elapsed="0.003711">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:17.306582" elapsed="0.023513">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:19.333433" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:19.332506" elapsed="0.000999"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:19.337656" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:19.333936" elapsed="0.003777"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:19.347443" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:19.347624" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:19.347790" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:19.337954" elapsed="0.009874"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:19.351473" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:19.348074" elapsed="0.003468"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:19.355381" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:19.351793" elapsed="0.003684">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:19.331403" elapsed="0.024194">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:21.358893" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:21.357954" elapsed="0.001010"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:21.363338" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:21.359359" elapsed="0.004020"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:21.373138" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:21.373325" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:21.373476" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:21.363615" elapsed="0.009898"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:21.377121" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:21.373833" elapsed="0.003355"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:21.380935" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:21.377410" elapsed="0.003623">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:21.356873" elapsed="0.024322">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:23.384140" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:23.383228" elapsed="0.000983"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:23.389080" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:23.384602" elapsed="0.004545"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:23.398447" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:23.398621" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:23.398785" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:23.389521" elapsed="0.009301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:23.402369" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:23.399072" elapsed="0.003366"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:23.406028" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:23.402663" elapsed="0.003435">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:23.382201" elapsed="0.024009">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:25.409433" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:25.408498" elapsed="0.001005"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:25.413402" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:25.409932" elapsed="0.003510"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:25.421758" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:25.422027" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:25.422163" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:25.413705" elapsed="0.008496"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:25.425832" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:25.422442" elapsed="0.003460"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:25.429900" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:25.426127" elapsed="0.003870">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:25.407368" elapsed="0.022783">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:27.433225" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:27.432285" elapsed="0.001011"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:27.438316" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:27.433724" elapsed="0.004654"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:27.445699" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:27.445862" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:27.445974" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:27.438836" elapsed="0.007167"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:27.448978" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:27.446182" elapsed="0.002867"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:27.452827" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:27.449278" elapsed="0.003647">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:27.431243" elapsed="0.021839">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.456235" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:29.455299" elapsed="0.001008"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.461301" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:29.456740" elapsed="0.004625"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:29.470405" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:29.470564" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:29.470715" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:29.461778" elapsed="0.008967"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.474618" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.471003" elapsed="0.003809"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.478563" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:12:29.475044" elapsed="0.003645">200.0 != 409.0</status>
</kw>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:12:29.454197" elapsed="0.024661">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:12:29.478958" level="FAIL">Keyword 'ExaBgpLib.Verify_ExaBgps_Connection' failed after retrying for 15 seconds. The last error was: 200.0 != 409.0</msg>
<arg>15s</arg>
<arg>2s</arg>
<arg>ExaBgpLib.Verify_ExaBgps_Connection</arg>
<arg>session</arg>
<arg>10.30.171.194</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:12:13.261345" elapsed="16.217708">Keyword 'ExaBgpLib.Verify_ExaBgps_Connection' failed after retrying for 15 seconds. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:12:29.479176" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:12:29.479228" level="INFO">${output} = Keyword 'ExaBgpLib.Verify_ExaBgps_Connection' failed after retrying for 15 seconds. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:13.260944" elapsed="16.218308"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:12:29.479475" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:12:29.479345" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.479317" elapsed="0.000254"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.479744" elapsed="0.000023"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.479921" elapsed="0.000020"/>
</kw>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="PASS" start="2026-06-06T03:12:13.260298" elapsed="16.219747"/>
</kw>
<msg time="2026-06-06T03:12:29.480099" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Invert_Failure</arg>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:13.259852" elapsed="16.220294"/>
</kw>
<arg>15s</arg>
<arg>2s</arg>
<arg>ExaBgpLib.Verify_ExaBgps_Connection</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Some negative checks report false failure for a short time. This keyword verifies no pass does happen within timeout period.</doc>
<status status="PASS" start="2026-06-06T03:12:13.259431" elapsed="16.220804"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.480939" level="INFO">[?2004l03:12:13 | 2191   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:12:13 | 2191   | [01;34mversion      [0m | [1m4.2.17  [0m
03:12:13 | 2191   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:12:13 | 2191   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:12:13 | 2191   | [01;34minstallation [0m | [1m        [0m
03:12:13 | 2191   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:12:13 | 2191   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:12:13 | 2191   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:12:13 | 2191   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:12:13 | 2191   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:12:13 | 2191   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:12:13 | 2191   | configuration[0m | . local-as         | '64496'[0m
03:12:13 | 2191   | configuration[0m | . peer-as          | '64496'[0m
03:12:13 | 2191   | configuration[0m | . md5-password     | 'topsecret'[0m
03:12:13 | 2191   | configuration[0m | &gt; capability       | [0m
03:12:13 | 2191   | configuration[0m | . route-refresh    | 'disable'[0m
03:12:13 | 2191   | configuration[0m | . add-path         | 'disable'[0m
03:12:13 | 2191   | configuration[0m | &lt; capability       | [0m
03:12:13 | 2191   | configuration[0m | &gt; family           | [0m
03:12:13 | 2191   | configuration[0m | . ipv4             | 'unicast'[0m
03:12:13 | 2191   | configuration[0m | &lt; family           | [0m
03:12:13 | 2191   | configuration[0m | &lt; neighbor         | [0m
03:12:13 | 2191   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:12:13 | 2191   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:12:13 | 2191   | reactor      [0m | initialising connection to peer-1[0m
03:12:13 | 2191   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m</msg>
<msg time="2026-06-06T03:12:29.481091" level="INFO">${output} = [?2004l03:12:13 | 2191   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:12:13 | 2191   | [01;34mversion      [0m | [1m4.2.17  [0m
03:12:13 | 2191   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:12:29.480803" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.481536" level="INFO">[?2004l03:12:13 | 2191   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:12:13 | 2191   | [01;34mversion      [0m | [1m4.2.17  [0m
03:12:13 | 2191   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:12:13 | 2191   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:12:13 | 2191   | [01;34minstallation [0m | [1m        [0m
03:12:13 | 2191   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:12:13 | 2191   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:12:13 | 2191   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:12:13 | 2191   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:12:13 | 2191   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:12:13 | 2191   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:12:13 | 2191   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:12:13 | 2191   | configuration[0m | . local-as         | '64496'[0m
03:12:13 | 2191   | configuration[0m | . peer-as          | '64496'[0m
03:12:13 | 2191   | configuration[0m | . md5-password     | 'topsecret'[0m
03:12:13 | 2191   | configuration[0m | &gt; capability       | [0m
03:12:13 | 2191   | configuration[0m | . route-refresh    | 'disable'[0m
03:12:13 | 2191   | configuration[0m | . add-path         | 'disable'[0m
03:12:13 | 2191   | configuration[0m | &lt; capability       | [0m
03:12:13 | 2191   | configuration[0m | &gt; family           | [0m
03:12:13 | 2191   | configuration[0m | . ipv4             | 'unicast'[0m
03:12:13 | 2191   | configuration[0m | &lt; family           | [0m
03:12:13 | 2191   | configuration[0m | &lt; neighbor         | [0m
03:12:13 | 2191   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:12:13 | 2191   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:12:13 | 2191   | reactor      [0m | initialising connection to peer-1[0m
03:12:13 | 2191   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.481281" elapsed="0.000412"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.482564" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:29.482195" elapsed="0.000397"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:29.482771" elapsed="0.000507"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:12:29.481907" elapsed="0.001444"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.613464" level="INFO">^C03:12:29 | 2191   | [00;31mreactor      [0m | [1m^C received[0m
03:12:29 | 2191   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:12:29 | 2191   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
03:12:29 | 2191   | [01;33moutgoing-1   [0m | [1mconnection to 10.30.170.38 closed[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:12:29.613714" level="INFO">${output} = ^C03:12:29 | 2191   | [00;31mreactor      [0m | [1m^C received[0m
03:12:29 | 2191   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:12:29 | 2191   | [01;33moutgoing-1   [0m | [1m...</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:29.483515" elapsed="0.130234"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.614366" level="INFO">^C03:12:29 | 2191   | [00;31mreactor      [0m | [1m^C received[0m
03:12:29 | 2191   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:12:29 | 2191   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
03:12:29 | 2191   | [01;33moutgoing-1   [0m | [1mconnection to 10.30.170.38 closed[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.614024" elapsed="0.000399"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.616849" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:29.615153" elapsed="0.001759"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.617742" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:12:29.617828" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:29.617081" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.618472" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.618216" elapsed="0.000312"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.617936" elapsed="0.000626"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.617910" elapsed="0.000679"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:12:29.614738" elapsed="0.003904"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:12:29.480493" elapsed="0.138222"/>
</kw>
<kw name="Delete_Bgp_Peer_Configuration" type="TEARDOWN">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.619756" level="INFO">&amp;{mapping} = { BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.171.194 }</msg>
<var>&amp;{mapping}</var>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:29.619264" elapsed="0.000521"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.662289" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:29.661896" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:29.663123" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:29.662851" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:29.663293" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:29.662490" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.663896" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:29.663487" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:29.664229" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_md5/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:29.664399" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:29.664089" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.664894" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.664618" elapsed="0.000389"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.666061" level="INFO">mapping: {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.665798" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.666551" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:29.666280" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.667463" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:29.666971" elapsed="0.000519"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:29.668291" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:29.668066" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:29.668373" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:12:29.668537" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:29.667703" elapsed="0.000876"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:29.668755" elapsed="0.000242"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:29.666831" elapsed="0.002209"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.669597" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:29.669294" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:29.670398" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:29.670186" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:29.670476" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:29.670629" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:29.669833" elapsed="0.000838"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:29.670829" elapsed="0.000292"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:29.669157" elapsed="0.002007"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:29.666632" elapsed="0.004568"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:29.671244" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:29.671403" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:29.665396" elapsed="0.006033"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.665084" elapsed="0.006378"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.671645" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:29.671487" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.665062" elapsed="0.006683"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.672486" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:29.671894" elapsed="0.000623"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:29.672568" elapsed="0.000064"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:29.661223" elapsed="0.011539"/>
</kw>
<msg time="2026-06-06T03:12:29.672820" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:29.648509" elapsed="0.024379"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.685223" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.697634" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_md5/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.710008" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.710210" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.710391" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.710778" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:29.710614" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:29.710598" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.711005" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.711177" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.711347" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:29.710570" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:29.710468" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.711573" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:29.711664" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:29.711791" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:29.644114" elapsed="0.067704"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.712963" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.712708" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:29.725156" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0pw9dge40uodz93a764eygo203.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:29.725255" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:29.725409" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:29.715319" elapsed="0.010127"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.713106" elapsed="0.012399"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:29.725844" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:29.725586" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.713060" elapsed="0.012904"/>
</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-06-06T03:12:29.730768" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.727418" elapsed="0.003413"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.727103" elapsed="0.003778"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.727077" elapsed="0.003840"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.734526" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.731317" elapsed="0.003274"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.730997" elapsed="0.003646"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.730973" elapsed="0.003724"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.735475" 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-06-06T03:12:29.734940" elapsed="0.000573"/>
</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-06-06T03:12:29.735977" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:29.735613" elapsed="0.000446"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.736770" 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-06-06T03:12:29.736323" elapsed="0.000484"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.736092" elapsed="0.000766"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.735587" elapsed="0.001301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.737698" 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-06-06T03:12:29.737119" elapsed="0.000619"/>
</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-06-06T03:12:29.738094" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:29.737839" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.738647" 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-06-06T03:12:29.738346" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.738181" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.737812" elapsed="0.000934"/>
</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-06-06T03:12:29.738903" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:29.739723" 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-06-06T03:12:29.739423" elapsed="0.000327"/>
</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-06-06T03:12:29.739915" elapsed="0.002310"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:12:29.726469" elapsed="0.015821"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:29.742337" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:29.744577" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:12:29.712082" elapsed="0.032523"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:29.744674" elapsed="0.000029"/>
</return>
<arg>${BGP_PEER_FOLDER}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:12:29.620043" elapsed="0.124759"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:12:29.618928" elapsed="0.125935"/>
</kw>
<doc>Verifies exabgp connected with md5 settings</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:13.036974" elapsed="16.707935"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Virtual_Env_Delete" 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-06-06T03:12:29.751183" level="INFO">${cd_and_command} = cd '.' &amp;&amp; rm -rf /tmp/defaultvenv</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-06-06T03:12:29.750849" elapsed="0.000362"/>
</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-06-06T03:12:29.752685" level="INFO">Executing command 'cd '.' &amp;&amp; rm -rf /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:12:29.787081" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:29.787687" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:12:29.787818" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:12:29.787919" 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-06-06T03:12:29.752478" elapsed="0.035499"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.790286" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:12:29.789537" elapsed="0.000860"/>
</kw>
<msg time="2026-06-06T03:12:29.790626" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:12:29.790776" 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-06-06T03:12:29.788535" elapsed="0.002298"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.792279" 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-06-06T03:12:29.791232" elapsed="0.001108"/>
</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-06-06T03:12:29.794956" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.794382" elapsed="0.000637"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.795575" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.795240" elapsed="0.000392"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.796207" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.795871" elapsed="0.000396"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:12:29.793404" elapsed="0.002942"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:29.792538" elapsed="0.003860"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.792482" elapsed="0.003955"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:12:29.796687" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:29.796517" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.796492" elapsed="0.000296"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:29.796992" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:12:29.796864" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.796842" elapsed="0.000278"/>
</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-06-06T03:12:29.797331" elapsed="0.000030"/>
</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-06-06T03:12:29.751922" elapsed="0.045578"/>
</kw>
<msg time="2026-06-06T03:12:29.797574" 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-06-06T03:12:29.751379" elapsed="0.046306"/>
</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 rm -rf /tmp/defaultvenv.
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-06-06T03:12:29.750178" elapsed="0.047624"/>
</kw>
<msg time="2026-06-06T03:12:29.797876" 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-06-06T03:12:29.746244" elapsed="0.051709"/>
</kw>
<arg>rm -rf ${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-06-06T03:12:29.745892" elapsed="0.052168"/>
</kw>
<doc>Deletes a directory with virtual env.</doc>
<status status="PASS" start="2026-06-06T03:12:29.745631" elapsed="0.052527"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:12:29.798370" elapsed="0.000702"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:29.799404" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:12:29.799297" elapsed="0.000256"/>
</kw>
<doc>Suite teardown keyword with old rib restoration</doc>
<status status="PASS" start="2026-06-06T03:12:29.745343" elapsed="0.054285"/>
</kw>
<doc>Functional test suite for bgp - n-path and all-path selection

Copyright (c) 2017 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests tcpmd5 connection of bgp peers. It uses odl and exabgp as bgp
peer. No routes are advertized, simple peer presence in the datastore is tested.
are configured via application peer.</doc>
<status status="PASS" start="2026-06-06T03:12:00.508189" elapsed="29.291516"/>
</suite>
<suite id="s1-s4" name="Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/basic.robot">
<kw name="Setup_Everything" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.889827" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:12:29.885467" elapsed="0.004412"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:12:29.885236" elapsed="0.004712"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.894762" 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-06-06T03:12:29.891052" elapsed="0.003739"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:12:29.894995" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:29.894877" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.894852" elapsed="0.000211"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.895612" 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-06-06T03:12:29.895223" elapsed="0.000450"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.896159" 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-06-06T03:12:29.895844" elapsed="0.000341"/>
</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-06-06T03:12:29.896721" elapsed="0.000292"/>
</kw>
<msg time="2026-06-06T03:12:29.897110" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:29.897156" 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-06-06T03:12:29.896356" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.897742" 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-06-06T03:12:29.897351" elapsed="0.000417"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.898777" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:12:29.898492" elapsed="0.000313"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.899212" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:12:29.898956" elapsed="0.000282"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.899736" 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-06-06T03:12:29.899427" elapsed="0.000336"/>
</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-06-06T03:12:29.904292" elapsed="0.000210"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.905010" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:12:29.904680" elapsed="0.000356"/>
</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-06-06T03:12:29.905190" elapsed="0.000226"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.906226" 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-06-06T03:12:29.905928" elapsed="0.000324"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:12:29.906298" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:12:29.906457" 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-06-06T03:12:29.905613" elapsed="0.000869"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:29.907097" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e768bb10&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-06-06T03:12:29.906643" elapsed="0.000588"/>
</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-06-06T03:12:29.907432" 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-06-06T03:12:29.903725" elapsed="0.003980"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:29.903511" elapsed="0.004241"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:12:29.899821" elapsed="0.007962"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.908354" 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-06-06T03:12:29.907950" elapsed="0.000448"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.908989" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:12:29.908564" elapsed="0.000470"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.909643" 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-06-06T03:12:29.909247" elapsed="0.000455"/>
</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-06-06T03:12:29.898040" elapsed="0.011721"/>
</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-06-06T03:12:29.890704" elapsed="0.019113"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:29.910001" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:29.909887" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.909865" elapsed="0.000203"/>
</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-06-06T03:12:29.913186" 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-06-06T03:12:29.912802" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.913693" 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-06-06T03:12:29.913376" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:29.913766" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:29.913921" 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-06-06T03:12:29.912452" elapsed="0.001494"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:29.914943" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:12:29.914676" elapsed="0.000293"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.916479" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:12:29.916589" 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-06-06T03:12:29.916303" elapsed="0.000313"/>
</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-06-06T03:12:29.921345" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:29.920645" elapsed="0.000803"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:29.920619" elapsed="0.000869"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.922254" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:12:29.921729" elapsed="0.000824"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.923566" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:29.922842" elapsed="0.000923"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.925012" 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-06-06T03:12:29.924056" elapsed="0.001009"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:12:29.926842" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:12:29.927019" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:29.926449" elapsed="0.000612"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:29.927422" elapsed="0.000534"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:12:29.929259" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:12:30.264281" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:12:00 UTC 2026

  System load:  0.01               Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:12:01 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:12:29.928929" elapsed="0.335651"/>
</kw>
<msg time="2026-06-06T03:12:30.264688" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:29.928333" elapsed="0.336518"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:12:29.925522" elapsed="0.339482"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.265957" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:12:30.278977" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:12:30.279336" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:12:30.279505" 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-06-06T03:12:30.265378" elapsed="0.014194"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:30.280119" elapsed="0.000793"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.282426" 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-06-06T03:12:30.281688" elapsed="0.000873"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:12:30.283124" elapsed="0.000064"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:30.282799" elapsed="0.000487"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.282763" elapsed="0.000572"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:12:30.283771" elapsed="0.000090"/>
</return>
<status status="PASS" start="2026-06-06T03:12:30.283468" elapsed="0.000493"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.283442" elapsed="0.000571"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:12:30.284091" elapsed="0.000023"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:30.289086" elapsed="0.000774"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:30.290234" elapsed="0.000384"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:30.290985" elapsed="0.000434"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:30.284772" elapsed="0.006771"/>
</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-06-06T03:12:29.919625" elapsed="0.372161"/>
</kw>
<msg time="2026-06-06T03:12:30.291864" 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-06-06T03:12:29.917995" elapsed="0.373958"/>
</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-06-06T03:12:29.917322" elapsed="0.374734"/>
</kw>
<msg time="2026-06-06T03:12:30.292109" 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-06-06T03:12:29.916801" elapsed="0.375371"/>
</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-06-06T03:12:30.295924" elapsed="0.000426"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:30.296573" elapsed="0.000238"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:30.297023" elapsed="0.000132"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:30.292591" elapsed="0.004633"/>
</kw>
<msg time="2026-06-06T03:12:30.297346" 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-06-06T03:12:29.915187" elapsed="0.382192"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.298090" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:30.297750" elapsed="0.000397"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:12:30.298208" elapsed="0.000043"/>
</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-06-06T03:12:29.914304" elapsed="0.384073"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:29.914126" elapsed="0.384378"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:29.913998" elapsed="0.384558"/>
</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-06-06T03:12:29.910291" elapsed="0.388340"/>
</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-06-06T03:12:30.298865" elapsed="0.000286"/>
</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-06-06T03:12:30.316491" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:30.316305" elapsed="0.000260"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.316272" elapsed="0.000331"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.317123" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:12:30.317287" 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-06-06T03:12:30.316889" elapsed="0.000438"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.317973" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:30.317562" elapsed="0.000476"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.318613" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:30.318261" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:30.319947" 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-06-06T03:12:30.319552" elapsed="0.000546">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:12:30.320257" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:12:30.320322" 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-06-06T03:12:30.318980" elapsed="0.001376"/>
</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-06-06T03:12:30.320825" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:30.320466" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.320438" elapsed="0.000536"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:30.322105" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:12:30.321719" elapsed="0.000422"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:12:30.322207" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:12:30.322428" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:12:30.321293" elapsed="0.001170"/>
</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-06-06T03:12:30.322720" elapsed="0.000568"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.323951" level="INFO">index=4
host=10.30.170.38
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-06-06T03:12:30.324092" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:12:30.323758" elapsed="0.000373"/>
</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-06-06T03:12:30.324346" elapsed="0.003450"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.328446" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:12:30.564271" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:12:30.328081" elapsed="0.236344"/>
</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-06-06T03:12:30.567998" elapsed="0.000375"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:30.568548" elapsed="0.000196"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:30.568900" elapsed="0.000104"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:30.565618" elapsed="0.003439"/>
</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-06-06T03:12:30.564936" elapsed="0.004169"/>
</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-06-06T03:12:30.315859" elapsed="0.253302"/>
</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-06-06T03:12:30.300214" elapsed="0.268997"/>
</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-06-06T03:12:30.299700" elapsed="0.269564"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:30.299432" elapsed="0.269876"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:12:30.299232" elapsed="0.270113"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:12:29.890242" elapsed="0.679165"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:30.572169" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:30.572051" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.572029" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:30.577068" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:30.576957" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.576939" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.578145" 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-06-06T03:12:30.577737" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.578817" 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-06-06T03:12:30.578342" elapsed="0.000509"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:30.578904" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:12:30.579073" 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-06-06T03:12:30.577374" elapsed="0.001725"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:30.584780" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:30.584662" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.584627" elapsed="0.000225"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:30.586136" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:30.586007" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.585988" elapsed="0.000219"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:30.586723" 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-06-06T03:12:30.586357" elapsed="0.000394"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.587150" 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-06-06T03:12:30.586918" elapsed="0.000259"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.650471" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:30.587873" elapsed="0.062924"/>
</kw>
<msg time="2026-06-06T03:12:30.651027" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:30.651081" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:12:30.587343" elapsed="0.063793"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.728308" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "b "a "s "i "c ". "r "[78Co "[A[78Cb
 "o "t "[K"
[?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-06-06T03:12:30.652474" elapsed="0.076058"/>
</kw>
<msg time="2026-06-06T03:12:30.728739" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:30.728788" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:12:30.651820" elapsed="0.077005"/>
</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-06-06T03:12:30.729298" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:30.728937" elapsed="0.000516"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.728905" elapsed="0.000578"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:30.730093" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "b "a "s "i "c ". "r "[78Co "[A[78Cb
 "o "t "[K"
[?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-06-06T03:12:30.729643" elapsed="0.000532"/>
</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-06-06T03:12:30.730494" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:30.730247" elapsed="0.000419"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.730227" elapsed="0.000469"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:30.730735" elapsed="0.000047"/>
</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-06-06T03:12:30.732886" elapsed="0.000467"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:30.733727" elapsed="0.000323"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:12:30.734391" elapsed="0.000244"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:30.732032" elapsed="0.002714"/>
</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-06-06T03:12:30.731086" elapsed="0.003797"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:30.585707" elapsed="0.149282"/>
</kw>
<msg time="2026-06-06T03:12:30.735089" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:30.735136" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:30.585014" elapsed="0.150159"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:30.735369" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:12:30.735255" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.735235" elapsed="0.000227"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:30.735924" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:30.736319" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:30.736393" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:30.584342" elapsed="0.152164"/>
</kw>
<msg time="2026-06-06T03:12:30.736603" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:30.736967" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:30.579480" elapsed="0.157530"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:30.737366" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:30.737092" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:30.737073" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:30.579332" elapsed="0.158138"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:30.579155" elapsed="0.158416"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:30.576641" elapsed="0.160991"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:12:30.570060" elapsed="0.167650"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:30.569572" elapsed="0.168183"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:12:29.884916" elapsed="0.852891"/>
</kw>
<kw name="Set Default Configuration" owner="SSHLibrary">
<arg>prompt=${TOOLS_SYSTEM_PROMPT}</arg>
<doc>Update the default `configuration`.</doc>
<status status="PASS" start="2026-06-06T03:12:30.737962" elapsed="0.000204"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:12:30.738327" elapsed="0.000196"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:12:30.740380" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:12:30.740462" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:30.740050" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:30.740763" elapsed="0.000606"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:12:30.742260" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:12:31.052562" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:12:02 UTC 2026

  System load:  0.0                Processes:             105
  Usage of /:   19.5% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:12:03 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:12:30.741934" elapsed="0.310793"/>
</kw>
<msg time="2026-06-06T03:12:31.052812" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:30.741548" elapsed="0.311342"/>
</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-06-06T03:12:30.739573" elapsed="0.313431"/>
</kw>
<msg time="2026-06-06T03:12:31.053058" 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-06-06T03:12:30.739115" elapsed="0.313990"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:12:30.738750" elapsed="0.314435"/>
</kw>
<kw name="Require_Python" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.054630" level="INFO">Executing command 'python3 --help'.</msg>
<msg time="2026-06-06T03:12:31.066858" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:31.067221" level="INFO">${stdout} = usage: python3 [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_ins...</msg>
<msg time="2026-06-06T03:12:31.067333" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:12:31.067427" 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-06-06T03:12:31.054411" elapsed="0.013068"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.069568" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:12:31.068960" elapsed="0.000742"/>
</kw>
<msg time="2026-06-06T03:12:31.069918" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:12:31.070015" 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-06-06T03:12:31.068070" elapsed="0.001995"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.071510" 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-06-06T03:12:31.070446" elapsed="0.001202"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.072471" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.071882" elapsed="0.000688"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.071829" elapsed="0.000781"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:12:31.072979" elapsed="0.000054"/>
</return>
<status status="PASS" start="2026-06-06T03:12:31.072821" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.072794" elapsed="0.000330"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.073295" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.073224" elapsed="0.000151"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:31.073192" elapsed="0.000219"/>
</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-06-06T03:12:31.073647" elapsed="0.000055"/>
</kw>
<msg time="2026-06-06T03:12:31.073928" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>python3 --help</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-06-06T03:12:31.054032" elapsed="0.019938"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:12:31.074218" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:12:31.074076" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.074049" elapsed="0.000289"/>
</if>
<kw name="Fatal Error" owner="BuiltIn">
<arg>Python 3 is not installed!</arg>
<doc>Stops the whole test execution.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.074559" elapsed="0.000031"/>
</kw>
<doc>Verify current SSH connection leads to machine with python working. Fatal fail otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:31.053550" elapsed="0.021154"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.077041" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:12:31.208351" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:12:31.208685" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:12:31.208763" level="INFO">${stderr} = Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'</msg>
<msg time="2026-06-06T03:12:31.208836" level="INFO">${rc} = 1</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-06-06T03:12:31.076396" elapsed="0.132497"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.210451" level="INFO">Length is 119.</msg>
<msg time="2026-06-06T03:12:31.210599" level="FAIL">'Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:12:31.209991" elapsed="0.000741">'Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'' should be empty.</status>
</kw>
<msg time="2026-06-06T03:12:31.210883" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:12:31.210947" level="INFO">${result} = 'Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'' should be empty.</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-06-06T03:12:31.209290" elapsed="0.001692"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.211871" level="INFO">${success} = False</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-06-06T03:12:31.211234" elapsed="0.000672"/>
</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-06-06T03:12:31.213396" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.213079" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.213991" level="INFO">Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.213680" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.214570" level="INFO">1</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.214256" elapsed="0.000369"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:12:31.212515" elapsed="0.002202"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.212025" elapsed="0.002738"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.211991" elapsed="0.002805"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:12:31.215005" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:12:31.214870" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.214847" elapsed="0.000274"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.215237" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.215192" elapsed="0.000096"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:31.215172" elapsed="0.000143"/>
</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-06-06T03:12:31.215506" elapsed="0.000029"/>
</kw>
<msg time="2026-06-06T03:12:31.215734" level="INFO">${passed} = False</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:12:31.075827" elapsed="0.139943"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="NOT RUN" start="2026-06-06T03:12:31.216001" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.215870" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.215844" elapsed="0.000244"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.254391" level="INFO">[chan 3] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:12:31.267159" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py' -&gt; '/home/jenkins/.//ipaddr.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:12:31.216392" elapsed="0.050918"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:12:31.075092" elapsed="0.192348"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.279425" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:12:31.267781" elapsed="0.011776"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:31.280398" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e7688710&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:12:31.279905" elapsed="0.000761"/>
</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-06-06T03:12:31.284355" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.284166" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.284131" elapsed="0.000336"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:31.285068" 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-06-06T03:12:31.284720" elapsed="0.000388"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.285693" level="INFO">${current_connection_index} = 7</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-06-06T03:12:31.285354" elapsed="0.000379"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.302188" level="INFO">log:set INFO</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:31.286540" elapsed="0.015859"/>
</kw>
<msg time="2026-06-06T03:12:31.302672" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:31.302756" level="INFO">${message_write} = log:set INFO
</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-06-06T03:12:31.285985" elapsed="0.016809"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.324633" 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-06-06T03:12:31.303918" elapsed="0.020887"/>
</kw>
<msg time="2026-06-06T03:12:31.324988" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:31.325038" 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-06-06T03:12:31.303208" elapsed="0.021858"/>
</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-06-06T03:12:31.325533" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.325189" elapsed="0.000407"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.325152" elapsed="0.000473"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.326206" 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-06-06T03:12:31.325802" elapsed="0.000456"/>
</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-06-06T03:12:31.326562" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.326330" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.326309" elapsed="0.000355"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:31.326713" elapsed="0.000051"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:31.328771" elapsed="0.000442"/>
</kw>
<msg time="2026-06-06T03:12:31.329263" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.328069" elapsed="0.001262"/>
</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="NOT RUN" start="2026-06-06T03:12:31.329501" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.329698" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:31.327706" elapsed="0.002082"/>
</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-06-06T03:12:31.327097" elapsed="0.002739"/>
</kw>
<arg>log:set ${ODL_LOG_LEVEL}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:31.281259" elapsed="0.048792"/>
</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-06-06T03:12:31.332393" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.332270" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.332246" elapsed="0.000224"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:31.332890" 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-06-06T03:12:31.332623" elapsed="0.000293"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.333260" level="INFO">${current_connection_index} = 7</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-06-06T03:12:31.333086" elapsed="0.000199"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.385256" level="INFO">log:set DEFAULT org.opendaylight.bgpcep</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:31.333846" elapsed="0.051563"/>
</kw>
<msg time="2026-06-06T03:12:31.385593" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:31.385645" level="INFO">${message_write} = log:set DEFAULT org.opendaylight.bgpcep
</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-06-06T03:12:31.333454" elapsed="0.052240"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.388077" 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-06-06T03:12:31.386439" elapsed="0.001706"/>
</kw>
<msg time="2026-06-06T03:12:31.388250" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:31.388295" 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-06-06T03:12:31.385967" elapsed="0.002357"/>
</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-06-06T03:12:31.388762" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.388424" elapsed="0.000398"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.388392" elapsed="0.000460"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.389532" 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-06-06T03:12:31.389068" elapsed="0.000540"/>
</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-06-06T03:12:31.389995" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.389734" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.389709" elapsed="0.000366"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:31.390114" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:31.392077" elapsed="0.000159"/>
</kw>
<msg time="2026-06-06T03:12:31.392285" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.391466" elapsed="0.000887"/>
</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="NOT RUN" start="2026-06-06T03:12:31.392521" elapsed="0.000021"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.392709" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:31.391109" elapsed="0.001687"/>
</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-06-06T03:12:31.390453" elapsed="0.002393"/>
</kw>
<arg>log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.bgpcep</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:31.330419" elapsed="0.062527"/>
</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-06-06T03:12:31.395358" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.395230" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.395203" elapsed="0.000233"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:31.395857" 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-06-06T03:12:31.395593" elapsed="0.000292"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.396223" level="INFO">${current_connection_index} = 7</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-06-06T03:12:31.396049" elapsed="0.000199"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.451316" level="INFO">log:set DEFAULT org.opendaylight.protocol</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:31.396950" elapsed="0.054516"/>
</kw>
<msg time="2026-06-06T03:12:31.451683" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:31.451733" level="INFO">${message_write} = log:set DEFAULT org.opendaylight.protocol
</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-06-06T03:12:31.396532" elapsed="0.055227"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.454152" 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-06-06T03:12:31.452508" elapsed="0.001703"/>
</kw>
<msg time="2026-06-06T03:12:31.454310" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:31.454354" 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-06-06T03:12:31.452037" elapsed="0.002344"/>
</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-06-06T03:12:31.454758" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.454479" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.454449" elapsed="0.000394"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.455351" 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-06-06T03:12:31.454993" elapsed="0.000409"/>
</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-06-06T03:12:31.455717" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.455474" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.455453" elapsed="0.000347"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:31.455839" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:31.458048" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:12:31.458244" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.457402" elapsed="0.000907"/>
</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="NOT RUN" start="2026-06-06T03:12:31.458474" elapsed="0.000021"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.458643" elapsed="0.000036"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:31.456745" elapsed="0.001999"/>
</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-06-06T03:12:31.456173" elapsed="0.002621"/>
</kw>
<arg>log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.protocol</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:31.393327" elapsed="0.065564"/>
</kw>
<doc>Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
put Python tool to mininet machine, setup imported resources.</doc>
<status status="PASS" start="2026-06-06T03:12:29.884554" elapsed="1.574393"/>
</kw>
<test id="s1-s4-t1" name="Check_For_Empty_Topology_Before_Talking" line="76">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.462531" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.462305" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.462286" elapsed="0.000328"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:31.462118" elapsed="0.000565"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.463761" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.463629" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.463610" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.468886" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.468776" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.468757" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.470041" 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-06-06T03:12:31.469598" elapsed="0.000478"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.470556" 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-06-06T03:12:31.470248" elapsed="0.000442"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:31.470756" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:31.470929" 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-06-06T03:12:31.469196" elapsed="0.001758"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:31.477061" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.476924" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.476897" elapsed="0.000247"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:31.478512" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.478394" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.478374" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:31.479104" 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-06-06T03:12:31.478777" elapsed="0.000356"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.479631" level="INFO">${current_connection_index} = 7</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-06-06T03:12:31.479333" elapsed="0.000346"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.551581" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:31.480204" elapsed="0.071750"/>
</kw>
<msg time="2026-06-06T03:12:31.552439" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:31.552546" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:31.479852" elapsed="0.072777"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.612377" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o "r "e "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:12:31.554073" elapsed="0.058604"/>
</kw>
<msg time="2026-06-06T03:12:31.612919" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:31.612969" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o ...</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-06-06T03:12:31.553154" elapsed="0.059856"/>
</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-06-06T03:12:31.613492" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.613136" elapsed="0.000419"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.613094" elapsed="0.000487"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.614167" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o "r "e "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:12:31.613776" elapsed="0.000464"/>
</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-06-06T03:12:31.614541" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.614310" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.614291" elapsed="0.000332"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:31.614686" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:31.617528" elapsed="0.000200"/>
</kw>
<msg time="2026-06-06T03:12:31.617797" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.616310" elapsed="0.001630"/>
</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="NOT RUN" start="2026-06-06T03:12:31.618237" elapsed="0.000085"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.618593" elapsed="0.000103"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:31.615615" elapsed="0.003201"/>
</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-06-06T03:12:31.615017" elapsed="0.003868"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:31.478036" elapsed="0.141020"/>
</kw>
<msg time="2026-06-06T03:12:31.619161" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:31.619208" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:31.477326" elapsed="0.141921"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:31.619455" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:12:31.619335" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.619312" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.620024" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.620380" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.620454" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:31.476470" elapsed="0.144100"/>
</kw>
<msg time="2026-06-06T03:12:31.620763" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:31.620812" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:31.471425" elapsed="0.149426"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.621201" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.620935" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.620915" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:31.471202" elapsed="0.150104"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:31.471016" elapsed="0.150324"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:31.468387" elapsed="0.153011"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:31.463328" elapsed="0.158130"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:31.462837" elapsed="0.158668"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:31.459714" elapsed="0.161849"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.675302" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:31.674851" elapsed="0.000485"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:31.676381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:31.675907" elapsed="0.000552">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:31.676558" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:31.675526" elapsed="0.001057"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.677222" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:31.676801" elapsed="0.000454"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:31.677629" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:31.677846" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:31.677460" elapsed="0.000473"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.678552" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.678176" elapsed="0.000444"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.680540" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.679874" elapsed="0.000758"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.681632" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:31.680942" elapsed="0.000772"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.682217" elapsed="0.000051"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.683000" elapsed="0.000052"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.683346" elapsed="0.000046"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:12:31.682020" elapsed="0.001496"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.681800" elapsed="0.001786"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:31.683645" elapsed="0.000056"/>
</return>
<msg time="2026-06-06T03:12:31.683861" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:31.679283" elapsed="0.004611"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.678764" elapsed="0.005172"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.684177" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.683974" elapsed="0.000266"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.678727" elapsed="0.005535"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.684998" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:31.684425" elapsed="0.000601"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:31.685079" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:31.674021" elapsed="0.011187"/>
</kw>
<msg time="2026-06-06T03:12:31.685323" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.660788" elapsed="0.024607"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.698796" elapsed="0.000064"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.711380" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.723969" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.724239" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.724526" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.724971" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.724815" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:31.724796" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.725200" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.725372" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.725542" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:31.724753" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.724616" elapsed="0.001012"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.725850" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.725939" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:12:31.726095" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:31.656280" elapsed="0.069846"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:31.727608" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:31.727287" elapsed="0.000438">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:31.727827" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:31.726876" elapsed="0.000977"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.728205" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.727928" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.728802" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:31.728474" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.728290" elapsed="0.000575"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.727908" elapsed="0.000979"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.731471" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:31.729049" elapsed="0.002449"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:31.731552" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:12:31.731730" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:31.726472" elapsed="0.005284"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:31.733015" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:31.732766" elapsed="0.000464">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:31.733342" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:31.732403" elapsed="0.000969"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:12:31.733588" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:31.733447" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.733427" elapsed="0.000269"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.733925" elapsed="0.000026"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.734110" elapsed="0.000057"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.734217" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:31.737724" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:31.732070" elapsed="0.005703"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.739714" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.739331" elapsed="0.000449"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.740347" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.740001" elapsed="0.000407"/>
</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-06-06T03:12:31.754714" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:31.755074" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Set-Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:12:31 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:12:31.755232" 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-06-06T03:12:31.743313" elapsed="0.011956"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.740501" elapsed="0.014831"/>
</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-06-06T03:12:31.755593" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.755369" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.740475" elapsed="0.015267"/>
</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-06-06T03:12:31.760554" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.757190" elapsed="0.003430"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.756874" elapsed="0.003819"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.756847" elapsed="0.003883"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.764349" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.761133" elapsed="0.003281"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.760811" elapsed="0.003651"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.760786" elapsed="0.003712"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.765302" 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-06-06T03:12:31.764757" elapsed="0.000583"/>
</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-06-06T03:12:31.765859" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.765439" elapsed="0.000508"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.766679" 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-06-06T03:12:31.766231" elapsed="0.000486"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.765982" elapsed="0.000785"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.765413" elapsed="0.001384"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.767539" 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-06-06T03:12:31.767023" elapsed="0.000553"/>
</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-06-06T03:12:31.768037" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.767699" elapsed="0.000420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.768823" 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-06-06T03:12:31.768384" elapsed="0.000475"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.768154" elapsed="0.000755"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.767671" elapsed="0.001268"/>
</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-06-06T03:12:31.769159" elapsed="0.000507"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:31.770462" 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-06-06T03:12:31.769966" elapsed="0.000533"/>
</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-06-06T03:12:31.770748" elapsed="0.002479"/>
</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-06-06T03:12:31.756252" elapsed="0.017042"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.773476" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.773365" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.773346" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:31.776398" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:12:31.773715" elapsed="0.002712"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:12:31.776481" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:12:31.776647" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:12:31.738166" elapsed="0.038522"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:31.776752" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:31.776905" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:31.633702" elapsed="0.143229"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.806025" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:31.805209" elapsed="0.000848"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:31.808213" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:31.807612" elapsed="0.000764">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:31.808510" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:31.806238" elapsed="0.002298"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.809516" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:31.808740" elapsed="0.000807"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:31.809987" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:31.810261" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:31.809739" elapsed="0.000550"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.810965" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:31.810504" elapsed="0.000525"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:31.811789" elapsed="0.000082"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.811111" elapsed="0.000844"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.812811" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:31.812165" elapsed="0.000744"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.811985" elapsed="0.001017"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.811087" elapsed="0.001940"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.814104" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:31.813185" elapsed="0.000950"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:31.814189" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:31.804336" elapsed="0.009988"/>
</kw>
<msg time="2026-06-06T03:12:31.814381" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.791486" elapsed="0.022945"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.827524" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.839943" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.852314" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.852539" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.852754" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.853181" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.853023" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:31.853005" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.853415" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.853590" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.853784" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:31.852968" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.852843" elapsed="0.001026"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.854031" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.854111" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:12:31.854253" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:31.788825" elapsed="0.065519"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.854535" elapsed="0.002322"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:31.858054" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:31.857645" elapsed="0.000440"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:31.858557" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:31.858247" elapsed="0.000339"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:12:31.858782" elapsed="0.000381"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:12:31.857196" elapsed="0.002031"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.856942" elapsed="0.002320"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.859446" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.859288" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.856922" elapsed="0.002601"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:12:31.778081" elapsed="0.081491"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:12:31.777259" elapsed="0.082411"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:31.777014" elapsed="0.082706"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.776996" elapsed="0.082748"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:31.859781" elapsed="0.000033"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:12:31.627267" elapsed="0.232650"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:12:31.622811" elapsed="0.237171"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:12:31.622167" elapsed="0.237861"/>
</kw>
<arg>empty_topology</arg>
<arg>timeout=180s</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:12:31.621753" elapsed="0.238334"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:31.860702" elapsed="0.000251"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:31.860370" elapsed="0.000648"/>
</kw>
<doc>Sanity check example-ipv4-topology is up but empty.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:31.459023" elapsed="0.402034"/>
</test>
<test id="s1-s4-t2" name="TC_LA_Reconfigure_Odl_To_Initiate_Connection" line="81">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.864668" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.864420" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.864401" elapsed="0.000369"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:31.864230" elapsed="0.000587"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.865849" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.865740" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.865720" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.871124" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.870929" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.870910" elapsed="0.000287"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.872229" 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-06-06T03:12:31.871842" elapsed="0.000414"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.872739" 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-06-06T03:12:31.872420" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:31.872810" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:31.872965" 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-06-06T03:12:31.871435" elapsed="0.001559"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:31.878398" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.878289" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.878269" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:31.879696" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:31.879560" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.879541" elapsed="0.000226"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:31.880222" 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-06-06T03:12:31.879916" elapsed="0.000332"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.880628" level="INFO">${current_connection_index} = 7</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-06-06T03:12:31.880411" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.925992" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:31.881180" elapsed="0.045041"/>
</kw>
<msg time="2026-06-06T03:12:31.926452" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:31.926501" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:31.880837" elapsed="0.045703"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:31.957213" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:12:31.927267" elapsed="0.030178"/>
</kw>
<msg time="2026-06-06T03:12:31.957698" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:31.957748" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "I "n "i "t ...</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-06-06T03:12:31.926830" elapsed="0.030958"/>
</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-06-06T03:12:31.958249" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.957907" elapsed="0.000402"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.957870" elapsed="0.000466"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.958892" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:12:31.958488" elapsed="0.000484"/>
</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-06-06T03:12:31.959281" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.959044" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.959025" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:31.959398" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:31.962298" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:12:31.962521" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.961135" elapsed="0.001552"/>
</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="NOT RUN" start="2026-06-06T03:12:31.963269" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.963615" elapsed="0.000092"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:31.960449" elapsed="0.003372"/>
</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-06-06T03:12:31.959744" elapsed="0.004169"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:31.879255" elapsed="0.084776"/>
</kw>
<msg time="2026-06-06T03:12:31.964146" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:31.964200" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "I "n "i "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:31.878622" elapsed="0.085617"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:31.964448" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:12:31.964324" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.964301" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.965006" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.965365" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:31.965437" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:31.877952" elapsed="0.087594"/>
</kw>
<msg time="2026-06-06T03:12:31.965676" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:31.965727" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "I "n "i "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:31.873363" elapsed="0.092402"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:31.966100" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:31.965841" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:31.965824" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:31.873218" elapsed="0.092985"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:31.873048" elapsed="0.093187"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:31.870546" elapsed="0.095745"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:31.865418" elapsed="0.100930"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:31.864975" elapsed="0.101420"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:31.862009" elapsed="0.104441"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:31.967434" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=false | BGP_RIB_OPENCONFIG=example-bgp-rib | LOCAL=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=false</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<arg>LOCAL=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:31.966757" elapsed="0.000706"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.001708" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.001268" elapsed="0.000475"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:32.002622" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:32.002329" elapsed="0.000402">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:32.002948" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:32.001925" elapsed="0.001051"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.003622" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:32.003177" elapsed="0.000491"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:32.004007" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:32.004225" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:32.003843" elapsed="0.000418"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.004796" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.004463" elapsed="0.000384"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.006049" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'LOCAL': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.005745" elapsed="0.000351"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.006825" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.006274" elapsed="0.000579"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.007551" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:32.007246" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:32.008431" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.008115" elapsed="0.000348"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:32.008526" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:12:32.008729" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:32.007788" elapsed="0.000966"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.008916" elapsed="0.000258"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:32.007103" elapsed="0.002113"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.009811" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:32.009474" elapsed="0.000363"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:32.010581" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.010356" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:32.010672" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:32.010832" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:32.010036" elapsed="0.000821"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.011010" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:32.009329" elapsed="0.001944"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.011833" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:32.011516" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:32.012674" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.012421" elapsed="0.000281"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:32.012752" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:32.012903" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:32.012053" elapsed="0.000875"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.013083" elapsed="0.000224"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:32.011383" elapsed="0.001964"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.013916" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:32.013591" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:32.014780" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.014546" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:32.014858" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:32.015019" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:32.014202" elapsed="0.000842"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.015198" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:32.013457" elapsed="0.002004"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.016027" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:32.015724" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:32.016886" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.016669" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:32.016964" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:32.017116" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:32.016241" elapsed="0.000900"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.017296" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:32.015573" elapsed="0.001987"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.018378" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:32.017830" elapsed="0.000575"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:32.019167" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.018933" elapsed="0.000263"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:32.019246" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:32.019399" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:32.018596" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:32.019578" elapsed="0.000245"/>
</kw>
<var name="${key}">LOCAL</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:12:32.017693" elapsed="0.002172"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:32.006909" elapsed="0.012992"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:32.019944" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:32.020107" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'LOCAL': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:32.005351" elapsed="0.014782"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.004936" elapsed="0.015230"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.020386" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.020194" elapsed="0.000261"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.004909" elapsed="0.015572"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.021357" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:32.020669" elapsed="0.000717"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:32.021436" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:32.000604" elapsed="0.020957"/>
</kw>
<msg time="2026-06-06T03:12:32.021617" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:31.987749" elapsed="0.033935"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.034172" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.046899" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.059554" elapsed="0.000043"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.059855" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.060059" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.060505" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.060347" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:32.060327" elapsed="0.000298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.060844" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.061042" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.061214" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:32.060284" elapsed="0.000983"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.060149" elapsed="0.001146"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.061583" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.061691" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:12:32.061864" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:31.983365" elapsed="0.078529"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.088916" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.088445" elapsed="0.000511"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:32.089815" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:32.089532" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:32.089992" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:32.089174" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.090681" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:32.090188" elapsed="0.000522"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:32.091025" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:32.091196" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:32.090880" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.091634" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
            &lt;local-address&gt;$LOCAL&lt;/local-address&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.091387" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:32.092159" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.091805" elapsed="0.000413"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.093034" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'LOCAL': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.092397" elapsed="0.000670"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.092247" elapsed="0.000865"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.091778" elapsed="0.001361"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.094114" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:32.093320" elapsed="0.000825"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:32.094199" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:32.087757" elapsed="0.006581"/>
</kw>
<msg time="2026-06-06T03:12:32.094399" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:32.074856" elapsed="0.019590"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.107236" elapsed="0.000063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.119925" elapsed="0.000059"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.132508" elapsed="0.000152"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.132905" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.133101" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.133615" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.133449" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:32.133426" elapsed="0.000293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.133870" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.134043" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.134213" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:32.133374" elapsed="0.000892"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.133190" elapsed="0.001103"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.134444" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.134525" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:12:32.134721" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:32.072066" elapsed="0.062687"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:32.136226" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:32.135923" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:32.136395" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:32.135497" elapsed="0.000923"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.136780" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.136493" elapsed="0.000345"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.137401" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.137045" elapsed="0.000389"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.136863" elapsed="0.000612"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.136473" elapsed="0.001027"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.139896" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:32.137692" elapsed="0.002230"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:32.139977" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:32.140152" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:32.135134" elapsed="0.005047"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.141846" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.141515" elapsed="0.000387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.142487" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;false&lt;/passive-mode&gt;
            &lt;local-address&gt;10.30.170.38&lt;/local-address&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.142181" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.143132" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.142800" elapsed="0.000391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.143742" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.143395" elapsed="0.000407"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:32.145089" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:32.144825" elapsed="0.000299"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:32.145632" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:32.145394" elapsed="0.000289"/>
</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-06-06T03:12:32.145899" elapsed="0.000431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.147232" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.146553" elapsed="0.000739"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:32.147353" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:12:32.147571" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:32.144243" elapsed="0.003361"/>
</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-06-06T03:12:32.171183" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '1136', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;false&lt;/passive-mode&gt;
            &lt;local-address&gt;10.30.170.38&lt;/local-address&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:12:32.171305" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:32.171457" 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-06-06T03:12:32.150793" elapsed="0.020693"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.147728" elapsed="0.023825"/>
</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-06-06T03:12:32.171854" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.171593" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.147701" elapsed="0.024265"/>
</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-06-06T03:12:32.176737" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.173263" elapsed="0.003545"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.172973" elapsed="0.003891"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.172949" elapsed="0.003955"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.181845" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.177372" elapsed="0.004572"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.176997" elapsed="0.005002"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.176966" elapsed="0.005069"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.182883" 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-06-06T03:12:32.182310" elapsed="0.000610"/>
</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-06-06T03:12:32.183354" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.183018" elapsed="0.000414"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.184107" 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-06-06T03:12:32.183715" elapsed="0.000427"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.183467" elapsed="0.000722"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.182992" elapsed="0.001226"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.184934" 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-06-06T03:12:32.184438" elapsed="0.000530"/>
</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-06-06T03:12:32.185375" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.185062" elapsed="0.000386"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.186129" 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-06-06T03:12:32.185743" elapsed="0.000419"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.185479" elapsed="0.000728"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.185037" elapsed="0.001196"/>
</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-06-06T03:12:32.186452" elapsed="0.000450"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:32.187431" 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-06-06T03:12:32.187120" elapsed="0.000338"/>
</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-06-06T03:12:32.187621" elapsed="0.002528"/>
</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-06-06T03:12:32.172448" elapsed="0.017781"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:32.190444" elapsed="0.000040"/>
</return>
<status status="PASS" start="2026-06-06T03:12:32.190323" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.190300" elapsed="0.000249"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:32.190733" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.190805" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:32.193180" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:12:32.140524" elapsed="0.052684"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:32.193276" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:32.193435" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:31.972426" elapsed="0.221035"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.193878" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.193564" elapsed="0.000386"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.193545" elapsed="0.000429"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:32.194091" elapsed="0.000034"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_local_address</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:31.967758" elapsed="0.226480"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.195572" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.195177" elapsed="0.000458"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.195159" elapsed="0.000535"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:32.195851" elapsed="0.000366"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.201606" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:32.201091" elapsed="0.000546"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:12:32.201913" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:12:32.201739" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.201718" elapsed="0.000282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.202167" elapsed="0.000024"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.202352" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.202532" elapsed="0.000022"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.202725" elapsed="0.000022"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.202901" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.203075" elapsed="0.000025"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.203255" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:12:32.200759" elapsed="0.002576"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:32.194954" elapsed="0.008434"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:12:32.194532" elapsed="0.008901"/>
</kw>
<doc>Configure ibgp peer with local-address.</doc>
<status status="PASS" start="2026-06-06T03:12:31.861430" elapsed="0.342048"/>
</test>
<test id="s1-s4-t3" name="TC_LA_Start_Bgp_Speaker_And_Verify_Connected" line="96">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.207382" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.207137" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.207117" elapsed="0.000352"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:32.206948" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.208601" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:32.208491" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.208472" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.213941" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:32.213771" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.213749" elapsed="0.000287"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.215213" 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-06-06T03:12:32.214757" elapsed="0.000484"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.215739" 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-06-06T03:12:32.215412" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:32.215893" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:12:32.216063" 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-06-06T03:12:32.214331" elapsed="0.001756"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:32.222103" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:32.221906" elapsed="0.000261"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.221885" elapsed="0.000310"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:32.223602" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:32.223492" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.223473" elapsed="0.000244"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:32.224193" 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-06-06T03:12:32.223872" elapsed="0.000350"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:32.224616" level="INFO">${current_connection_index} = 7</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-06-06T03:12:32.224393" elapsed="0.000254"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:32.287783" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:32.225181" elapsed="0.062943"/>
</kw>
<msg time="2026-06-06T03:12:32.288548" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:32.288715" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:32.224829" elapsed="0.063972"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:32.313864" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "S "t "a "r "t "_ "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V "e "r "i "f "y "_ "C "o "n "n "e "c "t "e "d "[K"
[?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-06-06T03:12:32.290176" elapsed="0.023806"/>
</kw>
<msg time="2026-06-06T03:12:32.314154" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:32.314202" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "S "t "a "r "t "_ "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V ...</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-06-06T03:12:32.289269" elapsed="0.024968"/>
</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-06-06T03:12:32.314604" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.314336" elapsed="0.000355"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.314308" elapsed="0.000410"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.315202" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "S "t "a "r "t "_ "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V "e "r "i "f "y "_ "C "o "n "n "e "c "t "e "d "[K"
[?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-06-06T03:12:32.314884" elapsed="0.000390"/>
</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-06-06T03:12:32.315568" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.315343" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.315324" elapsed="0.000340"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:32.315706" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:32.318427" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:12:32.318647" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:32.317281" elapsed="0.001612"/>
</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="NOT RUN" start="2026-06-06T03:12:32.319193" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.319544" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:32.316610" elapsed="0.003152"/>
</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-06-06T03:12:32.316033" elapsed="0.003803"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:32.223179" elapsed="0.096817"/>
</kw>
<msg time="2026-06-06T03:12:32.320094" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:32.320140" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "S "t "a "r "t "_ "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:32.222431" elapsed="0.097744"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:32.320366" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:32.320255" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.320235" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.320887" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.321233" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.321306" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:32.221507" elapsed="0.099911"/>
</kw>
<msg time="2026-06-06T03:12:32.321517" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:32.321568" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "S "t "a "r "t "_ "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:32.216528" elapsed="0.105076"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:32.321990" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:32.321701" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:32.321683" elapsed="0.000392"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:32.216372" elapsed="0.105729"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:32.216151" elapsed="0.105984"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:32.213307" elapsed="0.108885"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:32.208186" elapsed="0.114065"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:32.207692" elapsed="0.114606"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:32.204599" elapsed="0.117753"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.322982" level="INFO">${speaker_args} = --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --debug</msg>
<var>${speaker_args}</var>
<arg>--amount 3 --listen --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --debug</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.322527" elapsed="0.000482"/>
</kw>
<kw name="Start_BGP_Speaker_And_Verify_Connected" owner="BGPSpeaker">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.324723" level="INFO">${command} = python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --debug &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.324145" elapsed="0.000608"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.325168" level="INFO">python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --debug &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:32.324917" elapsed="0.000298"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:32.328376" level="INFO">python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --debug &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:12:32.328468" level="INFO">${output} =  python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --debug &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:32.325372" elapsed="0.003123"/>
</kw>
<arg>${arguments}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:12:32.323825" elapsed="0.004732"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.330027" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:32.329724" elapsed="0.000330"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:32.330600" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:32.330218" elapsed="0.000462"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:32.338119" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:32.338316" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:32.338457" level="FAIL">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:12:32.330870" elapsed="0.008336">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</status>
</kw>
<return>
<value>${response.content}</value>
<status status="NOT RUN" start="2026-06-06T03:12:32.339311" elapsed="0.000027"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:12:32.329274" elapsed="0.010197">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:34.342385" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:34.341547" elapsed="0.000906"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:34.343780" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:34.342879" elapsed="0.000963"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:34.352704" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:34.352886" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:34.353027" level="FAIL">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:12:34.344209" elapsed="0.009402">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</status>
</kw>
<return>
<value>${response.content}</value>
<status status="NOT RUN" start="2026-06-06T03:12:34.353739" elapsed="0.000031"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:12:34.340336" elapsed="0.013609">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:36.357441" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:36.356523" elapsed="0.001017"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:36.358688" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:36.357987" elapsed="0.000742"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:36.366099" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:36.366280" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:12:36.366425" level="FAIL">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:12:36.358966" elapsed="0.008077">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</status>
</kw>
<return>
<value>${response.content}</value>
<status status="NOT RUN" start="2026-06-06T03:12:36.367256" elapsed="0.000033"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:12:36.355241" elapsed="0.012183">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.370844" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:38.369906" elapsed="0.001008"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.375965" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:38.371302" elapsed="0.004729"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:38.387840" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:38.390835" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1991'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.0.1.32/28","prefix":"8.0.1.32/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.16/28","prefix":"8.0.1.16/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.0/28","prefix":"8.0.1.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.0.1.32/28","prefix":"8.0.1.32/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.16/28","prefix":"8.0.1.16/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.0/28","prefix":"8.0.1.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:12:38.391139" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:38.376405" elapsed="0.014794"/>
</kw>
<return>
<value>${response.content}</value>
<status status="PASS" start="2026-06-06T03:12:38.391335" elapsed="0.000084"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:12:38.368580" elapsed="0.028177"/>
</kw>
<msg time="2026-06-06T03:12:38.396978" level="INFO">${message} = {"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi"...</msg>
<var>${message}</var>
<arg>5x</arg>
<arg>2s</arg>
<arg>Verify_BGP_Speaker_Connection</arg>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:12:32.328748" elapsed="6.068289"/>
</kw>
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:38.397172" elapsed="0.000083"/>
</return>
<msg time="2026-06-06T03:12:38.397542" level="INFO">${output} = {"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi"...</msg>
<var>${output}</var>
<arg>${speaker_args}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>speaker_ip=${TOOLS_SYSTEM_IP}</arg>
<doc>Start the BGP speaker python utility, and verifies it's connection.
We can change connected variable to false to verify Speaker did not connect.</doc>
<status status="PASS" start="2026-06-06T03:12:32.323239" elapsed="6.074361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.398860" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.0.1.32/28","prefix":"8.0.1.32/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.16/28","prefix":"8.0.1.16/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.0/28","prefix":"8.0.1.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.0.1.32/28","prefix":"8.0.1.32/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.16/28","prefix":"8.0.1.16/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.0.1.0/28","prefix":"8.0.1.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"peer-role":"ibgp"}]}</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.398049" elapsed="0.001125"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:38.399936" elapsed="0.000256"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:38.399553" elapsed="0.000703"/>
</kw>
<doc>Verify that peer is present in odl's rib under local-address ip.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:32.203953" elapsed="6.196342"/>
</test>
<test id="s1-s4-t4" name="TC_LA_Kill_Bgp_Speaker" line="107">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:12:38.403746" elapsed="0.000222"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:12:38.403461" elapsed="0.000563"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.405104" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.404965" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.404941" elapsed="0.000235"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.410236" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.410119" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.410099" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.411416" 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-06-06T03:12:38.411003" elapsed="0.000441"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.411934" 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-06-06T03:12:38.411610" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:38.412006" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:38.412168" 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-06-06T03:12:38.410555" elapsed="0.001638"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:38.417954" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.417835" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.417814" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:38.419369" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.419255" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.419235" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:38.419944" 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-06-06T03:12:38.419591" elapsed="0.000381"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.420399" level="INFO">${current_connection_index} = 7</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-06-06T03:12:38.420165" elapsed="0.000261"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.456709" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:38.420974" elapsed="0.035963"/>
</kw>
<msg time="2026-06-06T03:12:38.457194" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:38.457253" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:38.420596" elapsed="0.036700"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.474415" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "K "i "l "l "_ "B "g "p "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:12:38.458029" elapsed="0.016601"/>
</kw>
<msg time="2026-06-06T03:12:38.474884" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:38.474953" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "K "i "l "l "_ "B "g "p "_ "S "p "e "a "k "e "r "[K"
[?1l&gt;[?2004l[?1h=[9...</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-06-06T03:12:38.457554" elapsed="0.017444"/>
</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-06-06T03:12:38.475476" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.475125" elapsed="0.000491"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.475086" elapsed="0.000585"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.476220" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "K "i "l "l "_ "B "g "p "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:12:38.475830" elapsed="0.000454"/>
</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-06-06T03:12:38.476582" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.476354" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.476334" elapsed="0.000351"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:38.476726" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:38.479641" elapsed="0.000173"/>
</kw>
<msg time="2026-06-06T03:12:38.479881" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:38.478338" elapsed="0.001685"/>
</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="NOT RUN" start="2026-06-06T03:12:38.480308" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.480675" elapsed="0.000086"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:38.477678" elapsed="0.003394"/>
</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-06-06T03:12:38.477066" elapsed="0.004076"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:38.418928" elapsed="0.062318"/>
</kw>
<msg time="2026-06-06T03:12:38.481350" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.481394" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "K "i "l "l "_ "B "g "p "_ "S "p "e "a "k "e "r "[K"
[?1l&gt;[?2004l[?1h=[9...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.418201" elapsed="0.063234"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:38.481631" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:12:38.481518" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.481497" elapsed="0.000244"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.482186" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.482545" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.482619" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:38.417454" elapsed="0.065297"/>
</kw>
<msg time="2026-06-06T03:12:38.482849" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.482893" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "K "i "l "l "_ "B "g "p "_ "S "p "e "a "k "e "r "[K"
[?1l&gt;[?2004l[?1h=[9...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:38.412591" elapsed="0.070341"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.483299" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.483039" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.483019" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:38.412442" elapsed="0.070961"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:38.412257" elapsed="0.071180"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:38.409711" elapsed="0.073785"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:38.404637" elapsed="0.078917"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.404182" elapsed="0.079420"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:12:38.401269" elapsed="0.082405"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.484994" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:38.484667" elapsed="0.000394"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:38.485221" elapsed="0.000232"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:12:38.484357" elapsed="0.001368"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.537404" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:38.486540" elapsed="0.050945"/>
</kw>
<msg time="2026-06-06T03:12:38.537595" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.537642" level="INFO">${message} = [?2004l^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.485917" elapsed="0.051775"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.538503" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:12:38.551304" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:38.551451" level="INFO">${output_log} = 2026-06-06 03:12:32,427 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:12:32,428 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:12:32,428 DEBUG BGP-T...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:38.538323" elapsed="0.013165"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.552141" level="INFO">2026-06-06 03:12:32,427 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:12:32,428 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:12:32,428 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:12:37,224 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:12:37,228 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:12:37,228 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:12:37,229 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:12:37,230 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:12:37,230 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:12:37,230 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:12:37,230 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:12:37,230 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:12:37,231 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:12:37,231 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:12:37,231 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:12:37,233 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:12:37,234 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.1.0')]
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:12:37,234 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.1.0')]/28 (0x1c08000100)
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08000100
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:12:37,235 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.1.16')]
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:12:37,236 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.1.16')]/28 (0x1c08000110)
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08000110
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.1.32')]
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:12:37,237 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.1.32')]/28 (0x1c08000120)
2026-06-06 03:12:37,238 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08000120
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0038988590240478516s
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:12:37,238 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:37,239 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:37,239 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:12:37,239 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:37,239 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:37,239 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:12:37,239 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:12:37,240 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:12:37,240 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:12:37,240 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:12:37,243 INFO BGP-Thread-1 (job): ... idle for 0.004s
2026-06-06 03:12:37,244 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.004s
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:12:37,244 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:12:37,245 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:12:37,245 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:12:37,245 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.551757" elapsed="0.000802"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:12:38.537957" elapsed="0.014769"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:12:38.553149" elapsed="0.000066"/>
</return>
<status status="PASS" start="2026-06-06T03:12:38.552884" elapsed="0.000399"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.552838" elapsed="0.000500"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.553712" elapsed="0.000051"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.554097" elapsed="0.000045"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:12:38.483968" elapsed="0.070299"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.556195" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:12:38.555429" elapsed="0.000861"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:12:38.554731" elapsed="0.001686"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:12:38.557722" elapsed="0.000465"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:12:38.557023" elapsed="0.001284"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:38.400694" elapsed="0.157699"/>
</test>
<test id="s1-s4-t5" name="TC_LA_Delete_Bgp_Peer_Configuration" line="116">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.563535" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.563262" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.563243" elapsed="0.000377"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:38.563072" elapsed="0.000619"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.564765" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.564635" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.564615" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.569796" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.569688" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.569668" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.570891" 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-06-06T03:12:38.570480" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.571404" 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-06-06T03:12:38.571081" elapsed="0.000350"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:38.571476" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:12:38.571635" 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-06-06T03:12:38.570099" elapsed="0.001576"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:38.577367" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.577259" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.577239" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:38.578639" elapsed="0.000042"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.578530" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.578511" elapsed="0.000226"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:38.579310" 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-06-06T03:12:38.578997" elapsed="0.000361"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.579764" level="INFO">${current_connection_index} = 7</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-06-06T03:12:38.579526" elapsed="0.000265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.614234" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:38.580301" elapsed="0.034036"/>
</kw>
<msg time="2026-06-06T03:12:38.614593" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:38.614660" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:38.579956" elapsed="0.034743"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.633870" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:12:38.615233" elapsed="0.018759"/>
</kw>
<msg time="2026-06-06T03:12:38.634165" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:38.634212" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u ...</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-06-06T03:12:38.614879" elapsed="0.019370"/>
</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-06-06T03:12:38.634578" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.634340" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.634316" elapsed="0.000368"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.635141" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:12:38.634832" elapsed="0.000375"/>
</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-06-06T03:12:38.635494" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.635274" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.635256" elapsed="0.000352"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:38.635644" elapsed="0.000046"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:38.638202" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:12:38.638407" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:38.637147" elapsed="0.001396"/>
</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="NOT RUN" start="2026-06-06T03:12:38.639022" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.639368" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:38.636495" elapsed="0.003060"/>
</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-06-06T03:12:38.635949" elapsed="0.003730"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:38.578225" elapsed="0.061558"/>
</kw>
<msg time="2026-06-06T03:12:38.639876" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.639921" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.577591" elapsed="0.062365"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:38.640143" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:38.640034" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.640015" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.640834" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.641181" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.641253" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:38.576917" elapsed="0.064447"/>
</kw>
<msg time="2026-06-06T03:12:38.641460" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.641505" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "L "A "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:38.572064" elapsed="0.069478"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.641954" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.641692" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.641672" elapsed="0.000362"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:38.571916" elapsed="0.070143"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:38.571736" elapsed="0.070355"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:38.569301" elapsed="0.072846"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:38.564336" elapsed="0.077869"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.563852" elapsed="0.078400"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:38.560550" elapsed="0.081757"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.643002" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.642506" elapsed="0.000524"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.685416" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:38.685034" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:38.686231" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:38.685975" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:38.686409" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:38.685617" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.687011" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:38.686603" elapsed="0.000453"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:38.687412" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_local_address/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:38.687587" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:38.687252" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.688095" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.687831" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.689176" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.688897" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.689700" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.689397" elapsed="0.000333"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.690435" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.690118" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.691229" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.691006" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.691307" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:38.691461" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.690675" elapsed="0.000811"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.691657" elapsed="0.000320"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:38.689971" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.692572" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.692270" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.693339" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.693125" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.693416" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:38.693567" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.692805" elapsed="0.000786"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.693764" elapsed="0.000385"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:38.692134" elapsed="0.002058"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:38.689787" elapsed="0.004441"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:38.694273" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:38.694436" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:38.688531" elapsed="0.005931"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.688219" elapsed="0.006275"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.694686" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.694518" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.688196" elapsed="0.006568"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.695498" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:38.694910" elapsed="0.000617"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:38.695575" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:38.684393" elapsed="0.011325"/>
</kw>
<msg time="2026-06-06T03:12:38.695774" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:38.671875" elapsed="0.023964"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.708167" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.720535" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_local_address/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.733142" elapsed="0.000062"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.733475" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.733895" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.734413" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.734233" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:38.734214" elapsed="0.000287"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.734678" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.734857" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.735026" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:38.734167" elapsed="0.000914"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.733991" elapsed="0.001119"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.735263" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.735345" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:12:38.735518" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:38.667545" elapsed="0.068004"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.736923" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.736563" elapsed="0.000417"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:38.750525" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:38.750680" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:38.750974" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:38.739104" elapsed="0.011953"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.737049" elapsed="0.014131"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.751762" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.751269" elapsed="0.000649"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.737030" elapsed="0.014940"/>
</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-06-06T03:12:38.759509" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.754831" elapsed="0.004742"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.754277" elapsed="0.005348"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.754233" elapsed="0.005454"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.763435" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.760139" elapsed="0.003362"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.759770" elapsed="0.003781"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.759746" elapsed="0.003839"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.764437" 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-06-06T03:12:38.763866" elapsed="0.000598"/>
</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-06-06T03:12:38.764869" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.764539" elapsed="0.000392"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.765439" 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-06-06T03:12:38.765128" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.764956" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.764520" elapsed="0.001005"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.766080" 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-06-06T03:12:38.765709" elapsed="0.000398"/>
</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-06-06T03:12:38.766456" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.766181" elapsed="0.000355"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.767215" 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-06-06T03:12:38.766819" elapsed="0.000431"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.766571" elapsed="0.000726"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.766161" elapsed="0.001167"/>
</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-06-06T03:12:38.767556" elapsed="0.000584"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:38.768833" 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-06-06T03:12:38.768381" elapsed="0.000487"/>
</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-06-06T03:12:38.769084" elapsed="0.003090"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:12:38.753267" elapsed="0.019001"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:38.772340" elapsed="0.000053"/>
</return>
<msg time="2026-06-06T03:12:38.774803" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:12:38.735884" elapsed="0.038948"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:38.774894" elapsed="0.000033"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_local_address</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:12:38.643259" elapsed="0.131774"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:38.775730" elapsed="0.000265"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:38.775369" elapsed="0.000693"/>
</kw>
<doc>Delete peer configuration.</doc>
<status status="PASS" start="2026-06-06T03:12:38.559312" elapsed="0.216789"/>
</test>
<test id="s1-s4-t6" name="Reconfigure_ODL_To_Accept_Connection" line="124">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.780930" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.780689" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.780666" elapsed="0.000350"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:38.780471" elapsed="0.000592"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.782091" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.781981" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.781962" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.787169" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.787056" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.787037" elapsed="0.000205"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.788360" 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-06-06T03:12:38.787893" elapsed="0.000495"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.788882" 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-06-06T03:12:38.788555" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:38.788953" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:12:38.789201" 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-06-06T03:12:38.787485" elapsed="0.001741"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:38.797365" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.797203" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.797170" elapsed="0.000275"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:38.798751" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:38.798610" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.798592" elapsed="0.000229"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:38.799286" 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-06-06T03:12:38.798972" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.799726" level="INFO">${current_connection_index} = 7</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-06-06T03:12:38.799482" elapsed="0.000271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.840298" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:38.800295" elapsed="0.040164"/>
</kw>
<msg time="2026-06-06T03:12:38.840680" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:38.840730" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:38.799918" elapsed="0.040848"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:38.872275" level="INFO">". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:12:38.841374" elapsed="0.031167"/>
</kw>
<msg time="2026-06-06T03:12:38.872835" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:38.872885" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n ...</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-06-06T03:12:38.840972" elapsed="0.031950"/>
</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-06-06T03:12:38.873382" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.873047" elapsed="0.000398"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.873007" elapsed="0.000466"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.874065" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:12:38.873627" elapsed="0.000511"/>
</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-06-06T03:12:38.874445" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.874210" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.874191" elapsed="0.000333"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:38.874564" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:38.877408" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:12:38.877625" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:38.876297" elapsed="0.001493"/>
</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="NOT RUN" start="2026-06-06T03:12:38.878084" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.878432" elapsed="0.000080"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:38.875561" elapsed="0.003068"/>
</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-06-06T03:12:38.874957" elapsed="0.003953"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:38.798305" elapsed="0.080728"/>
</kw>
<msg time="2026-06-06T03:12:38.879203" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.879251" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.797622" elapsed="0.081675"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:38.879556" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:12:38.879408" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.879380" elapsed="0.000288"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.880112" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.880467" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.880631" elapsed="0.000046"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:38.796658" elapsed="0.084136"/>
</kw>
<msg time="2026-06-06T03:12:38.880895" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:38.880941" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:38.789767" elapsed="0.091399"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.881552" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.881259" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.881239" elapsed="0.000431"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:38.789535" elapsed="0.092164"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:38.789289" elapsed="0.092447"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:38.786668" elapsed="0.095131"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:38.781685" elapsed="0.100174"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:38.781218" elapsed="0.100690"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:38.777415" elapsed="0.104549"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.883180" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=exam...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.882224" elapsed="0.000988"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.918988" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:38.918552" elapsed="0.000471"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:38.920010" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:38.919613" elapsed="0.000493">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:38.920220" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:38.919209" elapsed="0.001040"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.921029" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:38.920471" elapsed="0.000594"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:38.921470" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:38.921793" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:38.921287" elapsed="0.000545"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.922391" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.922059" elapsed="0.000398"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.923877" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:38.923498" elapsed="0.000442"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.924525" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.924163" elapsed="0.000397"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.925541" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.925142" elapsed="0.000434"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.926578" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.926283" elapsed="0.000329"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.926703" elapsed="0.000060"/>
</return>
<msg time="2026-06-06T03:12:38.926921" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.925853" elapsed="0.001095"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.927112" elapsed="0.000265"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:12:38.924949" elapsed="0.002484"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.928064" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.927756" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.929119" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.928898" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.929211" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:12:38.929410" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.928282" elapsed="0.001164"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.929676" elapsed="0.000294"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:12:38.927581" elapsed="0.002445"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.930697" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.930354" elapsed="0.000370"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.931466" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.931244" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.931548" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:38.931721" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.930917" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.931905" elapsed="0.000225"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:38.930191" elapsed="0.001979"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.932792" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.932424" elapsed="0.000395"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.933637" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.933384" elapsed="0.000300"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.933735" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:38.933890" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.933013" elapsed="0.000908"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.934100" elapsed="0.000229"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:38.932284" elapsed="0.002163"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.935154" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.934772" elapsed="0.000409"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.936087" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.935866" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.936165" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:38.936315" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.935436" elapsed="0.000904"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.936512" elapsed="0.000288"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:38.934569" elapsed="0.002276"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.937399" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.937097" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.938182" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.937967" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.938259" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:38.938433" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.937616" elapsed="0.000848"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.938694" elapsed="0.000295"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:38.936960" elapsed="0.002090"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.939813" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.939391" elapsed="0.000451"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.940589" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.940359" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.940711" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:12:38.940956" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.940034" elapsed="0.000955"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.941197" elapsed="0.000517"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:38.939203" elapsed="0.002556"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.942470" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.942062" elapsed="0.000442"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.943302" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.943087" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.943380" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:38.943543" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.942761" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.943745" elapsed="0.000226"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:12:38.941875" elapsed="0.002137"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.944566" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:38.944258" elapsed="0.000335"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:38.945399" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.945180" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:38.945485" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:38.945638" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:38.944852" elapsed="0.000831"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:38.945841" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:38.944124" elapsed="0.002036"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:38.924635" elapsed="0.021563"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:38.946246" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:38.946420" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': ...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:38.923068" elapsed="0.023388"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:38.922566" elapsed="0.023930"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.946705" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.946525" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:38.922532" elapsed="0.024254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:38.947718" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:38.946938" elapsed="0.000811"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:38.947801" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:38.917926" elapsed="0.030007"/>
</kw>
<msg time="2026-06-06T03:12:38.947992" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:38.905184" elapsed="0.042862"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.960836" elapsed="0.000083"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.973660" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.986216" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.986452" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.986660" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.987092" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:38.986936" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:38.986917" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.987324" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.987494" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.987679" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:38.986875" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.986752" elapsed="0.001083"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:38.987994" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:38.988075" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:12:38.988241" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:38.900691" elapsed="0.087579"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.018529" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:39.018138" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:39.019352" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:39.019093" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:39.019555" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:39.018747" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.020172" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:39.019780" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:39.020507" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:39.020694" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:39.020365" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.021197" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.020886" elapsed="0.000373"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:39.021696" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.021332" elapsed="0.000430"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.022256" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': ...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:39.021944" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.021789" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.021311" elapsed="0.001032"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.023327" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:39.022496" elapsed="0.000864"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:39.023452" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:39.017497" elapsed="0.006096"/>
</kw>
<msg time="2026-06-06T03:12:39.023672" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:39.004496" elapsed="0.019228"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.036036" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.048610" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.062486" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.062717" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.062907" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.063305" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.063154" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:39.063137" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.063536" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.063727" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.063900" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:39.063101" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:39.062990" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.064132" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:39.064222" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:12:39.064377" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:39.000759" elapsed="0.063649"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:39.065929" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:39.065619" elapsed="0.000393">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:39.066128" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:39.065181" elapsed="0.000980"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.066501" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.066237" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.067090" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:39.066784" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.066585" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.066217" elapsed="0.000958"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.069535" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:39.067331" elapsed="0.002232"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:39.069617" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:12:39.069797" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:39.064776" elapsed="0.005048"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.071335" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.070988" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.071825" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.071547" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.072298" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.072046" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.072768" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.072500" elapsed="0.000314"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:39.073734" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:39.073513" elapsed="0.000248"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:39.074099" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:39.073919" elapsed="0.000206"/>
</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-06-06T03:12:39.074280" elapsed="0.000232"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.074946" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.074693" elapsed="0.000299"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:39.075035" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:39.075192" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:39.073026" elapsed="0.002192"/>
</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-06-06T03:12:39.095379" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '1079', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:12:39.095635" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:39.095979" 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-06-06T03:12:39.077555" elapsed="0.018489"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.075290" elapsed="0.020860"/>
</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-06-06T03:12:39.096612" elapsed="0.000092"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.096213" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.075270" elapsed="0.021596"/>
</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-06-06T03:12:39.102208" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.098869" elapsed="0.003402"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.098522" elapsed="0.003799"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.098495" elapsed="0.003862"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.106126" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.102778" elapsed="0.003413"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.102436" elapsed="0.003806"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.102412" elapsed="0.003865"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.106887" 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-06-06T03:12:39.106473" elapsed="0.000443"/>
</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-06-06T03:12:39.107234" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.106987" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.107804" 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-06-06T03:12:39.107482" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.107316" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.106968" elapsed="0.000921"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.108420" 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-06-06T03:12:39.108052" elapsed="0.000394"/>
</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-06-06T03:12:39.108776" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.108517" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.109321" 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-06-06T03:12:39.109023" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.108859" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.108498" elapsed="0.000946"/>
</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-06-06T03:12:39.109603" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:39.110427" 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-06-06T03:12:39.110140" elapsed="0.000313"/>
</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-06-06T03:12:39.110613" elapsed="0.002293"/>
</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-06-06T03:12:39.097815" elapsed="0.015155"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:39.113145" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:12:39.113038" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.113019" elapsed="0.000215"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:39.113387" elapsed="0.000239"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:39.113697" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:12:39.115935" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:12:39.070161" elapsed="0.045802"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:39.116070" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:39.116230" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:38.889093" elapsed="0.227162"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.116598" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.116354" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.116337" elapsed="0.000372"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:39.116743" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:38.883528" elapsed="0.233341"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.118292" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.117912" elapsed="0.000446"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.117894" elapsed="0.000489"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:39.118530" elapsed="0.000334"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.123976" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:39.123547" elapsed="0.000458"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:12:39.124228" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:39.124082" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.124063" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.124463" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.124658" elapsed="0.000023"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.124841" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.125014" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.125186" elapsed="0.000020"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.125358" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.125605" elapsed="0.000028"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:12:39.123232" elapsed="0.002486"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:39.117701" elapsed="0.008070"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:12:39.117152" elapsed="0.008662"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:12:38.776691" elapsed="0.349162"/>
</test>
<test id="s1-s4-t7" name="Start_Talking_BGP_speaker" line="142">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.129914" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.129687" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.129667" elapsed="0.000330"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:39.129457" elapsed="0.000587"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:39.131102" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:39.130952" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.130933" elapsed="0.000242"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:39.136085" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:39.135977" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.135959" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.137161" 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-06-06T03:12:39.136778" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.137684" 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-06-06T03:12:39.137354" elapsed="0.000357"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:39.137758" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:39.137913" 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-06-06T03:12:39.136379" elapsed="0.001559"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:39.143554" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:39.143444" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.143425" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:39.144848" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:39.144739" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.144720" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:39.145368" 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-06-06T03:12:39.145067" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:39.145815" level="INFO">${current_connection_index} = 7</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-06-06T03:12:39.145579" elapsed="0.000262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:39.182729" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:39.146347" elapsed="0.036600"/>
</kw>
<msg time="2026-06-06T03:12:39.183179" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:39.183227" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:39.146006" elapsed="0.037256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:39.200975" level="INFO">". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "s "p "e "a "k "e "r "[K"
[?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-06-06T03:12:39.183989" elapsed="0.017087"/>
</kw>
<msg time="2026-06-06T03:12:39.201235" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:39.201281" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "s "p "e "a "k "e "r "[K"
[?1l&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-06-06T03:12:39.183518" elapsed="0.017800"/>
</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-06-06T03:12:39.201699" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.201415" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.201388" elapsed="0.000424"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.202272" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "s "p "e "a "k "e "r "[K"
[?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-06-06T03:12:39.201965" elapsed="0.000374"/>
</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-06-06T03:12:39.202631" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.202407" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.202388" elapsed="0.000343"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:39.202770" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:39.205569" elapsed="0.000259"/>
</kw>
<msg time="2026-06-06T03:12:39.205894" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:39.204328" elapsed="0.001703"/>
</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="NOT RUN" start="2026-06-06T03:12:39.206311" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.206672" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:39.203663" elapsed="0.003199"/>
</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-06-06T03:12:39.203085" elapsed="0.003842"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:39.144408" elapsed="0.062620"/>
</kw>
<msg time="2026-06-06T03:12:39.207317" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:39.207363" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "s "p "e "a "k "e "r "[K"
[?1l&gt;[?...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:39.143804" elapsed="0.063599"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:39.207596" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:39.207485" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.207464" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.208134" elapsed="0.000033"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.208557" elapsed="0.000029"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:39.208640" elapsed="0.000036"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:39.143102" elapsed="0.065682"/>
</kw>
<msg time="2026-06-06T03:12:39.208890" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:39.208939" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "s "p "e "a "k "e "r "[K"
[?1l&gt;[?...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:39.138323" elapsed="0.070660"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:39.209366" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:39.209073" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:39.209052" elapsed="0.000395"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:39.138171" elapsed="0.071300"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:39.137996" elapsed="0.071508"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:39.135599" elapsed="0.073964"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:39.130658" elapsed="0.078962"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:39.130201" elapsed="0.079486"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:39.126991" elapsed="0.082754"/>
</kw>
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.210843" level="INFO">${command} = python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:39.210474" elapsed="0.000397"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:39.211278" level="INFO">python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:39.211035" elapsed="0.000288"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:39.214698" level="INFO">python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:12:39.214794" level="INFO">${output} =  python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:39.211479" elapsed="0.003342"/>
</kw>
<arg>--amount 3 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_TOOL_LOG_LEVEL}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:12:39.209990" elapsed="0.004893"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.217807" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:12:39.216827" elapsed="10.002446">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.219999" elapsed="0.000063"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:12:39.216532" elapsed="10.003785">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:12:39.215865" elapsed="10.005119"/>
</kw>
<msg time="2026-06-06T03:12:49.221235" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:39.215476" elapsed="10.005819"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:12:49.221708" elapsed="0.000068"/>
</return>
<status status="PASS" start="2026-06-06T03:12:49.221482" elapsed="0.000364"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.221431" elapsed="0.000471"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.222379" elapsed="0.000056"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.222798" elapsed="0.000047"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:12:39.215187" elapsed="10.007788"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:49.224370" elapsed="0.000594"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:49.223571" elapsed="0.001491"/>
</kw>
<doc>Start Python speaker to connect to ODL, verify that the tool does not promptly exit.</doc>
<status status="PASS" start="2026-06-06T03:12:39.126315" elapsed="10.098804"/>
</test>
<test id="s1-s4-t8" name="Check_Talking_Connection_Is_Established" line="149">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.230546" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.230148" elapsed="0.000488"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.230119" elapsed="0.000573"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:49.229866" elapsed="0.000898"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.232321" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.232158" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.232131" elapsed="0.000334"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.237520" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.237412" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.237394" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.238614" 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-06-06T03:12:49.238221" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.239133" 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-06-06T03:12:49.238826" elapsed="0.000333"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:49.239205" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:49.239365" 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-06-06T03:12:49.237839" elapsed="0.001550"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:49.245116" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.245006" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.244986" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:49.246414" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.246305" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.246285" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:49.247066" 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-06-06T03:12:49.246746" elapsed="0.000347"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.247480" level="INFO">${current_connection_index} = 7</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-06-06T03:12:49.247262" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.281578" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:49.248048" elapsed="0.033650"/>
</kw>
<msg time="2026-06-06T03:12:49.281879" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:49.281926" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:49.247696" elapsed="0.034267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.302157" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "[K"
[?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-06-06T03:12:49.282498" elapsed="0.019768"/>
</kw>
<msg time="2026-06-06T03:12:49.302428" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:49.302474" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E ...</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-06-06T03:12:49.282143" elapsed="0.020368"/>
</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-06-06T03:12:49.302847" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.302591" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.302570" elapsed="0.000360"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.303382" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "[K"
[?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-06-06T03:12:49.303079" elapsed="0.000368"/>
</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-06-06T03:12:49.303753" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.303516" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.303497" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:49.303867" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:49.306403" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:12:49.306607" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.305371" elapsed="0.001477"/>
</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="NOT RUN" start="2026-06-06T03:12:49.307133" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.307470" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:49.304738" elapsed="0.002941"/>
</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-06-06T03:12:49.304152" elapsed="0.003594"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:49.245998" elapsed="0.061852"/>
</kw>
<msg time="2026-06-06T03:12:49.307942" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:49.307987" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.245343" elapsed="0.062680"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:49.308206" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:49.308098" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.308079" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.308726" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.309069" elapsed="0.000063"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.309184" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:49.244655" elapsed="0.064639"/>
</kw>
<msg time="2026-06-06T03:12:49.309389" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:49.309432" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:49.239798" elapsed="0.069669"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.309822" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.309544" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.309526" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:49.239633" elapsed="0.070292"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:49.239453" elapsed="0.070504"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:49.237049" elapsed="0.072963"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:49.231712" elapsed="0.078356"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.230995" elapsed="0.079119"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:49.226525" elapsed="0.083643"/>
</kw>
<kw name="Check_Speaker_Is_Connected">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Number_Of_Speaker_Connections">
<kw name="Count_Port_Occurences" owner="SSHKeywords">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_And_Install_Netstat" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.316491" level="INFO">Executing command 'netstat --version'.</msg>
<msg time="2026-06-06T03:12:49.330418" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:49.330674" level="INFO">${netstat_installed} = net-tools 2.10-alpha
Fred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others
+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX
AF: (inet) +UNIX +INET...</msg>
<var>${netstat_installed}</var>
<arg>netstat --version</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:49.316393" elapsed="0.014345"/>
</kw>
<if>
<branch type="IF" condition="'${netstat_installed}' is not string and '${netstat_installed}' != '0'">
<kw name="Install_Netstat" owner="SSHKeywords">
<doc>Install netstat if it is not already installed.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.331715" elapsed="0.000060"/>
</kw>
<msg time="2026-06-06T03:12:49.331861" level="FAIL">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</msg>
<status status="FAIL" start="2026-06-06T03:12:49.330911" elapsed="0.001062">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:12:49.330865" elapsed="0.001202">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</if>
<doc>Check if netstat is installed and install it if not.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.316116" elapsed="0.016281">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</kw>
<arg>Check_And_Install_Netstat</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.315722" elapsed="0.016826"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.333476" level="INFO">Executing command 'netstat -punta 2&gt; /dev/null | grep -E ":17900 .+ ESTABLISHED .+python" | wc -l'.</msg>
<msg time="2026-06-06T03:12:49.395126" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:49.395360" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>${NETSTAT_COMMAND} 2&gt; /dev/null | grep -E ":${port} .+ ${state} .+${name}" | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:49.332981" elapsed="0.062436"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:12:49.395536" elapsed="0.000075"/>
</return>
<msg time="2026-06-06T03:12:49.395945" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>17900</arg>
<arg>ESTABLISHED</arg>
<arg>python</arg>
<doc>Run 'netstat' on the remote machine and count occurences of given port in the given state connected to process with the given name.</doc>
<status status="PASS" start="2026-06-06T03:12:49.315344" elapsed="0.080657"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output}</arg>
<arg>${howmany}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:12:49.396381" elapsed="0.000844"/>
</kw>
<arg>1</arg>
<doc>Run netstat in mininet machine and parse it for number of established connections. Check it is ${howmany}.</doc>
<status status="PASS" start="2026-06-06T03:12:49.314969" elapsed="0.082398"/>
</kw>
<arg>5s</arg>
<arg>1s</arg>
<arg>Check_Number_Of_Speaker_Connections</arg>
<arg>1</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:12:49.310589" elapsed="0.086881"/>
</kw>
<doc>Give it several tries to see exactly one established connection.</doc>
<status status="PASS" start="2026-06-06T03:12:49.310306" elapsed="0.087293"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:49.398959" elapsed="0.000545"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:49.398225" elapsed="0.001459"/>
</kw>
<doc>See TCP (BGP) connection in established state.</doc>
<status status="PASS" start="2026-06-06T03:12:49.225718" elapsed="0.174057"/>
</test>
<test id="s1-s4-t9" name="Check_Talking_Topology_Is_Filled" line="154">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.407110" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.406789" elapsed="0.000401"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.406761" elapsed="0.000463"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:49.406389" elapsed="0.000898"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.408721" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.408531" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.408506" elapsed="0.000311"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.415431" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.415323" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.415305" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.416534" 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-06-06T03:12:49.416144" elapsed="0.000417"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.417056" 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-06-06T03:12:49.416755" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:49.417127" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:49.417283" 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-06-06T03:12:49.415751" elapsed="0.001557"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:49.422736" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.422612" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.422592" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:49.424095" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.423986" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.423967" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:49.424616" 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-06-06T03:12:49.424313" elapsed="0.000346"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.425068" level="INFO">${current_connection_index} = 7</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-06-06T03:12:49.424850" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.461135" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:49.425600" elapsed="0.035770"/>
</kw>
<msg time="2026-06-06T03:12:49.461609" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:49.461688" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:49.425259" elapsed="0.036470"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.479416" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:12:49.462451" elapsed="0.017091"/>
</kw>
<msg time="2026-06-06T03:12:49.479740" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:49.479786" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l ...</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-06-06T03:12:49.461999" elapsed="0.017824"/>
</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-06-06T03:12:49.480209" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.479924" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.479894" elapsed="0.000399"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.480927" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:12:49.480450" elapsed="0.000554"/>
</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-06-06T03:12:49.481309" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.481077" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.481056" elapsed="0.000333"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:49.481428" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:49.484192" elapsed="0.000154"/>
</kw>
<msg time="2026-06-06T03:12:49.484410" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.483037" elapsed="0.001510"/>
</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="NOT RUN" start="2026-06-06T03:12:49.484890" elapsed="0.000301"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.485463" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:49.482365" elapsed="0.003302"/>
</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-06-06T03:12:49.481782" elapsed="0.003954"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:49.423678" elapsed="0.062175"/>
</kw>
<msg time="2026-06-06T03:12:49.485950" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:49.485995" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.423023" elapsed="0.063011"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:49.486227" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:12:49.486115" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.486095" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.486773" elapsed="0.000112"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.487215" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.487288" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:49.422274" elapsed="0.065123"/>
</kw>
<msg time="2026-06-06T03:12:49.487491" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:49.487535" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:49.417709" elapsed="0.069864"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.487930" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.487665" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.487631" elapsed="0.000378"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:49.417546" elapsed="0.070488"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:49.417367" elapsed="0.070700"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:49.414953" elapsed="0.073170"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:49.408133" elapsed="0.080049"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.407500" elapsed="0.080731"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:49.401803" elapsed="0.086484"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.539981" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.539552" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.541129" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.540579" elapsed="0.000633">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.541311" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.540195" elapsed="0.001141"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.541999" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:49.541510" elapsed="0.000525"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.542456" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:49.542733" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:49.542263" elapsed="0.000507"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.543343" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.542996" elapsed="0.000410"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.544796" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.544291" elapsed="0.000588"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.545424" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.545051" elapsed="0.000400"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.545896" elapsed="0.000053"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.546770" elapsed="0.000053"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.547383" elapsed="0.000066"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:12:49.545696" elapsed="0.001910"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.545508" elapsed="0.002197"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:49.547765" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:12:49.547950" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:49.543915" elapsed="0.004061"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.543518" elapsed="0.004491"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.548229" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.548036" elapsed="0.000268"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.543483" elapsed="0.004849"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.549302" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:49.548537" elapsed="0.000795"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:49.549398" elapsed="0.000040"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:49.538889" elapsed="0.010684"/>
</kw>
<msg time="2026-06-06T03:12:49.549671" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.525962" elapsed="0.023789"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.563492" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.575928" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.588505" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.588746" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.589000" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.589427" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.589271" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:49.589251" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.589674" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.589853" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.590021" elapsed="0.000118"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:49.589213" elapsed="0.000965"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.589097" elapsed="0.001109"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.590360" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.590439" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:12:49.590591" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:49.521739" elapsed="0.068880"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.592070" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.591767" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.592241" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.591348" elapsed="0.000918"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.592602" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.592337" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.593218" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.592888" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.592701" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.592318" elapsed="0.000983"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.595604" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:49.593456" elapsed="0.002175"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:49.595697" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:12:49.595855" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:49.590974" elapsed="0.004906"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.597155" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.596874" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.597314" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.596516" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:12:49.597544" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:49.597409" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.597390" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.597796" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.597971" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.598036" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:49.599910" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:49.596188" elapsed="0.003748"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.601378" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.601121" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.601843" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.601578" elapsed="0.000309"/>
</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-06-06T03:12:49.610698" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:49.611067" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:12:49.611167" 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-06-06T03:12:49.604202" elapsed="0.006991"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.601995" elapsed="0.009243"/>
</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-06-06T03:12:49.611426" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.611265" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.601975" elapsed="0.009538"/>
</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-06-06T03:12:49.614959" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.612561" elapsed="0.002446"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.612336" elapsed="0.002707"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.612317" elapsed="0.002750"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.617614" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.615347" elapsed="0.002327"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.615124" elapsed="0.002586"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.615106" elapsed="0.002629"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.618301" 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-06-06T03:12:49.617911" elapsed="0.000417"/>
</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-06-06T03:12:49.618637" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.618398" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.619204" 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-06-06T03:12:49.618904" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.618735" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.618379" elapsed="0.000907"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.619823" 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-06-06T03:12:49.619445" elapsed="0.000405"/>
</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-06-06T03:12:49.620154" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.619918" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.620708" 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-06-06T03:12:49.620397" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.620235" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.619900" elapsed="0.000896"/>
</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-06-06T03:12:49.620975" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:49.621813" 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-06-06T03:12:49.621493" elapsed="0.000346"/>
</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-06-06T03:12:49.622000" elapsed="0.002268"/>
</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-06-06T03:12:49.611909" elapsed="0.012423"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.624512" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.624402" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.624383" elapsed="0.000239"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:49.627518" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:12:49.624791" elapsed="0.002756"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:12:49.627599" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:12:49.627778" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:12:49.600250" elapsed="0.027555"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:49.627868" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:49.628019" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:49.499550" elapsed="0.128495"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.658526" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.657762" elapsed="0.000797"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.660622" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.660057" elapsed="0.000744">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.660935" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.658752" elapsed="0.002209"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.661955" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:49.661175" elapsed="0.000809"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.662392" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:49.662689" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:49.662151" elapsed="0.000567"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.663309" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.662882" elapsed="0.000494"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:49.664109" elapsed="0.000079"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.663456" elapsed="0.000812"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.665132" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.664476" elapsed="0.000698"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.664297" elapsed="0.000959"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.663432" elapsed="0.001848"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.666305" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:49.665434" elapsed="0.000901"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:49.666388" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:49.656952" elapsed="0.009617"/>
</kw>
<msg time="2026-06-06T03:12:49.666626" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.644088" elapsed="0.022606"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.679170" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.691826" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.704249" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.704459" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.704656" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.705085" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.704908" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:49.704892" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.705313" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.705489" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.705676" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:49.704859" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.704746" elapsed="0.001014"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.705913" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.705991" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:49.706124" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:49.641475" elapsed="0.064677"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.706334" elapsed="0.002627"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:49.710291" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:49.709799" elapsed="0.000521"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:49.710945" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:49.710481" elapsed="0.000493"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:12:49.711136" elapsed="0.000341"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:12:49.709344" elapsed="0.002196"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.709045" elapsed="0.002529"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.711772" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.711600" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.709025" elapsed="0.002826"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:12:49.629217" elapsed="0.082684"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:12:49.628370" elapsed="0.083608"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.628128" elapsed="0.083897"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.628110" elapsed="0.083939"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:49.712084" elapsed="0.000030"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:12:49.493518" elapsed="0.218696"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:12:49.489333" elapsed="0.222943"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:12:49.488826" elapsed="0.223498"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:12:49.488429" elapsed="0.223955"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:49.712989" elapsed="0.000278"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:49.712678" elapsed="0.000653"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:49.400407" elapsed="0.312963"/>
</test>
<test id="s1-s4-t10" name="TC_R_Reset_Bgp_Peer_Session" line="159">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.716828" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.716581" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.716562" elapsed="0.000347"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:49.716395" elapsed="0.000561"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.718089" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.717958" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.717938" elapsed="0.000226"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.723154" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.723044" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.723025" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.724256" 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-06-06T03:12:49.723862" elapsed="0.000421"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.724778" 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-06-06T03:12:49.724458" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:49.724914" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:49.725095" 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-06-06T03:12:49.723459" elapsed="0.001662"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:49.730956" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.730840" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.730818" elapsed="0.000211"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:49.732274" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:49.732165" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.732145" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:49.732837" 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-06-06T03:12:49.732493" elapsed="0.000372"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.733269" level="INFO">${current_connection_index} = 7</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-06-06T03:12:49.733035" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.766119" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:49.733836" elapsed="0.032523"/>
</kw>
<msg time="2026-06-06T03:12:49.766621" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:49.766698" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:49.733467" elapsed="0.033272"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:49.782788" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "R "e "s "e "t "_ "B "g "p "_ "P "e "e "r "_ "S "e "s "s "i "o "n "[K"
[?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-06-06T03:12:49.767506" elapsed="0.015397"/>
</kw>
<msg time="2026-06-06T03:12:49.783073" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:49.783120" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "R "e "s "e "t "_ "B "g "p "_ "P "e "e "r "_ "S "e "s "s "i "o "n "[K"
...</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-06-06T03:12:49.767020" elapsed="0.016139"/>
</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-06-06T03:12:49.783556" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.783272" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.783232" elapsed="0.000470"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.784185" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "R "e "s "e "t "_ "B "g "p "_ "P "e "e "r "_ "S "e "s "s "i "o "n "[K"
[?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-06-06T03:12:49.783863" elapsed="0.000391"/>
</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-06-06T03:12:49.784553" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.784324" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.784305" elapsed="0.000329"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:49.784702" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:49.787499" elapsed="0.000171"/>
</kw>
<msg time="2026-06-06T03:12:49.787734" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.786358" elapsed="0.001514"/>
</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="NOT RUN" start="2026-06-06T03:12:49.788154" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.788496" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:49.785693" elapsed="0.003014"/>
</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-06-06T03:12:49.785041" elapsed="0.003735"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:49.731857" elapsed="0.057081"/>
</kw>
<msg time="2026-06-06T03:12:49.789037" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:49.789082" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "R "e "s "e "t "_ "B "g "p "_ "P "e "e "r "_ "S "e "s "s "i "o "n "[K"
...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.731197" elapsed="0.057924"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:49.789343" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:49.789230" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.789205" elapsed="0.000225"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.789904" elapsed="0.000036"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.790387" elapsed="0.000034"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.790487" elapsed="0.000022"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:49.730442" elapsed="0.060220"/>
</kw>
<msg time="2026-06-06T03:12:49.790803" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:49.790865" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "R "e "s "e "t "_ "B "g "p "_ "P "e "e "r "_ "S "e "s "s "i "o "n "[K"
...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:49.725513" elapsed="0.065406"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.791388" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.791028" elapsed="0.000434"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.791003" elapsed="0.000492"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:49.725363" elapsed="0.066167"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:49.725181" elapsed="0.066396"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:49.722676" elapsed="0.069004"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:49.717658" elapsed="0.074109"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:49.717136" elapsed="0.074697"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:49.714232" elapsed="0.077677"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.792877" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.792188" elapsed="0.000729"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.827322" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.826938" elapsed="0.000412"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.828137" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.827875" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.828310" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.827520" elapsed="0.000814"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.828904" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:49.828503" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.829262" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:49.829481" level="INFO">${template} = rests/operations/bgp-peer-rpc:reset-session
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:49.829098" elapsed="0.000409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.829943" level="INFO">rests/operations/bgp-peer-rpc:reset-session
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.829684" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.830978" level="INFO">mapping: {'IP': '10.30.171.194', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.830709" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.831451" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.831186" elapsed="0.000291"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.832173" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:49.831873" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:49.832964" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.832731" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:49.833042" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:49.833197" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:49.832392" elapsed="0.000872"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.833434" elapsed="0.000271"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:49.831731" elapsed="0.002017"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.834299" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:49.833998" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:49.835221" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.835007" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:49.835299" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:49.835451" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:49.834511" elapsed="0.000965"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:49.835632" elapsed="0.000244"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:49.833863" elapsed="0.002056"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:49.831533" elapsed="0.004420"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:49.835996" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:49.836152" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:49.830365" elapsed="0.005813"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.830058" elapsed="0.006152"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.836390" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.836235" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.830037" elapsed="0.006430"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.837089" level="INFO">${final_text} = rests/operations/bgp-peer-rpc:reset-session</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:49.836615" elapsed="0.000502"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:49.837167" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:49.826290" elapsed="0.011016"/>
</kw>
<msg time="2026-06-06T03:12:49.837360" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.813796" elapsed="0.023612"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.849762" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.862100" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.874376" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.874579" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.874777" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.875154" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.875004" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:49.874989" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.875379" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.875550" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.875738" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:49.874960" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.874856" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.875967" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.876044" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:49.876156" level="INFO">${uri} = rests/operations/bgp-peer-rpc:reset-session</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:49.809531" elapsed="0.066650"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.900840" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.900391" elapsed="0.000479"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.901757" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.901460" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.901925" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.901042" elapsed="0.000908"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.902511" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:49.902121" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.902857" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:49.903042" level="INFO">${template} = &lt;input xmlns="urn:opendaylight:params:xml:ns:yang:bgp-peer-rpc"&gt;
    &lt;peer-ref xmlns:rib="urn:opendaylight:params:xml:ns:yang:bgp-rib"&gt;/rib:bgp-rib/rib:rib[rib:id="$RIB_INSTANCE_NAME"]/rib:peer[rib:pe...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:49.902718" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.903479" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:bgp-peer-rpc"&gt;
    &lt;peer-ref xmlns:rib="urn:opendaylight:params:xml:ns:yang:bgp-rib"&gt;/rib:bgp-rib/rib:rib[rib:id="$RIB_INSTANCE_NAME"]/rib:peer[rib:peer-id="bgp://$IP"]&lt;/peer-ref&gt;
&lt;/input&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.903232" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:49.903915" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.903594" elapsed="0.000381"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.904445" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.904149" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.904000" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.903575" elapsed="0.000953"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.905498" level="INFO">${final_text} = &lt;input xmlns="urn:opendaylight:params:xml:ns:yang:bgp-peer-rpc"&gt;
    &lt;peer-ref xmlns:rib="urn:opendaylight:params:xml:ns:yang:bgp-rib"&gt;/rib:bgp-rib/rib:rib[rib:id="example-bgp-rib"]/rib:peer[rib:peer-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:49.904693" elapsed="0.000836"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:49.905581" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:49.899711" elapsed="0.006014"/>
</kw>
<msg time="2026-06-06T03:12:49.905781" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:49.887207" elapsed="0.018620"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.918056" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.930217" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.942441" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.942656" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.942842" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.943220" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.943070" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:49.943055" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.943445" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.943617" elapsed="0.000069"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.943846" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:49.943025" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.942922" elapsed="0.001005"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.944077" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:49.944154" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:49.944279" level="INFO">${data} = &lt;input xmlns="urn:opendaylight:params:xml:ns:yang:bgp-peer-rpc"&gt;
    &lt;peer-ref xmlns:rib="urn:opendaylight:params:xml:ns:yang:bgp-rib"&gt;/rib:bgp-rib/rib:rib[rib:id="example-bgp-rib"]/rib:peer[rib:peer-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:49.886202" elapsed="0.058104"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:49.945629" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:49.945351" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_session/restart/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:49.945810" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:49.944996" elapsed="0.000838"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.946160" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.945906" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.946726" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:49.946415" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.946241" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.945887" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.949317" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:49.946967" elapsed="0.002376"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:49.949419" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:12:49.949580" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_session/restart/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:49.944660" elapsed="0.004945"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.951298" level="INFO">rests/operations/bgp-peer-rpc:reset-session</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.951049" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.951759" level="INFO">&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:bgp-peer-rpc"&gt;
    &lt;peer-ref xmlns:rib="urn:opendaylight:params:xml:ns:yang:bgp-rib"&gt;/rib:bgp-rib/rib:rib[rib:id="example-bgp-rib"]/rib:peer[rib:peer-id="bgp://10.30.171.194"]&lt;/peer-ref&gt;
&lt;/input&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.951501" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.952204" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.951962" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.952637" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.952399" elapsed="0.000298"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:49.953545" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:49.953315" elapsed="0.000256"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:49.953921" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:49.953743" elapsed="0.000203"/>
</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-06-06T03:12:49.954098" elapsed="0.000203"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.954721" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.954460" elapsed="0.000348"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:49.954854" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:49.955012" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:49.952908" elapsed="0.002129"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:49.982735" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/operations/bgp-peer-rpc:reset-session 
 path_url=/rests/operations/bgp-peer-rpc:reset-session 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '245', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;input xmlns="urn:opendaylight:params:xml:ns:yang:bgp-peer-rpc"&gt;
    &lt;peer-ref xmlns:rib="urn:opendaylight:params:xml:ns:yang:bgp-rib"&gt;/rib:bgp-rib/rib:rib[rib:id="example-bgp-rib"]/rib:peer[rib:peer-id="bgp://10.30.171.194"]&lt;/peer-ref&gt;
&lt;/input&gt; 
 </msg>
<msg time="2026-06-06T03:12:49.982849" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/operations/bgp-peer-rpc:reset-session 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:49.983080" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>data=${data}</arg>
<arg>headers=${headers}</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:49.957375" elapsed="0.025763"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.955108" elapsed="0.028134"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:49.983689" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.983302" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.955090" elapsed="0.028798"/>
</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-06-06T03:12:49.989367" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.986117" elapsed="0.003341"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.985798" elapsed="0.003711"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.985759" elapsed="0.003786"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.993349" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:49.989966" elapsed="0.003448"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.989625" elapsed="0.003889"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.989600" elapsed="0.003951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.994194" 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-06-06T03:12:49.993806" elapsed="0.000416"/>
</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-06-06T03:12:49.994534" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.994293" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.995098" 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-06-06T03:12:49.994797" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.994616" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.994274" elapsed="0.000907"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.995721" 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-06-06T03:12:49.995342" elapsed="0.000406"/>
</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-06-06T03:12:49.996053" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:49.995817" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:49.996591" 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-06-06T03:12:49.996296" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:49.996134" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:49.995799" elapsed="0.000891"/>
</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-06-06T03:12:49.996846" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:49.997707" 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-06-06T03:12:49.997363" elapsed="0.000371"/>
</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-06-06T03:12:49.997898" elapsed="0.002254"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:12:49.984726" elapsed="0.015489"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:50.000470" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:50.000360" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.000340" elapsed="0.000216"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:50.000725" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.000798" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:50.003083" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:12:49.949952" elapsed="0.053158"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.003181" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.003336" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:49.798407" elapsed="0.204954"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.003722" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.003466" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.003449" elapsed="0.000366"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.003848" elapsed="0.000026"/>
</return>
<arg>folder=${BGP_VARIABLES_FOLDER}${/}peer_session/restart</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:49.793347" elapsed="0.210624"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:50.004560" elapsed="0.000261"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:50.004254" elapsed="0.000631"/>
</kw>
<doc>Reset Peer Session</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:49.713721" elapsed="0.291203"/>
</test>
<test id="s1-s4-t11" name="TC_R_Check_For_Empty_Topology_After_Resetting" line="168">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.008465" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.008244" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.008224" elapsed="0.000323"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:50.008057" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.009662" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.009538" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.009518" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.014710" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.014585" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.014567" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.015792" 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-06-06T03:12:50.015392" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.016278" 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-06-06T03:12:50.015980" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:50.016349" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.016502" 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-06-06T03:12:50.015010" elapsed="0.001517"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:50.021906" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.021797" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.021778" elapsed="0.000236"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:50.023210" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.023102" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.023083" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:50.023746" 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-06-06T03:12:50.023426" elapsed="0.000347"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:50.024156" level="INFO">${current_connection_index} = 7</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-06-06T03:12:50.023937" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:50.056313" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:50.024701" elapsed="0.031718"/>
</kw>
<msg time="2026-06-06T03:12:50.056588" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:50.056634" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:50.024343" elapsed="0.032357"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:50.077681" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "R "e "s "e "t "t "i "n "g "[K"
[?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-06-06T03:12:50.057418" elapsed="0.020374"/>
</kw>
<msg time="2026-06-06T03:12:50.077958" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:50.078004" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y ...</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-06-06T03:12:50.056879" elapsed="0.021162"/>
</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-06-06T03:12:50.078351" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.078120" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.078099" elapsed="0.000333"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.078908" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "R "e "s "e "t "t "i "n "g "[K"
[?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-06-06T03:12:50.078577" elapsed="0.000402"/>
</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-06-06T03:12:50.079267" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.079048" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.079029" elapsed="0.000316"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:50.079379" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:50.081917" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:12:50.082120" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.080849" elapsed="0.001399"/>
</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="NOT RUN" start="2026-06-06T03:12:50.082525" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.082887" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:50.080206" elapsed="0.002864"/>
</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-06-06T03:12:50.079663" elapsed="0.003471"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:50.022794" elapsed="0.060439"/>
</kw>
<msg time="2026-06-06T03:12:50.083324" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:50.083368" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:50.022173" elapsed="0.061232"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:50.083589" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:50.083482" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.083463" elapsed="0.000274"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.084151" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.084491" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.084562" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:50.021428" elapsed="0.063259"/>
</kw>
<msg time="2026-06-06T03:12:50.084783" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:50.084827" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "R "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:50.016915" elapsed="0.067949"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.085214" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.084941" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.084923" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:50.016769" elapsed="0.068548"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:50.016581" elapsed="0.068767"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:50.014221" elapsed="0.071179"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:50.009217" elapsed="0.076240"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:50.008764" elapsed="0.076738"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:50.005753" elapsed="0.079800"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.136439" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.136034" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.137341" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.137002" elapsed="0.000410">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.137506" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.136659" elapsed="0.000872"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.138113" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.137723" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.138442" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.138589" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.138305" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.139038" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.138793" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.140269" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.139810" elapsed="0.000520"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.140898" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.140505" elapsed="0.000419"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.141360" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.142103" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.142443" elapsed="0.000045"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.141171" elapsed="0.001438"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.141009" elapsed="0.001691"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.142751" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.142912" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:50.139446" elapsed="0.003491"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.139151" elapsed="0.003819"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.143145" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.142995" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.139131" elapsed="0.004091"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.143815" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.143365" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.143892" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.135404" elapsed="0.008609"/>
</kw>
<msg time="2026-06-06T03:12:50.144066" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.123088" elapsed="0.021026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.156524" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.168744" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.180946" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.181147" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.181326" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.181707" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.181544" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:50.181530" elapsed="0.000455"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.182137" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.182308" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.182520" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.181501" elapsed="0.001074"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.181401" elapsed="0.001200"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.182776" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.182857" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:50.182979" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.118923" elapsed="0.064082"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.184299" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.184059" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.184457" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.183702" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.184820" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.184552" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.185367" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.185073" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.184901" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.184533" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.187774" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.185604" elapsed="0.002202"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:50.187860" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.188013" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:50.183332" elapsed="0.004706"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.189256" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.189023" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.189411" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.188683" elapsed="0.000753"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:12:50.189658" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:12:50.189506" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.189486" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.189895" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.190068" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.190133" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:50.192164" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:50.188343" elapsed="0.003848"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.193581" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.193333" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.194088" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.193840" elapsed="0.000293"/>
</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-06-06T03:12:50.202353" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:50.202497" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:12:50.202591" 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-06-06T03:12:50.196245" elapsed="0.006372"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.194200" elapsed="0.008483"/>
</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-06-06T03:12:50.202873" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.202710" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.194181" elapsed="0.008777"/>
</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-06-06T03:12:50.206376" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.204031" elapsed="0.002392"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.203801" elapsed="0.002657"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.203781" elapsed="0.002702"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.209527" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.206779" elapsed="0.002812"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.206538" elapsed="0.003118"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.206522" elapsed="0.003171"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.210492" 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-06-06T03:12:50.209932" elapsed="0.000599"/>
</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-06-06T03:12:50.210985" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.210629" elapsed="0.000437"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.211789" 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-06-06T03:12:50.211344" elapsed="0.000482"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.211099" elapsed="0.000776"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.210604" elapsed="0.001300"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.212629" 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-06-06T03:12:50.212130" elapsed="0.000558"/>
</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-06-06T03:12:50.213115" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.212786" elapsed="0.000408"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.213892" 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-06-06T03:12:50.213454" elapsed="0.000474"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.213228" elapsed="0.000750"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.212760" elapsed="0.001247"/>
</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-06-06T03:12:50.214218" elapsed="0.000499"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:50.215436" 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-06-06T03:12:50.214952" elapsed="0.000523"/>
</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-06-06T03:12:50.215714" elapsed="0.004834"/>
</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-06-06T03:12:50.203314" elapsed="0.017298"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.220807" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.220700" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.220679" elapsed="0.000234"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:50.223721" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:12:50.221062" elapsed="0.002688"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:12:50.223803" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:50.223962" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:12:50.192504" elapsed="0.031485"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.224052" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:12:50.224199" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:50.096914" elapsed="0.127312"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.252573" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.251838" elapsed="0.000763"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.254637" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.254081" elapsed="0.000756">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.254971" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.252789" elapsed="0.002208"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.255936" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.255166" elapsed="0.000798"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.256365" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.256614" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.256130" elapsed="0.000533"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.257249" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.256828" elapsed="0.000483"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:50.257992" elapsed="0.000078"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.257381" elapsed="0.000768"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.259017" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.258355" elapsed="0.000703"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.258176" elapsed="0.000964"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.257360" elapsed="0.001805"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.260095" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.259317" elapsed="0.000807"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.260174" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.251105" elapsed="0.009195"/>
</kw>
<msg time="2026-06-06T03:12:50.260389" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.238559" elapsed="0.021880"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.273068" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.285258" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.297543" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.297756" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.297943" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.298351" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.298196" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:50.298180" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.298578" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.298771" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.298942" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.298151" elapsed="0.000843"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.298021" elapsed="0.001000"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.299176" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.299257" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:50.299375" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.235960" elapsed="0.063443"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.299581" elapsed="0.002188"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:50.302853" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.302513" elapsed="0.000369"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:50.303389" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.303076" elapsed="0.000341"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:12:50.303579" elapsed="0.000360"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:12:50.302101" elapsed="0.001899"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.301850" elapsed="0.002184"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.304212" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.304059" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.301831" elapsed="0.002458"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:12:50.225373" elapsed="0.078962"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:12:50.224551" elapsed="0.079858"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.224308" elapsed="0.080150"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.224290" elapsed="0.080192"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.304515" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:12:50.090654" elapsed="0.214006"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.086546" elapsed="0.218182"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:12:50.086060" elapsed="0.218714"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.085707" elapsed="0.219124"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:12:50.305416" elapsed="0.000261"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:12:50.305112" elapsed="0.000629"/>
</kw>
<doc>See example-ipv4-topology empty after resetting session</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:50.005173" elapsed="0.300608"/>
</test>
<test id="s1-s4-t12" name="TC_PG_Reconfigure_ODL_With_Peer_Group_To_Accept_Connection" line="173">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.309157" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.308937" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.308919" elapsed="0.000318"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:12:50.308750" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.310306" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.310197" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.310178" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.315422" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.315316" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.315297" elapsed="0.000218"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.316518" 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-06-06T03:12:50.316136" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.317027" 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-06-06T03:12:50.316729" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:50.317098" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.317252" 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-06-06T03:12:50.315757" elapsed="0.001519"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:50.322794" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.322684" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.322663" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:50.324035" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.323926" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.323907" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:50.324554" 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-06-06T03:12:50.324254" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:50.324987" level="INFO">${current_connection_index} = 7</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-06-06T03:12:50.324768" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:50.356873" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:50.325525" elapsed="0.031455"/>
</kw>
<msg time="2026-06-06T03:12:50.357147" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:50.357193" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:50.325178" elapsed="0.032078"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:50.380871" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e "e "r "_ "G "r "o "u "p "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:12:50.357836" elapsed="0.023164"/>
</kw>
<msg time="2026-06-06T03:12:50.381161" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:50.381206" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e ...</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-06-06T03:12:50.357442" elapsed="0.023800"/>
</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-06-06T03:12:50.381557" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.381323" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.381301" elapsed="0.000334"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.382112" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e "e "r "_ "G "r "o "u "p "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:12:50.381810" elapsed="0.000380"/>
</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-06-06T03:12:50.382476" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.382256" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.382238" elapsed="0.000316"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:50.382589" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:50.385270" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:12:50.385479" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.384098" elapsed="0.001512"/>
</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="NOT RUN" start="2026-06-06T03:12:50.385919" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.386254" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:50.383453" elapsed="0.002987"/>
</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-06-06T03:12:50.382905" elapsed="0.003601"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:50.323597" elapsed="0.063008"/>
</kw>
<msg time="2026-06-06T03:12:50.386726" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:50.386773" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:50.323023" elapsed="0.063789"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:50.387244" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:12:50.386947" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.386926" elapsed="0.000405"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.387762" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.388114" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.388186" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:50.322291" elapsed="0.066005"/>
</kw>
<msg time="2026-06-06T03:12:50.388389" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:50.388433" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:50.317658" elapsed="0.070812"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.388840" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.388545" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.388527" elapsed="0.000394"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:50.317497" elapsed="0.071448"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:50.317329" elapsed="0.071647"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:50.314953" elapsed="0.074078"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:50.309909" elapsed="0.079178"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:50.309437" elapsed="0.079695"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:50.306582" elapsed="0.082604"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.389946" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.389360" elapsed="0.000615"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.432084" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.431703" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.432914" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.432662" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.433085" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.432291" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.433681" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.433279" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.434017" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.434173" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.433880" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.434605" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.434361" elapsed="0.000347"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.435688" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.435412" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.436191" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.435899" elapsed="0.000320"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.436911" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.436591" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.437958" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.437516" elapsed="0.000469"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.438038" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.438191" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.437167" elapsed="0.001049"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.438375" elapsed="0.000245"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:12:50.436452" elapsed="0.002224"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.439333" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.438925" elapsed="0.000434"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.440129" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.439899" elapsed="0.000258"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.440207" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.440359" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.439553" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.440537" elapsed="0.000246"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:12:50.438789" elapsed="0.002036"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.441366" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.441071" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.442123" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.441912" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.442199" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.442348" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.441576" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.442526" elapsed="0.000239"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:50.440936" elapsed="0.001871"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.443355" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.443055" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.444149" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.443910" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.444231" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.444381" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.443570" elapsed="0.000836"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.444562" elapsed="0.000245"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:50.442920" elapsed="0.001928"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.436273" elapsed="0.008610"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.444925" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.445084" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:50.435085" elapsed="0.010025"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.434780" elapsed="0.010399"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.445365" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.445210" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.434759" elapsed="0.010684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.446233" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.445592" elapsed="0.000670"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.446312" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.431068" elapsed="0.015369"/>
</kw>
<msg time="2026-06-06T03:12:50.446491" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.418514" elapsed="0.028023"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.458927" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.471155" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.483240" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.483442" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.483663" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.484031" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.483886" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:50.483870" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.484249" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.484419" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.484584" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.483841" elapsed="0.000796"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.483739" elapsed="0.000938"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.484828" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.485019" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:12:50.485144" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.414257" elapsed="0.070949"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.486340" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.486083" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:12:50.502590" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:50.502688" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:50.502830" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:12:50.488478" elapsed="0.014388"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.486454" elapsed="0.016469"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.503180" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.502960" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.486436" elapsed="0.016887"/>
</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-06-06T03:12:50.508058" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.504779" elapsed="0.003344"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.504446" elapsed="0.003726"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.504420" elapsed="0.003787"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.511790" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.508596" elapsed="0.003258"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.508284" elapsed="0.003618"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.508260" elapsed="0.003677"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.512719" 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-06-06T03:12:50.512170" elapsed="0.000588"/>
</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-06-06T03:12:50.513193" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.512858" elapsed="0.000415"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.513982" 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-06-06T03:12:50.513534" elapsed="0.000484"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.513306" elapsed="0.000761"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.512832" elapsed="0.001264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.514853" 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-06-06T03:12:50.514323" elapsed="0.000568"/>
</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-06-06T03:12:50.515337" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.514989" elapsed="0.000429"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.516118" 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-06-06T03:12:50.515699" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.515451" elapsed="0.000752"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.514964" elapsed="0.001268"/>
</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-06-06T03:12:50.516443" elapsed="0.000506"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:50.517575" 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-06-06T03:12:50.517188" elapsed="0.000486"/>
</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-06-06T03:12:50.517905" elapsed="0.002993"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:12:50.503879" elapsed="0.017083"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:50.521010" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.523245" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:12:50.485480" elapsed="0.037793"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.523328" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:12:50.390207" elapsed="0.133245"/>
</kw>
<kw name="Configure_Peer_Group">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.524661" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | PEER_GROUP_NAME=internal-neighbor...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<arg>PEER_GROUP_NAME=${PEER_GROUP}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.523955" elapsed="0.000738"/>
</kw>
<kw name="Run_Keyword_If_At_Least_Else" owner="CompareStream">
<kw name="Get Index From List" owner="Collections">
<msg time="2026-06-06T03:12:50.533840" level="INFO">${position} = 2</msg>
<var>${position}</var>
<arg>${varargs}</arg>
<arg>\ELSE</arg>
<doc>Returns the index of the first occurrence of the ``value`` on the list.</doc>
<status status="PASS" start="2026-06-06T03:12:50.533634" elapsed="0.000233"/>
</kw>
<if>
<branch type="IF" condition="&quot;${position}&quot; == &quot;-1&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>Missing else statement in defined expresion</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.534165" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.533941" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.533921" elapsed="0.000323"/>
</if>
<kw name="Get Slice From List" owner="Collections">
<msg time="2026-06-06T03:12:50.534672" level="INFO">${varargs_if} = ['BuiltIn.Set Variable', 'verify_peer_group.sulfur']</msg>
<var>${varargs_if}</var>
<arg>${varargs}</arg>
<arg>0</arg>
<arg>${position}</arg>
<doc>Returns a slice of the given list between ``start`` and ``end`` indexes.</doc>
<status status="PASS" start="2026-06-06T03:12:50.534390" elapsed="0.000311"/>
</kw>
<kw name="Get Slice From List" owner="Collections">
<msg time="2026-06-06T03:12:50.537208" level="INFO">${varargs_else} = ['BuiltIn.Set Variable', 'verify_peer_group']</msg>
<var>${varargs_else}</var>
<arg>${varargs}</arg>
<arg>${position+1}</arg>
<doc>Returns a slice of the given list between ``start`` and ``end`` indexes.</doc>
<status status="PASS" start="2026-06-06T03:12:50.534877" elapsed="0.002359"/>
</kw>
<kw name="CompareStream__Convert_Input" owner="CompareStream">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.538181" level="INFO">${args} = []</msg>
<var>${args}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:12:50.537936" elapsed="0.000271"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.538629" level="INFO">${kwargs} = {}</msg>
<var>${kwargs}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.538369" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.539414" level="INFO">${arg} = BuiltIn.Set Variable</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.539117" elapsed="0.000323"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:12:50.539890" level="INFO">${removed} = BuiltIn.SetVariable</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.539599" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.542312" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.539995" elapsed="0.002376"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:12:50.542819" level="INFO">${splitted} = ['BuiltIn.Set Variable']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.542541" elapsed="0.000305"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.542395" elapsed="0.000491"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.539976" elapsed="0.002932"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.543324" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:12:50.543398" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:50.543057" elapsed="0.000364"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.543719" elapsed="0.000201"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.543491" elapsed="0.000468"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.544129" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.543983" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.543472" elapsed="0.000732"/>
</if>
<var name="${arg}">BuiltIn.Set Variable</var>
<status status="PASS" start="2026-06-06T03:12:50.538979" elapsed="0.005249"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.544914" level="INFO">${arg} = verify_peer_group.sulfur</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.544595" elapsed="0.000345"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:12:50.545366" level="INFO">${removed} = verify_peer_group.sulfur</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.545097" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.547982" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.545472" elapsed="0.002570"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:12:50.548451" level="INFO">${splitted} = ['verify_peer_group.sulfur']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.548215" elapsed="0.000262"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.548068" elapsed="0.000451"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.545453" elapsed="0.003087"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.548969" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:12:50.549043" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:50.548705" elapsed="0.000362"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.549349" elapsed="0.000195"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.549137" elapsed="0.000445"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.549770" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.549607" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.549119" elapsed="0.000733"/>
</if>
<var name="${arg}">verify_peer_group.sulfur</var>
<status status="PASS" start="2026-06-06T03:12:50.544461" elapsed="0.005415"/>
</iter>
<var>${arg}</var>
<value>@{arguments}</value>
<status status="PASS" start="2026-06-06T03:12:50.538738" elapsed="0.011167"/>
</for>
<return>
<value>${args}</value>
<value>${kwargs}</value>
<status status="PASS" start="2026-06-06T03:12:50.549944" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.550139" level="INFO">${args_if} = ['BuiltIn.Set Variable', 'verify_peer_group.sulfur']</msg>
<msg time="2026-06-06T03:12:50.550187" level="INFO">${kwargs_if} = {}</msg>
<var>${args_if}</var>
<var>${kwargs_if}</var>
<arg>@{varargs_if}</arg>
<doc>Splits arguments into args and kwargs is used in Run_Keyword_If_At_Least_Else and Run_Keyword_If_At_Most_Else.
The problem is, when the string contains =, but it is not a named argument (name=value). There can be many values containing =, but
for sure it is present in xmls. If the string starts with "&lt;" it will be treated as it is xml and splitting for
name and value will not be executed.
If named argument is passed into this kw, only string data are supported e.g. name=string. Complex variables such as lists or dictionaries
are not supported.</doc>
<status status="PASS" start="2026-06-06T03:12:50.537584" elapsed="0.012627"/>
</kw>
<kw name="CompareStream__Convert_Input" owner="CompareStream">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.551168" level="INFO">${args} = []</msg>
<var>${args}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:12:50.550924" elapsed="0.000271"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.551613" level="INFO">${kwargs} = {}</msg>
<var>${kwargs}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.551355" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.552364" level="INFO">${arg} = BuiltIn.Set Variable</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.552073" elapsed="0.000317"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:12:50.552828" level="INFO">${removed} = BuiltIn.SetVariable</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.552545" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.555263" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.552931" elapsed="0.002391"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:12:50.555744" level="INFO">${splitted} = ['BuiltIn.Set Variable']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.555497" elapsed="0.000274"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.555347" elapsed="0.000463"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.552913" elapsed="0.002918"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.556235" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:12:50.556308" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:50.555976" elapsed="0.000355"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.556610" elapsed="0.000208"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.556399" elapsed="0.000457"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.557027" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.556880" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.556381" elapsed="0.000721"/>
</if>
<var name="${arg}">BuiltIn.Set Variable</var>
<status status="PASS" start="2026-06-06T03:12:50.551939" elapsed="0.005187"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.557757" level="INFO">${arg} = verify_peer_group</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.557447" elapsed="0.000335"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:12:50.558244" level="INFO">${removed} = verify_peer_group</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.557937" elapsed="0.000333"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.560707" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.558349" elapsed="0.002419"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:12:50.561171" level="INFO">${splitted} = ['verify_peer_group']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.560939" elapsed="0.000258"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.560793" elapsed="0.000446"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.558331" elapsed="0.002929"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.561682" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:12:50.561757" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:12:50.561406" elapsed="0.000375"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.562065" elapsed="0.000193"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.561852" elapsed="0.000444"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.562493" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.562321" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.561833" elapsed="0.000737"/>
</if>
<var name="${arg}">verify_peer_group</var>
<status status="PASS" start="2026-06-06T03:12:50.557314" elapsed="0.005280"/>
</iter>
<var>${arg}</var>
<value>@{arguments}</value>
<status status="PASS" start="2026-06-06T03:12:50.551704" elapsed="0.010918"/>
</for>
<return>
<value>${args}</value>
<value>${kwargs}</value>
<status status="PASS" start="2026-06-06T03:12:50.562686" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.562880" level="INFO">${args_else} = ['BuiltIn.Set Variable', 'verify_peer_group']</msg>
<msg time="2026-06-06T03:12:50.562933" level="INFO">${kwargs_else} = {}</msg>
<var>${args_else}</var>
<var>${kwargs_else}</var>
<arg>@{varargs_else}</arg>
<doc>Splits arguments into args and kwargs is used in Run_Keyword_If_At_Least_Else and Run_Keyword_If_At_Most_Else.
The problem is, when the string contains =, but it is not a named argument (name=value). There can be many values containing =, but
for sure it is present in xmls. If the string starts with "&lt;" it will be treated as it is xml and splitting for
name and value will not be executed.
If named argument is passed into this kw, only string data are supported e.g. name=string. Complex variables such as lists or dictionaries
are not supported.</doc>
<status status="PASS" start="2026-06-06T03:12:50.550559" elapsed="0.012397"/>
</kw>
<if>
<branch type="IF" condition="${Stream_dict}[${ODL_STREAM}] &gt;= ${Stream_dict}[${lower_bound}]">
<kw name="Run Keyword" owner="BuiltIn">
<kw name="Set Variable" owner="BuiltIn">
<arg>verify_peer_group.sulfur</arg>
<arg>&amp;{kwargs_if}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.563746" elapsed="0.000269"/>
</kw>
<msg time="2026-06-06T03:12:50.564100" level="INFO">${resp} = verify_peer_group.sulfur</msg>
<var>${resp}</var>
<arg>@{args_if}</arg>
<arg>&amp;{kwargs_if}</arg>
<doc>Executes the given keyword with the given arguments.</doc>
<status status="PASS" start="2026-06-06T03:12:50.563339" elapsed="0.000785"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.563029" elapsed="0.001131"/>
</branch>
<branch type="ELSE">
<kw name="Run Keyword" owner="BuiltIn">
<var>${resp}</var>
<arg>@{args_else}</arg>
<arg>&amp;{kwargs_else}</arg>
<doc>Executes the given keyword with the given arguments.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.564336" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.564184" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.563012" elapsed="0.001403"/>
</if>
<return>
<value>${resp}</value>
<status status="PASS" start="2026-06-06T03:12:50.564448" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:12:50.564598" level="INFO">${verify_peer_group_folder} = verify_peer_group.sulfur</msg>
<var>${verify_peer_group_folder}</var>
<arg>sulfur</arg>
<arg>BuiltIn.Set Variable</arg>
<arg>verify_${peer_group_folder}.sulfur</arg>
<arg>ELSE</arg>
<arg>BuiltIn.Set Variable</arg>
<arg>verify_${peer_group_folder}</arg>
<doc>Compare ${lower_bound} to vanadium and in case vanadium is at least ${lower_bound},
run keyword defined before ELSE statement otherwise run keyword defined after ELSE statement and return its value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.533226" elapsed="0.031397"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.597449" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.597078" elapsed="0.000399"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.598255" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.598009" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.598421" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.597657" elapsed="0.000788"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.599016" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.598611" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.599417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.599569" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.599277" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.600020" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/peer-groups/peer-group=$PEER_GROUP_NAME
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.599772" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.601038" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_GROUP_NAME': 'internal-neighbors', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.600773" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.601507" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.601246" elapsed="0.000287"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.602239" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.601941" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.603222" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.602807" elapsed="0.000442"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.603300" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.603450" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.602453" elapsed="0.001021"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.603627" elapsed="0.000251"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:12:50.601775" elapsed="0.002143"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.604456" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.604161" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.605555" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.605151" elapsed="0.000430"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.605631" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:12:50.605815" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.604827" elapsed="0.001013"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.605994" elapsed="0.000220"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:50.604029" elapsed="0.002225"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.606814" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.606497" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.607795" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.607364" elapsed="0.000458"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.607872" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.608022" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.607034" elapsed="0.001013"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.608200" elapsed="0.000220"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:50.606364" elapsed="0.002097"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.609021" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.608726" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.609994" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.609558" elapsed="0.000463"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.610071" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.610219" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.609234" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.610442" elapsed="0.000243"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:50.608577" elapsed="0.002151"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.611266" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.610973" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.612233" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.611832" elapsed="0.000428"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.612309" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.612460" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.611477" elapsed="0.001007"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.612637" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:50.610840" elapsed="0.002076"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.613451" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.613159" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.614457" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.614053" elapsed="0.000430"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.614533" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.614700" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.613707" elapsed="0.001018"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.614877" elapsed="0.000220"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:12:50.613026" elapsed="0.002111"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.615714" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.615380" elapsed="0.000387"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.616872" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.616281" elapsed="0.000618"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.616949" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.617100" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.615955" elapsed="0.001169"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.617277" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:50.615248" elapsed="0.002290"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.618121" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.617827" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.619069" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.618666" elapsed="0.000429"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.619145" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.619292" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.618332" elapsed="0.000984"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.619474" elapsed="0.000278"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:12:50.617691" elapsed="0.002102"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.620332" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.620038" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.621270" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.620874" elapsed="0.000422"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.621346" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.621495" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.620542" elapsed="0.001020"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.621745" elapsed="0.000225"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:50.619905" elapsed="0.002106"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.601581" elapsed="0.020465"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.622088" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:50.622246" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:50.600428" elapsed="0.021845"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.600134" elapsed="0.022171"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.622479" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.622329" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.600115" elapsed="0.022439"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.623410" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.622717" elapsed="0.000721"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.623487" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.596450" elapsed="0.027159"/>
</kw>
<msg time="2026-06-06T03:12:50.623703" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.584127" elapsed="0.039625"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.636074" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.648157" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.660179" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.660375" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.660552" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.660930" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.660785" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:50.660770" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.661175" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.661352" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.661556" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.660740" elapsed="0.000870"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.660626" elapsed="0.001028"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.661806" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.661881" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:50.662002" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.579989" elapsed="0.082040"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.688114" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.687739" elapsed="0.000404"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.688894" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.688671" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.689055" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.688306" elapsed="0.000773"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.689625" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.689243" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.689971" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.690114" level="INFO">${template} = &lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;$PEER_GROUP_NAME&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/co...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.689830" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.690542" level="INFO">&lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;$PEER_GROUP_NAME&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/peer-group&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.690298" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:50.690980" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.690686" elapsed="0.000353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.691512" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.691212" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.691064" elapsed="0.000509"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.690666" elapsed="0.000928"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.692507" level="INFO">${final_text} = &lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.691758" elapsed="0.000829"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.692666" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.687106" elapsed="0.005696"/>
</kw>
<msg time="2026-06-06T03:12:50.692863" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.674686" elapsed="0.018224"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.705174" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.717197" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.730608" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.730823" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.731001" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.731370" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.731225" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:50.731209" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.731594" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.731779" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.731947" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.731181" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.731076" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.732199" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.732274" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:50.732408" level="INFO">${data} = &lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.672045" elapsed="0.060392"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.733785" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.733515" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.733944" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.733163" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.734423" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.734174" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.735141" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.734692" elapsed="0.000475"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.734504" elapsed="0.000697"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.734155" elapsed="0.001067"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.737568" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.735376" elapsed="0.002219"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:50.737661" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.737817" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:50.732832" elapsed="0.005010"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.739244" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.738988" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.739705" level="INFO">&lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/peer-group&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.739447" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.740210" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.739950" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.740672" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.740408" elapsed="0.000309"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:50.741578" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:50.741327" elapsed="0.000276"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:50.741953" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:50.741774" elapsed="0.000204"/>
</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-06-06T03:12:50.742129" elapsed="0.000199"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.742747" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.742485" elapsed="0.000306"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:50.742833" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.742986" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:50.740923" elapsed="0.002088"/>
</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-06-06T03:12:50.758274" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '1041', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/peer-group&gt; 
 </msg>
<msg time="2026-06-06T03:12:50.758512" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:50.758803" 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-06-06T03:12:50.745282" elapsed="0.013593"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.743080" elapsed="0.015904"/>
</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-06-06T03:12:50.759440" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.759050" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.743062" elapsed="0.016638"/>
</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-06-06T03:12:50.767095" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.761861" elapsed="0.005329"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.761331" elapsed="0.005937"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.761290" elapsed="0.006035"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.770179" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.767934" elapsed="0.002291"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.767450" elapsed="0.002810"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.767412" elapsed="0.002872"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.770855" 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-06-06T03:12:50.770455" elapsed="0.000428"/>
</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-06-06T03:12:50.771195" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.770954" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.771788" 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-06-06T03:12:50.771439" elapsed="0.000376"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.771277" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.770935" elapsed="0.000941"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.772401" 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-06-06T03:12:50.772037" elapsed="0.000390"/>
</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-06-06T03:12:50.772750" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.772497" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.773287" 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-06-06T03:12:50.772994" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.772832" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.772478" elapsed="0.000890"/>
</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-06-06T03:12:50.773521" elapsed="0.000360"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:50.774338" 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-06-06T03:12:50.774048" elapsed="0.000317"/>
</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-06-06T03:12:50.774519" elapsed="0.002330"/>
</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-06-06T03:12:50.760503" elapsed="0.016408"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:50.777085" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:12:50.776978" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.776959" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:50.777323" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.777389" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:50.779681" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:12:50.738172" elapsed="0.041537"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.779811" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:50.779968" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:50.569345" elapsed="0.210648"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.780331" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.780090" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.780073" elapsed="0.000350"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.780456" elapsed="0.000025"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${peer_group_folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:50.564906" elapsed="0.215671"/>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.829166" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.828739" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.830001" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.829743" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.830174" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.829369" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.830800" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.830368" elapsed="0.000459"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.831135" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.831301" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.830993" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.831755" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/peer-groups/peer-group=$PEER_GROUP_NAME?content=config
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.831490" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.832797" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_GROUP_NAME': 'internal-neighbors', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.832514" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.833278" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.833006" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.834014" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.833710" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.835206" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.834553" elapsed="0.000680"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.835289" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:50.835444" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.834231" elapsed="0.001238"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.835624" elapsed="0.000262"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:12:50.833550" elapsed="0.002416"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.836543" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.836219" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.837561" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.837136" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.837675" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:12:50.837837" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.836809" elapsed="0.001056"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.838145" elapsed="0.000238"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:50.836082" elapsed="0.002343"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.839202" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.838730" elapsed="0.000507"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.840247" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.839831" elapsed="0.000443"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.840338" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:12:50.840498" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.839479" elapsed="0.001044"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.840713" elapsed="0.000233"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:50.838563" elapsed="0.002426"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.841581" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.841238" elapsed="0.000369"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.842588" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.842136" elapsed="0.000478"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.842693" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.842846" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.841815" elapsed="0.001056"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.843025" elapsed="0.000278"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:50.841103" elapsed="0.002251"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.843935" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.843606" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.844931" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.844486" elapsed="0.000473"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.845010" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.845164" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.844152" elapsed="0.001037"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.845359" elapsed="0.000231"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:50.843467" elapsed="0.002165"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.846210" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.845909" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.847288" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.846873" elapsed="0.000442"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.847368" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:50.847563" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.846466" elapsed="0.001129"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.847778" elapsed="0.000232"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:12:50.845773" elapsed="0.002318"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.848743" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.848346" elapsed="0.000424"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.849718" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.849288" elapsed="0.000457"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.849797" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.849951" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.848964" elapsed="0.001011"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.850129" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:50.848210" elapsed="0.002227"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.851033" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.850719" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.852182" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.851570" elapsed="0.000639"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.852261" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.852413" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.851250" elapsed="0.001187"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.852594" elapsed="0.000282"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:12:50.850555" elapsed="0.002363"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.853472" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:50.853170" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:50.854460" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.854030" elapsed="0.000457"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:50.854539" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.854720" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:50.853707" elapsed="0.001038"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:50.854905" elapsed="0.000229"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:50.853033" elapsed="0.002143"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.833359" elapsed="0.021852"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:50.855254" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:50.855418" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:50.832186" elapsed="0.023258"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.831874" elapsed="0.023602"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.855671" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.855501" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.831852" elapsed="0.023898"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.856612" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.855896" elapsed="0.000794"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.856745" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.828091" elapsed="0.028787"/>
</kw>
<msg time="2026-06-06T03:12:50.856935" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.815383" elapsed="0.041601"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.869461" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.881673" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.893958" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.894158" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.894339" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.894729" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.894564" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:50.894549" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.894966" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.895137" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.895305" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:50.894520" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.894417" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.895531" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.895605" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:50.895745" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.811197" elapsed="0.084574"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.897072" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.896788" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.897236" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.896422" elapsed="0.000838"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.897606" elapsed="0.000069"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.897345" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.898249" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.897950" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.897769" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.897319" elapsed="0.001014"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.900921" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.898521" elapsed="0.002428"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:50.901003" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:50.901162" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:50.896097" elapsed="0.005090"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.902466" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.902224" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.902626" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.901878" elapsed="0.000788"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:12:50.902879" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:50.902741" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.902721" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.903112" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.903287" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.903352" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:12:50.905254" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:50.901499" elapsed="0.003781"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.906731" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.906462" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.907181" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.906935" elapsed="0.000289"/>
</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-06-06T03:12:50.918181" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:50.919231" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '479'} 
 body={"bgp-openconfig-extensions:peer-group":[{"peer-group-name":"internal-neighbors","transport":{"config":{"passive-mode":true}},"route-reflector":{"config":{"route-reflector-client":false}},"timers":{"config":{"hold-time":"180.0","connect-retry":"5.0"}},"config":{"peer-type":"INTERNAL"},"afi-safis":{"afi-safi":[{"afi-safi-name":"openconfig-bgp-types:IPV4-UNICAST"},{"afi-safi-name":"openconfig-bgp-types:IPV6-UNICAST"},{"afi-safi-name":"bgp-openconfig-extensions:LINKSTATE"}]}}]} 
 </msg>
<msg time="2026-06-06T03:12:50.919477" 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-06-06T03:12:50.909543" elapsed="0.009995"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.907291" elapsed="0.012341"/>
</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-06-06T03:12:50.920103" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.919728" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.907272" elapsed="0.013109"/>
</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-06-06T03:12:50.929226" level="INFO">{"bgp-openconfig-extensions:peer-group":[{"peer-group-name":"internal-neighbors","transport":{"config":{"passive-mode":true}},"route-reflector":{"config":{"route-reflector-client":false}},"timers":{"config":{"hold-time":"180.0","connect-retry":"5.0"}},"config":{"peer-type":"INTERNAL"},"afi-safis":{"afi-safi":[{"afi-safi-name":"openconfig-bgp-types:IPV4-UNICAST"},{"afi-safi-name":"openconfig-bgp-types:IPV6-UNICAST"},{"afi-safi-name":"bgp-openconfig-extensions:LINKSTATE"}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.922967" elapsed="0.006432"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.922402" elapsed="0.007080"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.922356" elapsed="0.007184"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.932293" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.930055" elapsed="0.002283"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.929707" elapsed="0.002665"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.929631" elapsed="0.002766"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.932978" 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-06-06T03:12:50.932566" elapsed="0.000439"/>
</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-06-06T03:12:50.933347" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.933078" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.933922" 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-06-06T03:12:50.933597" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.933432" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.933059" elapsed="0.000947"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.934532" 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-06-06T03:12:50.934169" elapsed="0.000390"/>
</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-06-06T03:12:50.934885" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.934630" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.935423" 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-06-06T03:12:50.935128" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.934965" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.934611" elapsed="0.000893"/>
</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-06-06T03:12:50.935674" elapsed="0.000355"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:50.936489" 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-06-06T03:12:50.936201" elapsed="0.000314"/>
</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-06-06T03:12:50.936689" elapsed="0.002466"/>
</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-06-06T03:12:50.921286" elapsed="0.017933"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:50.939397" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:50.939291" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.939271" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:50.942441" level="INFO">${text_normalized} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<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="PASS" start="2026-06-06T03:12:50.939614" elapsed="0.002856"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:12:50.942524" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:12:50.942699" level="INFO">${response_text} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:12:50.905597" elapsed="0.037129"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.942789" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:50.942944" level="INFO">${response_text} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:50.788753" elapsed="0.154256"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.970979" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.970576" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.971796" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:50.971517" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:50.971962" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:50.971176" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.972536" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:50.972154" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:50.972891" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group.sulfur/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:50.973047" level="INFO">${template} = {
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode"...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:50.972754" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.973473" level="INFO">{
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode": true
                }
            },
            "config": {
                "peer-type": "INTERNAL"
            },
            "afi-safis": {
                "afi-safi": [
                    {
                        "afi-safi-name": "openconfig-bgp-types:IPV6-UNICAST"
                    },
                    {
                        "afi-safi-name": "openconfig-bgp-types:IPV4-UNICAST"
                    },
                    {
                        "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
                    }
                ]
            },
            "timers": {
                "config": {
                    "hold-time": "180.0",
                    "connect-retry": "5.0"
                }
            },
            "route-reflector": {
                "config": {
                    "route-reflector-client": false
                }
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:50.973232" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:50.973909" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:50.973592" elapsed="0.000375"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.974450" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:50.974142" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.973991" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.973572" elapsed="0.000962"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:50.975182" level="INFO">${final_text} = {
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode"...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:50.974698" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:50.975260" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:50.969949" elapsed="0.005434"/>
</kw>
<msg time="2026-06-06T03:12:50.975441" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:50.957274" elapsed="0.018215"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.987689" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:50.999792" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.011989" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.012216" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.012398" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.012794" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.012625" elapsed="0.000226"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:51.012610" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.013015" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.013184" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.013351" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:51.012582" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.012477" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.013577" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.013665" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:12:51.013790" level="INFO">${expected_text} = {
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode"...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:50.954686" elapsed="0.059130"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:51.014196" elapsed="0.002367"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:51.017811" level="INFO">${expected_normalized} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.017324" elapsed="0.000515"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:12:51.018464" level="INFO">${actual_normalized} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.017993" elapsed="0.000533"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:12:51.018707" elapsed="0.000332"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:12:51.016911" elapsed="0.002190"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.016664" elapsed="0.002484"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.019343" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.019177" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.016625" elapsed="0.002804"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:12:50.944301" elapsed="0.075178"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:12:50.943342" elapsed="0.076215"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:50.943098" elapsed="0.076506"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:50.943079" elapsed="0.076550"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:51.019680" elapsed="0.000030"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${verify_peer_group_folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:12:50.784385" elapsed="0.235427"/>
</kw>
<doc>Configures peer group which is template for all the neighbors which are going
to be configured. Also after PUT, this case verifies presence of peer group within
peer-groups.</doc>
<status status="PASS" start="2026-06-06T03:12:50.523612" elapsed="0.496268"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.020911" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PEER_GROUP_NAME=internal-neighbors | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIV...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_GROUP_NAME=${PEER_GROUP}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.020083" elapsed="0.000858"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.053606" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:51.053226" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:51.054433" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:51.054160" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:51.054602" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:51.053819" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.055217" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:51.054811" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:51.055543" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:51.055818" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:51.055406" elapsed="0.000441"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.056253" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.056008" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.057273" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.057013" elapsed="0.000352"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.057996" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.057530" elapsed="0.000493"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.058719" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.058404" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.059473" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.059256" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.059621" elapsed="0.000062"/>
</return>
<msg time="2026-06-06T03:12:51.059820" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.058936" elapsed="0.000909"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.060005" elapsed="0.000241"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:12:51.058265" elapsed="0.002023"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.060856" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.060538" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.061607" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.061394" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.061700" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:51.061852" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.061073" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.062031" elapsed="0.000234"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:12:51.060402" elapsed="0.001904"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.062868" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.062553" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.063675" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.063402" elapsed="0.000301"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.063754" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.063905" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.063082" elapsed="0.000847"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.064083" elapsed="0.000223"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:12:51.062418" elapsed="0.001929"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.064917" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.064600" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.065695" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.065450" elapsed="0.000274"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.065773" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.065926" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.065132" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.066103" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:12:51.064465" elapsed="0.001902"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.066933" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.066612" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.067740" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.067489" elapsed="0.000277"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.067815" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.068063" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.067147" elapsed="0.000972"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.068561" elapsed="0.000536"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:12:51.066478" elapsed="0.002712"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.070888" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.069769" elapsed="0.001177"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.072615" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.072149" elapsed="0.000560"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.072822" elapsed="0.000065"/>
</return>
<msg time="2026-06-06T03:12:51.073152" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.071369" elapsed="0.001838"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.073548" elapsed="0.000526"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:12:51.069439" elapsed="0.004728"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.075469" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.074749" elapsed="0.000778"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.076471" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.076261" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.076545" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.076713" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.075939" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.076892" elapsed="0.000228"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:12:51.074417" elapsed="0.002744"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.077728" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.077407" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.078487" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.078275" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.078562" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:51.078739" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.077945" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.078917" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:51.077273" elapsed="0.001906"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.079789" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.079462" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.080529" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.080320" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.080603" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.080773" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.080003" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.080955" elapsed="0.000228"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:12:51.079322" elapsed="0.001902"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.081794" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:12:51.081475" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:12:51.082534" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.082323" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:12:51.082610" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.082779" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:12:51.082007" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:12:51.083002" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:12:51.081336" elapsed="0.001950"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:12:51.058074" elapsed="0.025255"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:12:51.083373" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.083539" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:12:51.056686" elapsed="0.026880"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.056368" elapsed="0.027231"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.083802" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.083624" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.056346" elapsed="0.027535"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.084757" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:51.084026" elapsed="0.000760"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:51.084835" elapsed="0.000027"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:51.052596" elapsed="0.032361"/>
</kw>
<msg time="2026-06-06T03:12:51.085011" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:51.040297" elapsed="0.044761"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.097397" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.109402" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.121784" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.121986" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.122163" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.122525" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.122380" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:51.122365" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.122775" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.122949" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.123161" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:51.122337" elapsed="0.000880"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.122237" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.123395" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.123472" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:51.123594" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:51.036143" elapsed="0.087478"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.149345" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:51.148968" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:51.150110" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:51.149897" elapsed="0.000279">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:51.150271" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:51.149539" elapsed="0.000756"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.150891" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:51.150479" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:12:51.151222" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:12:51.151361" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:12:51.151088" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.151813" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="$PEER_GROUP_NAME"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.151548" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:12:51.152229" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.151935" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.152776" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:51.152460" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.152312" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.151916" elapsed="0.000945"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.153726" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:51.153008" elapsed="0.000749"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:12:51.153807" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:12:51.148334" elapsed="0.005599"/>
</kw>
<msg time="2026-06-06T03:12:51.154020" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:51.135996" elapsed="0.018072"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.167386" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.179446" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.191507" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.191718" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.191899" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.192263" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.192118" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:12:51.192103" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.192485" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.192667" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.192838" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:12:51.192074" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.191973" elapsed="0.000945"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.193066" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.193141" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:51.193263" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:12:51.133393" elapsed="0.059898"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:12:51.194567" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:12:51.194316" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:12:51.194745" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:51.193973" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.195126" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.194876" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.195687" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:51.195378" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.195207" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.194856" elapsed="0.000915"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.198078" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:12:51.195925" elapsed="0.002179"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:12:51.198157" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:12:51.198311" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:12:51.193620" elapsed="0.004715"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.199733" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.199470" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.200176" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbors"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.199936" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.200623" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.200379" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.201088" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.200840" elapsed="0.000291"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:51.201977" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:12:51.201757" elapsed="0.000245"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:12:51.202333" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:12:51.202158" elapsed="0.000200"/>
</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-06-06T03:12:51.202509" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.203127" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.202880" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:12:51.203212" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:12:51.203364" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:12:51.201335" elapsed="0.002054"/>
</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-06-06T03:12:51.217059" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '296', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbors"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:12:51.217137" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:12:51.217276" 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-06-06T03:12:51.205674" elapsed="0.011637"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.203459" elapsed="0.013916"/>
</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-06-06T03:12:51.217662" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.217412" elapsed="0.000395"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.203441" elapsed="0.014398"/>
</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-06-06T03:12:51.222425" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.219171" elapsed="0.003316"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.218858" elapsed="0.003679"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.218831" elapsed="0.003741"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.226331" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.222989" elapsed="0.003407"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.222672" elapsed="0.003774"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.222628" elapsed="0.003853"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.227259" 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-06-06T03:12:51.226734" elapsed="0.000563"/>
</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-06-06T03:12:51.227752" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.227397" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.228518" 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-06-06T03:12:51.228102" elapsed="0.000452"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.227870" elapsed="0.000734"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.227371" elapsed="0.001263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.229391" 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-06-06T03:12:51.228885" elapsed="0.000543"/>
</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-06-06T03:12:51.229922" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.229556" elapsed="0.000447"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.230692" 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-06-06T03:12:51.230260" elapsed="0.000469"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.230036" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.229530" elapsed="0.001277"/>
</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-06-06T03:12:51.231025" elapsed="0.000481"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:12:51.232144" 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-06-06T03:12:51.231761" elapsed="0.000419"/>
</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-06-06T03:12:51.232397" elapsed="0.002734"/>
</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-06-06T03:12:51.218337" elapsed="0.016858"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:12:51.235368" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:51.235263" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.235244" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:12:51.235602" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.235687" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:12:51.237914" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:12:51.198683" elapsed="0.039258"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:51.238005" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:12:51.238157" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:12:51.025558" elapsed="0.212623"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.238516" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.238278" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.238261" elapsed="0.000400"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:12:51.238697" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer_group</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:12:51.021225" elapsed="0.217598"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.240108" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.239727" elapsed="0.000443"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.239708" elapsed="0.000487"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:51.240343" elapsed="0.000327"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.245745" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:51.245313" elapsed="0.000459"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:12:51.245996" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:12:51.245850" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.245829" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.246226" elapsed="0.000021"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.246401" elapsed="0.000020"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.246577" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.246764" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.246935" elapsed="0.000019"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.247103" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.247268" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:12:51.244978" elapsed="0.002366"/>
</kw>
<status status="PASS" start="2026-06-06T03:12:51.239480" elapsed="0.007915"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:12:51.239112" elapsed="0.008325"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:12:50.306011" elapsed="0.941465"/>
</test>
<test id="s1-s4-t13" name="TC_PG_Restart_Talking_BGP_Speaker" line="202">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:12:51.250679" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:12:51.250401" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.251961" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:51.251848" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.251827" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.256884" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:51.256777" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.256758" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.257993" 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-06-06T03:12:51.257591" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.258477" 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-06-06T03:12:51.258183" elapsed="0.000319"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:12:51.258585" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:12:51.258760" 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-06-06T03:12:51.257205" elapsed="0.001581"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:12:51.264324" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:51.264215" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.264195" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:12:51.265632" elapsed="0.000044"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:12:51.265526" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.265507" elapsed="0.000224"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:12:51.266179" 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-06-06T03:12:51.265878" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:12:51.266587" level="INFO">${current_connection_index} = 7</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-06-06T03:12:51.266367" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:51.303342" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:51.267138" elapsed="0.036311"/>
</kw>
<msg time="2026-06-06T03:12:51.303634" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:12:51.303705" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:12:51.266799" elapsed="0.036944"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:12:51.323228" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "s "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:12:51.304268" elapsed="0.019067"/>
</kw>
<msg time="2026-06-06T03:12:51.323497" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:12:51.323542" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "s "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e ...</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-06-06T03:12:51.303920" elapsed="0.019660"/>
</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-06-06T03:12:51.323916" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.323683" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.323638" elapsed="0.000358"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.324463" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "s "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:12:51.324142" elapsed="0.000388"/>
</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-06-06T03:12:51.324838" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.324598" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.324578" elapsed="0.000343"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:12:51.324955" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:12:51.327424" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:12:51.327626" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:12:51.326393" elapsed="0.001389"/>
</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="NOT RUN" start="2026-06-06T03:12:51.328066" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.328431" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:12:51.325775" elapsed="0.002843"/>
</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-06-06T03:12:51.325225" elapsed="0.003491"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:12:51.265223" elapsed="0.063632"/>
</kw>
<msg time="2026-06-06T03:12:51.328950" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:51.328994" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "s "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:51.264545" elapsed="0.064489"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:12:51.329217" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:12:51.329110" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.329091" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.329724" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.330061" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:12:51.330133" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:12:51.263872" elapsed="0.066368"/>
</kw>
<msg time="2026-06-06T03:12:51.330334" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:51.330378" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "s "t "a "r "t "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:12:51.259156" elapsed="0.071259"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.330759" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:12:51.330490" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.330473" elapsed="0.000364"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:12:51.259012" elapsed="0.071849"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:12:51.258840" elapsed="0.072050"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:12:51.256379" elapsed="0.074564"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:12:51.251541" elapsed="0.079457"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:51.251107" elapsed="0.079935"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:12:51.248258" elapsed="0.082835"/>
</kw>
<kw name="Restart_Talking_BGP_Speaker">
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.332781" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:12:51.332432" elapsed="0.000377"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:51.332968" elapsed="0.000232"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:12:51.331949" elapsed="0.001310"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:12:51.352100" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:12:51.333779" elapsed="0.018381"/>
</kw>
<msg time="2026-06-06T03:12:51.352253" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:12:51.352298" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:12:51.333430" elapsed="0.018893"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:12:51.352955" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:12:51.364550" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:12:51.364716" level="INFO">${output_log} = 2026-06-06 03:12:39,305 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:12:39,306 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job): Ope...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:12:51.352814" elapsed="0.011941"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.365343" level="INFO">2026-06-06 03:12:39,305 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:12:39,306 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:12:39,313 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:12:39,314 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:12:39,316 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:12:39,316 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:12:39,316 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:12:39,316 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0001983642578125s
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:39,317 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:12:39,318 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:39,318 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:39,318 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:12:39,318 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:12:39,318 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:12:39,318 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:12:39,329 INFO BGP-Thread-1 (job): ... idle for 0.010s
2026-06-06 03:12:39,329 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.010s
2026-06-06 03:12:49,338 INFO BGP-Thread-1 (job): ... idle for 10.008s
2026-06-06 03:12:49,338 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.019s
2026-06-06 03:12:49,338 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:12:49,338 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:12:49,338 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:12:49,990 INFO BGP-Thread-1 (job): NOTIFICATION message received: 0xffffffffffffffffffffffffffffffff0015030600
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.364981" elapsed="0.000531"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:12:51.352517" elapsed="0.013075"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:12:51.365864" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:12:51.365706" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:12:51.365678" elapsed="0.000301"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.366187" elapsed="0.000031"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:12:51.366421" elapsed="0.000029"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:12:51.331623" elapsed="0.034904"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.367700" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:12:51.367207" elapsed="0.000580"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:12:51.366811" elapsed="0.001061"/>
</kw>
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.369308" level="INFO">${command} = python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:12:51.368842" elapsed="0.000504"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:12:51.369932" level="INFO">python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:12:51.369573" elapsed="0.000422"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:12:51.402904" level="INFO">python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:12:51.403215" level="INFO">${output} =  python3 play.py --amount 3 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --info &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:12:51.370205" elapsed="0.033054"/>
</kw>
<arg>--amount 3 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_TOOL_LOG_LEVEL}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:12:51.368176" elapsed="0.035246"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.406889" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:12:51.406264" elapsed="10.001435">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.408021" elapsed="0.000032"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:12:51.405854" elapsed="10.002325">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:12:51.405237" elapsed="10.003097"/>
</kw>
<msg time="2026-06-06T03:13:01.408461" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:12:51.404569" elapsed="10.003919"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:13:01.408703" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:13:01.408589" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.408557" elapsed="0.000235"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.409035" elapsed="0.000029"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.409217" elapsed="0.000022"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:12:51.404006" elapsed="10.005294"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast. And Start it again.
We have to restart it this way because we reset session before</doc>
<status status="PASS" start="2026-06-06T03:12:51.331245" elapsed="10.078107"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:01.410049" elapsed="0.000311"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:13:01.409663" elapsed="0.000755"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:12:51.247714" elapsed="10.162742"/>
</test>
<test id="s1-s4-t14" name="TC_PG_Check_Talking_Topology_Is_Filled" line="209">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.414554" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.414312" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.414292" elapsed="0.000346"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:01.414099" elapsed="0.000607"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.415767" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.415655" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.415622" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.420745" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.420620" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.420601" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.421934" 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-06-06T03:13:01.421491" elapsed="0.000472"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.422443" 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-06-06T03:13:01.422133" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:01.422514" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:01.422699" 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-06-06T03:13:01.421091" elapsed="0.001634"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:01.428319" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.428195" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.428170" elapsed="0.000222"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:01.429695" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.429556" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.429537" elapsed="0.000231"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:01.430273" 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-06-06T03:13:01.429922" elapsed="0.000379"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.430749" level="INFO">${current_connection_index} = 7</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-06-06T03:13:01.430480" elapsed="0.000296"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.465297" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:01.431297" elapsed="0.034249"/>
</kw>
<msg time="2026-06-06T03:13:01.465879" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:01.465947" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:01.430946" elapsed="0.035052"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.486252" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:13:01.466918" elapsed="0.019511"/>
</kw>
<msg time="2026-06-06T03:13:01.486633" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:01.486704" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ ...</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-06-06T03:13:01.466311" elapsed="0.020433"/>
</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-06-06T03:13:01.487151" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.486850" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.486819" elapsed="0.000418"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.487774" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:13:01.487393" elapsed="0.000451"/>
</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-06-06T03:13:01.488206" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.487979" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.487959" elapsed="0.000327"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:01.488323" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:01.490959" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:13:01.491171" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:01.489920" elapsed="0.001387"/>
</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="NOT RUN" start="2026-06-06T03:13:01.491589" elapsed="0.000103"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.491956" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:01.489256" elapsed="0.002892"/>
</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-06-06T03:13:01.488657" elapsed="0.003557"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:01.429245" elapsed="0.063068"/>
</kw>
<msg time="2026-06-06T03:13:01.492409" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:01.492454" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:01.428559" elapsed="0.063933"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:01.492834" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:13:01.492570" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.492550" elapsed="0.000411"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.493410" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.493819" elapsed="0.000028"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.493897" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:01.427820" elapsed="0.066188"/>
</kw>
<msg time="2026-06-06T03:13:01.494104" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:01.494148" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "T "a "l "k "i "n "g "_ "T "o "p "o "l "o "g "y "_ ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:01.423121" elapsed="0.071064"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.494526" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.494262" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.494243" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:01.422969" elapsed="0.071660"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:01.422784" elapsed="0.071898"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:01.420239" elapsed="0.074521"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:01.415344" elapsed="0.079482"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:01.414866" elapsed="0.080009"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:01.411340" elapsed="0.083595"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.547888" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:01.547398" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.549026" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:01.548579" elapsed="0.000523">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:01.549201" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:01.548200" elapsed="0.001026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.549824" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:01.549401" elapsed="0.000450"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.550162" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:01.550342" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:01.550017" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.550813" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.550537" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.552191" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.551699" elapsed="0.000556"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.552868" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.552423" elapsed="0.000472"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.553339" elapsed="0.000048"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.554088" elapsed="0.000052"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.554441" elapsed="0.000047"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:01.553121" elapsed="0.001490"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.552952" elapsed="0.001756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:01.554763" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:01.554940" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:01.551296" elapsed="0.003669"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.550940" elapsed="0.004058"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.555180" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.555024" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.550915" elapsed="0.004342"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.555925" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:01.555406" elapsed="0.000547"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:01.556003" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:01.546633" elapsed="0.009497"/>
</kw>
<msg time="2026-06-06T03:13:01.556186" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:01.533462" elapsed="0.022777"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.569287" elapsed="0.000057"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.581623" elapsed="0.000071"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.594236" elapsed="0.000064"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.594557" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.594764" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.595209" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.595054" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:01.595034" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.595436" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.595606" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.595793" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:01.594994" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.594855" elapsed="0.001019"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.596024" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.596104" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:01.596263" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:01.529083" elapsed="0.067208"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.597797" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:01.597480" elapsed="0.000394">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:01.597969" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:01.597076" elapsed="0.000917"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.598338" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.598064" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.598922" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:01.598603" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.598420" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.598044" elapsed="0.000962"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.601686" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:01.599160" elapsed="0.002556"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:01.601772" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:01.601943" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:01.596714" elapsed="0.005318"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.603456" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:01.603161" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:01.603667" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:01.602767" elapsed="0.000932"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:01.603968" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:01.603794" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.603769" elapsed="0.000286"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.604223" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.604466" elapsed="0.000027"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.604553" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:13:01.606986" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:01.602381" elapsed="0.004647"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.608948" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.608621" elapsed="0.000382"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.609427" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.609166" elapsed="0.000305"/>
</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-06-06T03:13:01.620469" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:01.620775" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:13:01.620956" 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-06-06T03:13:01.611694" elapsed="0.009301"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.609547" elapsed="0.011528"/>
</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-06-06T03:13:01.621433" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.621121" elapsed="0.000424"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.609524" elapsed="0.012054"/>
</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-06-06T03:13:01.627281" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.623418" elapsed="0.003943"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.623000" elapsed="0.004419"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.622965" elapsed="0.004495"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.630725" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.627946" elapsed="0.002826"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.627549" elapsed="0.003259"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.627522" elapsed="0.003310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.631439" 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-06-06T03:13:01.631033" elapsed="0.000433"/>
</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-06-06T03:13:01.631798" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.631539" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.632476" 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-06-06T03:13:01.632118" elapsed="0.000389"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.631946" elapsed="0.000599"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.631520" elapsed="0.001046"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.633238" 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-06-06T03:13:01.632775" elapsed="0.000496"/>
</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-06-06T03:13:01.633591" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.633352" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.634154" 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-06-06T03:13:01.633856" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.633691" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.633333" elapsed="0.000905"/>
</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-06-06T03:13:01.634397" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:01.635231" 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-06-06T03:13:01.634936" elapsed="0.000321"/>
</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-06-06T03:13:01.635418" elapsed="0.002517"/>
</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-06-06T03:13:01.622209" elapsed="0.015821"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.638260" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.638124" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.638099" elapsed="0.000248"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:01.641458" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:13:01.638538" elapsed="0.002950"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:01.641544" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:01.641754" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:01.607585" elapsed="0.034195"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:01.641846" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:01.641998" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:01.506765" elapsed="0.135260"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.670950" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:01.670126" elapsed="0.000858"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.673107" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:01.672505" elapsed="0.000764">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:01.673403" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:01.671171" elapsed="0.002257"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.674470" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:01.673698" elapsed="0.000800"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.674934" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:01.675193" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:01.674690" elapsed="0.000532"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.675870" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.675386" elapsed="0.000570"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:01.676807" elapsed="0.000081"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.676049" elapsed="0.000921"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.677844" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:01.677183" elapsed="0.000702"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.677000" elapsed="0.000969"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.676022" elapsed="0.001972"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.678988" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:01.678150" elapsed="0.000868"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:01.679073" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:01.669162" elapsed="0.010048"/>
</kw>
<msg time="2026-06-06T03:13:01.679268" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:01.656461" elapsed="0.022859"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.692246" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.704572" elapsed="0.000058"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.716875" elapsed="0.000054"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.717168" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.717361" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.717970" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.717811" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:01.717792" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.718210" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.718383" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.718554" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:01.717752" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.717593" elapsed="0.001042"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.718803" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.718885" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:13:01.719045" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:01.653728" elapsed="0.065345"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:01.719253" elapsed="0.002290"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:01.722953" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.722368" elapsed="0.000616"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:01.723694" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.723145" elapsed="0.000586"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:01.723943" elapsed="0.000369"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:01.721922" elapsed="0.002453"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.721626" elapsed="0.002784"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.724590" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.724437" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.721607" elapsed="0.003080"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:01.643253" elapsed="0.081483"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:01.642393" elapsed="0.082420"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.642111" elapsed="0.082750"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.642093" elapsed="0.082793"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:01.724925" elapsed="0.000037"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:01.500297" elapsed="0.224770"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:01.496057" elapsed="0.229076"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:01.495465" elapsed="0.229715"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:01.495083" elapsed="0.230221"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:01.725940" elapsed="0.000250"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:01.725598" elapsed="0.000657"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:01.410720" elapsed="0.315575"/>
</test>
<test id="s1-s4-t15" name="TC_PG_Reconfigure_ODL_With_Peer_Group_Without_Ipv4_Unicast" line="214">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.730102" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.729848" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.729825" elapsed="0.000365"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:01.729617" elapsed="0.000621"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.731314" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.731197" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.731177" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.738129" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.738001" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.737978" elapsed="0.000229"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.739308" 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-06-06T03:13:01.738881" elapsed="0.000455"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.739824" 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-06-06T03:13:01.739504" elapsed="0.000383"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:01.739934" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:01.740096" 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-06-06T03:13:01.738473" elapsed="0.001646"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:01.745913" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.745794" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.745772" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:01.747400" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:01.747293" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.747275" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:01.747981" 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-06-06T03:13:01.747618" elapsed="0.000391"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.748408" level="INFO">${current_connection_index} = 7</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-06-06T03:13:01.748175" elapsed="0.000268"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.785147" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:01.748974" elapsed="0.036463"/>
</kw>
<msg time="2026-06-06T03:13:01.785768" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:01.785831" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:01.748609" elapsed="0.037270"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:01.835658" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e "e "r "_ "G "r "o "u "p "_ "W "i "t "h "o "u "t "_ "I "p "v "4 "_ "U "n "i "c "a "s "t "[K"
[?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-06-06T03:13:01.786868" elapsed="0.049012"/>
</kw>
<msg time="2026-06-06T03:13:01.836110" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:01.836159" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e ...</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-06-06T03:13:01.786221" elapsed="0.050037"/>
</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-06-06T03:13:01.836722" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.836373" elapsed="0.000411"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.836338" elapsed="0.000473"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.837377" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e "e "r "_ "G "r "o "u "p "_ "W "i "t "h "o "u "t "_ "I "p "v "4 "_ "U "n "i "c "a "s "t "[K"
[?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-06-06T03:13:01.836959" elapsed="0.000521"/>
</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-06-06T03:13:01.837906" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.837574" elapsed="0.000410"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.837547" elapsed="0.000464"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:01.838051" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:01.841159" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:13:01.841405" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:01.839817" elapsed="0.001732"/>
</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="NOT RUN" start="2026-06-06T03:13:01.841857" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.842425" elapsed="0.000083"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:01.839056" elapsed="0.003575"/>
</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-06-06T03:13:01.838389" elapsed="0.004343"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:01.746987" elapsed="0.095850"/>
</kw>
<msg time="2026-06-06T03:13:01.842941" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:01.842987" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:01.746155" elapsed="0.096871"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:01.843501" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:13:01.843115" elapsed="0.000462"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.843090" elapsed="0.000513"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.844148" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.844511" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.844585" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:01.745370" elapsed="0.099344"/>
</kw>
<msg time="2026-06-06T03:13:01.844812" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:01.844857" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "W "i "t "h "_ "P "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:01.740711" elapsed="0.104183"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.845237" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.844972" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.844954" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:01.740361" elapsed="0.104978"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:01.740180" elapsed="0.105191"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:01.737540" elapsed="0.107885"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:01.730891" elapsed="0.114591"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:01.730396" elapsed="0.115186"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:01.727284" elapsed="0.118352"/>
</kw>
<kw name="Configure_Peer_Group">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.847394" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | PEER_GROUP_NAME=internal-neighbor...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<arg>PEER_GROUP_NAME=${PEER_GROUP}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.846234" elapsed="0.001191"/>
</kw>
<kw name="Run_Keyword_If_At_Least_Else" owner="CompareStream">
<kw name="Get Index From List" owner="Collections">
<msg time="2026-06-06T03:13:01.856623" level="INFO">${position} = 2</msg>
<var>${position}</var>
<arg>${varargs}</arg>
<arg>\ELSE</arg>
<doc>Returns the index of the first occurrence of the ``value`` on the list.</doc>
<status status="PASS" start="2026-06-06T03:13:01.856418" elapsed="0.000247"/>
</kw>
<if>
<branch type="IF" condition="&quot;${position}&quot; == &quot;-1&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>Missing else statement in defined expresion</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.856972" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.856744" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.856724" elapsed="0.000329"/>
</if>
<kw name="Get Slice From List" owner="Collections">
<msg time="2026-06-06T03:13:01.857465" level="INFO">${varargs_if} = ['BuiltIn.Set Variable', 'verify_peer_group_without_ipv4.sulfur']</msg>
<var>${varargs_if}</var>
<arg>${varargs}</arg>
<arg>0</arg>
<arg>${position}</arg>
<doc>Returns a slice of the given list between ``start`` and ``end`` indexes.</doc>
<status status="PASS" start="2026-06-06T03:13:01.857199" elapsed="0.000293"/>
</kw>
<kw name="Get Slice From List" owner="Collections">
<msg time="2026-06-06T03:13:01.860045" level="INFO">${varargs_else} = ['BuiltIn.Set Variable', 'verify_peer_group_without_ipv4']</msg>
<var>${varargs_else}</var>
<arg>${varargs}</arg>
<arg>${position+1}</arg>
<doc>Returns a slice of the given list between ``start`` and ``end`` indexes.</doc>
<status status="PASS" start="2026-06-06T03:13:01.857672" elapsed="0.002403"/>
</kw>
<kw name="CompareStream__Convert_Input" owner="CompareStream">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.861109" level="INFO">${args} = []</msg>
<var>${args}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:13:01.860820" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.861578" level="INFO">${kwargs} = {}</msg>
<var>${kwargs}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.861305" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.862374" level="INFO">${arg} = BuiltIn.Set Variable</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.862064" elapsed="0.000336"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:13:01.862857" level="INFO">${removed} = BuiltIn.SetVariable</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.862562" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.866451" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.862964" elapsed="0.003548"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:13:01.866947" level="INFO">${splitted} = ['BuiltIn.Set Variable']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.866700" elapsed="0.000274"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.866538" elapsed="0.000477"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.862946" elapsed="0.004091"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.867491" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:13:01.867566" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:01.867183" elapsed="0.000407"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.867898" elapsed="0.000203"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.867679" elapsed="0.000461"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.868313" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.868166" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.867659" elapsed="0.000730"/>
</if>
<var name="${arg}">BuiltIn.Set Variable</var>
<status status="PASS" start="2026-06-06T03:13:01.861925" elapsed="0.006489"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.869071" level="INFO">${arg} = verify_peer_group_without_ipv4.sulfur</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.868766" elapsed="0.000333"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:13:01.869701" level="INFO">${removed} = verify_peer_group_without_ipv4.sulfur</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.869257" elapsed="0.000471"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.872235" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.869806" elapsed="0.002491"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:13:01.872734" level="INFO">${splitted} = ['verify_peer_group_without_ipv4.sulfur']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.872471" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.872323" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.869787" elapsed="0.003110"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.873330" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:13:01.873405" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:01.873048" elapsed="0.000382"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.873731" elapsed="0.000205"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.873500" elapsed="0.000476"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.874149" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.874001" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.873482" elapsed="0.000744"/>
</if>
<var name="${arg}">verify_peer_group_without_ipv4.sulfur</var>
<status status="PASS" start="2026-06-06T03:13:01.868614" elapsed="0.005637"/>
</iter>
<var>${arg}</var>
<value>@{arguments}</value>
<status status="PASS" start="2026-06-06T03:13:01.861677" elapsed="0.012606"/>
</for>
<return>
<value>${args}</value>
<value>${kwargs}</value>
<status status="PASS" start="2026-06-06T03:13:01.874329" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:01.874542" level="INFO">${args_if} = ['BuiltIn.Set Variable', 'verify_peer_group_without_ipv4.sulfur']</msg>
<msg time="2026-06-06T03:13:01.874593" level="INFO">${kwargs_if} = {}</msg>
<var>${args_if}</var>
<var>${kwargs_if}</var>
<arg>@{varargs_if}</arg>
<doc>Splits arguments into args and kwargs is used in Run_Keyword_If_At_Least_Else and Run_Keyword_If_At_Most_Else.
The problem is, when the string contains =, but it is not a named argument (name=value). There can be many values containing =, but
for sure it is present in xmls. If the string starts with "&lt;" it will be treated as it is xml and splitting for
name and value will not be executed.
If named argument is passed into this kw, only string data are supported e.g. name=string. Complex variables such as lists or dictionaries
are not supported.</doc>
<status status="PASS" start="2026-06-06T03:13:01.860448" elapsed="0.014168"/>
</kw>
<kw name="CompareStream__Convert_Input" owner="CompareStream">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.875667" level="INFO">${args} = []</msg>
<var>${args}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:13:01.875393" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.876143" level="INFO">${kwargs} = {}</msg>
<var>${kwargs}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.875866" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.876946" level="INFO">${arg} = BuiltIn.Set Variable</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.876604" elapsed="0.000374"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:13:01.877416" level="INFO">${removed} = BuiltIn.SetVariable</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.877139" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.879914" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.877522" elapsed="0.002454"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:13:01.880396" level="INFO">${splitted} = ['BuiltIn.Set Variable']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.880151" elapsed="0.000272"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.880003" elapsed="0.000461"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.877503" elapsed="0.002981"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.880937" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:13:01.881012" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:01.880632" elapsed="0.000405"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.881410" elapsed="0.000224"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.881124" elapsed="0.000569"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.881876" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.881720" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.881098" elapsed="0.000857"/>
</if>
<var name="${arg}">BuiltIn.Set Variable</var>
<status status="PASS" start="2026-06-06T03:13:01.876467" elapsed="0.005513"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.882704" level="INFO">${arg} = verify_peer_group_without_ipv4</msg>
<var>${arg}</var>
<arg>${arg}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.882375" elapsed="0.000357"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:13:01.883166" level="INFO">${removed} = verify_peer_group_without_ipv4</msg>
<var>${removed}</var>
<arg>${arg}</arg>
<arg>\n</arg>
<arg>${Space}</arg>
<arg>\t</arg>
<arg>\r</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.882890" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="&quot;${removed[0]}&quot; == &quot;&lt;&quot;">
<kw name="Create List" owner="BuiltIn">
<var>${splitted}</var>
<arg>${arg}</arg>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.885865" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.883273" elapsed="0.002653"/>
</branch>
<branch type="ELSE">
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:13:01.886433" level="INFO">${splitted} = ['verify_peer_group_without_ipv4']</msg>
<var>${splitted}</var>
<arg>${arg}</arg>
<arg>separator==</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.886138" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.885951" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.883254" elapsed="0.003341"/>
</if>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.887099" level="INFO">Length is 1.</msg>
<msg time="2026-06-06T03:13:01.887178" level="INFO">${len} = 1</msg>
<var>${len}</var>
<arg>${splitted}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:01.886768" elapsed="0.000435"/>
</kw>
<if>
<branch type="IF" condition="${len}==1">
<kw name="Append To List" owner="Collections">
<arg>${args}</arg>
<arg>${splitted}[0]</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.887522" elapsed="0.000225"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.887276" elapsed="0.000511"/>
</branch>
<branch type="ELSE">
<kw name="Set To Dictionary" owner="Collections">
<arg>${kwargs}</arg>
<arg>@{splitted}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.887960" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.887812" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.887256" elapsed="0.000782"/>
</if>
<var name="${arg}">verify_peer_group_without_ipv4</var>
<status status="PASS" start="2026-06-06T03:13:01.882237" elapsed="0.005826"/>
</iter>
<var>${arg}</var>
<value>@{arguments}</value>
<status status="PASS" start="2026-06-06T03:13:01.876221" elapsed="0.011874"/>
</for>
<return>
<value>${args}</value>
<value>${kwargs}</value>
<status status="PASS" start="2026-06-06T03:13:01.888141" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:13:01.888359" level="INFO">${args_else} = ['BuiltIn.Set Variable', 'verify_peer_group_without_ipv4']</msg>
<msg time="2026-06-06T03:13:01.888410" level="INFO">${kwargs_else} = {}</msg>
<var>${args_else}</var>
<var>${kwargs_else}</var>
<arg>@{varargs_else}</arg>
<doc>Splits arguments into args and kwargs is used in Run_Keyword_If_At_Least_Else and Run_Keyword_If_At_Most_Else.
The problem is, when the string contains =, but it is not a named argument (name=value). There can be many values containing =, but
for sure it is present in xmls. If the string starts with "&lt;" it will be treated as it is xml and splitting for
name and value will not be executed.
If named argument is passed into this kw, only string data are supported e.g. name=string. Complex variables such as lists or dictionaries
are not supported.</doc>
<status status="PASS" start="2026-06-06T03:13:01.875022" elapsed="0.013413"/>
</kw>
<if>
<branch type="IF" condition="${Stream_dict}[${ODL_STREAM}] &gt;= ${Stream_dict}[${lower_bound}]">
<kw name="Run Keyword" owner="BuiltIn">
<kw name="Set Variable" owner="BuiltIn">
<arg>verify_peer_group_without_ipv4.sulfur</arg>
<arg>&amp;{kwargs_if}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:01.889276" elapsed="0.000277"/>
</kw>
<msg time="2026-06-06T03:13:01.889656" level="INFO">${resp} = verify_peer_group_without_ipv4.sulfur</msg>
<var>${resp}</var>
<arg>@{args_if}</arg>
<arg>&amp;{kwargs_if}</arg>
<doc>Executes the given keyword with the given arguments.</doc>
<status status="PASS" start="2026-06-06T03:13:01.888860" elapsed="0.000824"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.888514" elapsed="0.001206"/>
</branch>
<branch type="ELSE">
<kw name="Run Keyword" owner="BuiltIn">
<var>${resp}</var>
<arg>@{args_else}</arg>
<arg>&amp;{kwargs_else}</arg>
<doc>Executes the given keyword with the given arguments.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.889916" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.889745" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.888495" elapsed="0.001503"/>
</if>
<return>
<value>${resp}</value>
<status status="PASS" start="2026-06-06T03:13:01.890033" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:01.890190" level="INFO">${verify_peer_group_folder} = verify_peer_group_without_ipv4.sulfur</msg>
<var>${verify_peer_group_folder}</var>
<arg>sulfur</arg>
<arg>BuiltIn.Set Variable</arg>
<arg>verify_${peer_group_folder}.sulfur</arg>
<arg>ELSE</arg>
<arg>BuiltIn.Set Variable</arg>
<arg>verify_${peer_group_folder}</arg>
<doc>Compare ${lower_bound} to vanadium and in case vanadium is at least ${lower_bound},
run keyword defined before ELSE statement otherwise run keyword defined after ELSE statement and return its value.</doc>
<status status="PASS" start="2026-06-06T03:13:01.855985" elapsed="0.034231"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.933879" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:01.933465" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.934817" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:01.934432" elapsed="0.000467">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:01.934995" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:01.934093" elapsed="0.000927"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.935591" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:01.935204" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:01.935947" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:01.936126" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:01.935804" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.936579" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/peer-groups/peer-group=$PEER_GROUP_NAME
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.936319" elapsed="0.000397"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.937732" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_GROUP_NAME': 'internal-neighbors', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:01.937444" elapsed="0.000336"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.938220" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.937945" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.939156" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.938627" elapsed="0.000557"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.940178" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.939724" elapsed="0.000481"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.940259" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:01.940418" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.939385" elapsed="0.001058"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.940602" elapsed="0.000264"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:01.938489" elapsed="0.002420"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.941459" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.941156" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.942418" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.942011" elapsed="0.000435"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.942496" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:01.942662" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.941690" elapsed="0.000998"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.942842" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:13:01.941022" elapsed="0.002086"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.943690" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.943371" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.944653" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.944227" elapsed="0.000455"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.944733" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:01.944884" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.943907" elapsed="0.001001"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.945061" elapsed="0.000222"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:13:01.943231" elapsed="0.002094"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.945899" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.945567" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.946858" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.946433" elapsed="0.000451"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.946936" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:01.947086" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.946113" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.947278" elapsed="0.000221"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:01.945435" elapsed="0.002106"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.948102" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.947805" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.949059" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.948633" elapsed="0.000485"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.949172" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:01.949325" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.948315" elapsed="0.001035"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.949503" elapsed="0.000253"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:01.947670" elapsed="0.002129"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.950343" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.950045" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.951529" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.950907" elapsed="0.000649"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.951608" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:13:01.951813" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.950570" elapsed="0.001271"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.952002" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:13:01.949911" elapsed="0.002356"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.952829" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.952514" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.953804" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.953361" elapsed="0.000469"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.953880" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:01.954031" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.953043" elapsed="0.001012"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.954209" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:01.952381" elapsed="0.002090"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.955032" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.954733" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.955999" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.955579" elapsed="0.000447"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.956076" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:01.956226" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.955260" elapsed="0.000990"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.956406" elapsed="0.000222"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:13:01.954583" elapsed="0.002112"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.957240" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:01.956943" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:01.958240" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.957824" elapsed="0.000449"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:01.958324" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:01.958473" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:01.957469" elapsed="0.001029"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:01.958668" elapsed="0.000233"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:01.956808" elapsed="0.002135"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:01.938301" elapsed="0.020677"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:01.959021" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:01.959198" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:01.937114" elapsed="0.022143"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:01.936796" elapsed="0.022496"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.959470" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.959318" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:01.936772" elapsed="0.022775"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:01.960471" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:01.959745" elapsed="0.000755"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:01.960551" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:01.932815" elapsed="0.027877"/>
</kw>
<msg time="2026-06-06T03:13:01.960758" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:01.920032" elapsed="0.040775"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.973213" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.985451" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.997854" elapsed="0.000057"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.998212" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.998419" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.998897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:01.998740" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:01.998721" elapsed="0.000292"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.999176" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.999345" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.999511" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:01.998676" elapsed="0.000888"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.998509" elapsed="0.001082"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:01.999757" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:01.999838" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:13:02.000090" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:01.914714" elapsed="0.085405"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.026228" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.025836" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.027092" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.026786" elapsed="0.000386">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.027268" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.026428" elapsed="0.000865"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.027866" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.027461" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.028201" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:02.028388" level="INFO">${template} = &lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;$PEER_GROUP_NAME&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/co...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.028059" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.028847" level="INFO">&lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;$PEER_GROUP_NAME&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/peer-group&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.028579" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:02.029277" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.028974" elapsed="0.000362"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.029828" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.029509" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.029361" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.028954" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.030869" level="INFO">${final_text} = &lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.030062" elapsed="0.000838"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.030951" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:02.025199" elapsed="0.005879"/>
</kw>
<msg time="2026-06-06T03:13:02.031177" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.012732" elapsed="0.018496"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.044190" elapsed="0.000110"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.057835" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.070404" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.070622" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.070843" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.071234" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.071084" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:02.071067" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.071461" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.071631" elapsed="0.000036"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.071819" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.071034" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.070925" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.072046" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.072122" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:02.072262" level="INFO">${data} = &lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.010058" elapsed="0.062234"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.073633" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.073360" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group_without_ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.073817" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.072986" elapsed="0.000910"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.074233" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.073972" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.074822" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.074498" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.074315" elapsed="0.000570"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.073953" elapsed="0.000953"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.077227" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.075063" elapsed="0.002190"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:02.077305" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.077457" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group_without_ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:02.072626" elapsed="0.004856"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.078897" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.078619" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.079340" level="INFO">&lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/peer-group&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.079102" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.079824" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.079550" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.080273" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.080020" elapsed="0.000320"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:02.081330" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:13:02.081134" elapsed="0.000226"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:13:02.081845" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:13:02.081670" elapsed="0.000201"/>
</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-06-06T03:13:02.082021" elapsed="0.000207"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.082628" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.082383" elapsed="0.000333"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:13:02.082761" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.082915" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:13:02.080724" elapsed="0.002216"/>
</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-06-06T03:13:02.102142" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '897', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;peer-group xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;peer-group-name&gt;internal-neighbors&lt;/peer-group-name&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/peer-group&gt; 
 </msg>
<msg time="2026-06-06T03:13:02.102302" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:02.102492" level="INFO">${response} = &lt;Response [204]&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-06-06T03:13:02.085231" elapsed="0.017323"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.083009" elapsed="0.019690"/>
</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-06-06T03:13:02.102987" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.102752" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.082991" elapsed="0.020124"/>
</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-06-06T03:13:02.107861" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.104520" elapsed="0.003402"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.104198" elapsed="0.003774"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.104170" elapsed="0.003838"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.111588" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.108399" elapsed="0.003272"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.108086" elapsed="0.003635"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.108063" elapsed="0.003693"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.112528" 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-06-06T03:13:02.111993" elapsed="0.000573"/>
</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-06-06T03:13:02.113022" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.112687" elapsed="0.000416"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.113810" 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-06-06T03:13:02.113370" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.113136" elapsed="0.000760"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.112659" elapsed="0.001266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.114926" 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-06-06T03:13:02.114149" elapsed="0.000816"/>
</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-06-06T03:13:02.115451" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.115064" elapsed="0.000503"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.116306" 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-06-06T03:13:02.115884" elapsed="0.000459"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.115612" elapsed="0.000781"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.115038" elapsed="0.001384"/>
</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-06-06T03:13:02.116638" elapsed="0.000604"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:02.117989" 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-06-06T03:13:02.117516" elapsed="0.000513"/>
</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-06-06T03:13:02.118259" elapsed="0.003230"/>
</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-06-06T03:13:02.103684" elapsed="0.017896"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:13:02.121850" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:13:02.121697" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.121667" elapsed="0.000314"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:13:02.122200" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.122299" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:13:02.124862" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:13:02.077824" elapsed="0.047066"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.124957" elapsed="0.000087"/>
</return>
<msg time="2026-06-06T03:13:02.125185" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:01.894930" elapsed="0.230279"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.125566" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.125310" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.125292" elapsed="0.000384"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.125710" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${peer_group_folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:13:01.890516" elapsed="0.235319"/>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.174044" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.173663" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.174909" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.174604" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.175086" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.174243" elapsed="0.000868"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.175690" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.175279" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.176024" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:02.176202" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.175884" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.176632" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/peer-groups/peer-group=$PEER_GROUP_NAME?content=config
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.176388" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.177698" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_GROUP_NAME': 'internal-neighbors', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.177407" elapsed="0.000339"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.178194" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.177913" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.178935" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.178620" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.179964" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.179502" elapsed="0.000489"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.180043" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:02.180197" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.179153" elapsed="0.001068"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.180401" elapsed="0.000275"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:02.178476" elapsed="0.002293"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.181352" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.181026" elapsed="0.000365"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.182469" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.181985" elapsed="0.000516"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.182563" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:13:02.182737" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.181583" elapsed="0.001181"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.182938" elapsed="0.000248"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:13:02.180888" elapsed="0.002341"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.183999" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.183488" elapsed="0.000547"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.185009" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.184573" elapsed="0.000463"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.185087" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:02.185239" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.184240" elapsed="0.001024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.185442" elapsed="0.000263"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:13:02.183351" elapsed="0.002398"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.186419" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.186034" elapsed="0.000420"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.187406" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.186999" elapsed="0.000433"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.187483" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:02.187631" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.186675" elapsed="0.000996"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.187826" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:02.185871" elapsed="0.002216"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.188665" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.188336" elapsed="0.000357"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.189601" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.189198" elapsed="0.000429"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.189694" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.189844" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.188882" elapsed="0.000986"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.190020" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:02.188203" elapsed="0.002083"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.190924" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.190560" elapsed="0.000390"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.191927" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.191494" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.192005" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.192154" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.191155" elapsed="0.001023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.192329" elapsed="0.000225"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:13:02.190426" elapsed="0.002206"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.193240" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.192939" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.194219" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.193806" elapsed="0.000441"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.194300" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:13:02.194477" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.193457" elapsed="0.001045"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.194681" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:02.192802" elapsed="0.002148"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.195577" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.195202" elapsed="0.000411"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.197297" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.196369" elapsed="0.000976"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.197420" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:13:02.197671" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.195899" elapsed="0.001811"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.197938" elapsed="0.000317"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:13:02.195066" elapsed="0.003277"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.199196" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.198780" elapsed="0.000452"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.200550" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.199977" elapsed="0.000610"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.200761" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:13:02.200972" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.199498" elapsed="0.001508"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.201223" elapsed="0.000308"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:02.198508" elapsed="0.003079"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:02.178275" elapsed="0.023360"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:02.201717" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:13:02.201948" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:02.177083" elapsed="0.024904"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.176766" elapsed="0.025267"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.202444" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.202072" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.176745" elapsed="0.025879"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.204014" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.202894" elapsed="0.001160"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.204112" elapsed="0.000040"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:02.173013" elapsed="0.031276"/>
</kw>
<msg time="2026-06-06T03:13:02.204362" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.160565" elapsed="0.043928"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.219737" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.232488" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.245050" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.245262" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.245459" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.245902" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.245742" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:02.245724" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.246136" elapsed="0.000039"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.246333" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.246501" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.245685" elapsed="0.000868"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.245551" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.246749" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.246825" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:02.246966" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.156412" elapsed="0.090793"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.250431" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.249761" elapsed="0.000829">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.250834" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.248828" elapsed="0.002059"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.251731" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.251121" elapsed="0.000740"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.253177" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.252379" elapsed="0.000891"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.251916" elapsed="0.001448"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.251076" elapsed="0.002338"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.259357" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.253800" elapsed="0.005597"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:02.259472" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:13:02.259711" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:02.248031" elapsed="0.011716"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.261527" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.261171" elapsed="0.000446">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.261773" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.260663" elapsed="0.001145"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:02.262098" elapsed="0.000059"/>
</return>
<status status="PASS" start="2026-06-06T03:13:02.261907" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.261881" elapsed="0.000357"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.262447" elapsed="0.000030"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.262720" elapsed="0.000031"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.262815" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:13:02.265464" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:02.260180" elapsed="0.005321"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.267315" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.267018" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.267791" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.267525" elapsed="0.000311"/>
</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-06-06T03:13:02.279219" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:02.280090" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '425'} 
 body={"bgp-openconfig-extensions:peer-group":[{"peer-group-name":"internal-neighbors","transport":{"config":{"passive-mode":true}},"route-reflector":{"config":{"route-reflector-client":false}},"timers":{"config":{"hold-time":"180.0","connect-retry":"5.0"}},"config":{"peer-type":"INTERNAL"},"afi-safis":{"afi-safi":[{"afi-safi-name":"openconfig-bgp-types:IPV6-UNICAST"},{"afi-safi-name":"bgp-openconfig-extensions:LINKSTATE"}]}}]} 
 </msg>
<msg time="2026-06-06T03:13:02.280355" 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-06-06T03:13:02.269990" elapsed="0.010432"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.267902" elapsed="0.012622"/>
</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-06-06T03:13:02.281000" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.280588" elapsed="0.000645"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.267884" elapsed="0.013404"/>
</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-06-06T03:13:02.289007" level="INFO">{"bgp-openconfig-extensions:peer-group":[{"peer-group-name":"internal-neighbors","transport":{"config":{"passive-mode":true}},"route-reflector":{"config":{"route-reflector-client":false}},"timers":{"config":{"hold-time":"180.0","connect-retry":"5.0"}},"config":{"peer-type":"INTERNAL"},"afi-safis":{"afi-safi":[{"afi-safi-name":"openconfig-bgp-types:IPV6-UNICAST"},{"afi-safi-name":"bgp-openconfig-extensions:LINKSTATE"}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.283633" elapsed="0.005484"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.283132" elapsed="0.006061"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.283090" elapsed="0.006159"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.334688" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.289909" elapsed="0.044849"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.289375" elapsed="0.045433"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.289337" elapsed="0.045505"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.335539" 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-06-06T03:13:02.335059" elapsed="0.000507"/>
</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-06-06T03:13:02.335926" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.335670" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.336484" 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-06-06T03:13:02.336177" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.336010" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.335624" elapsed="0.000946"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.337116" 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-06-06T03:13:02.336749" elapsed="0.000394"/>
</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-06-06T03:13:02.337456" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.337214" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.338052" 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-06-06T03:13:02.337718" elapsed="0.000361"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.337538" elapsed="0.000576"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.337195" elapsed="0.000940"/>
</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-06-06T03:13:02.338300" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:02.339127" 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-06-06T03:13:02.338832" elapsed="0.000321"/>
</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-06-06T03:13:02.339312" elapsed="0.002261"/>
</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-06-06T03:13:02.282156" elapsed="0.059498"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.341835" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.341727" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.341708" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:02.344949" level="INFO">${text_normalized} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<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="PASS" start="2026-06-06T03:13:02.342064" elapsed="0.002914"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:02.345030" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:13:02.345194" level="INFO">${response_text} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:02.265965" elapsed="0.079256"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.345283" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:02.345431" level="INFO">${response_text} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:02.134004" elapsed="0.211518"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.373609" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.373234" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.374483" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.374185" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.374673" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.373845" elapsed="0.000855"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.375258" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.374870" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.375594" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/verify_peer_group_without_ipv4.sulfur/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:02.375775" level="INFO">${template} = {
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode"...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.375455" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.376210" level="INFO">{
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode": true
                }
            },
            "config": {
                "peer-type": "INTERNAL"
            },
            "afi-safis": {
                "afi-safi": [
                    {
                        "afi-safi-name": "openconfig-bgp-types:IPV6-UNICAST"
                    },
                    {
                        "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
                    }
                ]
            },
            "timers": {
                "config": {
                    "hold-time": "180.0",
                    "connect-retry": "5.0"
                }
            },
            "route-reflector": {
                "config": {
                    "route-reflector-client": false
                }
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.375963" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:02.376625" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.376330" elapsed="0.000373"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.377179" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.376878" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.376728" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.376311" elapsed="0.000953"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.377931" level="INFO">${final_text} = {
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode"...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.377418" elapsed="0.000542"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.378010" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:02.372605" elapsed="0.005530"/>
</kw>
<msg time="2026-06-06T03:13:02.378193" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.360219" elapsed="0.018022"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.390395" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.402691" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//verify_peer_group_without_ipv4.sulfur/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.414946" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.415183" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.415370" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.415811" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.415653" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:02.415622" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.416038" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.416208" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.416374" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.415583" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.415460" elapsed="0.000994"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.416603" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.416695" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:13:02.416854" level="INFO">${expected_text} = {
    "bgp-openconfig-extensions:peer-group": [
        {
            "peer-group-name": "internal-neighbors",
            "transport": {
                "config": {
                    "passive-mode"...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.357328" elapsed="0.059554"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.417063" elapsed="0.002262"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:02.420604" level="INFO">${expected_normalized} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.420113" elapsed="0.000520"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:02.421311" level="INFO">${actual_normalized} = {
 "bgp-openconfig-extensions:peer-group": [
  {
   "afi-safis": {
    "afi-safi": [
     {
      "afi-safi-name": "bgp-openconfig-extensions:LINKSTATE"
     },
     {
      "afi-safi-name": "openconf...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.420873" elapsed="0.000467"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:02.421499" elapsed="0.000396"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:02.419677" elapsed="0.002281"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.419407" elapsed="0.002585"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.422171" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.422017" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.419388" elapsed="0.002860"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:02.346735" elapsed="0.075560"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:02.345894" elapsed="0.076481"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.345607" elapsed="0.076814"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.345589" elapsed="0.076857"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.422480" elapsed="0.000032"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${verify_peer_group_folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:02.129733" elapsed="0.292878"/>
</kw>
<arg>peer_group_folder=peer_group_without_ipv4</arg>
<doc>Configures peer group which is template for all the neighbors which are going
to be configured. Also after PUT, this case verifies presence of peer group within
peer-groups.</doc>
<status status="PASS" start="2026-06-06T03:13:01.845820" elapsed="0.576875"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.423953" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.423549" elapsed="0.000466"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.423532" elapsed="0.000508"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.424190" elapsed="0.000323"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.429550" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.429122" elapsed="0.000472"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:13:02.429836" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:02.429691" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.429671" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.430070" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.430248" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.430425" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.430593" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.430781" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.430951" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.431120" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.428812" elapsed="0.002383"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.423337" elapsed="0.007945"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:13:02.422973" elapsed="0.008352"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:13:01.726654" elapsed="0.704709"/>
</test>
<test id="s1-s4-t16" name="TC_PG_Check_For_Empty_Topology_After_Deconfiguration" line="219">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.435740" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.435503" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.435485" elapsed="0.000339"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:02.435317" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.436878" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.436771" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.436751" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.441810" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.441703" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.441684" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.442891" 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-06-06T03:13:02.442487" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.443382" 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-06-06T03:13:02.443083" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:02.443453" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.443608" 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-06-06T03:13:02.442108" elapsed="0.001525"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:02.449003" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.448897" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.448877" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:02.450274" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.450168" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.450149" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:02.450818" 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-06-06T03:13:02.450490" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:02.451230" level="INFO">${current_connection_index} = 7</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-06-06T03:13:02.451009" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:02.484198" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:02.451775" elapsed="0.032527"/>
</kw>
<msg time="2026-06-06T03:13:02.484487" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:02.484533" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:02.451417" elapsed="0.033150"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:02.509491" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "D "e "c "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:13:02.485130" elapsed="0.024473"/>
</kw>
<msg time="2026-06-06T03:13:02.509786" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:02.509832" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g ...</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-06-06T03:13:02.484771" elapsed="0.025096"/>
</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-06-06T03:13:02.510186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.509952" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.509928" elapsed="0.000387"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.510795" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "D "e "c "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:13:02.510460" elapsed="0.000405"/>
</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-06-06T03:13:02.511153" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.510933" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.510914" elapsed="0.000317"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:02.511263" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:02.513996" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:13:02.514206" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.512754" elapsed="0.001586"/>
</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="NOT RUN" start="2026-06-06T03:13:02.514625" elapsed="0.000104"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.514999" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:02.512115" elapsed="0.003090"/>
</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-06-06T03:13:02.511551" elapsed="0.003720"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:02.449864" elapsed="0.065509"/>
</kw>
<msg time="2026-06-06T03:13:02.515467" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:02.515674" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:02.449225" elapsed="0.066493"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:02.515908" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:02.515799" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.515780" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.516397" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.516752" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.516824" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:02.448543" elapsed="0.068388"/>
</kw>
<msg time="2026-06-06T03:13:02.517025" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:02.517070" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:02.444018" elapsed="0.073088"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.517466" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.517180" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.517163" elapsed="0.000383"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:02.443873" elapsed="0.073696"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:02.443702" elapsed="0.073898"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:02.441305" elapsed="0.076364"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:02.436462" elapsed="0.081266"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:02.436024" elapsed="0.081748"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:02.432615" elapsed="0.085211"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.568902" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.568505" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.569847" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.569459" elapsed="0.000465">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.570017" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.569100" elapsed="0.000942"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.570602" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.570210" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.570951" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:02.571105" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.570812" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.571537" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.571288" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.572773" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.572311" elapsed="0.000523"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.573385" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.573000" elapsed="0.000411"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.573994" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.574748" elapsed="0.000051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.575090" elapsed="0.000046"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.573802" elapsed="0.001456"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.573461" elapsed="0.001864"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:02.575373" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.575535" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:02.571964" elapsed="0.003595"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.571663" elapsed="0.003929"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.575783" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.575617" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.571628" elapsed="0.004232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.576441" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.576003" elapsed="0.000466"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.576518" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:02.567891" elapsed="0.008763"/>
</kw>
<msg time="2026-06-06T03:13:02.576710" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.555433" elapsed="0.021326"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.589185" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.601286" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.613411" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.613738" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.613927" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.614326" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.614176" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:02.614159" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.614552" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.614739" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.614910" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.614124" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.614009" elapsed="0.000980"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.615137" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.615212" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:02.615349" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.551208" elapsed="0.064172"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.616761" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.616472" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.616929" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.616087" elapsed="0.000867"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.617300" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.617041" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.617876" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.617564" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.617383" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.617022" elapsed="0.000987"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.620323" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.618165" elapsed="0.002186"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:02.620403" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:02.620562" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:02.615738" elapsed="0.004850"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.621897" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.621626" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.622057" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.621275" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:02.622290" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:13:02.622152" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.622133" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.622523" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.622714" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.622782" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:02.624800" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:02.620926" elapsed="0.003900"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.626269" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.626014" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.626734" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.626473" elapsed="0.000305"/>
</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-06-06T03:13:02.635305" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:02.635465" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:02.635597" 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-06-06T03:13:02.628875" elapsed="0.006759"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.626845" elapsed="0.008879"/>
</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-06-06T03:13:02.635979" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.635761" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.626827" elapsed="0.009272"/>
</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-06-06T03:13:02.640863" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.637556" elapsed="0.003390"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.637239" elapsed="0.003757"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.637213" elapsed="0.003818"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.644655" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.641427" elapsed="0.003296"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.641109" elapsed="0.003663"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.641086" elapsed="0.003720"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.645559" 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-06-06T03:13:02.645076" elapsed="0.000510"/>
</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-06-06T03:13:02.645967" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.645723" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.646528" 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-06-06T03:13:02.646213" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.646049" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.645703" elapsed="0.000908"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.647152" 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-06-06T03:13:02.646790" elapsed="0.000389"/>
</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-06-06T03:13:02.647483" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.647249" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.648039" 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-06-06T03:13:02.647745" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.647565" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.647230" elapsed="0.000891"/>
</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-06-06T03:13:02.648274" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:02.649114" 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-06-06T03:13:02.648803" elapsed="0.000337"/>
</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-06-06T03:13:02.649298" elapsed="0.002366"/>
</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-06-06T03:13:02.636603" elapsed="0.015126"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.651904" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.651798" elapsed="0.000149"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.651779" elapsed="0.000190"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:02.654771" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:02.652115" elapsed="0.002685"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:02.654852" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:02.655007" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:02.625172" elapsed="0.029860"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.655095" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:13:02.655242" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:02.529213" elapsed="0.126056"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.684657" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.683884" elapsed="0.000809"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.686920" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.686327" elapsed="0.000763">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.687292" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.684888" elapsed="0.002431"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.688273" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.687489" elapsed="0.000812"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.688742" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:02.689015" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.688479" elapsed="0.000565"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.689631" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.689205" elapsed="0.000505"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:02.690425" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.689782" elapsed="0.000807"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.691419" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.690813" elapsed="0.000649"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.690617" elapsed="0.000925"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.689762" elapsed="0.001805"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.692515" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.691746" elapsed="0.000799"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.692596" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:02.683023" elapsed="0.009873"/>
</kw>
<msg time="2026-06-06T03:13:02.692950" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.669700" elapsed="0.023300"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.705406" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.717548" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.729585" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.729795" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.730009" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.730390" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.730243" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:02.730228" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.730610" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.730796" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.730963" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.730198" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.730091" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.731190" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.731265" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:02.731386" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.667070" elapsed="0.064343"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.731590" elapsed="0.002190"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:02.734871" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.734527" elapsed="0.000373"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:02.735353" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.735056" elapsed="0.000325"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:02.735539" elapsed="0.000362"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:02.734108" elapsed="0.001853"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.733860" elapsed="0.002134"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.736169" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.736018" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.733840" elapsed="0.002404"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:02.656413" elapsed="0.079877"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:02.655591" elapsed="0.080774"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.655351" elapsed="0.081060"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.655333" elapsed="0.081102"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.736468" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:02.523028" elapsed="0.213565"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.518913" elapsed="0.217778"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:02.518395" elapsed="0.218377"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.517962" elapsed="0.218871"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:02.737419" elapsed="0.000253"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:02.737114" elapsed="0.000621"/>
</kw>
<doc>See example-ipv4-topology empty after resetting session.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:02.431901" elapsed="0.305872"/>
</test>
<test id="s1-s4-t17" name="TC_PG_Reconfigure_ODL_To_Accept_Connection" line="224">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.741475" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.741247" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.741228" elapsed="0.000329"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:02.741054" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.742620" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.742512" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.742493" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.747755" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.747630" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.747612" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.748855" 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-06-06T03:13:02.748433" elapsed="0.000449"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.749347" 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-06-06T03:13:02.749047" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:02.749417" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.749572" 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-06-06T03:13:02.748052" elapsed="0.001545"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:02.755012" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.754903" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.754884" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:02.756242" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:02.756135" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.756116" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:02.756811" 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-06-06T03:13:02.756457" elapsed="0.000381"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:02.757219" level="INFO">${current_connection_index} = 7</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-06-06T03:13:02.757003" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:02.791635" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:02.757765" elapsed="0.033996"/>
</kw>
<msg time="2026-06-06T03:13:02.791925" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:02.791972" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:02.757408" elapsed="0.034599"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:02.814847" level="INFO">". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:13:02.792551" elapsed="0.022597"/>
</kw>
<msg time="2026-06-06T03:13:02.815571" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:02.815740" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e ...</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-06-06T03:13:02.792182" elapsed="0.023747"/>
</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-06-06T03:13:02.816874" elapsed="0.000059"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.816161" elapsed="0.000871"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.816100" elapsed="0.000998"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.817990" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:13:02.817441" elapsed="0.000659"/>
</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-06-06T03:13:02.818559" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.818213" elapsed="0.000451"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.818184" elapsed="0.000519"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:02.818758" elapsed="0.000053"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:02.823167" elapsed="0.000497"/>
</kw>
<msg time="2026-06-06T03:13:02.823773" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.821224" elapsed="0.002762"/>
</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="NOT RUN" start="2026-06-06T03:13:02.824473" elapsed="0.000119"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.825059" elapsed="0.000113"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:02.820130" elapsed="0.005204"/>
</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-06-06T03:13:02.819219" elapsed="0.006209"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:02.755830" elapsed="0.069743"/>
</kw>
<msg time="2026-06-06T03:13:02.825747" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:02.825814" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:02.755237" elapsed="0.070629"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:02.826138" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:13:02.825980" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.825952" elapsed="0.000309"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.826868" elapsed="0.000037"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.827389" elapsed="0.000045"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.827510" elapsed="0.000032"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:02.754549" elapsed="0.073175"/>
</kw>
<msg time="2026-06-06T03:13:02.827878" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:02.827945" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "T "C "_ "P "G "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:02.749981" elapsed="0.078014"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.828599" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.828126" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.828091" elapsed="0.000656"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:02.749837" elapsed="0.078947"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:02.749663" elapsed="0.079166"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:02.747267" elapsed="0.081644"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:02.742224" elapsed="0.086781"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:02.741773" elapsed="0.087301"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:02.738873" elapsed="0.090348"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.830381" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PEER_GROUP_NAME=internal-neighbors | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIV...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_GROUP_NAME=${PEER_GROUP}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.829496" elapsed="0.000917"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.873564" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:02.873169" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.874389" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:02.874137" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:02.874560" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:02.873778" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.875182" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:02.874790" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:02.875514" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer_group/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:02.875709" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:02.875373" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.876206" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.875911" elapsed="0.000345"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.877268" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.876987" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.877758" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.877477" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.878496" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.878178" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.880784" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.880541" elapsed="0.000271"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.880865" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:02.881018" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.880203" elapsed="0.000840"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.881200" elapsed="0.000238"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:02.878038" elapsed="0.003441"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.882061" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.881746" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.882832" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.882599" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.882949" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:02.883102" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.882279" elapsed="0.000848"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.883280" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:13:02.881592" elapsed="0.001951"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.884108" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.883805" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.884895" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.884683" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.884971" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.885121" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.884347" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.885299" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:13:02.883669" elapsed="0.001898"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.886134" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.885833" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.886905" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.886692" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.886980" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:02.887128" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.886349" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.887304" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:13:02.885697" elapsed="0.001871"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.888155" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.887830" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.888916" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.888706" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.888991" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:02.889139" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.888369" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.889319" elapsed="0.000220"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:13:02.887697" elapsed="0.002027"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.890264" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.889970" elapsed="0.000369"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.891079" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.890869" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.891154" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:02.891300" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.890537" elapsed="0.000787"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.891476" elapsed="0.000417"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:13:02.889836" elapsed="0.002099"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.892499" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.892201" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.893373" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.893161" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.893485" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:02.893636" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.892845" elapsed="0.000831"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.893831" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:02.892044" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.894631" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.894338" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.895388" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.895180" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.895464" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.895612" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.894861" elapsed="0.000776"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.895806" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:02.894205" elapsed="0.001868"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.896666" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.896353" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.897402" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.897194" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.897477" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:02.897624" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.896879" elapsed="0.000786"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.897821" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:13:02.896218" elapsed="0.001868"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.898627" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:02.898329" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:02.899380" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.899173" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:02.899454" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:02.899600" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:02.898860" elapsed="0.000764"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:02.899799" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:02.898197" elapsed="0.001864"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:02.877838" elapsed="0.022287"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:02.900169" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:02.900330" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:02.876628" elapsed="0.023728"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.876325" elapsed="0.024063"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.900568" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.900413" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.876306" elapsed="0.024355"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.901530" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:02.900810" elapsed="0.000748"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.901607" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:02.872512" elapsed="0.029235"/>
</kw>
<msg time="2026-06-06T03:13:02.901837" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.859744" elapsed="0.042141"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.914210" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.926296" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.938359" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.938563" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.938754" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.939118" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.938972" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:02.938957" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.939342" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.939510" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.939696" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:02.938929" elapsed="0.000824"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.938829" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.939934" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:02.940025" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:02.940149" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.855402" elapsed="0.084774"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.941289" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.941035" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:13:02.953436" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:02.953483" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:02.953583" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:13:02.943450" elapsed="0.010159"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.941440" elapsed="0.012229"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:02.953918" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.953697" elapsed="0.000294"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.941422" elapsed="0.012591"/>
</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-06-06T03:13:02.958695" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.955027" elapsed="0.003773"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.954797" elapsed="0.004084"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.954778" elapsed="0.004162"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.964861" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:02.959587" elapsed="0.005379"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.959069" elapsed="0.005974"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.959031" elapsed="0.006067"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.966373" 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-06-06T03:13:02.965488" elapsed="0.000951"/>
</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-06-06T03:13:02.967280" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.966603" elapsed="0.000820"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.968553" 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-06-06T03:13:02.968007" elapsed="0.000573"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.967480" elapsed="0.001147"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.966561" elapsed="0.002105"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.969214" 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-06-06T03:13:02.968834" elapsed="0.000406"/>
</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-06-06T03:13:02.969577" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:02.969310" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:02.970168" 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-06-06T03:13:02.969860" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:02.969688" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:02.969291" elapsed="0.000976"/>
</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-06-06T03:13:02.970419" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:02.971223" 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-06-06T03:13:02.970948" elapsed="0.000301"/>
</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-06-06T03:13:02.971410" elapsed="0.002433"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:13:02.954371" elapsed="0.019550"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:13:02.973970" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:02.976311" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:13:02.940438" elapsed="0.035900"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:02.976437" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer_group</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:13:02.830832" elapsed="0.145731"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.009689" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.009295" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.010491" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.010239" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.010693" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.009902" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.011305" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.010906" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.011638" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:03.011855" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:03.011498" elapsed="0.000384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.012292" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.012046" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.013372" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.013110" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.013880" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.013579" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.014675" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.014289" elapsed="0.000413"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.015473" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.015240" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.015552" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:13:03.015724" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.014895" elapsed="0.000871"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.015924" elapsed="0.000236"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:03.014150" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.016966" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.016658" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.017761" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.017531" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.017837" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.017987" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.017200" elapsed="0.000812"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.018322" elapsed="0.000228"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:13:03.016327" elapsed="0.002265"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.019174" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.018862" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.019962" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.019722" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.020038" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:03.020186" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.019385" elapsed="0.000825"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.020364" elapsed="0.000221"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:13:03.018728" elapsed="0.001899"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.021199" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.020904" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.021954" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.021744" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.022030" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.022178" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.021411" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.022354" elapsed="0.000219"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:13:03.020756" elapsed="0.001870"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.023197" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.022901" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.023990" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.023755" elapsed="0.000263"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.024068" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.024217" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.023409" elapsed="0.000832"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.024394" elapsed="0.000217"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:13:03.022756" elapsed="0.001912"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.025221" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.024913" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.026003" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.025789" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.026078" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.026229" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.025439" elapsed="0.000815"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.026408" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:13:03.024779" elapsed="0.001908"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.027253" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.026938" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.028275" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.027871" elapsed="0.000431"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.028352" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.028506" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.027467" elapsed="0.001064"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.028742" elapsed="0.000235"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:03.026802" elapsed="0.002217"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.029558" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.029263" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.030481" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.030272" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.030556" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.030721" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.029956" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.030917" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:03.029129" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.031772" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.031428" elapsed="0.000370"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.032526" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.032301" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.032602" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.032785" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.031984" elapsed="0.000833"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.032998" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:13:03.031289" elapsed="0.001973"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.033988" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.033507" elapsed="0.000507"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.034742" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.034516" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.034819" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:03.034967" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.034199" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.035149" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:03.033373" elapsed="0.002044"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:03.013962" elapsed="0.021491"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:03.035498" elapsed="0.000208"/>
</return>
<msg time="2026-06-06T03:13:03.035845" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:03.012773" elapsed="0.023099"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.012412" elapsed="0.023493"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.036088" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.035932" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.012387" elapsed="0.023779"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.037076" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.036313" elapsed="0.000792"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.037154" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:03.008591" elapsed="0.028688"/>
</kw>
<msg time="2026-06-06T03:13:03.037381" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:02.996131" elapsed="0.041307"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.049991" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.062200" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.074677" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.074881" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.075064" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.075443" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.075290" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:03.075275" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.075723" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.075902" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.076071" elapsed="0.000038"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:03.075245" elapsed="0.000898"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.075142" elapsed="0.001027"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.076332" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.076411" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:03.076538" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:02.991970" elapsed="0.084595"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.103313" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.102936" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.104172" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.103894" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.104380" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.103530" elapsed="0.000875"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.104993" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.104575" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.105321" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:03.105477" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:03.105185" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.105926" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.105680" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:03.106366" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.106054" elapsed="0.000370"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.106926" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_GROUP_NAME': 'internal-neighbors', 'INITIATE': 'false', 'BGP_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.106611" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.106461" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.106035" elapsed="0.001011"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.108041" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.107217" elapsed="0.000854"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.108122" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:03.102270" elapsed="0.005975"/>
</kw>
<msg time="2026-06-06T03:13:03.108304" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.089507" elapsed="0.018843"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.120533" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.132849" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.146503" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.146805" elapsed="0.000032"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.147061" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.147601" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.147393" elapsed="0.000312"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:03.147354" elapsed="0.000386"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.147947" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.148186" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.148437" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:03.147313" elapsed="0.001216"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.147167" elapsed="0.001404"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.148801" elapsed="0.000029"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.148909" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:13:03.149096" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:03.086677" elapsed="0.062459"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.150937" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.150581" elapsed="0.000447">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.151156" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.150095" elapsed="0.001095"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.151699" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.151288" elapsed="0.000492"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.152496" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.152064" elapsed="0.000463"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.151815" elapsed="0.000747"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.151262" elapsed="0.001321"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.154951" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.152752" elapsed="0.002226"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:03.155032" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:03.155186" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:03.149604" elapsed="0.005607"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.156619" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.156371" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.157128" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.156887" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.157586" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.157340" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.158037" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.157799" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:03.158909" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:13:03.158710" elapsed="0.000224"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:13:03.159271" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:13:03.159093" elapsed="0.000203"/>
</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-06-06T03:13:03.159480" elapsed="0.000222"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.160119" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.159865" elapsed="0.000300"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:13:03.160210" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.160373" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:13:03.158282" elapsed="0.002122"/>
</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-06-06T03:13:03.175009" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '1079', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:13:03.175075" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:03.175168" 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-06-06T03:13:03.162727" elapsed="0.012473"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.160477" elapsed="0.014775"/>
</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-06-06T03:13:03.175573" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.175279" elapsed="0.000492"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.160459" elapsed="0.015361"/>
</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-06-06T03:13:03.183504" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.178111" elapsed="0.005493"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.177487" elapsed="0.006227"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.177443" elapsed="0.006329"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.186781" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.184409" elapsed="0.002419"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.183902" elapsed="0.002961"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.183863" elapsed="0.003025"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.187496" 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-06-06T03:13:03.187071" elapsed="0.000452"/>
</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-06-06T03:13:03.187856" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.187596" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.188405" 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-06-06T03:13:03.188108" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.187941" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.187577" elapsed="0.000911"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.189025" 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-06-06T03:13:03.188665" elapsed="0.000386"/>
</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-06-06T03:13:03.189364" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.189120" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.189953" 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-06-06T03:13:03.189630" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.189460" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.189102" elapsed="0.000934"/>
</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-06-06T03:13:03.190194" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:03.191017" 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-06-06T03:13:03.190726" elapsed="0.000317"/>
</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-06-06T03:13:03.191201" elapsed="0.002305"/>
</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-06-06T03:13:03.176673" elapsed="0.016911"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:13:03.193783" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.193669" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.193634" elapsed="0.000243"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:13:03.194031" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.194108" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:03.196402" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:13:03.155562" elapsed="0.040868"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.196498" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:03.196671" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:02.981223" elapsed="0.215475"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.197065" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.196799" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.196782" elapsed="0.000377"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.197192" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:13:02.976852" elapsed="0.220539"/>
</kw>
<kw name="Deconfigure_Peer_Group">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.198743" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | PEER_GROUP_NAME=internal-neighbor...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<arg>PEER_GROUP_NAME=${PEER_GROUP}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.197943" elapsed="0.000830"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.245682" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.245052" elapsed="0.000678"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.246727" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.246371" elapsed="0.000467">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.246978" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.245981" elapsed="0.001035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.247870" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.247306" elapsed="0.000601"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.248334" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/peer_group/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:03.248562" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:03.248130" elapsed="0.000473"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.249208" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/peer-groups/peer-group=$PEER_GROUP_NAME
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.248855" elapsed="0.000422"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.250764" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_GROUP_NAME': 'internal-neighbors', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.250372" elapsed="0.000461"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.251428" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.251060" elapsed="0.000395"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.252234" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.251901" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.253121" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.252891" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.253203" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:03.253370" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.252536" elapsed="0.000860"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.253582" elapsed="0.000303"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:03.251754" elapsed="0.002178"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.254605" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.254187" elapsed="0.000476"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.255657" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.255249" elapsed="0.000437"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.255809" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:03.255976" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.254887" elapsed="0.001115"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.256161" elapsed="0.000258"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:13:03.254048" elapsed="0.002415"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.257059" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.256746" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.257864" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.257607" elapsed="0.000284"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.257944" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:03.258108" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.257281" elapsed="0.000858"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.258306" elapsed="0.000239"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:13:03.256585" elapsed="0.002003"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.259349" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.258896" elapsed="0.000487"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.260204" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.259986" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.260282" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.260433" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.259620" elapsed="0.000837"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.260623" elapsed="0.000246"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:03.258721" elapsed="0.002190"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.261491" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.261164" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.262316" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.262092" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.262397" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:03.262552" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.261731" elapsed="0.000848"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.262831" elapsed="0.000282"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:03.261025" elapsed="0.002135"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.263781" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.263440" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.264573" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.264355" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.264670" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:13:03.264841" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.264003" elapsed="0.000863"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.265023" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:13:03.263277" elapsed="0.002014"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.265877" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.265546" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.266673" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.266437" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.266794" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:03.266951" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.266095" elapsed="0.000881"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.267150" elapsed="0.000302"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:03.265408" elapsed="0.002090"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.268352" level="INFO">${value} = internal-neighbors</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.267801" elapsed="0.000578"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.269145" level="INFO">${encoded} = internal-neighbors</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.268931" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.269222" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.269380" level="INFO">${encoded_value} = internal-neighbors</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.268581" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.269559" elapsed="0.000241"/>
</kw>
<var name="${key}">PEER_GROUP_NAME</var>
<var name="${value}">internal-neighbors</var>
<status status="PASS" start="2026-06-06T03:13:03.267614" elapsed="0.002229"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.270425" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.270123" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:03.271248" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.270991" elapsed="0.000284"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:03.271327" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.271477" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:03.270667" elapsed="0.000834"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.271675" elapsed="0.000226"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:03.269974" elapsed="0.001969"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:03.251519" elapsed="0.020460"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:03.272025" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:03.272188" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:03.249910" elapsed="0.022305"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.249390" elapsed="0.022858"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.272431" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.272277" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.249355" elapsed="0.023152"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.273403" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.272672" elapsed="0.000760"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.273484" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:03.243956" elapsed="0.029656"/>
</kw>
<msg time="2026-06-06T03:13:03.273685" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.230347" elapsed="0.043390"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.287078" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.299978" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//peer_group/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.312419" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.312663" elapsed="0.000033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.312875" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.313282" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.313128" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:03.313110" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.313520" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.313712" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.313917" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:03.313075" elapsed="0.000910"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.312959" elapsed="0.001054"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.314185" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.314268" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:03.314406" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:03.225391" elapsed="0.089043"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.315684" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.315385" elapsed="0.000360"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:13:03.328763" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:03.328902" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/peer-groups/peer-group=internal-neighbors 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:03.329177" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:13:03.319170" elapsed="0.010068"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.315818" elapsed="0.013549"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.329903" elapsed="0.000267"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.329443" elapsed="0.000837"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.315799" elapsed="0.014550"/>
</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-06-06T03:13:03.338703" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.333086" elapsed="0.005822"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.332478" elapsed="0.006531"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.332424" elapsed="0.006643"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.341919" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.339551" elapsed="0.002416"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.339199" elapsed="0.002804"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.339160" elapsed="0.002868"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.342658" 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-06-06T03:13:03.342226" elapsed="0.000462"/>
</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-06-06T03:13:03.343039" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.342763" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.343601" 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-06-06T03:13:03.343296" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.343124" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.342743" elapsed="0.000960"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.344238" 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-06-06T03:13:03.343868" elapsed="0.000398"/>
</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-06-06T03:13:03.344582" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.344337" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.345151" 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-06-06T03:13:03.344850" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.344683" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.344318" elapsed="0.000917"/>
</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-06-06T03:13:03.345398" elapsed="0.000372"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:03.346243" 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-06-06T03:13:03.345942" elapsed="0.000327"/>
</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-06-06T03:13:03.346428" elapsed="0.002304"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:13:03.331374" elapsed="0.017426"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:13:03.348852" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:13:03.351117" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:13:03.314742" elapsed="0.036402"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.351201" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}peer_group</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:13:03.199058" elapsed="0.152272"/>
</kw>
<doc>Deconfigures peer group which is template for all the neighbors</doc>
<status status="PASS" start="2026-06-06T03:13:03.197570" elapsed="0.153825"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.352713" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.352302" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.352283" elapsed="0.000518"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.352962" elapsed="0.000322"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.358627" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.358203" elapsed="0.000470"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:13:03.358926" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.358756" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.358735" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.359165" elapsed="0.000023"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.359345" elapsed="0.000022"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.359532" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.359722" elapsed="0.000022"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.359899" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.360073" elapsed="0.000022"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.360243" elapsed="0.000021"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:13:03.357851" elapsed="0.002470"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.352088" elapsed="0.008286"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:13:03.351700" elapsed="0.008716"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:13:02.738269" elapsed="0.622186"/>
</test>
<test id="s1-s4-t18" name="Kill_Talking_BGP_Speaker" line="248">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:03.363910" elapsed="0.000237"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:13:03.363604" elapsed="0.000602"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.365267" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.365143" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.365121" elapsed="0.000217"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.370259" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.370150" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.370132" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.371379" 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-06-06T03:13:03.370990" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.371897" 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-06-06T03:13:03.371573" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:03.371970" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:03.372125" 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-06-06T03:13:03.370560" elapsed="0.001589"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:03.377886" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.377775" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.377754" elapsed="0.000219"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:03.379336" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.379194" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.379169" elapsed="0.000245"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:03.379937" 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-06-06T03:13:03.379591" elapsed="0.000373"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.380488" level="INFO">${current_connection_index} = 7</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-06-06T03:13:03.380199" elapsed="0.000325"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.413284" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:03.381239" elapsed="0.032166"/>
</kw>
<msg time="2026-06-06T03:13:03.413590" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:03.413637" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:03.380770" elapsed="0.032928"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.437978" level="INFO">". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:13:03.414263" elapsed="0.023935"/>
</kw>
<msg time="2026-06-06T03:13:03.438428" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:03.438478" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?1l&gt;[?2004l...</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-06-06T03:13:03.413891" elapsed="0.024627"/>
</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-06-06T03:13:03.439035" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.438695" elapsed="0.000401"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.438629" elapsed="0.000496"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.439684" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:13:03.439279" elapsed="0.000470"/>
</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-06-06T03:13:03.440040" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.439818" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.439799" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:03.440157" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:03.442920" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:13:03.443134" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.441746" elapsed="0.001524"/>
</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="NOT RUN" start="2026-06-06T03:13:03.443551" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.443913" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:03.441076" elapsed="0.003029"/>
</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-06-06T03:13:03.440479" elapsed="0.003706"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:03.378828" elapsed="0.065461"/>
</kw>
<msg time="2026-06-06T03:13:03.444385" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.444431" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.378134" elapsed="0.066338"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:03.444680" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.444551" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.444531" elapsed="0.000236"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.445190" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.445542" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.445614" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:03.377408" elapsed="0.068336"/>
</kw>
<msg time="2026-06-06T03:13:03.445901" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.445945" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:03.372538" elapsed="0.073444"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.446315" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.446060" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.446041" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:03.372390" elapsed="0.074026"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:03.372209" elapsed="0.074240"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:03.369781" elapsed="0.076726"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:03.364833" elapsed="0.081753"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.364362" elapsed="0.082270"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:13:03.361423" elapsed="0.085284"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.447915" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.447573" elapsed="0.000370"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:03.448100" elapsed="0.000525"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:13:03.447301" elapsed="0.001414"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.469434" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:13:03.449252" elapsed="0.020275"/>
</kw>
<msg time="2026-06-06T03:13:03.469666" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.469712" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.448905" elapsed="0.020832"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.470539" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:13:03.482605" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:03.482773" level="INFO">${output_log} = 2026-06-06 03:12:51,486 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:12:51,488 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job): Ope...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:03.470336" elapsed="0.012476"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.483456" level="INFO">2026-06-06 03:12:51,486 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:12:51,488 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:12:51,493 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:12:51,494 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:12:51,494 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:12:51,494 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:12:51,494 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:12:51,494 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:12:51,494 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:12:51,496 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0001747608184814453s
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:51,497 INFO BGP-Thread-1 (job):   
2026-06-06 03:12:51,498 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:12:51,498 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:12:51,498 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:12:51,498 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:12:51,505 INFO BGP-Thread-1 (job): ... idle for 0.006s
2026-06-06 03:12:51,505 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.006s
2026-06-06 03:13:01,515 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:13:01,515 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.017s
2026-06-06 03:13:01,516 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:13:01,516 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:13:01,516 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:13:02,119 INFO BGP-Thread-1 (job): NOTIFICATION message received: 0xffffffffffffffffffffffffffffffff0015030600
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.483046" elapsed="0.000647"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:13:03.469988" elapsed="0.013790"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:13:03.484070" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.483887" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.483853" elapsed="0.000349"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.484423" elapsed="0.000035"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.484692" elapsed="0.000032"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:13:03.446983" elapsed="0.037826"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.485996" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:13:03.485501" elapsed="0.000557"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:13:03.485089" elapsed="0.001053"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:03.487105" elapsed="0.000302"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:13:03.486580" elapsed="0.000904"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:03.360818" elapsed="0.126720"/>
</test>
<test id="s1-s4-t19" name="Check_For_Empty_Topology_After_Talking" line="257">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.492592" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.492273" elapsed="0.000422"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.492247" elapsed="0.000485"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:03.492011" elapsed="0.000788"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.494308" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.494136" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.494103" elapsed="0.000326"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.501036" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.500927" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.500908" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.502405" 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-06-06T03:13:03.501979" elapsed="0.000455"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.502934" 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-06-06T03:13:03.502599" elapsed="0.000361"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:03.503006" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:03.503161" 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-06-06T03:13:03.501383" elapsed="0.001803"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:03.508836" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.508708" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.508687" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:03.510157" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.510048" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.510029" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:03.510737" 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-06-06T03:13:03.510393" elapsed="0.000371"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.511233" level="INFO">${current_connection_index} = 7</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-06-06T03:13:03.510989" elapsed="0.000271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.545546" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:03.511857" elapsed="0.033992"/>
</kw>
<msg time="2026-06-06T03:13:03.546065" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:03.546114" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:03.511451" elapsed="0.034700"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.568556" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:13:03.546949" elapsed="0.021729"/>
</kw>
<msg time="2026-06-06T03:13:03.568842" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:03.568889" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</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-06-06T03:13:03.546456" elapsed="0.022468"/>
</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-06-06T03:13:03.569274" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.569018" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.568992" elapsed="0.000365"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.569843" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:13:03.569506" elapsed="0.000405"/>
</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-06-06T03:13:03.570261" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.569978" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.569960" elapsed="0.000381"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:03.570380" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:03.573084" elapsed="0.000334"/>
</kw>
<msg time="2026-06-06T03:13:03.573488" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.571957" elapsed="0.001668"/>
</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="NOT RUN" start="2026-06-06T03:13:03.573940" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.574293" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:03.571287" elapsed="0.003192"/>
</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-06-06T03:13:03.570722" elapsed="0.003823"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:03.509731" elapsed="0.064937"/>
</kw>
<msg time="2026-06-06T03:13:03.574764" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.574810" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.509062" elapsed="0.065785"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:03.575034" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.574925" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.574906" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.575524" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.575885" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.575959" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:03.508340" elapsed="0.067727"/>
</kw>
<msg time="2026-06-06T03:13:03.576176" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.576221" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:03.503565" elapsed="0.072692"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.576656" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.576378" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.576359" elapsed="0.000378"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:03.503420" elapsed="0.073342"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:03.503244" elapsed="0.073550"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:03.500535" elapsed="0.076315"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:03.493699" elapsed="0.083209"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.493020" elapsed="0.083933"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:03.488762" elapsed="0.088244"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.629140" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.628657" elapsed="0.000519"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.630196" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.629740" elapsed="0.000533">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.630370" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.629365" elapsed="0.001029"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.631031" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.630584" elapsed="0.000486"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.631399" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:03.631568" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:03.631245" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.632027" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.631770" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.633357" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.632895" elapsed="0.000530"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.634050" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:03.633593" elapsed="0.000485"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.634508" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.635332" elapsed="0.000051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.635701" elapsed="0.000046"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:03.634315" elapsed="0.001550"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.634136" elapsed="0.001794"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:03.635983" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:03.636155" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:03.632526" elapsed="0.003654"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.632158" elapsed="0.004054"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.636389" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.636238" elapsed="0.000268"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.632132" elapsed="0.004396"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.637155" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.636696" elapsed="0.000488"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.637234" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:03.627764" elapsed="0.009595"/>
</kw>
<msg time="2026-06-06T03:13:03.637415" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.614914" elapsed="0.022552"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.649794" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.662269" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.674958" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.675179" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.675369" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.675825" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.675657" elapsed="0.000226"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:03.675624" elapsed="0.000285"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.676054" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.676225" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.676395" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:03.675587" elapsed="0.000861"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.675473" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.676634" elapsed="0.000039"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.676734" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:13:03.676879" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:03.610676" elapsed="0.066230"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.678415" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.678118" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.678600" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.677690" elapsed="0.000936"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.678981" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.678715" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.679556" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.679257" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.679064" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.678695" elapsed="0.000961"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.682075" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.679817" elapsed="0.002285"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:03.682197" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:03.682360" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:03.677305" elapsed="0.005080"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.683685" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.683411" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.683874" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.683071" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:03.684121" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.683982" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.683953" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.684358" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.684539" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.684605" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:03.686897" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:03.682738" elapsed="0.004186"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.688358" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.688091" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.688886" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.688562" elapsed="0.000369"/>
</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-06-06T03:13:03.697605" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:03.697759" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:03.697876" 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-06-06T03:13:03.691295" elapsed="0.006608"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.688998" elapsed="0.008949"/>
</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-06-06T03:13:03.698132" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.697974" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.688979" elapsed="0.009301"/>
</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-06-06T03:13:03.701693" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.699318" elapsed="0.002424"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.699094" elapsed="0.002683"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.699075" elapsed="0.002793"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.704569" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.702157" elapsed="0.002458"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.701928" elapsed="0.002736"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.701911" elapsed="0.002778"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.705249" 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-06-06T03:13:03.704860" elapsed="0.000416"/>
</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-06-06T03:13:03.705590" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.705347" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.706172" 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-06-06T03:13:03.705872" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.705691" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.705328" elapsed="0.000927"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.706796" 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-06-06T03:13:03.706419" elapsed="0.000404"/>
</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-06-06T03:13:03.707145" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.706906" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.707701" 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-06-06T03:13:03.707388" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.707226" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.706875" elapsed="0.000910"/>
</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-06-06T03:13:03.707954" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:03.708891" 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-06-06T03:13:03.708489" elapsed="0.000429"/>
</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-06-06T03:13:03.709080" elapsed="0.002315"/>
</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-06-06T03:13:03.698668" elapsed="0.012825"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.711772" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.711594" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.711566" elapsed="0.000301"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:03.715423" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:03.712092" elapsed="0.003360"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:03.715506" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:03.715680" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:03.687252" elapsed="0.028456"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.715772" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:03.715922" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:03.588465" elapsed="0.127518"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.745167" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.744347" elapsed="0.000852"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.747316" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.746734" elapsed="0.000750">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:03.747629" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.745377" elapsed="0.002293"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.748675" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:03.747845" elapsed="0.000861"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:03.749118" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:03.749395" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:03.748875" elapsed="0.000551"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.750077" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.749602" elapsed="0.000537"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:03.750880" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.750218" elapsed="0.000824"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.751896" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.751251" elapsed="0.000688"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.751072" elapsed="0.000951"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.750194" elapsed="0.001853"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.753040" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.752211" elapsed="0.000859"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.753124" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:03.743593" elapsed="0.009665"/>
</kw>
<msg time="2026-06-06T03:13:03.753313" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.730767" elapsed="0.022596"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.766100" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.778355" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.790740" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.790944" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.791127" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.791517" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.791367" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:03.791352" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.791756" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.791928" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.792098" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:03.791321" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.791212" elapsed="0.000967"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.792330" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.792405" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:03.792526" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:03.727996" elapsed="0.064557"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.792752" elapsed="0.002231"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:03.796093" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.795749" elapsed="0.000373"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:03.796581" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:03.796279" elapsed="0.000330"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:03.796794" elapsed="0.000328"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:03.795308" elapsed="0.001875"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.795064" elapsed="0.002154"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.797396" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.797244" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.795045" elapsed="0.002432"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:03.717151" elapsed="0.080438"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:03.716335" elapsed="0.081353"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:03.716072" elapsed="0.081665"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.716053" elapsed="0.081710"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:03.797797" elapsed="0.000030"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:03.582270" elapsed="0.215660"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.578052" elapsed="0.219942"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:03.577530" elapsed="0.220513"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:03.577149" elapsed="0.220955"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:03.798710" elapsed="0.000245"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:03.798386" elapsed="0.000633"/>
</kw>
<doc>See example-ipv4-topology empty again.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:03.487975" elapsed="0.311083"/>
</test>
<test id="s1-s4-t20" name="Start_Listening_BGP_Speaker" line="262">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.802589" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.802334" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.802315" elapsed="0.000377"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:03.802150" elapsed="0.000588"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.803734" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.803611" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.803592" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.808830" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.808723" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.808705" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.809955" 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-06-06T03:13:03.809549" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.810454" 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-06-06T03:13:03.810153" elapsed="0.000336"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:03.810534" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:03.810703" 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-06-06T03:13:03.809129" elapsed="0.001598"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:03.816061" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.815953" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.815933" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:03.817280" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:03.817173" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.817155" elapsed="0.000192"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:03.817843" 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-06-06T03:13:03.817513" elapsed="0.000357"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.818250" level="INFO">${current_connection_index} = 7</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-06-06T03:13:03.818034" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.852394" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:03.818835" elapsed="0.033691"/>
</kw>
<msg time="2026-06-06T03:13:03.852733" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:03.852782" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:03.818475" elapsed="0.034343"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.870250" level="INFO">". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:13:03.853433" elapsed="0.016956"/>
</kw>
<msg time="2026-06-06T03:13:03.870575" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:03.870623" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
...</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-06-06T03:13:03.853020" elapsed="0.017662"/>
</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-06-06T03:13:03.871094" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.870803" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.870770" elapsed="0.000410"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.871698" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:13:03.871331" elapsed="0.000446"/>
</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-06-06T03:13:03.872077" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.871847" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.871828" elapsed="0.000328"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:03.872194" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:03.875158" elapsed="0.001897"/>
</kw>
<msg time="2026-06-06T03:13:03.877125" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:03.874003" elapsed="0.003255"/>
</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="NOT RUN" start="2026-06-06T03:13:03.877563" elapsed="0.000091"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.877935" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:03.873304" elapsed="0.004818"/>
</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-06-06T03:13:03.872729" elapsed="0.005458"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:03.816872" elapsed="0.061413"/>
</kw>
<msg time="2026-06-06T03:13:03.878376" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.878420" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.816281" elapsed="0.062177"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:03.878671" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:13:03.878546" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.878526" elapsed="0.000231"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.879163" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.879510" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:03.879580" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:03.815605" elapsed="0.064105"/>
</kw>
<msg time="2026-06-06T03:13:03.879805" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:03.879849" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:03.811094" elapsed="0.068839"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:03.880268" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:03.880013" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:03.879995" elapsed="0.000351"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:03.810950" elapsed="0.069420"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:03.810779" elapsed="0.069623"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:03.808347" elapsed="0.072109"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:03.803324" elapsed="0.077185"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:03.802894" elapsed="0.077658"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:03.799979" elapsed="0.080625"/>
</kw>
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.881754" level="INFO">${command} = python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --info &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:03.881392" elapsed="0.000390"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:03.882189" level="INFO">python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --info &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:03.881943" elapsed="0.000293"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:03.885366" level="INFO">python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --info &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:13:03.885461" level="INFO">${output} =  python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --info &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:03.882390" elapsed="0.003098"/>
</kw>
<arg>--amount 3 --listen --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --${BGP_TOOL_LOG_LEVEL}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:13:03.880863" elapsed="0.004687"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:13.887774" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.887171" elapsed="10.001381">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.888903" elapsed="0.000033"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:13:03.886902" elapsed="10.002152">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:13:03.886462" elapsed="10.002745"/>
</kw>
<msg time="2026-06-06T03:13:13.889340" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:03.886098" elapsed="10.003269"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:13:13.889562" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:13:13.889462" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.889436" elapsed="0.000233"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.889906" elapsed="0.000027"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.890085" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:13:03.885813" elapsed="10.004353"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:13.890873" elapsed="0.000312"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:13.890460" elapsed="0.000789"/>
</kw>
<doc>Start Python speaker in listening mode, verify that the tool does not exit quickly.</doc>
<status status="PASS" start="2026-06-06T03:13:03.799378" elapsed="10.091908"/>
</test>
<test id="s1-s4-t21" name="Check_Listening_Connection_Is_Not_Established_Yet" line="268">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.895488" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:13.895251" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.895232" elapsed="0.000339"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:13.895062" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:13.896701" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:13.896575" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.896555" elapsed="0.000217"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:13.901685" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:13.901562" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.901544" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:13.902783" 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-06-06T03:13:13.902375" elapsed="0.000435"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:13.903276" 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-06-06T03:13:13.902975" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:13.903346" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:13.903500" 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-06-06T03:13:13.901995" elapsed="0.001529"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:13.909191" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:13.909082" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.909062" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:13.910550" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:13.910442" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.910423" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:13.911102" 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-06-06T03:13:13.910789" elapsed="0.000340"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:13.911510" level="INFO">${current_connection_index} = 7</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-06-06T03:13:13.911292" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:13.948505" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:13.912057" elapsed="0.036565"/>
</kw>
<msg time="2026-06-06T03:13:13.948837" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:13.948884" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:13.911719" elapsed="0.037200"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:13.972260" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "N "o "t "_ "E "s "t "a "b "l "i "s "h "e "d "_ "Y "e "t "[K"
[?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-06-06T03:13:13.949475" elapsed="0.022899"/>
</kw>
<msg time="2026-06-06T03:13:13.972542" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:13.972588" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</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-06-06T03:13:13.949109" elapsed="0.023514"/>
</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-06-06T03:13:13.972985" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:13.972736" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.972709" elapsed="0.000358"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:13.973525" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "N "o "t "_ "E "s "t "a "b "l "i "s "h "e "d "_ "Y "e "t "[K"
[?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-06-06T03:13:13.973213" elapsed="0.000457"/>
</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-06-06T03:13:13.973964" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:13.973742" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.973722" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:13.974078" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:13.976795" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:13:13.977008" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:13.975683" elapsed="0.001457"/>
</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="NOT RUN" start="2026-06-06T03:13:13.977421" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.977778" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:13.975034" elapsed="0.002931"/>
</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-06-06T03:13:13.974376" elapsed="0.003655"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:13.910138" elapsed="0.067992"/>
</kw>
<msg time="2026-06-06T03:13:13.978225" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:13.978270" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:13.909493" elapsed="0.068814"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:13.978493" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:13.978384" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.978365" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.979003" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.979352" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:13.979424" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:13.908741" elapsed="0.070794"/>
</kw>
<msg time="2026-06-06T03:13:13.979629" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:13.979691" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:13.904040" elapsed="0.075687"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:13.980057" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:13.979803" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:13.979785" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:13.903842" elapsed="0.076315"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:13.903582" elapsed="0.076607"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:13.901196" elapsed="0.079078"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:13.896243" elapsed="0.084089"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:13.895789" elapsed="0.084587"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:13.892475" elapsed="0.087955"/>
</kw>
<kw name="Check_Speaker_Is_Not_Connected">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Number_Of_Speaker_Connections">
<kw name="Count_Port_Occurences" owner="SSHKeywords">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_And_Install_Netstat" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:13.986622" level="INFO">Executing command 'netstat --version'.</msg>
<msg time="2026-06-06T03:13:14.000088" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:14.000257" level="INFO">${netstat_installed} = net-tools 2.10-alpha
Fred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others
+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX
AF: (inet) +UNIX +INET...</msg>
<var>${netstat_installed}</var>
<arg>netstat --version</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:13.986521" elapsed="0.013830"/>
</kw>
<if>
<branch type="IF" condition="'${netstat_installed}' is not string and '${netstat_installed}' != '0'">
<kw name="Install_Netstat" owner="SSHKeywords">
<doc>Install netstat if it is not already installed.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.001014" elapsed="0.000056"/>
</kw>
<msg time="2026-06-06T03:13:14.001150" level="FAIL">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</msg>
<status status="FAIL" start="2026-06-06T03:13:14.000460" elapsed="0.000800">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:13:14.000432" elapsed="0.000920">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</if>
<doc>Check if netstat is installed and install it if not.</doc>
<status status="FAIL" start="2026-06-06T03:13:13.986244" elapsed="0.015359">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</kw>
<arg>Check_And_Install_Netstat</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:13.985852" elapsed="0.015928"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:14.002624" level="INFO">Executing command 'netstat -punta 2&gt; /dev/null | grep -E ":17900 .+ ESTABLISHED .+python" | wc -l'.</msg>
<msg time="2026-06-06T03:13:14.049723" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:14.049947" level="INFO">${output} = 0</msg>
<var>${output}</var>
<arg>${NETSTAT_COMMAND} 2&gt; /dev/null | grep -E ":${port} .+ ${state} .+${name}" | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:14.002140" elapsed="0.047863"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:13:14.050118" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:13:14.050473" level="INFO">${output} = 0</msg>
<var>${output}</var>
<arg>17900</arg>
<arg>ESTABLISHED</arg>
<arg>python</arg>
<doc>Run 'netstat' on the remote machine and count occurences of given port in the given state connected to process with the given name.</doc>
<status status="PASS" start="2026-06-06T03:13:13.985416" elapsed="0.065113"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output}</arg>
<arg>${howmany}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:13:14.050947" elapsed="0.000829"/>
</kw>
<arg>0</arg>
<doc>Run netstat in mininet machine and parse it for number of established connections. Check it is ${howmany}.</doc>
<status status="PASS" start="2026-06-06T03:13:13.985047" elapsed="0.066871"/>
</kw>
<arg>3s</arg>
<arg>1s</arg>
<arg>Check_Number_Of_Speaker_Connections</arg>
<arg>0</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:13.980870" elapsed="0.071151"/>
</kw>
<doc>Give it a few tries to see zero established connections.</doc>
<status status="PASS" start="2026-06-06T03:13:13.980569" elapsed="0.071579"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:14.053608" elapsed="0.000567"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:14.052909" elapsed="0.001410"/>
</kw>
<doc>See no TCP connection, as both ODL and tool are in listening mode.</doc>
<status status="PASS" start="2026-06-06T03:13:13.891808" elapsed="0.162596"/>
</test>
<test id="s1-s4-t22" name="Check_For_Empty_Topology_Before_Listening" line="272">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.060414" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.059884" elapsed="0.000610"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.059855" elapsed="0.000674"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:14.059602" elapsed="0.000993"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.062178" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:14.061994" elapsed="0.000249"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.061960" elapsed="0.000315"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.069055" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:14.068950" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.068931" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.070137" 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-06-06T03:13:14.069746" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.070633" 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-06-06T03:13:14.070336" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:14.070720" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:14.070875" 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-06-06T03:13:14.069351" elapsed="0.001549"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:14.076942" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:14.076827" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.076805" elapsed="0.000209"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:14.078259" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:14.078149" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.078131" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:14.078809" 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-06-06T03:13:14.078480" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:14.079223" level="INFO">${current_connection_index} = 7</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-06-06T03:13:14.079005" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:14.111761" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:14.079777" elapsed="0.032171"/>
</kw>
<msg time="2026-06-06T03:13:14.112196" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:14.112246" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:14.079414" elapsed="0.032867"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:14.132718" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o "r "e "_ "L "i "s "t "e "n "i "n "g "[K"
[?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-06-06T03:13:14.112980" elapsed="0.019861"/>
</kw>
<msg time="2026-06-06T03:13:14.133015" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:14.133061" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o ...</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-06-06T03:13:14.112525" elapsed="0.020573"/>
</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-06-06T03:13:14.133539" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.133270" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.133241" elapsed="0.000383"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.134124" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o "r "e "_ "L "i "s "t "e "n "i "n "g "[K"
[?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-06-06T03:13:14.133798" elapsed="0.000392"/>
</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-06-06T03:13:14.134478" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.134258" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.134239" elapsed="0.000317"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:14.134593" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:14.137354" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:13:14.137567" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:14.136228" elapsed="0.001490"/>
</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="NOT RUN" start="2026-06-06T03:13:14.137999" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.138336" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:14.135498" elapsed="0.003026"/>
</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-06-06T03:13:14.134935" elapsed="0.003654"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:14.077836" elapsed="0.060874"/>
</kw>
<msg time="2026-06-06T03:13:14.138807" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:14.138854" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:14.077177" elapsed="0.061714"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:14.139079" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:14.138970" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.138951" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.139585" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.139965" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.140038" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:14.076289" elapsed="0.063890"/>
</kw>
<msg time="2026-06-06T03:13:14.140277" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:14.140322" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "B "e "f "o ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:14.071312" elapsed="0.069047"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.140719" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.140436" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.140418" elapsed="0.000380"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:14.071160" elapsed="0.069662"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:14.070958" elapsed="0.069898"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:14.068452" elapsed="0.072463"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:14.061557" elapsed="0.079416"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:14.060833" elapsed="0.080187"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:14.056379" elapsed="0.084696"/>
</kw>
<kw name="Verify_That_Topology_Does_Not_Change_From">
<kw name="Verify_Keyword_Does_Not_Fail_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Confirm_Keyword_Fails_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.197418" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:14.196979" elapsed="0.000474"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:14.198297" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.198001" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:14.198469" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:14.197634" elapsed="0.000860"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.199074" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:14.198681" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:14.199426" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:14.199615" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:14.199273" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.200101" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.199827" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.201241" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.200982" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.201747" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:14.201455" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.202125" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.202339" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.202519" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:14.201984" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.201829" elapsed="0.000781"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:14.202676" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:13:14.202852" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:14.200611" elapsed="0.002266"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.200235" elapsed="0.002674"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.203255" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.202935" elapsed="0.000377"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.200207" elapsed="0.003126"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.203957" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:14.203483" elapsed="0.000502"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:14.204301" elapsed="0.000107"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:14.196308" elapsed="0.008395"/>
</kw>
<msg time="2026-06-06T03:13:14.204951" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:14.183780" elapsed="0.021272"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.221701" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.235435" elapsed="0.000075"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.248047" elapsed="0.000049"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.248332" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.248534" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.249033" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.248867" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:14.248846" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.249275" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.249449" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.249621" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:14.248798" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.248631" elapsed="0.001091"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.249881" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.249966" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:13:14.250146" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:14.179406" elapsed="0.070770"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:14.251722" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.251380" elapsed="0.000425">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:14.251904" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:14.250947" elapsed="0.000982"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.252406" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.252047" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.253005" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:14.252700" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.252491" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.252026" elapsed="0.001065"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.255419" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:14.253251" elapsed="0.002196"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:14.255501" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:14.255681" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:14.250545" elapsed="0.005162"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:14.257030" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.256771" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:14.257194" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:14.256409" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:14.257432" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:14.257291" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.257271" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.257687" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.257866" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.257933" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:14.260057" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:14.256072" elapsed="0.004013"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.261581" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.261320" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.262050" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.261804" elapsed="0.000341"/>
</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-06-06T03:13:14.272891" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:14.273179" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:14.273437" 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-06-06T03:13:14.264303" elapsed="0.009196"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.262213" elapsed="0.011390"/>
</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-06-06T03:13:14.274101" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.273704" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.262194" elapsed="0.012101"/>
</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-06-06T03:13:14.282214" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.276798" elapsed="0.005525"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.276247" elapsed="0.006158"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.276200" elapsed="0.006261"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.286417" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.283132" elapsed="0.003400"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.282589" elapsed="0.003979"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.282550" elapsed="0.004044"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.287205" 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-06-06T03:13:14.286795" elapsed="0.000438"/>
</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-06-06T03:13:14.287550" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.287305" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.288185" 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-06-06T03:13:14.287822" elapsed="0.000390"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.287635" elapsed="0.000614"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.287286" elapsed="0.000984"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.288821" 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-06-06T03:13:14.288436" elapsed="0.000413"/>
</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-06-06T03:13:14.289159" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.288920" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.289721" 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-06-06T03:13:14.289406" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.289242" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.288901" elapsed="0.000904"/>
</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-06-06T03:13:14.289963" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:14.290799" 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-06-06T03:13:14.290480" elapsed="0.000346"/>
</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-06-06T03:13:14.290986" elapsed="0.002273"/>
</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-06-06T03:13:14.275177" elapsed="0.018147"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.293506" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:14.293396" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.293376" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:14.296378" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:14.293739" elapsed="0.002668"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:14.296461" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:13:14.296627" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:14.260411" elapsed="0.036258"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:14.296736" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:14.296891" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:14.157028" elapsed="0.139890"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.325129" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:14.324741" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:14.326030" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.325754" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:14.326207" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:14.325389" elapsed="0.000843"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.326822" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:14.326403" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:14.327165" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:14.327327" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:14.327024" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.327781" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:14.327513" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:14.328237" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.327912" elapsed="0.000385"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.328785" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:14.328472" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.328322" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.327877" elapsed="0.000991"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.329460" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:14.329024" elapsed="0.000464"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:14.329539" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:14.324081" elapsed="0.005604"/>
</kw>
<msg time="2026-06-06T03:13:14.329741" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:14.311373" elapsed="0.018421"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.341885" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.354269" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.366523" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.366782" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.366965" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.367354" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.367207" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:14.367192" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.367577" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.367762" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.367970" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:14.367162" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.367051" elapsed="0.001004"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.368207" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.368284" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:14.368403" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:14.308758" elapsed="0.059673"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:14.368609" elapsed="0.002174"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:14.371973" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:14.371529" elapsed="0.000473"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:14.372442" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:14.372162" elapsed="0.000308"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:14.372628" elapsed="0.000355"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:14.371114" elapsed="0.001930"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.370865" elapsed="0.002214"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:14.373258" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:14.373104" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.370845" elapsed="0.002490"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:14.298074" elapsed="0.075308"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:14.297251" elapsed="0.076206"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:14.297004" elapsed="0.076499"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.296986" elapsed="0.076542"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:14.373562" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:14.150634" elapsed="0.223202"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:14.145995" elapsed="0.227960"/>
</kw>
<msg time="2026-06-06T03:13:14.374123" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:14.374169" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:14.145410" elapsed="0.228783"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:14.374377" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:14.374267" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:14.374249" elapsed="0.000195"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.375045" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:14.374593" elapsed="0.000478"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:14.375674" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.375232" elapsed="0.000508">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.145069" elapsed="0.230802">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.438618" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:15.438169" elapsed="0.000501"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:15.439510" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:15.439227" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:15.439747" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:15.438874" elapsed="0.000899"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.440347" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:15.439952" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:15.440713" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:15.440883" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:15.440541" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.441333" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.441076" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.442413" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.442146" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.442966" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:15.442627" elapsed="0.000367"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.443342" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.443554" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.443752" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:15.443202" elapsed="0.000610"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.443050" elapsed="0.000794"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:15.443894" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:13:15.444065" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:15.441809" elapsed="0.002282"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.441460" elapsed="0.002663"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.444301" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.444148" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.441435" elapsed="0.003007"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.445095" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:15.444596" elapsed="0.000527"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:15.445175" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:15.437512" elapsed="0.007794"/>
</kw>
<msg time="2026-06-06T03:13:15.445361" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:15.424736" elapsed="0.020679"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.459624" elapsed="0.000067"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.472122" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.484429" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.484682" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.484875" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.485295" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.485142" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:15.485123" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.485530" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.485722" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.485899" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:15.485083" elapsed="0.000872"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.484964" elapsed="0.001019"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.486135" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.486215" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:13:15.486366" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:15.420179" elapsed="0.066215"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:15.487926" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:15.487613" elapsed="0.000390">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:15.488100" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:15.487209" elapsed="0.000917"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.488473" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.488200" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.489105" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:15.488787" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.488560" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.488180" elapsed="0.001011"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.491724" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:15.489382" elapsed="0.002370"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:15.491805" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:13:15.491966" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:15.486840" elapsed="0.005151"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:15.493250" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:15.493004" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:15.493410" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:15.492653" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:15.493663" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:13:15.493508" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.493488" elapsed="0.000265"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.493903" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.494081" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.494148" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:15.496389" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:15.492305" elapsed="0.004112"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.497869" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.497589" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.498331" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.498083" elapsed="0.000294"/>
</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-06-06T03:13:15.507472" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:15.507608" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:15.507742" 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-06-06T03:13:15.500623" elapsed="0.007146"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.498460" elapsed="0.009354"/>
</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-06-06T03:13:15.508005" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.507842" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.498439" elapsed="0.009701"/>
</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-06-06T03:13:15.512115" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.509246" elapsed="0.002938"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.509016" elapsed="0.003217"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.508995" elapsed="0.003274"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.515933" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.512694" elapsed="0.003305"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.512349" elapsed="0.003699"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.512324" elapsed="0.003760"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.516896" 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-06-06T03:13:15.516325" elapsed="0.000609"/>
</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-06-06T03:13:15.517379" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.517036" elapsed="0.000426"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.518186" 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-06-06T03:13:15.517753" elapsed="0.000471"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.517496" elapsed="0.000780"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.517008" elapsed="0.001297"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.519154" 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-06-06T03:13:15.518536" elapsed="0.000656"/>
</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-06-06T03:13:15.519634" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.519294" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.520499" 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-06-06T03:13:15.520064" elapsed="0.000472"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.519798" elapsed="0.000789"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.519266" elapsed="0.001351"/>
</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-06-06T03:13:15.520858" elapsed="0.000491"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:15.522028" 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-06-06T03:13:15.521587" elapsed="0.000479"/>
</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-06-06T03:13:15.522291" elapsed="0.002608"/>
</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-06-06T03:13:15.508529" elapsed="0.016435"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.525148" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:15.525037" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.525016" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:15.528010" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:15.525369" elapsed="0.002671"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:15.528095" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:15.528259" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:15.496756" elapsed="0.031530"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:15.528349" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:15.528501" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:15.397333" elapsed="0.131232"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.556957" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:15.556556" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:15.557758" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:15.557495" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:15.557924" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:15.557156" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.558526" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:15.558122" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:15.558934" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:15.559094" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:15.558783" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.559566" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:15.559289" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:15.560082" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.559708" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.560631" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:15.560327" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.560174" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.559685" elapsed="0.001049"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.561459" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:15.560911" elapsed="0.000585"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:15.561562" elapsed="0.000041"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:15.555935" elapsed="0.005810"/>
</kw>
<msg time="2026-06-06T03:13:15.561804" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:15.543276" elapsed="0.018585"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.574365" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.590192" elapsed="0.000075"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.608502" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.608733" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.608921" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.609374" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.609215" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:15.609197" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.609616" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.609807" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.609977" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:15.609153" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.609012" elapsed="0.001047"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.610210" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.610288" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:15.610415" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:15.540626" elapsed="0.069817"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:15.610625" elapsed="0.002234"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:15.613961" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:15.613622" elapsed="0.000367"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:15.614424" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:15.614147" elapsed="0.000304"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:15.614609" elapsed="0.000376"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:15.613190" elapsed="0.001856"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.612942" elapsed="0.002138"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:15.615258" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:15.615106" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.612922" elapsed="0.002413"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:15.529768" elapsed="0.085661"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:15.528935" elapsed="0.086576"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:15.528670" elapsed="0.086888"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.528635" elapsed="0.086948"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:15.615617" elapsed="0.000045"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:15.388509" elapsed="0.227382"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:15.379682" elapsed="0.236293"/>
</kw>
<msg time="2026-06-06T03:13:15.616155" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:15.616202" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:15.378217" elapsed="0.238008"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:15.616410" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:15.616298" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:15.616279" elapsed="0.000198"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.617088" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:15.616626" elapsed="0.000490"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:15.617730" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:15.617276" elapsed="0.000524">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:15.377171" elapsed="0.240741">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.678141" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:16.677713" elapsed="0.000461"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:16.678997" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:16.678726" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:16.679170" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:16.678363" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.679774" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:16.679369" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:16.680110" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:16.680276" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:16.679968" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.680725" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.680463" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.681782" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.681491" elapsed="0.000335"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.682268" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:16.681991" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.682635" elapsed="0.000038"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.682925" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.683106" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:16.682495" elapsed="0.000669"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.682349" elapsed="0.000847"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:16.683244" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:16.683411" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:16.681165" elapsed="0.002271"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.680850" elapsed="0.002617"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.683659" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.683493" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.680824" elapsed="0.002914"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.684333" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:16.683885" elapsed="0.000476"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:16.684411" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:16.677058" elapsed="0.007484"/>
</kw>
<msg time="2026-06-06T03:13:16.684596" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:16.664697" elapsed="0.019964"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.697067" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.709196" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.721279" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.721485" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.721749" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.722147" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.721995" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:16.721979" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.722371" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.722540" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.722725" elapsed="0.000060"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:16.721948" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.721841" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.723001" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.723078" elapsed="0.000160"/>
</return>
<msg time="2026-06-06T03:13:16.723341" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:16.660387" elapsed="0.062980"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:16.724677" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:16.724412" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:16.724839" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:16.724045" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.725213" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.724961" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.725801" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:16.725475" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.725294" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.724941" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.728173" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:16.726037" elapsed="0.002163"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:16.728252" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:16.728407" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:16.723713" elapsed="0.004718"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:16.729709" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:16.729420" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:16.729870" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:16.729081" elapsed="0.000813"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:16.730102" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:16.729966" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.729946" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.730334" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.730509" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.730574" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:16.732604" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:16.728754" elapsed="0.003877"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.734069" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.733817" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.734516" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.734272" elapsed="0.000288"/>
</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-06-06T03:13:16.743043" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:16.743192" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:16.743318" 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-06-06T03:13:16.736724" elapsed="0.006621"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.734679" elapsed="0.008716"/>
</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-06-06T03:13:16.743603" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.743424" elapsed="0.000271"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.734658" elapsed="0.009060"/>
</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-06-06T03:13:16.747265" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.744812" elapsed="0.002502"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.744557" elapsed="0.002793"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.744535" elapsed="0.002840"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.750080" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.747675" elapsed="0.002451"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.747432" elapsed="0.002729"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.747414" elapsed="0.002772"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.750773" 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-06-06T03:13:16.750361" elapsed="0.000440"/>
</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-06-06T03:13:16.751117" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.750874" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.751680" 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-06-06T03:13:16.751365" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.751198" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.750854" elapsed="0.000910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.752287" 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-06-06T03:13:16.751926" elapsed="0.000387"/>
</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-06-06T03:13:16.752619" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.752383" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.753182" 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-06-06T03:13:16.752882" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.752717" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.752364" elapsed="0.000900"/>
</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-06-06T03:13:16.753418" elapsed="0.000374"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:16.754260" 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-06-06T03:13:16.753960" elapsed="0.000327"/>
</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-06-06T03:13:16.754447" elapsed="0.002272"/>
</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-06-06T03:13:16.744109" elapsed="0.012676"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.756968" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:16.756857" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.756837" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:16.759849" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:16.757186" elapsed="0.002740"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:16.759982" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:16.760147" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:16.732959" elapsed="0.027215"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:16.760238" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:16.760392" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:16.638414" elapsed="0.122004"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.788272" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:16.787898" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:16.789071" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:16.788823" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:16.789238" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:16.788467" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.789880" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:16.789434" elapsed="0.000474"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:16.790214" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:16.790368" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:16.790076" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.790823" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:16.790556" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:16.791236" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.790939" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.791786" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:16.791473" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.791322" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.790919" elapsed="0.000952"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.792451" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:16.792022" elapsed="0.000458"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:16.792530" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:16.787266" elapsed="0.005406"/>
</kw>
<msg time="2026-06-06T03:13:16.792779" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:16.774896" elapsed="0.017939"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.805147" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.817243" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.829443" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.829753" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.829953" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.830360" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.830210" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:16.830194" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.830586" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.830774" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.830947" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:16.830161" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.830038" elapsed="0.000989"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.831176" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.831253" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:16.831370" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:16.772268" elapsed="0.059129"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:16.831576" elapsed="0.002235"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:16.834926" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:16.834614" elapsed="0.000341"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:16.835435" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:16.835156" elapsed="0.000307"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:16.835622" elapsed="0.000345"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:16.834165" elapsed="0.001868"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.833895" elapsed="0.002171"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:16.836243" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:16.836092" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.833875" elapsed="0.002445"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:16.761568" elapsed="0.074799"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:16.760763" elapsed="0.075678"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:16.760504" elapsed="0.075982"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.760485" elapsed="0.076026"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:16.836544" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:16.629876" elapsed="0.206936"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:16.621260" elapsed="0.215636"/>
</kw>
<msg time="2026-06-06T03:13:16.837060" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:16.837105" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:16.619989" elapsed="0.217140"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:16.837310" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:16.837201" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:16.837182" elapsed="0.000194"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.838014" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:16.837524" elapsed="0.000524"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:16.838677" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:16.838222" elapsed="0.000520">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:16.619016" elapsed="0.219843">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.898193" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:17.897765" elapsed="0.000465"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:17.899139" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:17.898861" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:17.899351" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:17.898447" elapsed="0.000931"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.900052" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:17.899593" elapsed="0.000490"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:17.900402" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:17.900788" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:17.900252" elapsed="0.000575"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.901285" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:17.901002" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.902536" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:17.902238" elapsed="0.000347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.903088" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:17.902803" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.903460" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.903691" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.903872" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:17.903320" elapsed="0.000611"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:17.903172" elapsed="0.000790"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:17.904012" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:13:17.904199" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:17.901822" elapsed="0.002405"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.901427" elapsed="0.002833"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.904439" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:17.904285" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.901400" elapsed="0.003118"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.905161" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:17.904705" elapsed="0.000484"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:17.905239" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:17.897087" elapsed="0.008277"/>
</kw>
<msg time="2026-06-06T03:13:17.905418" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:17.884200" elapsed="0.021270"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.917944" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.930203" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.942397" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.942695" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.942885" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.943279" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:17.943129" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:17.943112" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.943507" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.943693" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.943865" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:17.943077" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:17.942968" elapsed="0.000977"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.944095" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:17.944172" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:13:17.944308" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:17.879953" elapsed="0.064381"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:17.945738" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:17.945446" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:17.945907" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:17.945065" elapsed="0.000867"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.946272" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:17.946004" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.946865" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:17.946549" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.946364" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.945984" elapsed="0.000963"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.949292" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:17.947107" elapsed="0.002212"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:17.949371" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:17.949525" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:17.944715" elapsed="0.004835"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:17.950798" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:17.950539" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:17.950979" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:17.950200" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:17.951216" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:17.951078" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.951057" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.951448" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:17.951681" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:17.951752" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:17.953818" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:17.949872" elapsed="0.003973"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.955258" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:17.955003" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.955722" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:17.955462" elapsed="0.000305"/>
</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-06-06T03:13:17.964008" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:17.964144" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:17.964257" 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-06-06T03:13:17.957936" elapsed="0.006348"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.955836" elapsed="0.008493"/>
</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-06-06T03:13:17.964514" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:17.964355" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.955816" elapsed="0.008808"/>
</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-06-06T03:13:17.968072" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:17.965676" elapsed="0.002444"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.965436" elapsed="0.002719"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.965417" elapsed="0.002764"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.971479" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:17.968463" elapsed="0.003080"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.968237" elapsed="0.003355"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.968220" elapsed="0.003406"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.972424" 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-06-06T03:13:17.971885" elapsed="0.000577"/>
</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-06-06T03:13:17.972939" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:17.972562" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.973768" 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-06-06T03:13:17.973322" elapsed="0.000482"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.973069" elapsed="0.000786"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.972535" elapsed="0.001348"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.974610" 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-06-06T03:13:17.974107" elapsed="0.000560"/>
</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-06-06T03:13:17.975101" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:17.974768" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:17.975872" 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-06-06T03:13:17.975436" elapsed="0.000473"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.975213" elapsed="0.000748"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.974741" elapsed="0.001260"/>
</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-06-06T03:13:17.976223" elapsed="0.000539"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:17.977478" 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-06-06T03:13:17.977068" elapsed="0.000448"/>
</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-06-06T03:13:17.977761" elapsed="0.003253"/>
</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-06-06T03:13:17.965006" elapsed="0.016092"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:17.981275" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:17.981169" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.981148" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:17.985581" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:17.981492" elapsed="0.004119"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:17.985680" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:17.985842" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:17.954163" elapsed="0.031707"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:17.985933" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:17.986083" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:17.857268" elapsed="0.128841"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.014529" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:18.014138" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:18.015377" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:18.015111" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:18.015548" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:18.014763" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.016176" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:18.015782" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:18.016549" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:18.016755" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:18.016393" elapsed="0.000390"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.017191" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:18.016945" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:18.017611" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:18.017309" elapsed="0.000379"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.018158" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:18.017866" elapsed="0.000366"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:18.017715" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:18.017287" elapsed="0.001004"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.018892" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:18.018442" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:18.018973" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:18.013496" elapsed="0.005604"/>
</kw>
<msg time="2026-06-06T03:13:18.019155" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:18.000842" elapsed="0.018365"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.031754" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.044003" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.056260" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.056463" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.056678" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.057097" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:18.056943" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:18.056926" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.057335" elapsed="0.000025"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.057514" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.057701" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:18.056890" elapsed="0.000868"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:18.056766" elapsed="0.001020"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.057936" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:18.058013" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:18.058134" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:17.998167" elapsed="0.060036"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:18.058390" elapsed="0.002276"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:18.061749" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:18.061423" elapsed="0.000361"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:18.062240" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:18.061948" elapsed="0.000320"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:18.062427" elapsed="0.000358"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:18.060998" elapsed="0.001852"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:18.060751" elapsed="0.002134"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:18.063071" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:18.062912" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:18.060731" elapsed="0.002419"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:17.987302" elapsed="0.075895"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:17.986438" elapsed="0.076834"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:17.986193" elapsed="0.077124"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:17.986175" elapsed="0.077165"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:18.063373" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:17.850934" elapsed="0.212686"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:17.842312" elapsed="0.221413"/>
</kw>
<msg time="2026-06-06T03:13:18.063888" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:18.063933" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:17.840995" elapsed="0.222960"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:18.064134" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:18.064026" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:18.064008" elapsed="0.000191"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.064847" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:18.064344" elapsed="0.000531"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:18.065490" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:18.065043" elapsed="0.000528">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:17.839995" elapsed="0.225724">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.126991" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:19.126569" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:19.127958" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:19.127662" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:19.128133" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:19.127296" elapsed="0.000863"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.128750" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:19.128331" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:19.129097" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:19.129260" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:19.128948" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.129725" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.129452" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.130778" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.130500" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.131265" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:19.130990" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.131628" elapsed="0.000037"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.131888" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.132067" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:19.131489" elapsed="0.000636"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.131346" elapsed="0.000810"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:19.132203" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:19.132370" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:19.130168" elapsed="0.002228"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.129853" elapsed="0.002576"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.132607" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.132455" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.129828" elapsed="0.002880"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.133308" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:19.132860" elapsed="0.000477"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:19.133386" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:19.125929" elapsed="0.007583"/>
</kw>
<msg time="2026-06-06T03:13:19.133567" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:19.113250" elapsed="0.020369"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.146341" elapsed="0.000063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.158887" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.171206" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.171443" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.171663" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.172120" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.171961" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:19.171941" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.172359" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.172533" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.172719" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:19.171897" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.171764" elapsed="0.001040"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.172958" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.173041" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:13:19.173207" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:19.108573" elapsed="0.064662"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:19.174707" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:19.174389" elapsed="0.000396">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:19.174882" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:19.173965" elapsed="0.000942"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.175252" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.174980" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.175866" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:19.175520" elapsed="0.000373"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.175336" elapsed="0.000593"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.174960" elapsed="0.000992"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.178293" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:19.176111" elapsed="0.002209"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:19.178373" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:19.178529" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:19.173573" elapsed="0.005037"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:19.179910" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:19.179626" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:19.180071" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:19.179279" elapsed="0.000818"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:19.180310" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:19.180170" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.180150" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.180549" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.180744" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.180814" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:19.182875" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:19.178943" elapsed="0.003960"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.184355" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.184094" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.184832" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.184562" elapsed="0.000315"/>
</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-06-06T03:13:19.195208" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:19.195354" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:19.195466" 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-06-06T03:13:19.187070" elapsed="0.008423"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.184945" elapsed="0.010597"/>
</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-06-06T03:13:19.195803" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.195572" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.184925" elapsed="0.010970"/>
</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-06-06T03:13:19.199434" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.197003" elapsed="0.002480"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.196766" elapsed="0.002752"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.196746" elapsed="0.002798"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.202965" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.199884" elapsed="0.003145"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.199601" elapsed="0.003476"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.199584" elapsed="0.003527"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.203977" 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-06-06T03:13:19.203360" elapsed="0.000656"/>
</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-06-06T03:13:19.204461" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.204118" elapsed="0.000423"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.205257" 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-06-06T03:13:19.204833" elapsed="0.000460"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.204576" elapsed="0.000843"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.204091" elapsed="0.001359"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.206222" 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-06-06T03:13:19.205702" elapsed="0.000557"/>
</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-06-06T03:13:19.206721" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.206359" elapsed="0.000446"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.207489" 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-06-06T03:13:19.207069" elapsed="0.000457"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.206839" elapsed="0.000738"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.206332" elapsed="0.001274"/>
</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-06-06T03:13:19.207884" elapsed="0.000542"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:19.209111" 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-06-06T03:13:19.208695" elapsed="0.000453"/>
</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-06-06T03:13:19.209373" elapsed="0.003358"/>
</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-06-06T03:13:19.196292" elapsed="0.016509"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.212990" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:19.212877" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.212855" elapsed="0.000207"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:19.215940" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:19.213217" elapsed="0.002752"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:19.216023" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:13:19.216199" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:19.183221" elapsed="0.033005"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:19.216289" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:19.216444" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:19.084703" elapsed="0.131767"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.244347" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:19.243838" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:19.245169" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:19.244904" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:19.245339" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:19.244542" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.245938" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:19.245533" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:19.246333" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:19.246488" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:19.246190" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.246947" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:19.246693" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:19.247368" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.247063" elapsed="0.000365"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.247938" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:19.247622" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.247453" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.247043" elapsed="0.000979"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.248608" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:19.248171" elapsed="0.000465"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:19.248704" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:19.243178" elapsed="0.005652"/>
</kw>
<msg time="2026-06-06T03:13:19.248885" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:19.230776" elapsed="0.018161"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.261309" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.274496" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.286602" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.286825" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.287010" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.287418" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.287265" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:19.287247" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.287734" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.287913" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.288086" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:19.287213" elapsed="0.000928"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.287095" elapsed="0.001075"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.288322" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.288400" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:19.288532" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:19.228162" elapsed="0.060398"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:19.288756" elapsed="0.002200"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:19.292080" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:19.291762" elapsed="0.000349"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:19.292548" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:19.292271" elapsed="0.000304"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:19.292749" elapsed="0.000332"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:19.291288" elapsed="0.001855"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.291037" elapsed="0.002140"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:19.293356" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:19.293203" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.291018" elapsed="0.002416"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:19.217676" elapsed="0.075806"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:19.216835" elapsed="0.076724"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:19.216556" elapsed="0.077050"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.216538" elapsed="0.077092"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:19.293681" elapsed="0.000031"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:19.078265" elapsed="0.215675"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:19.069465" elapsed="0.224559"/>
</kw>
<msg time="2026-06-06T03:13:19.294197" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:19.294244" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:19.067954" elapsed="0.226313"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:19.294449" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:19.294340" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:19.294321" elapsed="0.000196"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.295192" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:19.294748" elapsed="0.000472"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:19.295853" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:19.295380" elapsed="0.000543">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:19.066823" elapsed="0.229212">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.354710" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:20.354251" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:20.355631" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:20.355358" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:20.355838" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:20.354974" elapsed="0.000889"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.356432" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:20.356036" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:20.356793" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:20.356972" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:20.356628" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.357420" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.357167" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.358556" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.358295" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.359090" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:20.358808" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.359470" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.359704" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.359886" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:20.359327" elapsed="0.000619"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.359177" elapsed="0.000801"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:20.360028" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:13:20.360206" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:20.357953" elapsed="0.002278"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.357550" elapsed="0.002713"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.360455" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.360291" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.357524" elapsed="0.003009"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.361167" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:20.360698" elapsed="0.000497"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:20.361243" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:20.353483" elapsed="0.007886"/>
</kw>
<msg time="2026-06-06T03:13:20.361492" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:20.340883" elapsed="0.020670"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.374088" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.386158" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.398242" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.398452" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.398652" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.399075" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.398924" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:20.398905" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.399302" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.399471" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.399667" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:20.398868" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.398739" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.399901" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.399979" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:20.400119" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:20.336482" elapsed="0.063664"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:20.401552" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:20.401251" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:20.401743" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:20.400864" elapsed="0.000904"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.402162" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.401842" elapsed="0.000380"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.402786" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:20.402442" elapsed="0.000372"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.402248" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.401822" elapsed="0.001052"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.405251" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:20.403033" elapsed="0.002244"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:20.405330" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:20.405486" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:20.400494" elapsed="0.005016"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:20.406851" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:20.406516" elapsed="0.000401">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:20.407012" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:20.406175" elapsed="0.000862"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:20.407261" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:20.407109" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.407089" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.407496" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.407687" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.407756" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:20.409818" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:20.405845" elapsed="0.004001"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.411301" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.411024" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.411776" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.411504" elapsed="0.000316"/>
</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-06-06T03:13:20.420962" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:20.421112" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:20.421223" 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-06-06T03:13:20.413935" elapsed="0.007318"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.411887" elapsed="0.009411"/>
</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-06-06T03:13:20.421512" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.421326" elapsed="0.000258"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.411867" elapsed="0.009740"/>
</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-06-06T03:13:20.425124" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.422688" elapsed="0.002484"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.422446" elapsed="0.002762"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.422426" elapsed="0.002807"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.427811" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.425515" elapsed="0.002452"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.425290" elapsed="0.002715"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.425272" elapsed="0.002758"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.428629" 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-06-06T03:13:20.428206" elapsed="0.000470"/>
</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-06-06T03:13:20.429000" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.428749" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.429596" 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-06-06T03:13:20.429260" elapsed="0.000364"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.429082" elapsed="0.000594"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.428730" elapsed="0.000968"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.430256" 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-06-06T03:13:20.429862" elapsed="0.000432"/>
</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-06-06T03:13:20.430612" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.430366" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.431232" 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-06-06T03:13:20.430906" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.430711" elapsed="0.000589"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.430347" elapsed="0.000973"/>
</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-06-06T03:13:20.431475" elapsed="0.000381"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:20.432400" 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-06-06T03:13:20.432028" elapsed="0.000408"/>
</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-06-06T03:13:20.432679" elapsed="0.003393"/>
</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-06-06T03:13:20.422000" elapsed="0.014161"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.436413" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:20.436262" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.436234" elapsed="0.000273"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:20.440148" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:20.436736" elapsed="0.003441"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:20.440231" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:20.440395" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:20.410173" elapsed="0.030248"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:20.440485" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:20.440652" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:20.314410" elapsed="0.126271"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.468633" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:20.468252" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:20.469545" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:20.469272" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:20.469732" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:20.468923" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.470322" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:20.469930" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:20.470672" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:20.470842" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:20.470518" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.471280" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:20.471031" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:20.471714" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.471396" elapsed="0.000378"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.472273" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:20.471965" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.471814" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.471376" elapsed="0.000981"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.472956" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:20.472505" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:20.473035" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:20.467607" elapsed="0.005557"/>
</kw>
<msg time="2026-06-06T03:13:20.473217" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:20.455065" elapsed="0.018205"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.485929" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.498222" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.510557" elapsed="0.000042"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.510958" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.511146" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.511581" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.511420" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:20.511402" elapsed="0.000280"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.511830" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.512001" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.512169" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:20.511366" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.511241" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.512409" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.512490" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:20.512627" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:20.452418" elapsed="0.060252"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:20.512873" elapsed="0.002306"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:20.516311" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:20.515986" elapsed="0.000354"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:20.516790" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:20.516496" elapsed="0.000321"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:20.516976" elapsed="0.000335"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:20.515533" elapsed="0.001838"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.515261" elapsed="0.002144"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:20.517582" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:20.517431" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.515242" elapsed="0.002445"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:20.441875" elapsed="0.075860"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:20.441022" elapsed="0.076790"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:20.440767" elapsed="0.077093"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.440749" elapsed="0.077136"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:20.517920" elapsed="0.000032"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:20.306606" elapsed="0.211570"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:20.299609" elapsed="0.218687"/>
</kw>
<msg time="2026-06-06T03:13:20.518463" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:20.518510" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:20.298360" elapsed="0.220175"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:20.518758" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:20.518609" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:20.518590" elapsed="0.000236"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.519414" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:20.518976" elapsed="0.000480"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:20.520072" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:20.519617" elapsed="0.000527">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:20.297201" elapsed="0.223056">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.586433" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:21.586031" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:21.587272" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:21.587013" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:21.587443" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:21.586663" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.588047" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:21.587653" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:21.588391" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:21.588554" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:21.588243" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.589010" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.588758" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.590058" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.589779" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.590538" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:21.590268" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.590918" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.591129" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.591313" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:21.590778" elapsed="0.000594"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.590618" elapsed="0.000784"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:21.591449" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:13:21.591614" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:21.589434" elapsed="0.002221"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.589133" elapsed="0.002556"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.591868" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.591715" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.589109" elapsed="0.002892"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.592603" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:21.592154" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:21.592700" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:21.585349" elapsed="0.007479"/>
</kw>
<msg time="2026-06-06T03:13:21.592883" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:21.572893" elapsed="0.020041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.605494" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.617726" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.630047" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.630265" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.630448" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.630854" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.630701" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:21.630684" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.631085" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.631260" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.631432" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:21.630635" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.630527" elapsed="0.000994"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.631687" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.631767" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:13:21.631897" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:21.568685" elapsed="0.063238"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:21.633332" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:21.633056" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:21.633501" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:21.632690" elapsed="0.000836"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.633880" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.633597" elapsed="0.000367"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.634472" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:21.634177" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.633990" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.633578" elapsed="0.000977"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.636890" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:21.634737" elapsed="0.002179"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:21.636968" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:21.637123" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:21.632319" elapsed="0.004829"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:21.638419" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:21.638172" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:21.638577" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:21.637810" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:21.638830" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:21.638692" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.638671" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.639066" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.639241" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.639307" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:21.641361" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:21.637465" elapsed="0.003923"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.642860" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.642588" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.643311" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.643063" elapsed="0.000292"/>
</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-06-06T03:13:21.651922" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:21.652059" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:21.652168" 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-06-06T03:13:21.645590" elapsed="0.006605"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.643423" elapsed="0.008839"/>
</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-06-06T03:13:21.652535" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.652301" elapsed="0.000405"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.643404" elapsed="0.009337"/>
</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-06-06T03:13:21.657853" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.654290" elapsed="0.003652"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.653957" elapsed="0.004038"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.653927" elapsed="0.004106"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.661846" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.658450" elapsed="0.003504"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.658118" elapsed="0.003889"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.658092" elapsed="0.003952"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.662674" 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-06-06T03:13:21.662266" elapsed="0.000436"/>
</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-06-06T03:13:21.663018" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.662775" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.663568" 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-06-06T03:13:21.663266" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.663102" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.662755" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.664195" 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-06-06T03:13:21.663831" elapsed="0.000390"/>
</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-06-06T03:13:21.664529" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.664293" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.665088" 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-06-06T03:13:21.664790" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.664611" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.664274" elapsed="0.000898"/>
</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-06-06T03:13:21.665325" elapsed="0.000371"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:21.666196" 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-06-06T03:13:21.665867" elapsed="0.000356"/>
</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-06-06T03:13:21.666385" elapsed="0.002300"/>
</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-06-06T03:13:21.653283" elapsed="0.015467"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.668929" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:21.668822" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.668801" elapsed="0.000196"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:21.671792" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:21.669147" elapsed="0.002674"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:21.671875" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:21.672032" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:21.641723" elapsed="0.030335"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:21.672121" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:21.672272" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:21.546469" elapsed="0.125862"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.700473" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:21.700090" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:21.701266" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:21.701028" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:21.701429" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:21.700686" elapsed="0.000768"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.702050" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:21.701622" elapsed="0.000455"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:21.702379" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:21.702533" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:21.702241" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.702988" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:21.702736" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:21.703403" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.703100" elapsed="0.000362"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.703953" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:21.703654" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.703487" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.703081" elapsed="0.000956"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.704619" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:21.704188" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:21.704714" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:21.699456" elapsed="0.005386"/>
</kw>
<msg time="2026-06-06T03:13:21.704898" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:21.686945" elapsed="0.018007"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.717144" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.733214" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.745544" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.745759" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.745967" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.746355" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.746200" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:21.746184" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.746580" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.746769" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.746942" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:21.746154" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.746049" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.747170" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.747247" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:21.747364" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:21.684280" elapsed="0.063111"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:21.747573" elapsed="0.002348"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:21.750978" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:21.750683" elapsed="0.000323"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:21.751448" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:21.751163" elapsed="0.000313"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:21.751634" elapsed="0.000344"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:21.750251" elapsed="0.001788"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.750005" elapsed="0.002069"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:21.752254" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:21.752098" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.749985" elapsed="0.002345"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:21.673498" elapsed="0.078920"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:21.672683" elapsed="0.079813"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:21.672420" elapsed="0.080123"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.672401" elapsed="0.080166"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:21.752601" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:21.533251" elapsed="0.219615"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:21.523766" elapsed="0.229182"/>
</kw>
<msg time="2026-06-06T03:13:21.753115" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:21.753160" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:21.522440" elapsed="0.230744"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:21.753370" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:21.753256" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:21.753238" elapsed="0.000198"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.754060" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:21.753583" elapsed="0.000505"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:21.754721" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:21.754254" elapsed="0.000536">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:21.521388" elapsed="0.233517">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.814968" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:22.814543" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:22.815812" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:22.815527" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:22.815988" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:22.815186" elapsed="0.000826"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.816594" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:22.816183" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:22.816996" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:22.817194" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:22.816843" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.817676" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.817404" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.818791" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.818485" elapsed="0.000352"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.819282" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:22.819005" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.819672" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.819954" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.820139" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:22.819515" elapsed="0.000685"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.819364" elapsed="0.000867"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:22.820280" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:22.820452" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:22.818132" elapsed="0.002353"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.817824" elapsed="0.002695"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.820716" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.820546" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.817797" elapsed="0.003013"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.821469" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:22.820973" elapsed="0.000525"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:22.821549" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:22.813915" elapsed="0.007777"/>
</kw>
<msg time="2026-06-06T03:13:22.821748" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:22.801149" elapsed="0.020692"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.834397" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.846730" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.859502" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.859778" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.860017" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.860528" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.860329" elapsed="0.000273"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:22.860304" elapsed="0.000331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.860849" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.861072" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.861291" elapsed="0.000088"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:22.860261" elapsed="0.001164"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.860123" elapsed="0.001334"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.861669" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.861768" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:13:22.861970" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:22.796925" elapsed="0.065081"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:22.863822" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:22.863439" elapsed="0.000475">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:22.864042" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:22.862918" elapsed="0.001158"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.864555" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.864177" elapsed="0.000456"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.865221" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:22.864889" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.864692" elapsed="0.000594"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.864149" elapsed="0.001159"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.867725" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:22.865469" elapsed="0.002285"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:22.867806" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:13:22.867983" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:22.862443" elapsed="0.005565"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:22.869298" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:22.869039" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:22.869459" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:22.868689" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:22.869726" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:22.869567" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.869545" elapsed="0.000301"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.870001" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.870197" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.870266" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:22.872397" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:22.868330" elapsed="0.004094"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.873979" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.873675" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.874444" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.874193" elapsed="0.000295"/>
</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-06-06T03:13:22.883159" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:22.883302" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:22.883426" 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-06-06T03:13:22.876707" elapsed="0.006747"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.874607" elapsed="0.008892"/>
</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-06-06T03:13:22.883708" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.883526" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.874586" elapsed="0.009212"/>
</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-06-06T03:13:22.887674" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.884837" elapsed="0.002906"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.884592" elapsed="0.003200"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.884572" elapsed="0.003254"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.891412" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.888221" elapsed="0.003256"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.887905" elapsed="0.003620"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.887880" elapsed="0.003679"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.892392" 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-06-06T03:13:22.891811" elapsed="0.000619"/>
</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-06-06T03:13:22.892889" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.892530" elapsed="0.000440"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.893668" 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-06-06T03:13:22.893229" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.893003" elapsed="0.000755"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.892503" elapsed="0.001292"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.894550" 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-06-06T03:13:22.894132" elapsed="0.000445"/>
</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-06-06T03:13:22.894944" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.894668" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.895493" 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-06-06T03:13:22.895193" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.895030" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.894629" elapsed="0.000946"/>
</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-06-06T03:13:22.895743" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:22.896570" 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-06-06T03:13:22.896261" elapsed="0.000335"/>
</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-06-06T03:13:22.896773" elapsed="0.002286"/>
</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-06-06T03:13:22.884163" elapsed="0.014959"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.899307" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:22.899194" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.899174" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:22.902154" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:22.899524" elapsed="0.002694"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:22.902273" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:22.902433" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:22.872763" elapsed="0.029696"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:22.902523" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:22.902692" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:22.774218" elapsed="0.128501"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.930630" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:22.930251" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:22.931425" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:22.931193" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:22.931583" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:22.930852" elapsed="0.000756"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.932181" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:22.931794" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:22.932507" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:22.932692" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:22.932369" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.933123" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:22.932879" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:22.933534" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.933235" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.934112" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:22.933785" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.933618" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.933215" elapsed="0.000979"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.934790" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:22.934343" elapsed="0.000477"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:22.934870" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:22.929598" elapsed="0.005397"/>
</kw>
<msg time="2026-06-06T03:13:22.935093" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:22.917166" elapsed="0.017981"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.947403" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.959562" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.971871" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.972073" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.972253" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.972637" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.972488" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:22.972472" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.972882" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.973052" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.973219" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:22.972443" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.972334" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.973447" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.973523" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:22.973644" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:22.914551" elapsed="0.059133"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:22.973864" elapsed="0.002193"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:22.977109" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:22.976814" elapsed="0.000324"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:22.977616" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:22.977335" elapsed="0.000313"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:22.977823" elapsed="0.000329"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:22.976383" elapsed="0.001830"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.976139" elapsed="0.002108"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:22.978431" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:22.978275" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.976119" elapsed="0.002389"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:22.903870" elapsed="0.074717"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:22.903049" elapsed="0.075630"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:22.902805" elapsed="0.075921"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.902787" elapsed="0.075963"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:22.978784" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:22.767814" elapsed="0.211215"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:22.758547" elapsed="0.220564"/>
</kw>
<msg time="2026-06-06T03:13:22.979278" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:22.979323" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:22.757143" elapsed="0.222203"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:22.979528" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:22.979418" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:22.979400" elapsed="0.000194"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.980195" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:22.979765" elapsed="0.000456"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:22.980820" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:22.980377" elapsed="0.000505">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:22.756081" elapsed="0.224917">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.039558" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.039164" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.040398" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.040129" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.040569" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.039789" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.041198" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.040780" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.041533" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:24.041768" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:24.041391" elapsed="0.000404"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.042209" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.041959" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.043241" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.042984" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.043742" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.043452" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.044104" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.044316" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.044495" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.043965" elapsed="0.000588"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.043823" elapsed="0.000761"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:24.044631" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:13:24.044819" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:24.042636" elapsed="0.002209"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.042333" elapsed="0.002545"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.045055" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.044903" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.042308" elapsed="0.002826"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.045782" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.045310" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.045861" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.038517" elapsed="0.007469"/>
</kw>
<msg time="2026-06-06T03:13:24.046041" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.026037" elapsed="0.020056"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.058569" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.070816" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.082933" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.083175" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.083357" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.083744" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.083580" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:24.083564" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.083972" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.084145" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.084314" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.083535" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.083433" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.084540" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.084616" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:24.084751" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:24.021818" elapsed="0.062959"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.086040" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.085802" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.086197" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.085428" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.086543" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.086294" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.087128" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.086835" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.086636" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.086274" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.089507" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.087367" elapsed="0.002167"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:24.089585" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.089783" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:24.085100" elapsed="0.004709"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.091044" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.090806" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.091200" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.090443" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:24.091442" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.091297" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.091276" elapsed="0.000248"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.091690" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.091905" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.091972" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.095313" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:24.090117" elapsed="0.005234"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.096850" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.096527" elapsed="0.000381"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.097450" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.097123" elapsed="0.000377"/>
</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-06-06T03:13:24.105685" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:24.105817" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:24.105953" 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-06-06T03:13:24.099731" elapsed="0.006250"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.097575" elapsed="0.008450"/>
</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-06-06T03:13:24.106211" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.106051" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.097551" elapsed="0.008747"/>
</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-06-06T03:13:24.109717" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.107334" elapsed="0.002432"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.107107" elapsed="0.002694"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.107088" elapsed="0.002739"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.113332" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.110174" elapsed="0.003225"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.109888" elapsed="0.003561"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.109869" elapsed="0.003614"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.114322" 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-06-06T03:13:24.113740" elapsed="0.000626"/>
</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-06-06T03:13:24.114833" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.114468" elapsed="0.000449"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.115609" 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-06-06T03:13:24.115184" elapsed="0.000467"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.114953" elapsed="0.000771"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.114440" elapsed="0.001315"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.116503" 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-06-06T03:13:24.115984" elapsed="0.000557"/>
</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-06-06T03:13:24.117005" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.116646" elapsed="0.000441"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.117797" 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-06-06T03:13:24.117351" elapsed="0.000484"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.117121" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.116614" elapsed="0.001300"/>
</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-06-06T03:13:24.118170" elapsed="0.000398"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:24.119088" 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-06-06T03:13:24.118794" elapsed="0.000321"/>
</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-06-06T03:13:24.119274" elapsed="0.002267"/>
</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-06-06T03:13:24.106677" elapsed="0.014928"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.121803" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.121693" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.121673" elapsed="0.000199"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:24.124669" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:24.122022" elapsed="0.002679"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:24.124756" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:24.124915" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:24.095708" elapsed="0.029235"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.125006" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:24.125157" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:23.998917" elapsed="0.126266"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.153608" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.153229" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.154397" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.154168" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.154588" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.153825" elapsed="0.000788"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.155188" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.154798" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.155521" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:24.155814" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:24.155385" elapsed="0.000457"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.156252" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.156005" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:24.156694" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.156366" elapsed="0.000390"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.157227" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.156933" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.156781" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.156346" elapsed="0.001001"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.157946" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.157498" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.158026" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.152583" elapsed="0.005568"/>
</kw>
<msg time="2026-06-06T03:13:24.158205" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.140063" elapsed="0.018194"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.170500" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.182783" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.195078" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.195282" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.195462" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.195858" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.195708" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:24.195692" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.196083" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.196254" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.196423" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.195649" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.195542" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.196669" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.196749" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:24.196866" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:24.137420" elapsed="0.059511"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.197116" elapsed="0.002370"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:24.200537" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.200244" elapsed="0.000322"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:24.201030" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.200744" elapsed="0.000314"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:24.201215" elapsed="0.000326"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:24.199829" elapsed="0.001773"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.199568" elapsed="0.002068"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.201832" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.201679" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.199549" elapsed="0.002361"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:24.126528" elapsed="0.075431"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:24.125508" elapsed="0.076525"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.125267" elapsed="0.076811"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.125249" elapsed="0.076852"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.202134" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:23.992153" elapsed="0.210210"/>
</kw>
<arg>empty_topology</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:23.984756" elapsed="0.217685"/>
</kw>
<msg time="2026-06-06T03:13:24.202602" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.202651" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:23.983208" elapsed="0.219490"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.202882" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.202770" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.202751" elapsed="0.000197"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.203539" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.203092" elapsed="0.000474"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.204158" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.203739" elapsed="0.000479">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:13:23.982229" elapsed="0.222103">None</status>
</kw>
<msg time="2026-06-06T03:13:24.204419" level="FAIL">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</msg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Invert_Failure</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.144333" elapsed="10.060180">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</status>
</kw>
<msg time="2026-06-06T03:13:24.204568" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Invert_Failure</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.143952" elapsed="10.060664"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Compare_Topology</arg>
<arg>empty_topology</arg>
<doc>Some Keywords need several tries to finally fail, this keyword passes if and only if the failure ultimately happens.</doc>
<status status="FAIL" start="2026-06-06T03:13:14.143584" elapsed="10.061154">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</status>
</kw>
<msg time="2026-06-06T03:13:24.204906" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:13:24.204950" level="INFO">${output} = Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:14.143168" elapsed="10.061806"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:13:24.205160" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.205048" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.205029" elapsed="0.000213"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.205397" elapsed="0.000022"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.205568" elapsed="0.000020"/>
</kw>
<arg>Confirm_Keyword_Fails_Within_Timeout</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="PASS" start="2026-06-06T03:13:14.142531" elapsed="10.063175"/>
</kw>
<msg time="2026-06-06T03:13:24.205759" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Invert_Failure</arg>
<arg>Confirm_Keyword_Fails_Within_Timeout</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:14.142082" elapsed="10.063724"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Some positive checks report false success for a short time. This keyword verifies no failure does happen within timeout period.
This implementation needs more complicated logic than, Verify_Keyword_Never_Passes_Within_Timeout,
so use that keyword in case you have a negative check handy.</doc>
<status status="PASS" start="2026-06-06T03:13:14.141660" elapsed="10.064225"/>
</kw>
<arg>empty_topology</arg>
<doc>Verify that Compare_Topology keeps passing, it will hold its last result.</doc>
<status status="PASS" start="2026-06-06T03:13:14.141261" elapsed="10.064690"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.206537" elapsed="0.000263"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.206231" elapsed="0.000633"/>
</kw>
<doc>Sanity check example-ipv4-topology is still empty.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:14.055050" elapsed="10.151854"/>
</test>
<test id="s1-s4-t23" name="Reconfigure_ODL_To_Initiate_Connection" line="277">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.210751" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.210512" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.210493" elapsed="0.000342"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:24.210327" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.211950" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.211842" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.211823" elapsed="0.000196"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.217122" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.217014" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.216996" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.218207" 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-06-06T03:13:24.217825" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.218718" 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-06-06T03:13:24.218400" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:24.218791" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.218947" 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-06-06T03:13:24.217425" elapsed="0.001547"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:24.224453" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.224343" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.224320" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:24.225719" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.225585" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.225566" elapsed="0.000224"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:24.226278" 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-06-06T03:13:24.225976" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.226709" level="INFO">${current_connection_index} = 7</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-06-06T03:13:24.226472" elapsed="0.000265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.258632" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:24.227252" elapsed="0.031499"/>
</kw>
<msg time="2026-06-06T03:13:24.258931" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:24.258980" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:24.226905" elapsed="0.032113"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.277008" level="INFO">". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:13:24.259547" elapsed="0.017566"/>
</kw>
<msg time="2026-06-06T03:13:24.277273" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:24.277319" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C ...</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-06-06T03:13:24.259196" elapsed="0.018161"/>
</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-06-06T03:13:24.277685" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.277435" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.277415" elapsed="0.000351"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.278210" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:13:24.277913" elapsed="0.000364"/>
</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-06-06T03:13:24.278562" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.278344" elapsed="0.000271"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.278325" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:24.278693" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:24.281306" elapsed="0.000277"/>
</kw>
<msg time="2026-06-06T03:13:24.281664" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.280162" elapsed="0.001635"/>
</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="NOT RUN" start="2026-06-06T03:13:24.282083" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.282434" elapsed="0.000202"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:24.279493" elapsed="0.003285"/>
</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-06-06T03:13:24.278960" elapsed="0.003884"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:24.225278" elapsed="0.057665"/>
</kw>
<msg time="2026-06-06T03:13:24.283035" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.283080" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.224697" elapsed="0.058421"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:24.283305" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.283195" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.283176" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.283811" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.284172" elapsed="0.000060"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.284283" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:24.223997" elapsed="0.060401"/>
</kw>
<msg time="2026-06-06T03:13:24.284492" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.284536" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "I "n "i "t "i "a "t "e "_ "C ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:24.219365" elapsed="0.065208"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.284924" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.284669" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.284631" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:24.219198" elapsed="0.065827"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:24.219025" elapsed="0.066028"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:24.216635" elapsed="0.068471"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.211518" elapsed="0.073642"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.211038" elapsed="0.074168"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.207973" elapsed="0.077285"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.286206" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=true | BGP_RIB=example-bgp-rib | PASSIVE_MODE=false | BGP_RIB_OPENCONFIG=exam...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=true</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=false</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.285447" elapsed="0.000788"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.319424" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.319051" elapsed="0.000401"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.320193" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.319971" elapsed="0.000288">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.320354" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.319616" elapsed="0.000763"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.321002" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.320590" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.321330" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:24.321472" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:24.321195" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.321922" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.321677" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.322928" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'true', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.322667" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.323643" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.323175" elapsed="0.000508"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.324357" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.324057" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.325159" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.324939" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.325236" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.325387" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.324573" elapsed="0.000839"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.325568" elapsed="0.000250"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:24.323918" elapsed="0.001941"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.326409" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.326109" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.327175" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.326963" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.327251" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.327401" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.326623" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.327579" elapsed="0.000241"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:13:24.325973" elapsed="0.001887"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.328404" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.328107" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.329190" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.328979" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.329266" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.329415" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.328616" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.329593" elapsed="0.000239"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:13:24.327972" elapsed="0.001901"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.330424" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.330121" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.331192" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.330980" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.331267" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.331418" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.330643" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.331598" elapsed="0.000241"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:13:24.329985" elapsed="0.001895"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.332425" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.332126" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.333212" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.332993" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.333287" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.333437" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.332642" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.333672" elapsed="0.000229"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:13:24.331992" elapsed="0.001952"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.334702" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.334193" elapsed="0.000537"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.335459" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.335245" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.335535" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:24.335708" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.334920" elapsed="0.000813"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.335890" elapsed="0.000225"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:13:24.334057" elapsed="0.002100"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.336892" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.336405" elapsed="0.000514"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.337683" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.337447" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.337763" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.337917" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.337118" elapsed="0.000825"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.338100" elapsed="0.000229"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:24.336270" elapsed="0.002099"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.338946" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.338623" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.339724" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.339489" elapsed="0.000263"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.339803" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:24.339958" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.339163" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.340140" elapsed="0.000228"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:13:24.338485" elapsed="0.001925"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.341038" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.340680" elapsed="0.000384"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:24.341799" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.341570" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:24.341875" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:24.342024" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:24.341253" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.342201" elapsed="0.000219"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:24.340525" elapsed="0.001936"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:24.323734" elapsed="0.018761"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:24.342538" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:24.342716" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'true', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:24.322326" elapsed="0.020417"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.322033" elapsed="0.020743"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.342952" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.342801" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.322015" elapsed="0.021013"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.343928" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.343214" elapsed="0.000743"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.344008" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.318415" elapsed="0.025718"/>
</kw>
<msg time="2026-06-06T03:13:24.344187" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.305881" elapsed="0.038353"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.356675" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.368959" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.381449" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.381674" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.381860" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.382228" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.382080" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:24.382065" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.382456" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.382627" elapsed="0.000036"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.382816" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.382037" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.381935" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.383042" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.383118" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.383237" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:24.301647" elapsed="0.081616"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.409421" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.409045" elapsed="0.000404"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.410283" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.410071" elapsed="0.000277">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.410443" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.409619" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.411044" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.410637" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.411370" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:24.411496" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:24.411236" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.411946" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.411701" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:24.412365" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.412072" elapsed="0.000351"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.412913" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'true', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.412596" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.412448" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.412053" elapsed="0.000944"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.413948" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.413143" elapsed="0.000835"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.414028" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.408414" elapsed="0.005738"/>
</kw>
<msg time="2026-06-06T03:13:24.414210" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.395937" elapsed="0.018319"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.426647" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.438956" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.451171" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.451372" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.451553" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.451938" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.451791" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:24.451777" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.452161" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.452330" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.452497" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.451747" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.451627" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.452738" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.452815" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.452947" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:24.393269" elapsed="0.059707"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.454289" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.453997" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.454452" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.453633" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.454817" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.454549" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.455356" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.455064" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.454898" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.454530" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.457803" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.455632" elapsed="0.002198"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:24.457883" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.458036" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:24.453308" elapsed="0.004752"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.459452" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.459204" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.459913" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;false&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.459673" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.460368" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.460127" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.460824" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.460564" elapsed="0.000303"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:24.461680" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:13:24.461471" elapsed="0.000237"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:13:24.462038" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:13:24.461865" elapsed="0.000199"/>
</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-06-06T03:13:24.462215" elapsed="0.000224"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.462866" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.462601" elapsed="0.000309"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:13:24.462952" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:24.463107" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:13:24.461068" elapsed="0.002064"/>
</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-06-06T03:13:24.479130" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '1080', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;false&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:13:24.479220" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:24.479453" level="INFO">${response} = &lt;Response [204]&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-06-06T03:13:24.465427" elapsed="0.014086"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.463201" elapsed="0.016414"/>
</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-06-06T03:13:24.480088" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.479727" elapsed="0.000513"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.463183" elapsed="0.017106"/>
</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-06-06T03:13:24.487965" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.482461" elapsed="0.005639"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.481961" elapsed="0.006232"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.481920" elapsed="0.006332"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.492643" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.488934" elapsed="0.003770"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.488381" elapsed="0.004359"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.488343" elapsed="0.004422"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.493311" 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-06-06T03:13:24.492933" elapsed="0.000406"/>
</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-06-06T03:13:24.493665" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.493409" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.494213" 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-06-06T03:13:24.493913" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.493749" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.493391" elapsed="0.000905"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.494858" 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-06-06T03:13:24.494457" elapsed="0.000428"/>
</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-06-06T03:13:24.495193" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.494956" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.495783" 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-06-06T03:13:24.495471" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.495274" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.494937" elapsed="0.000929"/>
</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-06-06T03:13:24.496018" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:24.496825" 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-06-06T03:13:24.496533" elapsed="0.000318"/>
</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-06-06T03:13:24.497007" elapsed="0.002294"/>
</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-06-06T03:13:24.481131" elapsed="0.018233"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:13:24.499538" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.499432" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.499413" elapsed="0.000210"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:13:24.499792" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.499862" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.502076" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:13:24.458403" elapsed="0.043700"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.502167" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:24.502356" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:24.290961" elapsed="0.211421"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.502742" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.502482" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.502465" elapsed="0.000380"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.502879" elapsed="0.000030"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:13:24.286513" elapsed="0.216494"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.503587" elapsed="0.000267"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.503275" elapsed="0.000649"/>
</kw>
<doc>Replace BGP peer config module, now with initiate-connection set to true.</doc>
<status status="PASS" start="2026-06-06T03:13:24.207129" elapsed="0.296834"/>
</test>
<test id="s1-s4-t24" name="Check_Listening_Connection_Is_Established" line="294">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.508161" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.507936" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.507917" elapsed="0.000329"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:24.507746" elapsed="0.000548"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.511050" elapsed="0.000039"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.510712" elapsed="0.000464"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.510626" elapsed="0.000603"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.520995" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.520852" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.520827" elapsed="0.000255"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.522302" 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-06-06T03:13:24.521827" elapsed="0.000506"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.522844" 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-06-06T03:13:24.522508" elapsed="0.000363"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:24.522918" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:13:24.523105" 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-06-06T03:13:24.521392" elapsed="0.001738"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:24.528846" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.528728" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.528705" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:24.530179" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.530068" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.530049" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:24.530765" 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-06-06T03:13:24.530403" elapsed="0.000390"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.531217" level="INFO">${current_connection_index} = 7</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-06-06T03:13:24.530966" elapsed="0.000277"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.563295" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:24.531789" elapsed="0.031803"/>
</kw>
<msg time="2026-06-06T03:13:24.564147" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:24.564200" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:24.531417" elapsed="0.032827"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.584481" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "[K"
[?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-06-06T03:13:24.565069" elapsed="0.019568"/>
</kw>
<msg time="2026-06-06T03:13:24.584870" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:24.584919" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</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-06-06T03:13:24.564532" elapsed="0.020426"/>
</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-06-06T03:13:24.585389" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.585075" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.585040" elapsed="0.000439"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.586147" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "[K"
[?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-06-06T03:13:24.585638" elapsed="0.000607"/>
</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-06-06T03:13:24.586599" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.586336" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.586314" elapsed="0.000395"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:24.586750" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:24.589939" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:13:24.590175" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.588548" elapsed="0.001770"/>
</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="NOT RUN" start="2026-06-06T03:13:24.590614" elapsed="0.000117"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.591014" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:24.587853" elapsed="0.003359"/>
</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-06-06T03:13:24.587120" elapsed="0.004162"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:24.529761" elapsed="0.061624"/>
</kw>
<msg time="2026-06-06T03:13:24.591485" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.591533" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.529080" elapsed="0.062493"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:24.591794" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.591676" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.591634" elapsed="0.000309"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.592384" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.592779" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.592854" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:24.528345" elapsed="0.064621"/>
</kw>
<msg time="2026-06-06T03:13:24.593066" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.593112" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:24.523558" elapsed="0.069592"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.593554" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.593288" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.593269" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:24.523403" elapsed="0.070315"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:24.523200" elapsed="0.070557"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:24.520309" elapsed="0.073511"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.509879" elapsed="0.084001"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.508454" elapsed="0.085477"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.504984" elapsed="0.089005"/>
</kw>
<kw name="Check_Speaker_Is_Connected">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Number_Of_Speaker_Connections">
<kw name="Count_Port_Occurences" owner="SSHKeywords">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_And_Install_Netstat" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.601211" level="INFO">Executing command 'netstat --version'.</msg>
<msg time="2026-06-06T03:13:24.615938" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:24.616419" level="INFO">${netstat_installed} = net-tools 2.10-alpha
Fred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others
+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX
AF: (inet) +UNIX +INET...</msg>
<var>${netstat_installed}</var>
<arg>netstat --version</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:24.601076" elapsed="0.015441"/>
</kw>
<if>
<branch type="IF" condition="'${netstat_installed}' is not string and '${netstat_installed}' != '0'">
<kw name="Install_Netstat" owner="SSHKeywords">
<doc>Install netstat if it is not already installed.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.618207" elapsed="0.000094"/>
</kw>
<msg time="2026-06-06T03:13:24.618429" level="FAIL">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</msg>
<status status="FAIL" start="2026-06-06T03:13:24.616909" elapsed="0.001707">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:13:24.616818" elapsed="0.002021">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</if>
<doc>Check if netstat is installed and install it if not.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.600781" elapsed="0.018415">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</kw>
<arg>Check_And_Install_Netstat</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.600194" elapsed="0.019323"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.621036" level="INFO">Executing command 'netstat -punta 2&gt; /dev/null | grep -E ":17900 .+ ESTABLISHED .+python" | wc -l'.</msg>
<msg time="2026-06-06T03:13:24.665416" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:24.665829" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>${NETSTAT_COMMAND} 2&gt; /dev/null | grep -E ":${port} .+ ${state} .+${name}" | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:24.620288" elapsed="0.045608"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:13:24.666066" elapsed="0.000106"/>
</return>
<msg time="2026-06-06T03:13:24.666520" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>17900</arg>
<arg>ESTABLISHED</arg>
<arg>python</arg>
<doc>Run 'netstat' on the remote machine and count occurences of given port in the given state connected to process with the given name.</doc>
<status status="PASS" start="2026-06-06T03:13:24.599764" elapsed="0.066818"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output}</arg>
<arg>${howmany}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:13:24.667179" elapsed="0.000998"/>
</kw>
<arg>1</arg>
<doc>Run netstat in mininet machine and parse it for number of established connections. Check it is ${howmany}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.599142" elapsed="0.069247"/>
</kw>
<arg>5s</arg>
<arg>1s</arg>
<arg>Check_Number_Of_Speaker_Connections</arg>
<arg>1</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:24.594453" elapsed="0.074060"/>
</kw>
<doc>Give it several tries to see exactly one established connection.</doc>
<status status="PASS" start="2026-06-06T03:13:24.594142" elapsed="0.074563"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.670023" elapsed="0.000417"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.669493" elapsed="0.001042"/>
</kw>
<doc>See TCP (BGP) connection in established state.</doc>
<status status="PASS" start="2026-06-06T03:13:24.504344" elapsed="0.166261"/>
</test>
<test id="s1-s4-t25" name="Check_Listening_Topology_Is_Filled" line="298">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.676236" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.675882" elapsed="0.000441"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.675847" elapsed="0.000514"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:24.675563" elapsed="0.000868"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.677903" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.677785" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.677765" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.683150" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.683034" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.683013" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.684399" 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-06-06T03:13:24.683958" elapsed="0.000488"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.685039" 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-06-06T03:13:24.684666" elapsed="0.000403"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:24.685116" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:13:24.685289" 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-06-06T03:13:24.683479" elapsed="0.001836"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:24.691235" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.691115" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.691092" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:24.692579" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.692467" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.692448" elapsed="0.000237"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:24.693225" 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-06-06T03:13:24.692844" elapsed="0.000420"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.693714" level="INFO">${current_connection_index} = 7</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-06-06T03:13:24.693454" elapsed="0.000287"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.731003" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:24.694266" elapsed="0.037158"/>
</kw>
<msg time="2026-06-06T03:13:24.731869" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:24.731977" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:24.693912" elapsed="0.038150"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:24.752202" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:13:24.733357" elapsed="0.018949"/>
</kw>
<msg time="2026-06-06T03:13:24.752468" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:24.752514" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</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-06-06T03:13:24.732495" elapsed="0.020057"/>
</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-06-06T03:13:24.752903" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.752643" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.752615" elapsed="0.000369"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.753436" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:13:24.753133" elapsed="0.000375"/>
</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-06-06T03:13:24.753819" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.753575" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.753556" elapsed="0.000372"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:24.753965" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:24.756579" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:13:24.756806" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.755464" elapsed="0.001477"/>
</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="NOT RUN" start="2026-06-06T03:13:24.757220" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.757556" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:24.754828" elapsed="0.002937"/>
</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-06-06T03:13:24.754262" elapsed="0.003709"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:24.692156" elapsed="0.065921"/>
</kw>
<msg time="2026-06-06T03:13:24.758174" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.758219" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.691486" elapsed="0.066771"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:24.758446" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.758337" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.758317" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.758962" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.759308" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.759378" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:24.690742" elapsed="0.068747"/>
</kw>
<msg time="2026-06-06T03:13:24.759587" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:24.759632" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:24.685747" elapsed="0.073972"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.760059" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.759800" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.759782" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:24.685575" elapsed="0.074585"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:24.685382" elapsed="0.074810"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:24.682604" elapsed="0.077644"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.677449" elapsed="0.082858"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.676677" elapsed="0.083677"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.671975" elapsed="0.088434"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.812415" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.811984" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.813317" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.812984" elapsed="0.000405">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.813483" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.812621" elapsed="0.000886"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.814092" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.813700" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.814438" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:24.814611" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:24.814285" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.815095" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.814831" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.816321" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.815879" elapsed="0.000503"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.816925" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:24.816549" elapsed="0.000403"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.817355" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.818089" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.818428" elapsed="0.000047"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.817166" elapsed="0.001431"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.817002" elapsed="0.001734"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:24.818789" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:24.818952" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:24.815508" elapsed="0.003469"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.815210" elapsed="0.003798"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.819186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.819033" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.815190" elapsed="0.004110"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.819911" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.819451" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.819988" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.811308" elapsed="0.008806"/>
</kw>
<msg time="2026-06-06T03:13:24.820168" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.798755" elapsed="0.021462"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.832761" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.845038" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.857430" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.857635" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.857832" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.858200" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.858052" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:24.858037" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.858426" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.858596" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.858783" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.858008" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.857906" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.859011" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.859087" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.859242" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:24.794484" elapsed="0.064784"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.860582" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.860345" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.860759" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.860002" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.861106" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.860855" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.861677" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.861360" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.861188" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.860836" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.864122" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.861919" elapsed="0.002230"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:24.864202" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:24.864357" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:24.859670" elapsed="0.004711"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.865624" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.865393" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.865809" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.865055" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:24.866039" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:24.865904" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.865885" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.866276" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.866450" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.866516" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.868609" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:24.864726" elapsed="0.003910"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.870087" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.869807" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.870538" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.870293" elapsed="0.000289"/>
</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-06-06T03:13:24.879413" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:24.879593" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:13:24.879774" 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-06-06T03:13:24.872742" elapsed="0.007070"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.870662" elapsed="0.009209"/>
</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-06-06T03:13:24.880128" elapsed="0.000074"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.879908" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.870628" elapsed="0.009670"/>
</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-06-06T03:13:24.885103" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.881766" elapsed="0.003405"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.881423" elapsed="0.003796"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.881396" elapsed="0.003859"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.888765" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.885674" elapsed="0.003137"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.885334" elapsed="0.003512"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.885310" elapsed="0.003562"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.889418" 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-06-06T03:13:24.889037" elapsed="0.000408"/>
</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-06-06T03:13:24.889774" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.889516" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.890325" 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-06-06T03:13:24.890024" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.889859" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.889497" elapsed="0.000914"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.890960" 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-06-06T03:13:24.890575" elapsed="0.000412"/>
</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-06-06T03:13:24.891295" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.891056" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.891868" 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-06-06T03:13:24.891552" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.891375" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.891038" elapsed="0.000912"/>
</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-06-06T03:13:24.892103" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:24.892926" 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-06-06T03:13:24.892618" 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-06-06T03:13:24.893113" elapsed="0.002293"/>
</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-06-06T03:13:24.880828" elapsed="0.014640"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.895692" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.895538" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.895519" elapsed="0.000243"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:24.898677" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:13:24.895913" elapsed="0.002795"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:24.898760" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:24.898918" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:24.868970" elapsed="0.029974"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.899006" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:24.899197" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:24.772057" elapsed="0.127166"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.928054" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.927265" elapsed="0.000818"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.930069" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:24.929532" elapsed="0.000688">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:24.930352" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:24.928251" elapsed="0.002126"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.931315" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:24.930549" elapsed="0.000794"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:24.931760" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:24.931984" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:24.931511" elapsed="0.000526"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.932635" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:24.932208" elapsed="0.000526"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:24.933393" elapsed="0.000081"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.932804" elapsed="0.000750"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.934383" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:24.933778" elapsed="0.000646"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.933581" elapsed="0.000923"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.932785" elapsed="0.001742"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.935452" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.934701" elapsed="0.000780"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.935530" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:24.926540" elapsed="0.009136"/>
</kw>
<msg time="2026-06-06T03:13:24.935734" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.913961" elapsed="0.021822"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.948295" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.960535" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.972885" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.973084" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.973264" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.973642" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.973492" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:24.973477" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.973881" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.974052" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.974220" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:24.973448" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.973340" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.974471" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.974551" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:24.974684" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:24.911200" elapsed="0.063513"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:24.974893" elapsed="0.002366"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:24.978468" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.978012" elapsed="0.000486"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:24.979121" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:24.978683" elapsed="0.000467"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:24.979310" elapsed="0.000403"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:24.977582" elapsed="0.002194"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.977340" elapsed="0.002470"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:24.979989" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:24.979835" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.977321" elapsed="0.002779"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:24.900396" elapsed="0.079754"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:24.899551" elapsed="0.080676"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:24.899307" elapsed="0.080966"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.899289" elapsed="0.081008"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:24.980331" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:24.765903" elapsed="0.214555"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.761403" elapsed="0.219115"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:24.760915" elapsed="0.219666"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:24.760547" elapsed="0.220093"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.981246" elapsed="0.000248"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:24.980938" elapsed="0.000620"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:24.670978" elapsed="0.310619"/>
</test>
<test id="s1-s4-t26" name="Kill_Listening_BGP_Speaker" line="303">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:24.985488" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:13:24.985220" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.986779" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.986664" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.986629" elapsed="0.000219"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:24.991722" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.991594" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.991576" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.992829" 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-06-06T03:13:24.992399" elapsed="0.000458"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:24.993318" 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-06-06T03:13:24.993022" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:24.993388" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:24.993540" 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-06-06T03:13:24.992023" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:24.999184" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:24.999076" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:24.999056" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:25.000409" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.000298" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.000280" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:25.000982" 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-06-06T03:13:25.000623" elapsed="0.000386"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.001387" level="INFO">${current_connection_index} = 7</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-06-06T03:13:25.001174" elapsed="0.000239"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.040696" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:25.001939" elapsed="0.039029"/>
</kw>
<msg time="2026-06-06T03:13:25.041285" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:25.041340" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:25.001580" elapsed="0.039799"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.060150" level="INFO">". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:13:25.042224" elapsed="0.018217"/>
</kw>
<msg time="2026-06-06T03:13:25.060896" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:25.061006" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?1l...</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-06-06T03:13:25.041704" elapsed="0.019400"/>
</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-06-06T03:13:25.062063" elapsed="0.000065"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.061335" elapsed="0.000878"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.061269" elapsed="0.001009"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.063114" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:13:25.062535" elapsed="0.000693"/>
</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-06-06T03:13:25.063732" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.063335" elapsed="0.000482"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.063304" elapsed="0.000548"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:25.063911" elapsed="0.000066"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:25.068389" elapsed="0.000249"/>
</kw>
<msg time="2026-06-06T03:13:25.068792" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:25.066423" elapsed="0.002580"/>
</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="NOT RUN" start="2026-06-06T03:13:25.069789" elapsed="0.000123"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.070318" elapsed="0.000093"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:25.065360" elapsed="0.005169"/>
</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-06-06T03:13:25.064434" elapsed="0.006164"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:24.999996" elapsed="0.070739"/>
</kw>
<msg time="2026-06-06T03:13:25.070849" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.070897" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?1l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.999410" elapsed="0.071535"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:25.071144" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:25.071030" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.071008" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.071737" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.072108" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.072184" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:24.998734" elapsed="0.073569"/>
</kw>
<msg time="2026-06-06T03:13:25.072426" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.072483" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?1l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:24.993971" elapsed="0.078617"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.072964" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.072692" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.072672" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:24.993804" elapsed="0.079269"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:24.993614" elapsed="0.079499"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:24.991230" elapsed="0.081949"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:24.986361" elapsed="0.086881"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:24.985930" elapsed="0.087364"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:13:24.982681" elapsed="0.090674"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.074727" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:25.074309" elapsed="0.000450"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:25.074923" elapsed="0.000295"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:13:25.074026" elapsed="0.001255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.095671" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:13:25.076143" elapsed="0.019602"/>
</kw>
<msg time="2026-06-06T03:13:25.095853" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.095898" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:25.075487" elapsed="0.020437"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.096598" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:13:25.108749" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:25.108895" level="INFO">${output_log} = 2026-06-06 03:13:03,970 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:13:24,500 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:13:24,500 INFO BGP-Thread-1 (job): O...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:25.096445" elapsed="0.012490"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.109576" level="INFO">2026-06-06 03:13:03,970 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:13:24,500 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:13:24,500 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:13:24,500 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:13:24,500 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:13:24,501 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:13:24,502 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:13:24,502 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:13:24,503 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.00022530555725097656s
2026-06-06 03:13:24,504 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:24,505 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:13:24,506 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:13:24,506 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:13:24,506 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:13:24,512 INFO BGP-Thread-1 (job): ... idle for 0.006s
2026-06-06 03:13:24,513 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.006s
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.109179" elapsed="0.000617"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:13:25.096140" elapsed="0.013747"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:13:25.110240" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:13:25.110053" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.110015" elapsed="0.000359"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.110757" elapsed="0.000062"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.111262" elapsed="0.000063"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:13:25.073687" elapsed="0.037808"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.113565" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:13:25.112695" elapsed="0.001030"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:13:25.111997" elapsed="0.001867"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:25.115360" elapsed="0.000675"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:13:25.114525" elapsed="0.001667"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:24.982018" elapsed="0.134286"/>
</test>
<test id="s1-s4-t27" name="Check_For_Empty_Topology_After_Listening" line="312">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.122241" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.121903" elapsed="0.000414"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.121872" elapsed="0.000478"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:25.121631" elapsed="0.000781"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.123746" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.123589" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.123568" elapsed="0.000266"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.130187" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.130016" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.129988" elapsed="0.000300"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.131796" 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-06-06T03:13:25.131182" elapsed="0.000655"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.132409" 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-06-06T03:13:25.132058" elapsed="0.000382"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:25.132499" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:13:25.132709" 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-06-06T03:13:25.130640" elapsed="0.002095"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:25.139099" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.138980" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.138958" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:25.140429" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.140301" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.140281" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:25.141014" 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-06-06T03:13:25.140692" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.141445" level="INFO">${current_connection_index} = 7</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-06-06T03:13:25.141212" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.177286" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:25.142017" elapsed="0.035483"/>
</kw>
<msg time="2026-06-06T03:13:25.177731" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:25.177787" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:25.141667" elapsed="0.036159"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.200370" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "L "i "s "t "e "n "i "n "g "[K"
[?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-06-06T03:13:25.178477" elapsed="0.022010"/>
</kw>
<msg time="2026-06-06T03:13:25.200678" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:25.200729" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</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-06-06T03:13:25.178064" elapsed="0.022703"/>
</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-06-06T03:13:25.201118" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.200864" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.200837" elapsed="0.000365"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.201693" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "L "i "s "t "e "n "i "n "g "[K"
[?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-06-06T03:13:25.201354" elapsed="0.000412"/>
</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-06-06T03:13:25.202075" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.201836" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.201817" elapsed="0.000341"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:25.202196" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:25.205124" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:13:25.205354" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:25.203893" elapsed="0.001610"/>
</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="NOT RUN" start="2026-06-06T03:13:25.205818" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.206168" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:25.203189" elapsed="0.003186"/>
</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-06-06T03:13:25.202527" elapsed="0.003920"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:25.139988" elapsed="0.066563"/>
</kw>
<msg time="2026-06-06T03:13:25.206667" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.206718" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:25.139336" elapsed="0.067422"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:25.206951" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:25.206839" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.206819" elapsed="0.000292"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.207556" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.207934" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.208007" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:25.138587" elapsed="0.069532"/>
</kw>
<msg time="2026-06-06T03:13:25.208217" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.208262" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:25.133164" elapsed="0.075134"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.208700" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.208420" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.208401" elapsed="0.000379"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:25.133009" elapsed="0.075796"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:25.132805" elapsed="0.076038"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:25.129436" elapsed="0.079467"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:25.123223" elapsed="0.085738"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:25.122616" elapsed="0.086392"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:25.118732" elapsed="0.090331"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.261850" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:25.261335" elapsed="0.000563"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:25.262952" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:25.262482" elapsed="0.000553">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:25.263135" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:25.262116" elapsed="0.001044"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.263839" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:25.263360" elapsed="0.000507"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:25.264190" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:25.264370" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:25.264039" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.264848" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.264559" elapsed="0.000335"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.266461" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.265901" elapsed="0.000625"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.267105" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:25.266724" elapsed="0.000408"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.267612" elapsed="0.000109"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.268463" elapsed="0.000053"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.268840" elapsed="0.000046"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:25.267407" elapsed="0.001605"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.267200" elapsed="0.001883"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:25.269141" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:13:25.269346" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:25.265417" elapsed="0.003956"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.264985" elapsed="0.004421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.269595" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.269434" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.264956" elapsed="0.004859"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.270526" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:25.270009" elapsed="0.000546"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:25.270605" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:25.260609" elapsed="0.010148"/>
</kw>
<msg time="2026-06-06T03:13:25.270817" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:25.247622" elapsed="0.023255"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.284461" elapsed="0.000081"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.297304" elapsed="0.000075"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.310348" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.310608" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.310827" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.311281" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.311121" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:25.311100" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.311520" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.311728" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.311904" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:25.311053" elapsed="0.000906"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.310919" elapsed="0.001069"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.312187" elapsed="0.000025"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.312277" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:13:25.312470" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:25.243173" elapsed="0.069328"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:25.314158" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:25.313832" elapsed="0.000412">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:25.314345" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:25.313343" elapsed="0.001029"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.314748" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.314450" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.315335" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:25.315032" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.314834" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.314430" elapsed="0.000994"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.317798" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:25.315583" elapsed="0.002242"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:25.317878" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:25.318039" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:25.312951" elapsed="0.005113"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:25.319305" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:25.319067" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:25.319463" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:25.318725" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:25.319715" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:25.319558" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.319539" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.319949" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.320123" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.320190" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:13:25.324616" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:25.318379" elapsed="0.006265"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.326108" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.325842" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.326566" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.326314" elapsed="0.000296"/>
</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-06-06T03:13:25.335967" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:25.336296" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:25.336476" 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-06-06T03:13:25.328807" elapsed="0.007703"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.326695" elapsed="0.009870"/>
</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-06-06T03:13:25.336807" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.336596" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.326675" elapsed="0.010295"/>
</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-06-06T03:13:25.342778" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.338879" elapsed="0.003972"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.338459" elapsed="0.004444"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.338411" elapsed="0.004528"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.346803" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.343356" elapsed="0.003516"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.343022" elapsed="0.003901"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.342997" elapsed="0.003962"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.347821" 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-06-06T03:13:25.347218" elapsed="0.000643"/>
</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-06-06T03:13:25.348328" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.347966" elapsed="0.000446"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.349216" 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-06-06T03:13:25.348758" elapsed="0.000498"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.348448" elapsed="0.000862"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.347938" elapsed="0.001403"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.350020" 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-06-06T03:13:25.349516" elapsed="0.000531"/>
</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-06-06T03:13:25.350358" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.350118" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.350934" 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-06-06T03:13:25.350603" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.350439" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.350100" elapsed="0.000918"/>
</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-06-06T03:13:25.351177" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:25.352126" 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-06-06T03:13:25.351719" elapsed="0.000436"/>
</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-06-06T03:13:25.352357" elapsed="0.002601"/>
</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-06-06T03:13:25.337434" elapsed="0.017601"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.355291" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.355149" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.355124" elapsed="0.000241"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:25.358457" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:25.355541" elapsed="0.002946"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:25.358543" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:13:25.358747" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:25.324990" elapsed="0.033785"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:25.358840" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:25.359011" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:25.220697" elapsed="0.138395"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.388611" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:25.387869" elapsed="0.000775"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:25.390776" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:25.390194" elapsed="0.000750">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:25.391081" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:25.388832" elapsed="0.002274"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.392056" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:25.391279" elapsed="0.000805"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:25.392492" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:25.392769" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:25.392255" elapsed="0.000542"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.393415" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.392964" elapsed="0.000514"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:25.394192" elapsed="0.000079"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.393550" elapsed="0.000801"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.395202" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:25.394572" elapsed="0.000671"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.394378" elapsed="0.000946"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.393528" elapsed="0.001819"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.396382" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:25.395506" elapsed="0.000908"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:25.396465" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:25.387137" elapsed="0.009457"/>
</kw>
<msg time="2026-06-06T03:13:25.396665" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:25.374351" elapsed="0.022367"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.409288" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.422136" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.434736" elapsed="0.000049"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.435040" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.435264" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.435793" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.435594" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:25.435573" elapsed="0.000317"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.436047" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.436229" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.436412" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:25.435526" elapsed="0.000941"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.435371" elapsed="0.001127"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.436673" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.436759" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:13:25.436931" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:25.371592" elapsed="0.065370"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:25.437153" elapsed="0.003180"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:25.442194" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:25.441492" elapsed="0.000751"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:25.442807" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:25.442453" elapsed="0.000384"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:25.443002" elapsed="0.000361"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:25.440865" elapsed="0.002566"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.440459" elapsed="0.003007"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.443669" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.443493" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.440430" elapsed="0.003320"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:25.360372" elapsed="0.083489"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:25.359464" elapsed="0.084483"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:25.359191" elapsed="0.084806"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.359167" elapsed="0.084857"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:25.444060" elapsed="0.000038"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:25.214584" elapsed="0.229628"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:25.210134" elapsed="0.234153"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:25.209591" elapsed="0.234761"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:25.209232" elapsed="0.235205"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:25.445171" elapsed="0.000282"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:25.444802" elapsed="0.000717"/>
</kw>
<doc>Post-condition: Check example-ipv4-topology is empty again.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:25.117255" elapsed="0.328328"/>
</test>
<test id="s1-s4-t28" name="Start_Listening_BGP_Speaker_Case_2" line="317">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.449728" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.449392" elapsed="0.000409"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.449362" elapsed="0.000468"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:25.449182" elapsed="0.000703"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.451003" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.450888" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.450869" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.456268" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.456159" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.456140" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.457395" 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-06-06T03:13:25.456990" elapsed="0.000435"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.457985" 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-06-06T03:13:25.457593" elapsed="0.000419"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:25.458059" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:13:25.458228" 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-06-06T03:13:25.456580" elapsed="0.001674"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:25.464135" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.463998" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.463971" elapsed="0.000254"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:25.465682" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:25.465537" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.465513" elapsed="0.000246"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:25.466282" 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-06-06T03:13:25.465955" elapsed="0.000357"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.466772" level="INFO">${current_connection_index} = 7</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-06-06T03:13:25.466503" elapsed="0.000298"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.501891" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:25.467442" elapsed="0.034895"/>
</kw>
<msg time="2026-06-06T03:13:25.502864" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:25.502976" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:25.467063" elapsed="0.036000"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.520869" level="INFO">". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:25.504223" elapsed="0.016761"/>
</kw>
<msg time="2026-06-06T03:13:25.521151" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:25.521199" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C ...</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-06-06T03:13:25.503511" elapsed="0.017726"/>
</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-06-06T03:13:25.521610" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.521340" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.521308" elapsed="0.000417"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.522202" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:25.521886" elapsed="0.000390"/>
</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-06-06T03:13:25.522619" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.522346" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.522326" elapsed="0.000397"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:25.522778" elapsed="0.000051"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:25.525645" elapsed="0.000195"/>
</kw>
<msg time="2026-06-06T03:13:25.525908" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:25.524473" elapsed="0.001576"/>
</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="NOT RUN" start="2026-06-06T03:13:25.526379" elapsed="0.000118"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.526802" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:25.523779" elapsed="0.003213"/>
</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-06-06T03:13:25.523152" elapsed="0.003909"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:25.465189" elapsed="0.061974"/>
</kw>
<msg time="2026-06-06T03:13:25.527261" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.527311" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:25.464427" elapsed="0.062928"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:25.527574" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:25.527459" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.527435" elapsed="0.000255"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.528124" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.528481" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:25.528555" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:25.463596" elapsed="0.065095"/>
</kw>
<msg time="2026-06-06T03:13:25.528849" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:25.528895" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:25.458685" elapsed="0.070249"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:25.529278" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:25.529015" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:25.528997" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:25.458515" elapsed="0.070868"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:25.458317" elapsed="0.071104"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:25.455787" elapsed="0.073698"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:25.450567" elapsed="0.078979"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:25.450052" elapsed="0.079545"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:25.446724" elapsed="0.082948"/>
</kw>
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.530770" level="INFO">${command} = python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=2 --insert=2 --withdraw=1 --updates=single --firstprefix=8.0.0.240 --info &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:25.530378" elapsed="0.000422"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:25.531281" level="INFO">python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=2 --insert=2 --withdraw=1 --updates=single --firstprefix=8.0.0.240 --info &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:25.531020" elapsed="0.000310"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:25.535648" level="INFO">python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=2 --insert=2 --withdraw=1 --updates=single --firstprefix=8.0.0.240 --info &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:13:25.535853" level="INFO">${output} =  python3 play.py --amount 3 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=2 --insert=2 --withdraw=1 --updates=single --firstprefix=8.0.0.240 --info &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:25.531534" elapsed="0.004362"/>
</kw>
<arg>--amount 3 --listen --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --prefill=2 --insert=2 --withdraw=1 --updates=single --firstprefix=8.0.0.240 --${BGP_TOOL_LOG_LEVEL}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:13:25.529913" elapsed="0.006061"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.538484" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:13:25.537889" elapsed="10.001391">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.539605" elapsed="0.000052"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:13:25.537587" elapsed="10.002193">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:13:25.536913" elapsed="10.003019"/>
</kw>
<msg time="2026-06-06T03:13:35.540073" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:25.536514" elapsed="10.003587"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:13:35.540293" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:13:35.540199" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.540171" elapsed="0.000211"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.540619" elapsed="0.000042"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.540824" elapsed="0.000024"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:13:25.536221" elapsed="10.004692"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:35.541577" elapsed="0.000325"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:35.541206" elapsed="0.000873"/>
</kw>
<doc>BGP Speaker introduces 2 prefixes in the first update &amp; another 2 prefixes while the very first is withdrawn in 2nd update</doc>
<status status="PASS" start="2026-06-06T03:13:25.445987" elapsed="10.096132"/>
</test>
<test id="s1-s4-t29" name="Check_Listening_Connection_Is_Established_Case_2" line="323">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.545990" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.545741" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.545721" elapsed="0.000354"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:35.545506" elapsed="0.000617"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.547172" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.547059" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.547040" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.552235" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.552112" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.552090" elapsed="0.000216"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.553350" 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-06-06T03:13:35.552951" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.553880" 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-06-06T03:13:35.553547" elapsed="0.000359"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:35.553952" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:35.554110" 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-06-06T03:13:35.552541" elapsed="0.001595"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:35.560151" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.559873" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.559852" elapsed="0.000369"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:35.561447" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.561336" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.561317" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:35.562013" 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-06-06T03:13:35.561694" elapsed="0.000346"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.562433" level="INFO">${current_connection_index} = 7</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-06-06T03:13:35.562210" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.600297" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:35.562997" elapsed="0.037683"/>
</kw>
<msg time="2026-06-06T03:13:35.601128" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:35.601237" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:35.562626" elapsed="0.038696"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.625767" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:35.602762" elapsed="0.023209"/>
</kw>
<msg time="2026-06-06T03:13:35.626195" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:35.626243" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</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-06-06T03:13:35.601840" elapsed="0.024441"/>
</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-06-06T03:13:35.626748" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.626396" elapsed="0.000499"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.626362" elapsed="0.000562"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.627454" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:35.627079" elapsed="0.000449"/>
</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-06-06T03:13:35.627842" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.627597" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.627578" elapsed="0.000345"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:35.627963" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:35.630746" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:13:35.630961" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:35.629605" elapsed="0.001494"/>
</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="NOT RUN" start="2026-06-06T03:13:35.631382" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.631746" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:35.628950" elapsed="0.002983"/>
</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-06-06T03:13:35.628342" elapsed="0.003659"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:35.561028" elapsed="0.071075"/>
</kw>
<msg time="2026-06-06T03:13:35.632202" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:35.632248" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:35.560382" elapsed="0.071908"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:35.632510" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:35.632397" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.632376" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.633049" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.633403" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.633475" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:35.559493" elapsed="0.074094"/>
</kw>
<msg time="2026-06-06T03:13:35.633704" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:35.633751" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:35.554539" elapsed="0.079259"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.634141" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.633878" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.633860" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:35.554390" elapsed="0.079857"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:35.554195" elapsed="0.080086"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:35.551711" elapsed="0.082631"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:35.546756" elapsed="0.087648"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:35.546282" elapsed="0.088171"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:35.543182" elapsed="0.091332"/>
</kw>
<kw name="Check_Speaker_Is_Connected">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Number_Of_Speaker_Connections">
<kw name="Count_Port_Occurences" owner="SSHKeywords">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_And_Install_Netstat" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.641240" level="INFO">Executing command 'netstat --version'.</msg>
<msg time="2026-06-06T03:13:35.655283" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:35.655438" level="INFO">${netstat_installed} = net-tools 2.10-alpha
Fred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others
+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX
AF: (inet) +UNIX +INET...</msg>
<var>${netstat_installed}</var>
<arg>netstat --version</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:35.641133" elapsed="0.014344"/>
</kw>
<if>
<branch type="IF" condition="'${netstat_installed}' is not string and '${netstat_installed}' != '0'">
<kw name="Install_Netstat" owner="SSHKeywords">
<doc>Install netstat if it is not already installed.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.656359" elapsed="0.000085"/>
</kw>
<msg time="2026-06-06T03:13:35.656531" level="FAIL">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</msg>
<status status="FAIL" start="2026-06-06T03:13:35.655600" elapsed="0.001080">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:13:35.655565" elapsed="0.001222">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</if>
<doc>Check if netstat is installed and install it if not.</doc>
<status status="FAIL" start="2026-06-06T03:13:35.640853" elapsed="0.016221">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</kw>
<arg>Check_And_Install_Netstat</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:35.640428" elapsed="0.016802"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.658190" level="INFO">Executing command 'netstat -punta 2&gt; /dev/null | grep -E ":17900 .+ ESTABLISHED .+python" | wc -l'.</msg>
<msg time="2026-06-06T03:13:35.706012" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:35.706342" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>${NETSTAT_COMMAND} 2&gt; /dev/null | grep -E ":${port} .+ ${state} .+${name}" | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:35.657628" elapsed="0.048774"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:13:35.706556" elapsed="0.000148"/>
</return>
<msg time="2026-06-06T03:13:35.707027" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>17900</arg>
<arg>ESTABLISHED</arg>
<arg>python</arg>
<doc>Run 'netstat' on the remote machine and count occurences of given port in the given state connected to process with the given name.</doc>
<status status="PASS" start="2026-06-06T03:13:35.640078" elapsed="0.067007"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output}</arg>
<arg>${howmany}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:13:35.707637" elapsed="0.000884"/>
</kw>
<arg>1</arg>
<doc>Run netstat in mininet machine and parse it for number of established connections. Check it is ${howmany}.</doc>
<status status="PASS" start="2026-06-06T03:13:35.639558" elapsed="0.069164"/>
</kw>
<arg>5s</arg>
<arg>1s</arg>
<arg>Check_Number_Of_Speaker_Connections</arg>
<arg>1</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:35.635062" elapsed="0.073776"/>
</kw>
<doc>Give it several tries to see exactly one established connection.</doc>
<status status="PASS" start="2026-06-06T03:13:35.634723" elapsed="0.074262"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:35.710376" elapsed="0.000580"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:35.709610" elapsed="0.001489"/>
</kw>
<doc>See TCP (BGP) connection in established state.</doc>
<status status="PASS" start="2026-06-06T03:13:35.542570" elapsed="0.168614"/>
</test>
<test id="s1-s4-t30" name="Check_Listening_Topology_Is_Filled_Case_2" line="327">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.717231" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.716871" elapsed="0.000447"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.716837" elapsed="0.000521"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:35.716539" elapsed="0.000889"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.718987" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.718818" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.718790" elapsed="0.000301"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.724907" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.724797" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.724778" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.726034" 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-06-06T03:13:35.725608" elapsed="0.000454"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.726537" 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-06-06T03:13:35.726232" elapsed="0.000332"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:35.726609" elapsed="0.000053"/>
</return>
<msg time="2026-06-06T03:13:35.726795" 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-06-06T03:13:35.725220" elapsed="0.001601"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:35.732492" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.732377" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.732357" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:35.733860" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.733749" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.733729" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:35.734405" 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-06-06T03:13:35.734084" elapsed="0.000347"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.734846" level="INFO">${current_connection_index} = 7</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-06-06T03:13:35.734600" elapsed="0.000272"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.771086" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:35.735391" elapsed="0.035946"/>
</kw>
<msg time="2026-06-06T03:13:35.771588" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:35.771638" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:35.735035" elapsed="0.036674"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:35.819894" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:35.772486" elapsed="0.047787"/>
</kw>
<msg time="2026-06-06T03:13:35.820530" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:35.820579" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</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-06-06T03:13:35.771995" elapsed="0.048624"/>
</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-06-06T03:13:35.821158" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.820778" elapsed="0.000443"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.820737" elapsed="0.000513"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.821841" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:35.821402" elapsed="0.000518"/>
</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-06-06T03:13:35.822227" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.821992" elapsed="0.000291"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.821972" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:35.822347" 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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:35.825300" elapsed="0.000160"/>
</kw>
<msg time="2026-06-06T03:13:35.825527" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:35.824032" elapsed="0.001664"/>
</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="NOT RUN" start="2026-06-06T03:13:35.825979" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.826321" elapsed="0.000073"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:35.823334" elapsed="0.003173"/>
</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-06-06T03:13:35.822719" elapsed="0.003857"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:35.733402" elapsed="0.093301"/>
</kw>
<msg time="2026-06-06T03:13:35.826808" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:35.826854" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:35.732769" elapsed="0.094126"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:35.827373" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:13:35.827251" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.826957" elapsed="0.000506"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.827934" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.828295" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.828368" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:35.732020" elapsed="0.096459"/>
</kw>
<msg time="2026-06-06T03:13:35.828577" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:35.828621" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:35.727216" elapsed="0.101460"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.829045" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.828757" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.828738" elapsed="0.000388"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:35.727067" elapsed="0.102084"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:35.726882" elapsed="0.102304"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:35.724392" elapsed="0.104853"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:35.718359" elapsed="0.111006"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:35.717683" elapsed="0.111732"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:35.713173" elapsed="0.116300"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.882336" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:35.881883" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:35.883397" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:35.882945" elapsed="0.000533">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:35.883575" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:35.882561" elapsed="0.001039"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.884200" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:35.883804" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:35.884541" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:35.884740" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:35.884395" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.885195" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:35.884928" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.886879" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:35.886405" elapsed="0.000536"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.887483" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:35.887110" elapsed="0.000399"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.887960" elapsed="0.000047"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.888735" elapsed="0.000051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.889077" elapsed="0.000047"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:35.887766" elapsed="0.001549"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.887569" elapsed="0.001816"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:35.889442" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:13:35.889627" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:35.886031" elapsed="0.003639"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.885329" elapsed="0.004376"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.889891" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.889734" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.885299" elapsed="0.004668"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.890604" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:35.890116" elapsed="0.000517"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:35.890702" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:35.881073" elapsed="0.009757"/>
</kw>
<msg time="2026-06-06T03:13:35.890950" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:35.868278" elapsed="0.022729"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.904018" elapsed="0.000070"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.916542" elapsed="0.000047"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.928908" elapsed="0.000055"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.929216" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.929434" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.929920" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.929762" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:35.929742" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.930150" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.930338" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.930507" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:35.929693" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.929523" elapsed="0.001064"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.930757" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.930839" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:13:35.931009" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:35.863754" elapsed="0.067284"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:35.932521" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:35.932220" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:35.932715" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:35.931800" elapsed="0.000939"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.933155" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.932812" elapsed="0.000402"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.933780" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:35.933462" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.933239" elapsed="0.000605"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.932792" elapsed="0.001074"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.936445" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:35.934020" elapsed="0.002452"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:35.936527" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:35.936709" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:35.931412" elapsed="0.005323"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:35.937986" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:35.937749" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:35.938144" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:35.937391" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:35.938375" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:35.938239" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.938220" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.938607" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:35.938803" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.938869" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:35.940784" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:35.937046" elapsed="0.003765"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.942257" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:35.941998" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.942721" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:35.942457" elapsed="0.000308"/>
</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-06-06T03:13:35.958041" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:35.958203" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:13:35.958333" 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-06-06T03:13:35.944871" elapsed="0.013490"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.942831" elapsed="0.015579"/>
</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-06-06T03:13:35.958622" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.958441" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.942812" elapsed="0.015920"/>
</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-06-06T03:13:35.962765" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:35.959872" elapsed="0.002978"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.959614" elapsed="0.003373"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.959594" elapsed="0.003434"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.967781" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:35.963571" elapsed="0.004283"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.963140" elapsed="0.004772"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.963104" elapsed="0.004846"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.968920" 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-06-06T03:13:35.968237" elapsed="0.000728"/>
</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-06-06T03:13:35.969539" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.969091" elapsed="0.000538"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.970239" 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-06-06T03:13:35.969932" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.969689" elapsed="0.000611"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.969053" elapsed="0.001268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.970869" 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-06-06T03:13:35.970484" elapsed="0.000412"/>
</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-06-06T03:13:35.971209" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:35.970972" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:35.971767" 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-06-06T03:13:35.971452" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.971291" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.970953" elapsed="0.000896"/>
</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-06-06T03:13:35.972012" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:35.972897" 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-06-06T03:13:35.972561" elapsed="0.000363"/>
</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-06-06T03:13:35.973087" elapsed="0.002537"/>
</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-06-06T03:13:35.959136" elapsed="0.016578"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:35.975903" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:35.975789" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.975770" elapsed="0.000206"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:35.978995" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:13:35.976129" elapsed="0.002895"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:35.979078" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:13:35.979249" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:35.941125" elapsed="0.038152"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:35.979340" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:35.979498" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:35.841389" elapsed="0.138157"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.012412" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.011377" elapsed="0.001072"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.014625" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.014034" elapsed="0.000783">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:36.014960" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:36.012659" elapsed="0.002327"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.015958" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:36.015162" elapsed="0.000824"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.016401" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:36.016692" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:36.016156" elapsed="0.000566"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.017321" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.016892" elapsed="0.000496"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:36.018208" elapsed="0.000082"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.017474" elapsed="0.000900"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.019241" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.018591" elapsed="0.000693"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.018405" elapsed="0.000961"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.017446" elapsed="0.001945"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.020415" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:36.019547" elapsed="0.000898"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:36.020500" elapsed="0.000038"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:36.010377" elapsed="0.010286"/>
</kw>
<msg time="2026-06-06T03:13:36.020725" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:35.995361" elapsed="0.025422"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.033779" elapsed="0.000065"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.046220" elapsed="0.000068"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.058714" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.058952" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.059147" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.059583" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.059427" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:36.059408" elapsed="0.000280"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.059839" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.060012" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.060182" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:36.059363" elapsed="0.000872"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.059237" elapsed="0.001025"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.060434" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.060516" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:13:36.060697" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:35.992528" elapsed="0.068200"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.060909" elapsed="0.002410"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:36.064671" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:36.064124" elapsed="0.000578"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:36.065296" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:36.064863" elapsed="0.000461"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:36.065485" elapsed="0.000383"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:36.063675" elapsed="0.002259"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.063402" elapsed="0.002566"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.066149" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.065994" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.063382" elapsed="0.002845"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:35.981106" elapsed="0.085168"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:35.980028" elapsed="0.086323"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:35.979680" elapsed="0.086760"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:35.979636" elapsed="0.086831"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:36.066502" elapsed="0.000036"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:35.835114" elapsed="0.231544"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:35.830616" elapsed="0.236111"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:35.830063" elapsed="0.236713"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:35.829630" elapsed="0.237207"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:36.067427" elapsed="0.000527"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:36.067116" elapsed="0.000904"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:35.711867" elapsed="0.356191"/>
</test>
<test id="s1-s4-t31" name="Kill_Listening_BGP_Speaker_Case_2" line="332">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:36.071461" elapsed="0.000241"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:13:36.071190" elapsed="0.000570"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.072800" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.072678" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.072640" elapsed="0.000229"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.077829" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.077672" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.077638" elapsed="0.000265"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.078941" 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-06-06T03:13:36.078524" elapsed="0.000445"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.079436" 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-06-06T03:13:36.079136" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:36.079507" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:13:36.079687" 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-06-06T03:13:36.078143" elapsed="0.001571"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:36.085441" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.085331" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.085310" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:36.086765" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.086630" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.086611" elapsed="0.000223"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:36.087284" 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-06-06T03:13:36.086985" elapsed="0.000326"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.087717" level="INFO">${current_connection_index} = 7</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-06-06T03:13:36.087476" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.123073" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:36.088280" elapsed="0.034912"/>
</kw>
<msg time="2026-06-06T03:13:36.123391" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:36.123439" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:36.087909" elapsed="0.035567"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.145204" level="INFO">". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:36.124159" elapsed="0.021244"/>
</kw>
<msg time="2026-06-06T03:13:36.145627" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:36.145702" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a ...</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-06-06T03:13:36.123781" elapsed="0.021960"/>
</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-06-06T03:13:36.146207" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.145860" elapsed="0.000408"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.145822" elapsed="0.000476"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.146859" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:36.146454" elapsed="0.000475"/>
</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-06-06T03:13:36.147230" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.147005" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.146979" elapsed="0.000330"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:36.147349" 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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:36.150183" elapsed="0.000159"/>
</kw>
<msg time="2026-06-06T03:13:36.150406" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.148979" elapsed="0.001568"/>
</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="NOT RUN" start="2026-06-06T03:13:36.150853" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.151189" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:36.148298" elapsed="0.003124"/>
</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-06-06T03:13:36.147708" elapsed="0.003783"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:36.086330" elapsed="0.065276"/>
</kw>
<msg time="2026-06-06T03:13:36.151738" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.151784" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.085683" elapsed="0.066143"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:36.152022" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:36.151908" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.151887" elapsed="0.000222"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.152548" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.152924" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.152997" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:36.084833" elapsed="0.068280"/>
</kw>
<msg time="2026-06-06T03:13:36.153212" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.153257" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:36.080097" elapsed="0.073202"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.153636" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.153377" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.153359" elapsed="0.000373"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:36.079949" elapsed="0.073809"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:36.079770" elapsed="0.074084"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:36.077285" elapsed="0.076640"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:36.072364" elapsed="0.081637"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.071922" elapsed="0.082128"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:13:36.069020" elapsed="0.085088"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.155358" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:36.155029" elapsed="0.000356"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:36.155544" elapsed="0.000363"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:13:36.154752" elapsed="0.001231"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.174188" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:13:36.156488" elapsed="0.017782"/>
</kw>
<msg time="2026-06-06T03:13:36.174386" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.174431" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.156149" elapsed="0.018307"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.175185" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:13:36.188165" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:36.188387" level="INFO">${output_log} = 2026-06-06 03:13:25,629 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:13:30,126 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:13:30,127 INFO BGP-Thread-1 (job): O...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:36.175031" elapsed="0.013414"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.189478" level="INFO">2026-06-06 03:13:25,629 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:13:30,126 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:13:30,127 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:13:30,127 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:13:30,127 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:13:30,127 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:13:30,127 INFO BGP-Thread-1 (job):   Prefix base: 8.0.0.240/28
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 2
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 1
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Fast pre-fill up to 2 prefixes
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 1
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Common single UPDATE will be generated for both NLRI &amp; WITHDRAWN lists
2026-06-06 03:13:30,128 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:13:30,130 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:13:30,130 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:13:30,130 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:13:30,130 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): Number of iterations: 2
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 1
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): The pre-fill phase duration: 6.175041198730469e-05s
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 1
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): The 2nd test phase duration: 3.6716461181640625e-05s
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:30,131 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:13:30,132 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:30,132 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:30,132 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:13:30,132 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:13:30,132 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:13:30,132 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:13:30,137 INFO BGP-Thread-1 (job): ... idle for 0.005s
2026-06-06 03:13:30,137 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.005s
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.188868" elapsed="0.000818"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:13:36.174715" elapsed="0.015102"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:13:36.190432" elapsed="0.000070"/>
</return>
<status status="PASS" start="2026-06-06T03:13:36.190141" elapsed="0.000433"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.190014" elapsed="0.000618"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.191017" elapsed="0.000048"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.191396" elapsed="0.000044"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:13:36.154394" elapsed="0.037173"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.193424" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:13:36.192698" elapsed="0.000818"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:13:36.192034" elapsed="0.001636"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:36.195074" elapsed="0.000461"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:13:36.194316" elapsed="0.001368"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:36.068417" elapsed="0.127358"/>
</test>
<test id="s1-s4-t32" name="Check_For_Empty_Topology_After_Listening_Case_2" line="341">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.201310" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.201067" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.201045" elapsed="0.000351"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:36.200867" elapsed="0.000576"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.202527" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.202416" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.202397" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.207497" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.207390" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.207372" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.208596" 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-06-06T03:13:36.208204" elapsed="0.000419"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.209110" 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-06-06T03:13:36.208808" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:36.209182" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:13:36.209342" 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-06-06T03:13:36.207815" elapsed="0.001552"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:36.215099" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.214988" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.214968" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:36.216380" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.216271" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.216252" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:36.216935" 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-06-06T03:13:36.216600" elapsed="0.000364"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.217356" level="INFO">${current_connection_index} = 7</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-06-06T03:13:36.217129" elapsed="0.000253"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.255727" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:36.217911" elapsed="0.037924"/>
</kw>
<msg time="2026-06-06T03:13:36.256000" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:36.256046" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:36.217547" elapsed="0.038621"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.285461" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "L "i "s "t "e "n "i "n "g "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:36.256729" elapsed="0.028848"/>
</kw>
<msg time="2026-06-06T03:13:36.285768" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:36.285815" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</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-06-06T03:13:36.256354" elapsed="0.029498"/>
</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-06-06T03:13:36.286347" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.285938" elapsed="0.000466"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.285914" elapsed="0.000515"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.286911" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "L "i "s "t "e "n "i "n "g "_ "C "a "s "e "_ "2 "[K"
[?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-06-06T03:13:36.286579" elapsed="0.000404"/>
</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-06-06T03:13:36.287274" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.287053" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.287033" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:36.287389" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:36.290156" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:13:36.290403" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.288902" elapsed="0.001637"/>
</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="NOT RUN" start="2026-06-06T03:13:36.290840" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.291178" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:36.288255" elapsed="0.003106"/>
</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-06-06T03:13:36.287706" elapsed="0.003719"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:36.215964" elapsed="0.075561"/>
</kw>
<msg time="2026-06-06T03:13:36.291620" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.291685" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.215326" elapsed="0.076400"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:36.291914" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:36.291805" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.291786" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.292407" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.292787" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.292863" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:36.214630" elapsed="0.078346"/>
</kw>
<msg time="2026-06-06T03:13:36.293071" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.293116" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:36.209776" elapsed="0.083380"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.293488" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.293233" elapsed="0.000351"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.293215" elapsed="0.000394"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:36.209610" elapsed="0.084024"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:36.209427" elapsed="0.084261"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:36.207028" elapsed="0.086719"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:36.202114" elapsed="0.091691"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.201604" elapsed="0.092249"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:36.197819" elapsed="0.096088"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.345405" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.345023" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.346324" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.345968" elapsed="0.000434">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:36.346534" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:36.345603" elapsed="0.000958"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.347150" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:36.346757" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.347483" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:36.347644" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:36.347344" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.348099" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.347851" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.349323" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.348880" elapsed="0.000504"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.349931" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:36.349550" elapsed="0.000410"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.350364" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.351126" elapsed="0.000049"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.351464" elapsed="0.000045"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:36.350176" elapsed="0.001452"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.350013" elapsed="0.001708"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:36.351770" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:36.351932" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:36.348512" elapsed="0.003444"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.348211" elapsed="0.003778"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.352165" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.352014" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.348192" elapsed="0.004049"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.352847" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:36.352386" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:36.352982" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:36.344387" elapsed="0.008721"/>
</kw>
<msg time="2026-06-06T03:13:36.353162" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.331930" elapsed="0.021281"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.365696" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.377926" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.390263" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.390464" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.390677" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.391050" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.390903" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:36.390888" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.391271" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.391441" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.391608" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:36.390859" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.390758" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.391857" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.391932" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:36.392051" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:36.327683" elapsed="0.064394"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.393374" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.393136" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:36.393531" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:36.392790" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.393897" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.393628" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.394455" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.394162" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.393980" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.393609" elapsed="0.000929"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.396882" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:36.394736" elapsed="0.002172"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:36.396960" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:13:36.397112" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:36.392443" elapsed="0.004693"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.398354" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.398124" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:36.398509" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:36.397786" elapsed="0.000747"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:36.398776" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:13:36.398604" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.398585" elapsed="0.000278"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.399013" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.399188" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.399254" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:36.401281" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:36.397444" elapsed="0.003864"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.402772" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.402475" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.403223" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.402979" elapsed="0.000287"/>
</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-06-06T03:13:36.419537" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:36.419697" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:36.419811" 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-06-06T03:13:36.405362" elapsed="0.014475"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.403332" elapsed="0.016549"/>
</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-06-06T03:13:36.420065" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.419908" elapsed="0.000263"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.403313" elapsed="0.016885"/>
</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-06-06T03:13:36.423622" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.421234" elapsed="0.002453"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.421011" elapsed="0.002711"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.420992" elapsed="0.002755"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.427253" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.424090" elapsed="0.003226"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.423803" elapsed="0.003561"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.423785" elapsed="0.003613"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.428184" 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-06-06T03:13:36.427628" elapsed="0.000593"/>
</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-06-06T03:13:36.428677" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.428320" elapsed="0.000440"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.429441" 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-06-06T03:13:36.429023" elapsed="0.000454"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.428794" elapsed="0.000732"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.428294" elapsed="0.001261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.430318" 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-06-06T03:13:36.429802" elapsed="0.000553"/>
</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-06-06T03:13:36.430836" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.430452" elapsed="0.000467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.431598" 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-06-06T03:13:36.431178" elapsed="0.000457"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.430952" elapsed="0.000753"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.430427" elapsed="0.001308"/>
</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-06-06T03:13:36.431946" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:36.432768" 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-06-06T03:13:36.432457" elapsed="0.000337"/>
</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-06-06T03:13:36.432951" elapsed="0.002263"/>
</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-06-06T03:13:36.420569" elapsed="0.014707"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.435452" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.435346" elapsed="0.000149"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.435328" elapsed="0.000189"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:36.438288" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:36.435682" elapsed="0.002634"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:36.438368" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:36.438524" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:36.401627" elapsed="0.036923"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:36.438612" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:36.438805" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:36.305419" elapsed="0.133445"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.467278" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.466507" elapsed="0.000800"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.469288" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.468765" elapsed="0.000676">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:36.469574" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:36.467473" elapsed="0.002126"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.470541" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:36.469788" elapsed="0.000781"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:36.471023" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:36.471271" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:36.470751" elapsed="0.000548"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.471902" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.471459" elapsed="0.000507"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:36.472664" elapsed="0.000082"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.472036" elapsed="0.000790"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.473658" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.473034" elapsed="0.000667"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.472854" elapsed="0.000931"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.472016" elapsed="0.001794"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.474742" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:36.473961" elapsed="0.000811"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:36.474823" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:36.465808" elapsed="0.009165"/>
</kw>
<msg time="2026-06-06T03:13:36.475029" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.453408" elapsed="0.021672"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.487498" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.499709" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.512069" elapsed="0.000056"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.512372" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.512563" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.513035" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.512879" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:36.512859" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.513265" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.513432" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.513600" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:36.512816" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.512668" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.513851" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.513936" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:13:36.514095" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:36.450768" elapsed="0.063356"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.514306" elapsed="0.002283"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:36.517821" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:36.517404" elapsed="0.000446"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:36.518450" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:36.518007" elapsed="0.000471"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:36.518634" elapsed="0.000410"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:36.516969" elapsed="0.002137"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.516690" elapsed="0.002452"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.519320" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.519168" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.516669" elapsed="0.002727"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:36.440040" elapsed="0.079465"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:36.439204" elapsed="0.080380"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:36.438958" elapsed="0.080673"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.438940" elapsed="0.080737"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:36.519716" elapsed="0.000037"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:36.299349" elapsed="0.220510"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:36.294926" elapsed="0.225000"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:36.294414" elapsed="0.225568"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:36.294050" elapsed="0.225994"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:36.520639" elapsed="0.000262"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:36.520330" elapsed="0.000635"/>
</kw>
<doc>Post-condition: Check example-ipv4-topology is empty again.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:36.196444" elapsed="0.324559"/>
</test>
<test id="s1-s4-t33" name="Start_Listening_BGP_Speaker_Case_3" line="346">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.524754" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.524499" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.524480" elapsed="0.000359"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:36.524314" elapsed="0.000571"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.525916" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.525807" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.525788" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.531138" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.531008" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.530988" elapsed="0.000222"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.532274" 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-06-06T03:13:36.531860" elapsed="0.000442"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.532791" 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-06-06T03:13:36.532471" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:36.532862" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:13:36.533023" 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-06-06T03:13:36.531457" elapsed="0.001591"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:36.538498" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.538389" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.538369" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:36.539788" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:36.539675" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.539630" elapsed="0.000226"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:36.540309" 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-06-06T03:13:36.540005" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.540733" level="INFO">${current_connection_index} = 7</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-06-06T03:13:36.540499" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.577592" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:36.541342" elapsed="0.036388"/>
</kw>
<msg time="2026-06-06T03:13:36.577910" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:36.577960" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:36.540998" elapsed="0.037000"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.600134" level="INFO">". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:36.578557" elapsed="0.021744"/>
</kw>
<msg time="2026-06-06T03:13:36.600507" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:36.600553" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C ...</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-06-06T03:13:36.578188" elapsed="0.022404"/>
</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-06-06T03:13:36.601041" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.600733" elapsed="0.000367"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.600699" elapsed="0.000429"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.601659" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:36.601285" elapsed="0.000447"/>
</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-06-06T03:13:36.602028" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.601801" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.601782" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:36.602145" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:36.604921" elapsed="0.000338"/>
</kw>
<msg time="2026-06-06T03:13:36.605324" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:36.603779" elapsed="0.001682"/>
</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="NOT RUN" start="2026-06-06T03:13:36.605776" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.606122" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:36.603072" elapsed="0.003235"/>
</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-06-06T03:13:36.602473" elapsed="0.003899"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:36.539342" elapsed="0.067127"/>
</kw>
<msg time="2026-06-06T03:13:36.606560" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.606605" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.538736" elapsed="0.067925"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:36.606849" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:36.606740" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.606721" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.607378" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.607816" elapsed="0.000030"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:36.607897" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:36.538050" elapsed="0.069964"/>
</kw>
<msg time="2026-06-06T03:13:36.608161" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:36.608206" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "S "t "a "r "t "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:36.533430" elapsed="0.074814"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:36.608578" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:36.608322" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:36.608304" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:36.533283" elapsed="0.075418"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:36.533106" elapsed="0.075628"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:36.530610" elapsed="0.078179"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:36.525487" elapsed="0.083359"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:36.525040" elapsed="0.083853"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:36.522018" elapsed="0.086930"/>
</kw>
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.609996" level="INFO">${command} = python3 play.py --amount 2 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=0 --insert=3 --withdraw=1 --updates=single --info &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:36.609643" elapsed="0.000381"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:36.610424" level="INFO">python3 play.py --amount 2 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=0 --insert=3 --withdraw=1 --updates=single --info &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:36.610184" elapsed="0.000286"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:36.614743" level="INFO">python3 play.py --amount 2 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=0 --insert=3 --withdraw=1 --updates=single --info &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:13:36.614847" level="INFO">${output} =  python3 play.py --amount 2 --listen --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --prefill=0 --insert=3 --withdraw=1 --updates=single --info &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:36.610622" elapsed="0.004254"/>
</kw>
<arg>--amount 2 --listen --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --prefill=0 --insert=3 --withdraw=1 --updates=single --${BGP_TOOL_LOG_LEVEL}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:13:36.609191" elapsed="0.005750"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.617213" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.616616" elapsed="10.001446">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.618400" elapsed="0.000034"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:13:36.616332" elapsed="10.002225">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:13:36.615927" elapsed="10.002801"/>
</kw>
<msg time="2026-06-06T03:13:46.618858" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:36.615541" elapsed="10.003343"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:13:46.619082" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:13:46.618985" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.618957" elapsed="0.000215"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.619409" elapsed="0.000026"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.619587" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:13:36.615186" elapsed="10.004498"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:46.620361" elapsed="0.000326"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:46.619972" elapsed="0.000873"/>
</kw>
<doc>BGP Speaker introduces 3 prefixes while the first one occures again in the withdrawn list (to be ignored by controller)</doc>
<status status="PASS" start="2026-06-06T03:13:36.521346" elapsed="10.099541"/>
</test>
<test id="s1-s4-t34" name="Check_Listening_Connection_Is_Established_Case_3" line="352">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.626562" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.626327" elapsed="0.000294"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.626308" elapsed="0.000353"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:46.626138" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.627735" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.627609" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.627591" elapsed="0.000212"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.632629" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.632523" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.632505" elapsed="0.000208"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.633875" 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-06-06T03:13:46.633430" elapsed="0.000472"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.634385" 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-06-06T03:13:46.634084" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:46.634455" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:46.634608" 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-06-06T03:13:46.633053" elapsed="0.001579"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:46.640174" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.640064" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.640045" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:46.641433" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.641327" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.641309" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:46.642054" 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-06-06T03:13:46.641703" elapsed="0.000379"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.642469" level="INFO">${current_connection_index} = 7</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-06-06T03:13:46.642248" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.678339" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:46.643015" elapsed="0.035565"/>
</kw>
<msg time="2026-06-06T03:13:46.678856" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:46.678906" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:46.642673" elapsed="0.036271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.734112" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:46.679715" elapsed="0.054529"/>
</kw>
<msg time="2026-06-06T03:13:46.734457" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:46.734504" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</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-06-06T03:13:46.679207" elapsed="0.055333"/>
</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-06-06T03:13:46.734969" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.734668" elapsed="0.000421"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.734612" elapsed="0.000507"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.735668" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s "_ "E "s "t "a "b "l "i "s "h "e "d "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:46.735269" elapsed="0.000471"/>
</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-06-06T03:13:46.736040" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.735811" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.735791" elapsed="0.000329"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:46.736157" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:46.738802" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:13:46.739017" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:46.737724" elapsed="0.001430"/>
</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="NOT RUN" start="2026-06-06T03:13:46.739436" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.739800" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:46.737047" elapsed="0.002942"/>
</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-06-06T03:13:46.736453" elapsed="0.003602"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:46.641026" elapsed="0.099128"/>
</kw>
<msg time="2026-06-06T03:13:46.740249" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:46.740293" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:46.640404" elapsed="0.099926"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:46.740522" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:46.740409" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.740389" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.741048" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.741397" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.741471" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:46.639724" elapsed="0.101856"/>
</kw>
<msg time="2026-06-06T03:13:46.741722" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:46.741768" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "C "o "n "n "e "c "t "i "o "n "_ "I "s ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:46.635074" elapsed="0.106732"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.742149" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.741885" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.741866" elapsed="0.000363"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:46.634928" elapsed="0.107326"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:46.634747" elapsed="0.107541"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:46.632161" elapsed="0.110184"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:46.627308" elapsed="0.115091"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:46.626863" elapsed="0.115582"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:46.621837" elapsed="0.120662"/>
</kw>
<kw name="Check_Speaker_Is_Connected">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Number_Of_Speaker_Connections">
<kw name="Count_Port_Occurences" owner="SSHKeywords">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_And_Install_Netstat" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.749071" level="INFO">Executing command 'netstat --version'.</msg>
<msg time="2026-06-06T03:13:46.763052" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:46.763276" level="INFO">${netstat_installed} = net-tools 2.10-alpha
Fred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others
+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX
AF: (inet) +UNIX +INET...</msg>
<var>${netstat_installed}</var>
<arg>netstat --version</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:46.748966" elapsed="0.014371"/>
</kw>
<if>
<branch type="IF" condition="'${netstat_installed}' is not string and '${netstat_installed}' != '0'">
<kw name="Install_Netstat" owner="SSHKeywords">
<doc>Install netstat if it is not already installed.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.764280" elapsed="0.000055"/>
</kw>
<msg time="2026-06-06T03:13:46.764414" level="FAIL">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</msg>
<status status="FAIL" start="2026-06-06T03:13:46.763506" elapsed="0.001015">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:13:46.763460" elapsed="0.001152">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</if>
<doc>Check if netstat is installed and install it if not.</doc>
<status status="FAIL" start="2026-06-06T03:13:46.748686" elapsed="0.016220">Invalid IF condition: Evaluating expression "'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' is not string and 'net-tools 2.10-alpha\nFred Baumgarten, Alan Cox, Bernd Eckenfels, Phil Blundell, Tuan Hoang, Brian Micek and others\n+NEW_ADDRT +RTF_IRTT +RTF_REJECT +FW_MASQUERADE +I18N +SELINUX\nAF: (inet) +UNIX +INET +INET6 +IPX +AX25 +NETROM +X25 +ATALK +ECONET +ROSE -BLUETOOTH\nHW:  +ETHER +ARC +SLIP +PPP +TUNNEL -TR +AX25 +NETROM +X25 +FR +ROSE +ASH +SIT +FDDI +HIPPI +HDLC/LAPB +EUI64 ' != '0'" failed: SyntaxError: unterminated string literal (detected at line 1) (&lt;string&gt;, line 1)

Variables in the original expression "'${netstat_installed}' is not string and '${netstat_installed}' != '0'" were resolved before the expression was evaluated. Try using "$netstat_installed is not string and $netstat_installed != '0'" syntax to avoid that. See Evaluating Expressions appendix in Robot Framework User Guide for more details.</status>
</kw>
<arg>Check_And_Install_Netstat</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:46.748269" elapsed="0.016781"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.765953" level="INFO">Executing command 'netstat -punta 2&gt; /dev/null | grep -E ":17900 .+ ESTABLISHED .+python" | wc -l'.</msg>
<msg time="2026-06-06T03:13:46.813965" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:46.814219" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>${NETSTAT_COMMAND} 2&gt; /dev/null | grep -E ":${port} .+ ${state} .+${name}" | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:46.765411" elapsed="0.048873"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:13:46.814409" elapsed="0.000079"/>
</return>
<msg time="2026-06-06T03:13:46.814827" level="INFO">${output} = 1</msg>
<var>${output}</var>
<arg>17900</arg>
<arg>ESTABLISHED</arg>
<arg>python</arg>
<doc>Run 'netstat' on the remote machine and count occurences of given port in the given state connected to process with the given name.</doc>
<status status="PASS" start="2026-06-06T03:13:46.747934" elapsed="0.066951"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output}</arg>
<arg>${howmany}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:13:46.815270" elapsed="0.000810"/>
</kw>
<arg>1</arg>
<doc>Run netstat in mininet machine and parse it for number of established connections. Check it is ${howmany}.</doc>
<status status="PASS" start="2026-06-06T03:13:46.747492" elapsed="0.068812"/>
</kw>
<arg>5s</arg>
<arg>1s</arg>
<arg>Check_Number_Of_Speaker_Connections</arg>
<arg>1</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:46.742952" elapsed="0.073461"/>
</kw>
<doc>Give it several tries to see exactly one established connection.</doc>
<status status="PASS" start="2026-06-06T03:13:46.742655" elapsed="0.073891"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:46.817962" elapsed="0.000588"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:46.817182" elapsed="0.001551"/>
</kw>
<doc>See TCP (BGP) connection in established state.</doc>
<status status="PASS" start="2026-06-06T03:13:46.621256" elapsed="0.197568"/>
</test>
<test id="s1-s4-t35" name="Check_Listening_Topology_Is_Filled_Case_3" line="356">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.825042" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.824712" elapsed="0.000412"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.824682" elapsed="0.000477"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:46.824424" elapsed="0.000802"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.826744" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.826568" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.826541" elapsed="0.000299"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.832994" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.832883" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.832865" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.834127" 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-06-06T03:13:46.833697" elapsed="0.000457"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.834633" 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-06-06T03:13:46.834332" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:46.834723" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:46.834880" 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-06-06T03:13:46.833296" elapsed="0.001609"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:46.840577" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.840466" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.840446" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:46.841902" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:46.841782" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.841759" elapsed="0.000219"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:46.842455" 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-06-06T03:13:46.842131" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.842891" level="INFO">${current_connection_index} = 7</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-06-06T03:13:46.842666" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.880537" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:46.843426" elapsed="0.037209"/>
</kw>
<msg time="2026-06-06T03:13:46.880852" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:46.880901" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:46.843083" elapsed="0.037853"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:46.903738" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:46.881464" elapsed="0.022476"/>
</kw>
<msg time="2026-06-06T03:13:46.904244" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:46.904292" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</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-06-06T03:13:46.881115" elapsed="0.023215"/>
</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-06-06T03:13:46.904778" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.904441" elapsed="0.000399"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.904409" elapsed="0.000458"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.905384" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:46.905020" elapsed="0.000433"/>
</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-06-06T03:13:46.905766" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.905523" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.905504" elapsed="0.000383"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:46.905927" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:46.908614" elapsed="0.000359"/>
</kw>
<msg time="2026-06-06T03:13:46.909043" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:46.907552" elapsed="0.001629"/>
</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="NOT RUN" start="2026-06-06T03:13:46.909471" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.909896" elapsed="0.000082"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:46.906881" elapsed="0.003217"/>
</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-06-06T03:13:46.906268" elapsed="0.003897"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:46.841427" elapsed="0.068863"/>
</kw>
<msg time="2026-06-06T03:13:46.910390" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:46.910436" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:46.840821" elapsed="0.069651"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:46.910685" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:13:46.910552" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.910533" elapsed="0.000239"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.911187" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.911542" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.911616" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:46.840118" elapsed="0.071629"/>
</kw>
<msg time="2026-06-06T03:13:46.911844" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:46.911888" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "L "i "s "t "e "n "i "n "g "_ "T "o "p "o "l "o "g "y "_ "I "s "_ "F ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:46.835287" elapsed="0.076638"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.912262" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.912003" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.911984" elapsed="0.000358"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:46.835139" elapsed="0.077228"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:46.834962" elapsed="0.077437"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:46.832496" elapsed="0.079960"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:46.826137" elapsed="0.086418"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:46.825447" elapsed="0.087157"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:46.820607" elapsed="0.092072"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.964352" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:46.963959" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:46.965313" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:46.964916" elapsed="0.000479">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:46.965491" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:46.964554" elapsed="0.000961"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.966117" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:46.965711" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:46.966452" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:46.966619" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:46.966312" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.967075" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:46.966824" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.968325" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:46.967873" elapsed="0.000515"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.968939" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:46.968558" elapsed="0.000408"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.969373" elapsed="0.000045"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.970144" elapsed="0.000051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.970485" elapsed="0.000046"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:46.969183" elapsed="0.001493"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:46.969020" elapsed="0.001724"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:46.970792" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:13:46.970958" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:46.967504" elapsed="0.003479"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:46.967195" elapsed="0.003821"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.971191" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:46.971040" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:46.967172" elapsed="0.004095"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:46.971882" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:46.971418" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:46.971961" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:46.963305" elapsed="0.008779"/>
</kw>
<msg time="2026-06-06T03:13:46.972189" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:46.950622" elapsed="0.021618"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.984448" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:46.996522" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.008960" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.009165" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.009346" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.009735" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.009568" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:47.009552" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.009989" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.010162" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.010331" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:47.009524" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.009421" elapsed="0.000988"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.010557" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.010632" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:47.010768" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:46.946348" elapsed="0.064446"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.012058" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.011815" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.012216" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.011452" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.012601" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.012312" elapsed="0.000365"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.013185" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.012884" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.012703" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.012293" elapsed="0.000976"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.015593" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:47.013426" elapsed="0.002194"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:47.015686" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:47.015842" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:47.011123" elapsed="0.004744"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.017095" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.016861" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.017253" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.016504" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:47.017485" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.017348" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.017329" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.017736" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.017914" elapsed="0.000051"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.018012" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:47.019886" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:47.016175" elapsed="0.003738"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.021311" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.021058" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.021778" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.021517" elapsed="0.000306"/>
</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-06-06T03:13:47.031047" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:47.031184" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:13:47.031298" 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-06-06T03:13:47.024259" elapsed="0.007070"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.021889" elapsed="0.009486"/>
</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-06-06T03:13:47.031561" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.031402" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.021871" elapsed="0.009799"/>
</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-06-06T03:13:47.035111" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.032702" elapsed="0.002458"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.032460" elapsed="0.002769"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.032441" elapsed="0.002816"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.037811" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.035545" elapsed="0.002312"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.035317" elapsed="0.002575"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.035299" elapsed="0.002618"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.038590" 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-06-06T03:13:47.038122" elapsed="0.000506"/>
</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-06-06T03:13:47.039097" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.038759" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.039882" 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-06-06T03:13:47.039440" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.039212" elapsed="0.000756"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.038732" elapsed="0.001265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.040748" 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-06-06T03:13:47.040223" elapsed="0.000562"/>
</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-06-06T03:13:47.041214" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.040883" elapsed="0.000410"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.042025" 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-06-06T03:13:47.041552" elapsed="0.000511"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.041327" elapsed="0.000785"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.040858" elapsed="0.001282"/>
</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-06-06T03:13:47.042354" elapsed="0.000360"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:47.043174" 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-06-06T03:13:47.042882" elapsed="0.000319"/>
</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-06-06T03:13:47.043358" elapsed="0.002257"/>
</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-06-06T03:13:47.032036" elapsed="0.013659"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.045874" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.045766" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.045747" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:47.048849" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:13:47.046110" elapsed="0.002768"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:47.048930" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:47.049087" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:47.020225" elapsed="0.028889"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.049175" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:13:47.049323" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:46.924200" elapsed="0.125149"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.077936" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.077128" elapsed="0.000837"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.079993" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.079442" elapsed="0.000709">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.080285" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.078148" elapsed="0.002163"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.081264" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:47.080486" elapsed="0.000807"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.081716" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:47.081968" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:47.081460" elapsed="0.000536"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.082625" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.082190" elapsed="0.000519"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:47.083395" elapsed="0.000081"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.082781" elapsed="0.000779"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.084393" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.083783" elapsed="0.000651"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.083588" elapsed="0.000930"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.082761" elapsed="0.001781"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.085477" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.084710" elapsed="0.000797"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.085559" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:47.076397" elapsed="0.009371"/>
</kw>
<msg time="2026-06-06T03:13:47.085825" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.063880" elapsed="0.021996"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.098655" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.110819" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.123375" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.123605" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.123813" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.124233" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.124080" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:47.124061" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.124466" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.124637" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.124824" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:47.124022" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.123900" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.125058" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.125138" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:13:47.125288" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:47.061251" elapsed="0.064066"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.125504" elapsed="0.002278"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:47.129192" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.128553" elapsed="0.000669"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:47.129837" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.129383" elapsed="0.000483"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:47.130027" elapsed="0.000369"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:47.128118" elapsed="0.002340"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.127864" elapsed="0.002629"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.130688" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.130518" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.127844" elapsed="0.002924"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:47.050530" elapsed="0.080286"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:47.049692" elapsed="0.081202"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.049432" elapsed="0.081556"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.049414" elapsed="0.081600"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.131049" elapsed="0.000034"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:46.918117" elapsed="0.213069"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:46.913727" elapsed="0.217525"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:46.913189" elapsed="0.218113"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:46.912830" elapsed="0.218535"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:47.131976" elapsed="0.000243"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:47.131659" elapsed="0.000625"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:46.819276" elapsed="0.313047"/>
</test>
<test id="s1-s4-t36" name="Kill_Listening_BGP_Speaker_Case_3" line="361">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:47.135532" elapsed="0.000236"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:13:47.135257" elapsed="0.000568"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.136844" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.136723" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.136704" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.141936" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.141828" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.141810" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.143031" 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-06-06T03:13:47.142633" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.143519" 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-06-06T03:13:47.143221" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:47.143588" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:47.143761" 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-06-06T03:13:47.142250" elapsed="0.001536"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:47.149107" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.148999" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.148979" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:47.150360" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.150252" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.150232" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:47.150901" 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-06-06T03:13:47.150577" elapsed="0.000350"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.151306" level="INFO">${current_connection_index} = 7</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-06-06T03:13:47.151091" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.191342" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:47.151852" elapsed="0.039626"/>
</kw>
<msg time="2026-06-06T03:13:47.191674" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:47.191725" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:47.151496" elapsed="0.040265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.216168" level="INFO">". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:47.192403" elapsed="0.023870"/>
</kw>
<msg time="2026-06-06T03:13:47.216437" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:47.216484" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a ...</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-06-06T03:13:47.192038" elapsed="0.024482"/>
</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-06-06T03:13:47.216862" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.216601" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.216579" elapsed="0.000366"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.217407" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:47.217092" elapsed="0.000387"/>
</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-06-06T03:13:47.217798" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.217551" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.217531" elapsed="0.000348"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:47.217913" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:47.220506" elapsed="0.000310"/>
</kw>
<msg time="2026-06-06T03:13:47.220883" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.219465" elapsed="0.001555"/>
</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="NOT RUN" start="2026-06-06T03:13:47.221306" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.221674" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:47.218826" elapsed="0.003040"/>
</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-06-06T03:13:47.218247" elapsed="0.003684"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:47.149906" elapsed="0.072124"/>
</kw>
<msg time="2026-06-06T03:13:47.222122" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.222207" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.149326" elapsed="0.072924"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:47.222444" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.222330" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.222311" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.222952" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.223292" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.223362" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:47.148663" elapsed="0.074807"/>
</kw>
<msg time="2026-06-06T03:13:47.223562" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.223606" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "K "i "l "l "_ "L "i "s "t "e "n "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "_ "C "a ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:47.144151" elapsed="0.079503"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.223987" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.223733" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.223715" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:47.144006" elapsed="0.080081"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:47.143838" elapsed="0.080312"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:47.141453" elapsed="0.082753"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:47.136415" elapsed="0.087847"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.135981" elapsed="0.088326"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:13:47.133104" elapsed="0.091255"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.225551" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.225236" elapsed="0.000343"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:47.225759" elapsed="0.000236"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:13:47.224969" elapsed="0.001097"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.248453" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:13:47.226594" elapsed="0.021922"/>
</kw>
<msg time="2026-06-06T03:13:47.248631" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.248729" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.226247" elapsed="0.022512"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.249389" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:13:47.261423" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:47.261559" level="INFO">${output_log} = 2026-06-06 03:13:36,712 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:13:41,219 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:13:41,220 INFO BGP-Thread-1 (job): O...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:47.249242" elapsed="0.012354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.262244" level="INFO">2026-06-06 03:13:36,712 INFO BGP-Thread-1 (job): Connecting in the listening mode.
2026-06-06 03:13:41,219 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:13:41,220 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:13:41,220 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 2
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 3
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 1
2026-06-06 03:13:41,221 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:13:41,222 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 2
2026-06-06 03:13:41,222 INFO BGP-Thread-1 (job):   Common single UPDATE will be generated for both NLRI &amp; WITHDRAWN lists
2026-06-06 03:13:41,222 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 2
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): Number of iterations: 1
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:13:41,224 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 1
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job): The 2nd test phase duration: 6.794929504394531e-05s
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job):   
2026-06-06 03:13:41,225 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:13:41,226 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:13:41,226 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:13:41,226 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:13:41,237 INFO BGP-Thread-1 (job): ... idle for 0.011s
2026-06-06 03:13:41,237 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.011s
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.261854" elapsed="0.000515"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:13:47.248959" elapsed="0.013493"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:13:47.262780" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.262590" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.262562" elapsed="0.000341"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.263126" elapsed="0.000031"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.263375" elapsed="0.000029"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:13:47.224630" elapsed="0.038857"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.264717" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:13:47.264206" elapsed="0.000580"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:13:47.263794" elapsed="0.001082"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:13:47.265770" elapsed="0.000305"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:13:47.265287" elapsed="0.000870"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:47.132546" elapsed="0.133726"/>
</test>
<test id="s1-s4-t37" name="Check_For_Empty_Topology_After_Listening_Case_3" line="370">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.271685" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.271338" elapsed="0.000434"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.271311" elapsed="0.000497"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:47.271060" elapsed="0.000817"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.273379" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.273219" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.273192" elapsed="0.000289"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.279030" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.278922" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.278904" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.280106" 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-06-06T03:13:47.279721" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.280599" 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-06-06T03:13:47.280299" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:47.280686" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:47.280842" 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-06-06T03:13:47.279326" elapsed="0.001542"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:47.286385" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.286255" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.286213" elapsed="0.000243"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:47.287626" elapsed="0.000036"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.287518" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.287499" elapsed="0.000220"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:47.288204" 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-06-06T03:13:47.287867" elapsed="0.000370"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.288633" level="INFO">${current_connection_index} = 7</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-06-06T03:13:47.288415" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.327191" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:47.289182" elapsed="0.038111"/>
</kw>
<msg time="2026-06-06T03:13:47.327457" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:47.327671" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:47.288844" elapsed="0.038926"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.357733" level="INFO">". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "L "i "s "t "e "n "i "n "g "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:47.328319" elapsed="0.029524"/>
</kw>
<msg time="2026-06-06T03:13:47.358011" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:47.358059" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</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-06-06T03:13:47.327972" elapsed="0.030123"/>
</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-06-06T03:13:47.358528" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.358209" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.358170" elapsed="0.000451"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.359106" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e "r "_ "L "i "s "t "e "n "i "n "g "_ "C "a "s "e "_ "3 "[K"
[?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-06-06T03:13:47.358802" elapsed="0.000375"/>
</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-06-06T03:13:47.359467" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.359245" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.359226" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:47.359579" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:47.362048" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:13:47.362252" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.361034" elapsed="0.001381"/>
</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="NOT RUN" start="2026-06-06T03:13:47.362715" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.363058" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:47.360398" elapsed="0.002847"/>
</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-06-06T03:13:47.359867" elapsed="0.003444"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:47.287207" elapsed="0.076206"/>
</kw>
<msg time="2026-06-06T03:13:47.363504" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.363548" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.286614" elapsed="0.076969"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:47.363794" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.363684" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.363663" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.364269" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.364608" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.364697" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:47.285882" elapsed="0.078924"/>
</kw>
<msg time="2026-06-06T03:13:47.364898" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.364942" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "T "o "p "o "l "o "g "y "_ "A "f "t "e ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:47.281272" elapsed="0.083706"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.365305" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.365052" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.365035" elapsed="0.000389"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:47.281091" elapsed="0.084358"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:47.280919" elapsed="0.084559"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:47.278542" elapsed="0.086988"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:47.272790" elapsed="0.092793"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.272107" elapsed="0.093519"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:47.267421" elapsed="0.098274"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.416814" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.416418" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.417723" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.417349" elapsed="0.000457">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.417901" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.417011" elapsed="0.000915"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.418527" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:47.418093" elapsed="0.000462"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.418876" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:47.419032" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:47.418736" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.419461" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.419216" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.420703" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.420232" elapsed="0.000534"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.421287" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.420932" elapsed="0.000381"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.421724" elapsed="0.000047"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.422450" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.422826" elapsed="0.000045"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:13:47.421519" elapsed="0.001473"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.421362" elapsed="0.001696"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:47.423106" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:47.423268" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:47.419887" elapsed="0.003406"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.419574" elapsed="0.003751"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.423505" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.423350" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.419554" elapsed="0.004028"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.424185" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.423744" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.424298" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:47.415796" elapsed="0.008626"/>
</kw>
<msg time="2026-06-06T03:13:47.424476" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.403463" elapsed="0.021061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.436965" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.449091" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.461300" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.461500" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.461694" elapsed="0.000200"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.462249" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.462100" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:47.462085" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.462497" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.462696" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.462866" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:47.462057" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.461954" elapsed="0.000991"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.463094" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.463169" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:13:47.463287" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:47.399246" elapsed="0.064067"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.464607" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.464371" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.464785" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.464023" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.465128" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.464880" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.465695" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.465381" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.465210" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.464861" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.468110" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:47.465935" elapsed="0.002202"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:13:47.468188" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:47.468341" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:47.463692" elapsed="0.004680"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.469595" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.469362" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.469767" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.469022" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:13:47.469997" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.469862" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.469843" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.470229" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.470400" elapsed="0.000034"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.470481" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:47.472504" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:13:47.468692" elapsed="0.003839"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.473951" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.473697" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.474398" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.474155" elapsed="0.000320"/>
</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-06-06T03:13:47.485233" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:47.485418" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:13:47.485572" 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-06-06T03:13:47.476586" elapsed="0.009026"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.474544" elapsed="0.011167"/>
</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-06-06T03:13:47.485985" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.485752" elapsed="0.000377"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.474526" elapsed="0.011637"/>
</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-06-06T03:13:47.491303" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.487725" elapsed="0.003647"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.487371" elapsed="0.004051"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.487343" elapsed="0.004116"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.495297" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.491901" elapsed="0.003474"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.491541" elapsed="0.003893"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.491516" elapsed="0.003961"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.496311" 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-06-06T03:13:47.495746" elapsed="0.000605"/>
</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-06-06T03:13:47.496834" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.496456" elapsed="0.000466"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.497675" 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-06-06T03:13:47.497205" elapsed="0.000511"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.496958" elapsed="0.000813"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.496428" elapsed="0.001375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.498625" 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-06-06T03:13:47.498046" elapsed="0.000639"/>
</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-06-06T03:13:47.499145" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.498792" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.499774" 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-06-06T03:13:47.499459" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.499266" elapsed="0.000570"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.498765" elapsed="0.001093"/>
</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-06-06T03:13:47.500011" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:47.500828" 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-06-06T03:13:47.500521" 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-06-06T03:13:47.501014" elapsed="0.002284"/>
</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-06-06T03:13:47.486740" elapsed="0.016621"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.503539" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.503433" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.503413" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:47.506380" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:13:47.503772" elapsed="0.002637"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:13:47.506487" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:13:47.506661" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:13:47.472859" elapsed="0.033830"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.506757" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:13:47.506909" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:13:47.377221" elapsed="0.129748"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.535444" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.534715" elapsed="0.000757"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.537454" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.536938" elapsed="0.000674">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.537761" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.535656" elapsed="0.002130"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.538759" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:47.537954" elapsed="0.000834"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.539189" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:47.539418" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:47.538954" elapsed="0.000492"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.540048" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.539606" elapsed="0.000504"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:13:47.540794" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.540178" elapsed="0.000774"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.541780" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.541159" elapsed="0.000662"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.540979" elapsed="0.000922"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.540159" elapsed="0.001766"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.542875" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.542076" elapsed="0.000829"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.542955" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:47.533975" elapsed="0.009106"/>
</kw>
<msg time="2026-06-06T03:13:47.543135" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.521460" elapsed="0.021724"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.555547" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.567960" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.580100" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.580301" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.580485" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.580877" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.580729" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:47.580713" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.581100" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.581270" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.581442" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:47.580682" elapsed="0.000812"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.580563" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.581681" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.581759" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:13:47.581879" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:47.518843" elapsed="0.063064"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.582086" elapsed="0.002342"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:47.585521" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.585195" elapsed="0.000354"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:13:47.586033" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.585730" elapsed="0.000331"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:13:47.586217" elapsed="0.000357"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:13:47.584774" elapsed="0.001862"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.584510" elapsed="0.002178"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.586869" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.586715" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.584490" elapsed="0.002456"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:13:47.508133" elapsed="0.078896"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:13:47.507302" elapsed="0.079806"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.507056" elapsed="0.080099"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.507038" elapsed="0.080141"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.587215" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:13:47.370937" elapsed="0.216408"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.366734" elapsed="0.220674"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:13:47.366168" elapsed="0.221287"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.365828" elapsed="0.221686"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:47.588115" elapsed="0.000244"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:47.587806" elapsed="0.000616"/>
</kw>
<doc>Post-condition: Check example-ipv4-topology is empty again.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:13:47.266588" elapsed="0.321873"/>
</test>
<test id="s1-s4-t38" name="Delete_Bgp_Peer_Configuration" line="375">
<kw name="Setup_Test_With_Logging_And_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.591825" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.591584" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.591566" elapsed="0.000341"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:13:47.591400" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.592947" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.592840" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.592822" elapsed="0.000194"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.597845" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.597738" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.597720" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.598988" 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-06-06T03:13:47.598574" elapsed="0.000442"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.599508" 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-06-06T03:13:47.599181" elapsed="0.000355"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:47.599583" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:47.599757" 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-06-06T03:13:47.598155" elapsed="0.001627"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:47.605368" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.605255" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.605235" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:47.606603" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.606473" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.606455" elapsed="0.000245"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:47.607148" 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-06-06T03:13:47.606849" elapsed="0.000326"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.607589" level="INFO">${current_connection_index} = 7</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-06-06T03:13:47.607338" elapsed="0.000277"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.645195" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:47.608192" elapsed="0.037105"/>
</kw>
<msg time="2026-06-06T03:13:47.645465" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:47.645512" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:13:47.607842" elapsed="0.037706"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.669582" level="INFO">". "t "x "t ". "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:13:47.646102" elapsed="0.023608"/>
</kw>
<msg time="2026-06-06T03:13:47.669884" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:47.669930" level="INFO">${message_wait} =  ". "t "x "t ". "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n ...</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-06-06T03:13:47.645750" elapsed="0.024215"/>
</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-06-06T03:13:47.670325" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.670058" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.670031" elapsed="0.000380"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.670925" level="INFO"> ". "t "x "t ". "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:13:47.670560" elapsed="0.000428"/>
</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-06-06T03:13:47.671278" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.671057" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.671038" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:47.671391" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:13:47.673925" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:13:47.674132" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.672895" elapsed="0.001370"/>
</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="NOT RUN" start="2026-06-06T03:13:47.674544" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.674929" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:47.672253" elapsed="0.002860"/>
</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-06-06T03:13:47.671703" elapsed="0.003475"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:47.606173" elapsed="0.069103"/>
</kw>
<msg time="2026-06-06T03:13:47.675373" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.675418" level="INFO">${message} =  ". "t "x "t ". "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.605589" elapsed="0.069866"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:47.675638" elapsed="0.000051"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.675530" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.675511" elapsed="0.000238"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.676155" elapsed="0.000024"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.676496" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.676568" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:47.604916" elapsed="0.071779"/>
</kw>
<msg time="2026-06-06T03:13:47.676789" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.676877" level="INFO">${output} =  ". "t "x "t ". "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:47.600146" elapsed="0.076769"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.677247" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.676992" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.676974" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:47.600001" elapsed="0.077347"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:47.599834" elapsed="0.077545"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:47.597364" elapsed="0.080069"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:47.592537" elapsed="0.084951"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:47.592105" elapsed="0.085428"/>
</kw>
<doc>Test case setup which skips on previous failure. If not, logs test case name to Karaf log.
Recommended to be used as the default test case setup.</doc>
<status status="PASS" start="2026-06-06T03:13:47.589238" elapsed="0.088347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.678337" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.677775" elapsed="0.000594"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.720182" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:13:47.719807" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.720960" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:13:47.720725" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:13:47.721127" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:13:47.720376" elapsed="0.000776"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.721723" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:13:47.721320" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:13:47.722051" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:13:47.722211" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:13:47.721915" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.722664" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.722403" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.723712" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.723434" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.724185" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.723921" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.724889" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.724572" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:47.725665" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.725430" elapsed="0.000262"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:47.725776" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:13:47.725933" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:47.725104" elapsed="0.000854"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.726117" elapsed="0.000239"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:13:47.724435" elapsed="0.001961"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.726970" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.726657" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:47.727882" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.727502" elapsed="0.000406"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:47.727959" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:47.728111" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:47.727184" elapsed="0.000952"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.728292" elapsed="0.000228"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:13:47.726509" elapsed="0.002052"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.729124" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.728825" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:47.729881" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.729669" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:47.729956" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:47.730105" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:47.729338" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.730281" elapsed="0.000222"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:13:47.728688" elapsed="0.001855"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.731132" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:13:47.730835" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:13:47.731893" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.731682" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:13:47.731969" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:47.732117" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:13:47.731343" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:13:47.732293" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:13:47.730673" elapsed="0.001882"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:13:47.724260" elapsed="0.008329"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:13:47.732630" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:13:47.732803" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:13:47.723107" elapsed="0.009722"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.722807" elapsed="0.010055"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.733037" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.732886" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.722788" elapsed="0.010325"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.733884" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:13:47.733258" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.733963" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:13:47.719169" elapsed="0.014918"/>
</kw>
<msg time="2026-06-06T03:13:47.734177" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.706788" elapsed="0.027437"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.746343" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.758939" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.772674" elapsed="0.000062"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.773147" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.773447" elapsed="0.000033"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.774122" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.773892" elapsed="0.000311"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:13:47.773864" elapsed="0.000377"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.774455" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.774792" elapsed="0.000034"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.775052" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:13:47.773808" elapsed="0.001324"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.773578" elapsed="0.001594"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.775403" elapsed="0.000030"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.775515" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:13:47.775767" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:13:47.702543" elapsed="0.073264"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.777503" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.777098" elapsed="0.000473"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:13:47.794380" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node047o5f525m0d7h5uchurapln44.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:47.794597" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:13:47.794916" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:13:47.781058" elapsed="0.013908"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.777680" elapsed="0.017374"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.795413" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.795111" elapsed="0.000379"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.777636" elapsed="0.017879"/>
</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-06-06T03:13:47.799450" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.796917" elapsed="0.002637"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.796614" elapsed="0.003002"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.796582" elapsed="0.003096"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.804466" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.800125" elapsed="0.004423"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.799771" elapsed="0.004837"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.799743" elapsed="0.004925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.805555" 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-06-06T03:13:47.804968" elapsed="0.000625"/>
</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-06-06T03:13:47.806090" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.805724" elapsed="0.000454"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.806981" 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-06-06T03:13:47.806474" elapsed="0.000548"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.806216" elapsed="0.000864"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.805693" elapsed="0.001422"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.807869" 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-06-06T03:13:47.807362" elapsed="0.000544"/>
</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-06-06T03:13:47.808337" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.808007" elapsed="0.000410"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.809109" 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-06-06T03:13:47.808704" elapsed="0.000441"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:47.808453" elapsed="0.000744"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.807977" elapsed="0.001252"/>
</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-06-06T03:13:47.809473" elapsed="0.000513"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:13:47.810617" 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-06-06T03:13:47.810219" elapsed="0.000451"/>
</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-06-06T03:13:47.810959" elapsed="0.003328"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:13:47.796004" elapsed="0.018382"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:13:47.814462" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:13:47.817759" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:13:47.776221" elapsed="0.041575"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:13:47.817875" elapsed="0.000040"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:13:47.678603" elapsed="0.139453"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:13:47.818988" elapsed="0.000339"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:13:47.818471" elapsed="0.000946"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:13:47.588694" elapsed="0.230859"/>
</test>
<kw name="Teardown_Everything" type="TEARDOWN">
<kw name="Search_And_Kill_Remote_Python" owner="KillPythonTool">
<kw name="Search_For_Remote_Python_Processes" owner="KillPythonTool">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.821712" level="INFO">Executing command 'ps -elf | egrep python | egrep 'play.py' | egrep -v grep'.</msg>
<msg time="2026-06-06T03:13:47.845354" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:13:47.845601" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>ps -elf | egrep python | egrep ${filter} | egrep -v grep</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:47.821477" elapsed="0.024198"/>
</kw>
<return>
<value>${processes}</value>
<status status="PASS" start="2026-06-06T03:13:47.845789" elapsed="0.000072"/>
</return>
<msg time="2026-06-06T03:13:47.846092" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>${filter}</arg>
<doc>Only searches for the list of processes, in case something else than kill has to be done with them.</doc>
<status status="PASS" start="2026-06-06T03:13:47.821090" elapsed="0.025045"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.846987" level="INFO"/>
<arg>${processes}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.846450" elapsed="0.000606"/>
</kw>
<kw name="Kill_Remote_Processes" owner="KillPythonTool">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.848429" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:13:47.848551" level="INFO">${arg_length} = 0</msg>
<var>${arg_length}</var>
<arg>${pself_lines}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:47.848002" elapsed="0.000588"/>
</kw>
<if>
<branch type="IF" condition="${arg_length} == 0">
<return>
<status status="PASS" start="2026-06-06T03:13:47.848994" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:13:47.848731" elapsed="0.000355"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.848699" elapsed="0.000431"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${commands}</var>
<arg>echo '${pself_lines}' | awk '{print "kill -${signal}",$4}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.849382" elapsed="0.000038"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${commands}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.849700" elapsed="0.000036"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${stdout}</var>
<var>${stderr}</var>
<arg>echo 'set -exu; ${commands}' | sudo sh</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:47.849989" elapsed="0.000037"/>
</kw>
<arg>${processes}</arg>
<doc>Kill processes by PIDs from given list (no-op if the list is empty), using specified signal. Log the kill commands used.</doc>
<status status="PASS" start="2026-06-06T03:13:47.847489" elapsed="0.002644"/>
</kw>
<arg>'play\.py'</arg>
<doc>The main keyword. Search for processes, Log the list of them, kill them.</doc>
<status status="PASS" start="2026-06-06T03:13:47.820700" elapsed="0.029522"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:13:47.850580" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:13:47.850456" elapsed="0.000744"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:13:47.851449" elapsed="0.000645"/>
</kw>
<doc>Make sure Python tool was killed, delete all sessions, tear down imported Resources.</doc>
<status status="PASS" start="2026-06-06T03:13:47.820285" elapsed="0.031898"/>
</kw>
<doc>Basic tests for odl-bgpcep-bgp-all feature.

Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

Test suite performs basic BGP functional test cases:
BGP peer initiated connection
- introduce and check 3 prefixes in one update message
ODL controller initiated connection:
- introduce and check 3 prefixes in one update message
- introduce 2 prefixes in first update message and then additional 2 prefixes
in another update while the very first prefix is withdrawn
- introduce 3 prefixes and try to withdraw the first one
(to be ignored by controller) in a single update message

TC_R (test case reset) tests session-reset functionality.
Resets the session, and than verifies that example-ipv4-topology is empty again.

TC_LA (test case local address) tests configuration of internal peer
with local-address configured
- configure peer with local-address and connect bgp-speaker to it
with tools_system_ip
- check filled topology

TC_PG (test case peer group) tests configuration and reconfiguration
of peer-groups and neighbors configured by them.
- configure peer-group, and assign neighbor to this peer-group
- check filled topology
- reconfigure peer-group without ipv4 unicast afi-safi
- check empty topology
- reconfigre neighbor without peer-group, delete peer-group

Brief description how to perform BGP functional test:
https://wiki.opendaylight.org/view/BGP_LS_PCEP:Lithium_Feature_Tests#How_to_test_2</doc>
<status status="PASS" start="2026-06-06T03:12:29.800631" elapsed="78.051604"/>
</suite>
<suite id="s1-s5" name="Bgp Ipv6 Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/bgp_ipv6_basic.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.953447" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:13:47.949012" elapsed="0.004489"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:13:47.948778" elapsed="0.004793"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.958516" 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-06-06T03:13:47.954694" elapsed="0.003851"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:13:47.958772" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.958632" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.958608" elapsed="0.000234"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.959395" 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-06-06T03:13:47.959014" elapsed="0.000425"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.959935" 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-06-06T03:13:47.959604" elapsed="0.000440"/>
</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-06-06T03:13:47.960568" elapsed="0.000311"/>
</kw>
<msg time="2026-06-06T03:13:47.960979" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:47.961026" 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-06-06T03:13:47.960219" elapsed="0.000831"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.961599" 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-06-06T03:13:47.961220" elapsed="0.000405"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.962624" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:13:47.962351" elapsed="0.000315"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.963117" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:13:47.962819" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.963595" 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-06-06T03:13:47.963304" elapsed="0.000318"/>
</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-06-06T03:13:47.966917" elapsed="0.000233"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.967654" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:13:47.967312" elapsed="0.000371"/>
</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-06-06T03:13:47.967839" elapsed="0.000231"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.968883" 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-06-06T03:13:47.968565" elapsed="0.000346"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:13:47.968957" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:13:47.969116" 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-06-06T03:13:47.968264" elapsed="0.000878"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:13:47.969751" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59d25d0&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-06-06T03:13:47.969300" elapsed="0.000599"/>
</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-06-06T03:13:47.970063" elapsed="0.000190"/>
</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-06-06T03:13:47.966331" elapsed="0.003981"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:47.966143" elapsed="0.004214"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:13:47.963694" elapsed="0.006694"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.970998" 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-06-06T03:13:47.970549" elapsed="0.000494"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.971607" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:13:47.971209" elapsed="0.000455"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.972213" 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-06-06T03:13:47.971828" elapsed="0.000427"/>
</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-06-06T03:13:47.961894" elapsed="0.010418"/>
</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-06-06T03:13:47.954329" elapsed="0.018040"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:47.972548" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:47.972434" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.972415" elapsed="0.000200"/>
</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-06-06T03:13:47.975870" 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-06-06T03:13:47.975467" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.976360" 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-06-06T03:13:47.976061" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:47.976432" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:13:47.976589" 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-06-06T03:13:47.975090" elapsed="0.001524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:47.977616" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:13:47.977343" elapsed="0.000315"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.978400" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:13:47.978502" 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-06-06T03:13:47.978237" elapsed="0.000292"/>
</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-06-06T03:13:47.982258" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:47.981683" elapsed="0.000660"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:47.981660" elapsed="0.000721"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.983059" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:13:47.982585" elapsed="0.000757"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.984289" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:47.983612" elapsed="0.000787"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.985567" 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-06-06T03:13:47.984688" elapsed="0.000930"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:13:47.987349" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:13:47.987529" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:47.986965" elapsed="0.000606"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.987930" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:13:47.989525" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:13:48.659330" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:13:48 UTC 2026

  System load:  0.0                Processes:             120
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:12:30 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:13:47.989201" elapsed="0.670315"/>
</kw>
<msg time="2026-06-06T03:13:48.659607" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.988753" elapsed="0.671083"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:13:47.986072" elapsed="0.673919"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:48.661002" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:13:48.674277" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:13:48.674697" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:13:48.674940" 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-06-06T03:13:48.660475" elapsed="0.014578"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:13:48.675870" elapsed="0.001153"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:48.679736" 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-06-06T03:13:48.678386" elapsed="0.001604"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:13:48.680954" elapsed="0.000115"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:48.680355" elapsed="0.000883"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.680300" elapsed="0.001024"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:13:48.682048" elapsed="0.000139"/>
</return>
<status status="PASS" start="2026-06-06T03:13:48.681510" elapsed="0.000857"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.681470" elapsed="0.000989"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:13:48.682592" elapsed="0.000036"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:48.687183" elapsed="0.000557"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:13:48.688027" elapsed="0.000289"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:13:48.688577" elapsed="0.000242"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:48.683881" elapsed="0.005010"/>
</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-06-06T03:13:47.980732" elapsed="0.708336"/>
</kw>
<msg time="2026-06-06T03:13:48.689125" 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-06-06T03:13:47.979894" elapsed="0.709286"/>
</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-06-06T03:13:47.979393" elapsed="0.709868"/>
</kw>
<msg time="2026-06-06T03:13:48.689304" 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-06-06T03:13:47.978857" elapsed="0.710493"/>
</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-06-06T03:13:48.692151" 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-06-06T03:13:48.692664" elapsed="0.000181"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:13:48.693027" elapsed="0.000105"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:48.689657" elapsed="0.003528"/>
</kw>
<msg time="2026-06-06T03:13:48.693282" 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-06-06T03:13:47.977879" elapsed="0.715428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:48.693765" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:48.693493" elapsed="0.000314"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:13:48.693851" elapsed="0.000031"/>
</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-06-06T03:13:47.976987" elapsed="0.716993"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:47.976811" elapsed="0.717209"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:47.976683" elapsed="0.717397"/>
</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-06-06T03:13:47.972851" elapsed="0.721309"/>
</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-06-06T03:13:48.694329" elapsed="0.000221"/>
</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-06-06T03:13:48.709026" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:48.708912" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.708892" elapsed="0.000203"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:48.709391" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:13:48.709496" 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-06-06T03:13:48.709253" elapsed="0.000270"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:48.709994" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:48.709695" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:48.710440" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:48.710195" elapsed="0.000289"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:48.711253" 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-06-06T03:13:48.711026" elapsed="0.000339">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:13:48.711478" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:13:48.711523" 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-06-06T03:13:48.710660" elapsed="0.000886"/>
</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-06-06T03:13:48.711922" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:48.711623" elapsed="0.000376"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.711604" elapsed="0.000420"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:48.712779" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:13:48.712493" elapsed="0.000313"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:13:48.712855" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:13:48.713006" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:13:48.712223" elapsed="0.000807"/>
</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-06-06T03:13:48.713189" elapsed="0.000414"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:48.713905" level="INFO">index=4
host=10.30.170.38
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-06-06T03:13:48.714006" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:13:48.713797" elapsed="0.000236"/>
</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-06-06T03:13:48.714183" elapsed="0.002506"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:13:48.717147" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:13:48.870971" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:13:48.716876" elapsed="0.154265"/>
</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-06-06T03:13:48.874752" elapsed="0.000378"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:13:48.875303" elapsed="0.000176"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:13:48.875636" elapsed="0.000197"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:48.872328" elapsed="0.003602"/>
</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-06-06T03:13:48.871576" elapsed="0.004415"/>
</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-06-06T03:13:48.708613" elapsed="0.167434"/>
</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-06-06T03:13:48.695357" elapsed="0.180740"/>
</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-06-06T03:13:48.694973" elapsed="0.181216"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:48.694829" elapsed="0.181409"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:13:48.694670" elapsed="0.181608"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:13:47.953881" elapsed="0.922475"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:48.879236" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:48.879111" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.879087" elapsed="0.000225"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:13:48.884292" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:48.884180" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.884161" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:48.885343" 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-06-06T03:13:48.884949" elapsed="0.000422"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:13:48.885853" 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-06-06T03:13:48.885535" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:13:48.885924" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:13:48.886106" 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-06-06T03:13:48.884594" elapsed="0.001538"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:13:48.892046" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:48.891923" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.891869" elapsed="0.000247"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:13:48.893329" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:48.893201" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:48.893183" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:13:48.893895" 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-06-06T03:13:48.893546" elapsed="0.000376"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:48.894309" 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-06-06T03:13:48.894084" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:13:48.933509" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:13:48.895019" elapsed="0.038782"/>
</kw>
<msg time="2026-06-06T03:13:48.933995" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:13:48.934045" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:13:48.894496" elapsed="0.039588"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.006472" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "i "p "[78Cv "[A[78C6
 "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:13:48.934964" elapsed="0.071752"/>
</kw>
<msg time="2026-06-06T03:13:49.006983" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:13:49.007032" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:13:48.934338" elapsed="0.072731"/>
</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-06-06T03:13:49.007512" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:49.007180" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:49.007147" elapsed="0.000604"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:49.008367" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "i "p "[78Cv "[A[78C6
 "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:13:49.007919" elapsed="0.000530"/>
</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-06-06T03:13:49.008778" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:49.008519" elapsed="0.000411"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:49.008500" elapsed="0.000457"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:13:49.008998" elapsed="0.000042"/>
</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-06-06T03:13:49.011097" elapsed="0.000462"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:13:49.011932" elapsed="0.000341"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:13:49.012617" elapsed="0.000260"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:13:49.010279" elapsed="0.002690"/>
</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-06-06T03:13:49.009327" elapsed="0.003781"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:13:48.892911" elapsed="0.120302"/>
</kw>
<msg time="2026-06-06T03:13:49.013309" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:49.013356" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:48.892271" elapsed="0.121121"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:13:49.013587" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:13:49.013478" elapsed="0.000424"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:49.013458" elapsed="0.000474"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:49.014348" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:49.014718" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:13:49.014792" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:13:48.891578" elapsed="0.123326"/>
</kw>
<msg time="2026-06-06T03:13:49.015003" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:13:49.015049" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:13:48.886589" elapsed="0.128499"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:13:49.015427" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:13:49.015168" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:49.015150" elapsed="0.000358"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:13:48.886442" elapsed="0.129091"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:13:48.886213" elapsed="0.129354"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:13:48.883832" elapsed="0.131792"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:13:48.877018" elapsed="0.138681"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:13:48.876525" elapsed="0.139259"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:13:47.948434" elapsed="1.067404"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.016374" level="INFO">${conn_id} = 7</msg>
<var>${conn_id}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=10s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:13:49.015995" elapsed="0.000406"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:13:49.016936" level="INFO">${conn_id} = 7</msg>
<arg>${conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:13:49.016572" elapsed="0.000409"/>
</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-06-06T03:13:49.018818" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:13:49.018899" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:13:49.018406" elapsed="0.000517"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:49.019085" elapsed="0.000543"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.020548" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:13:49.361129" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:13:48 UTC 2026

  System load:  0.0                Processes:             120
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  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 Jun  6 03:13:48 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:13:49.020227" elapsed="0.341120"/>
</kw>
<msg time="2026-06-06T03:13:49.361458" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:49.019823" elapsed="0.341741"/>
</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-06-06T03:13:49.017966" elapsed="0.343772"/>
</kw>
<msg time="2026-06-06T03:13:49.361800" 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-06-06T03:13:49.017523" elapsed="0.344344"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:13:49.017181" elapsed="0.344778"/>
</kw>
<kw name="Configure_Ipv6_Network">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.362757" level="INFO">Executing command 'ip route | grep '^default' | awk '{print $5}''.</msg>
<msg time="2026-06-06T03:13:49.375532" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:49.375746" level="INFO">${main_net_interface} = ens3</msg>
<var>${main_net_interface}</var>
<arg>ip route | grep '^default' | awk '{print $5}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:49.362576" elapsed="0.013210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:49.376684" level="INFO">Using network interface: ens3</msg>
<arg>Using network interface: ${main_net_interface}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:49.376103" elapsed="0.000651"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.377278" level="INFO">Executing command 'sudo ip -6 addr add 2607:f0d0:1002:0011:0000:0000:0000:0002/64 dev ens3'.</msg>
<msg time="2026-06-06T03:13:49.440720" level="INFO">Command exited with return code 0.</msg>
<arg>sudo ip -6 addr add ${IPV6_IP}/${IPV6_PREFIX_LENGTH} dev ${main_net_interface}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:49.376993" elapsed="0.063846"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.441358" level="INFO">Executing command 'sudo ip -6 route add default via 2607:f0d0:1002:0011:0000:0000:0000:0001'.</msg>
<msg time="2026-06-06T03:13:49.505175" level="INFO">Command exited with return code 0.</msg>
<arg>sudo ip -6 route add default via ${IPV6_IP_GW}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:49.441121" elapsed="0.064266"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.506193" level="INFO">Executing command 'sudo ip -6 addr show'.</msg>
<msg time="2026-06-06T03:13:49.568501" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:49.568928" level="INFO">${stdout} = 1: lo: &lt;LOOPBACK,UP,LOWER_UP&gt; mtu 65536 state UNKNOWN qlen 1000
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens3: &lt;BROADCAST,MULTICAST,UP,LOWER_UP&gt; mtu 1458 state U...</msg>
<var>${stdout}</var>
<arg>sudo ip -6 addr show</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:49.505914" elapsed="0.063086"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:49.570438" level="INFO">1: lo: &lt;LOOPBACK,UP,LOWER_UP&gt; mtu 65536 state UNKNOWN qlen 1000
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: ens3: &lt;BROADCAST,MULTICAST,UP,LOWER_UP&gt; mtu 1458 state UP qlen 1000
    inet6 2607:f0d0:1002:11::2/64 scope global tentative 
       valid_lft forever preferred_lft forever
    inet6 fe80::f816:3eff:fe38:4578/64 scope link 
       valid_lft forever preferred_lft forever</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:49.569597" elapsed="0.001176"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:13:49.571496" level="INFO">Executing command 'sudo ip -6 route show'.</msg>
<msg time="2026-06-06T03:13:49.628916" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:49.629287" level="INFO">${stdout} = ::1 dev lo proto kernel metric 256 pref medium
2607:f0d0:1002:11::/64 dev ens3 proto kernel metric 256 pref medium
fe80::/64 dev ens3 proto kernel metric 256 pref medium
default via 2607:f0d0:1002:11:...</msg>
<var>${stdout}</var>
<arg>sudo ip -6 route show</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:13:49.571233" elapsed="0.058134"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:49.630818" level="INFO">::1 dev lo proto kernel metric 256 pref medium
2607:f0d0:1002:11::/64 dev ens3 proto kernel metric 256 pref medium
fe80::/64 dev ens3 proto kernel metric 256 pref medium
default via 2607:f0d0:1002:11::1 dev ens3 metric 1024 pref medium</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:49.629999" elapsed="0.000930"/>
</kw>
<doc>Reconfigures basic network settings on controller</doc>
<status status="PASS" start="2026-06-06T03:13:49.362211" elapsed="0.268854"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:13:49.643630" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:13:49.643265" elapsed="0.000412"/>
</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-06-06T03:13:49.645288" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:13:50.205806" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:13:50.206192" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 328ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:13:50.206304" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:13:50.206399" 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-06-06T03:13:49.645068" elapsed="0.561387"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:13:50.208676" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:13:50.208001" elapsed="0.000787"/>
</kw>
<msg time="2026-06-06T03:13:50.209010" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:13:50.209109" 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-06-06T03:13:50.207075" elapsed="0.002155"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:13:50.210249" 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-06-06T03:13:50.209600" elapsed="0.000687"/>
</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-06-06T03:13:50.211955" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 328ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:50.211562" elapsed="0.000500"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:50.212670" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:50.212293" elapsed="0.000440"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:13:50.213332" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:13:50.212952" elapsed="0.000445"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:13:50.211017" elapsed="0.002472"/>
</kw>
<status status="PASS" start="2026-06-06T03:13:50.210415" elapsed="0.003140"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:50.210379" elapsed="0.003223"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:13:50.213862" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:13:50.213707" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:50.213680" elapsed="0.000282"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:13:50.214165" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-06-06T03:13:50.214036" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:13:50.214014" elapsed="0.000281"/>
</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-06-06T03:13:50.214521" elapsed="0.000051"/>
</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-06-06T03:13:49.644455" elapsed="0.570300"/>
</kw>
<msg time="2026-06-06T03:13:50.214841" 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-06-06T03:13:49.643853" elapsed="0.571062"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:13:49.642549" elapsed="0.572607"/>
</kw>
<msg time="2026-06-06T03:13:50.215239" 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-06-06T03:13:49.633248" elapsed="0.582057"/>
</kw>
<arg>virtualenv ${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-06-06T03:13:49.632236" elapsed="0.583222"/>
</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-06-06T03:13:50.223458" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/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-06-06T03:13:50.223116" elapsed="0.000371"/>
</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-06-06T03:13:50.225476" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-06-06T03:14:07.937695" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:14:07.938282" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Downloading pip-26.1.2-py3-none-any.whl (1.8 MB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━...</msg>
<msg time="2026-06-06T03:14:07.938479" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:14:07.938706" 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-06-06T03:13:50.225001" elapsed="17.713805"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:14:07.944403" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:14:07.943266" elapsed="0.001436"/>
</kw>
<msg time="2026-06-06T03:14:07.945065" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:14:07.945239" 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-06-06T03:14:07.939630" elapsed="0.005699"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:14:07.948439" 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-06-06T03:14:07.945988" elapsed="0.002494"/>
</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-06-06T03:14:07.950937" level="INFO">Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Downloading pip-26.1.2-py3-none-any.whl (1.8 MB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 1.8/1.8 MB 30.1 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.1.2</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:14:07.950536" elapsed="0.000506"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:14:07.951822" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:14:07.951409" elapsed="0.000542"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:14:07.952767" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:14:07.952343" elapsed="0.000532"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:14:07.949614" elapsed="0.003358"/>
</kw>
<status status="PASS" start="2026-06-06T03:14:07.948682" elapsed="0.004392"/>
</branch>
<status status="PASS" start="2026-06-06T03:14:07.948653" elapsed="0.004450"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:14:07.953347" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:14:07.953162" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:14:07.953144" elapsed="0.000344"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:14:07.953757" elapsed="0.000045"/>
</return>
<status status="PASS" start="2026-06-06T03:14:07.953543" elapsed="0.000362"/>
</branch>
<status status="PASS" start="2026-06-06T03:14:07.953527" elapsed="0.000407"/>
</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-06-06T03:14:07.954085" 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-06-06T03:13:50.224319" elapsed="17.729951"/>
</kw>
<msg time="2026-06-06T03:14:07.954329" 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-06-06T03:13:50.223667" elapsed="17.730792"/>
</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/defaultvenv/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-06-06T03:13:50.222483" elapsed="17.732064"/>
</kw>
<msg time="2026-06-06T03:14:07.954602" 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-06-06T03:13:50.218217" elapsed="17.736448"/>
</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-06-06T03:13:50.217637" elapsed="17.737110"/>
</kw>
<msg time="2026-06-06T03:14:07.954796" 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-06-06T03:13:50.216963" elapsed="17.737878"/>
</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-06-06T03:13:50.216449" elapsed="17.738467"/>
</kw>
<msg time="2026-06-06T03:14:07.954958" 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-06-06T03:13:50.215713" elapsed="17.739288"/>
</kw>
<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-06-06T03:13:49.631570" elapsed="18.323505"/>
</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-06-06T03:14:07.962740" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:14:07.962393" elapsed="0.000376"/>
</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-06-06T03:14:07.964594" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; deactivate'.</msg>
<msg time="2026-06-06T03:14:45.907417" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:14:45.908001" level="INFO">${stdout} = Collecting setuptools==44.0.0
  Downloading setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Downloading setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━...</msg>
<msg time="2026-06-06T03:14:45.908179" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:14:45.908290" 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-06-06T03:14:07.964241" elapsed="37.944109"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:14:45.913909" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:14:45.912495" elapsed="0.001693"/>
</kw>
<msg time="2026-06-06T03:14:45.914555" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:14:45.914701" 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-06-06T03:14:45.909142" elapsed="0.005620"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:14:45.917198" 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-06-06T03:14:45.915314" elapsed="0.001912"/>
</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-06-06T03:14:45.919527" level="INFO">Collecting setuptools==44.0.0
  Downloading setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Downloading setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 583.2/583.2 kB 22.0 MB/s  0:00:00
Installing collected packages: setuptools
  Attempting uninstall: setuptools
    Found existing installation: setuptools 59.6.0
    Uninstalling setuptools-59.6.0:
      Successfully uninstalled setuptools-59.6.0
Successfully installed setuptools-44.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:14:45.919178" elapsed="0.000431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:14:45.920358" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:14:45.919984" elapsed="0.000444"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:14:45.921235" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:14:45.920833" elapsed="0.000475"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:14:45.918222" elapsed="0.003297"/>
</kw>
<status status="PASS" start="2026-06-06T03:14:45.917379" elapsed="0.004243"/>
</branch>
<status status="PASS" start="2026-06-06T03:14:45.917350" elapsed="0.004319"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:14:45.921897" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:14:45.921735" elapsed="0.000262"/>
</branch>
<status status="PASS" start="2026-06-06T03:14:45.921715" elapsed="0.000308"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:14:45.922215" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:14:45.922080" elapsed="0.000258"/>
</branch>
<status status="PASS" start="2026-06-06T03:14:45.922063" elapsed="0.000304"/>
</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-06-06T03:14:45.922522" elapsed="0.000025"/>
</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-06-06T03:14:07.963548" elapsed="37.959138"/>
</kw>
<msg time="2026-06-06T03:14:45.922750" 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-06-06T03:14:07.962932" elapsed="37.959881"/>
</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/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:14:07.961783" elapsed="37.961135"/>
</kw>
<msg time="2026-06-06T03:14:45.922977" 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-06-06T03:14:07.957462" elapsed="37.965562"/>
</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-06-06T03:14:07.956912" elapsed="37.966207"/>
</kw>
<msg time="2026-06-06T03:14:45.923172" 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-06-06T03:14:07.956479" elapsed="37.966739"/>
</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-06-06T03:14:07.956067" elapsed="37.967242"/>
</kw>
<msg time="2026-06-06T03:14:45.923357" 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-06-06T03:14:07.955541" elapsed="37.967860"/>
</kw>
<arg>setuptools==44.0.0</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-06-06T03:14:07.955278" elapsed="37.968209"/>
</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-06-06T03:14:45.931698" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==4.2.4; 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-06-06T03:14:45.931265" elapsed="0.000466"/>
</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-06-06T03:14:45.933834" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==4.2.4; deactivate'.</msg>
<msg time="2026-06-06T03:15:38.009987" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:38.010766" level="INFO">${stdout} = Collecting exabgp==4.2.4
  Downloading exabgp-4.2.4.tar.gz (394 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to buil...</msg>
<msg time="2026-06-06T03:15:38.010887" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:15:38.010982" 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-06-06T03:14:45.933413" elapsed="52.077623"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.016239" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:15:38.014891" elapsed="0.001664"/>
</kw>
<msg time="2026-06-06T03:15:38.016944" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:15:38.017031" 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-06-06T03:15:38.011876" elapsed="0.005188"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.018798" 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-06-06T03:15:38.017492" elapsed="0.001346"/>
</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-06-06T03:15:38.022185" level="INFO">Collecting exabgp==4.2.4
  Downloading exabgp-4.2.4.tar.gz (394 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: setuptools in /tmp/defaultvenv/lib/python3.10/site-packages (from exabgp==4.2.4) (44.0.0)
Building wheels for collected packages: exabgp
  Building wheel for exabgp (pyproject.toml): started
  Building wheel for exabgp (pyproject.toml): finished with status 'done'
  Created wheel for exabgp: filename=exabgp-4.2.4-py3-none-any.whl size=567682 sha256=02a222c27542ef11d568059b6487c2641396222a1a0bebc6ef06afed9510761e
  Stored in directory: /home/jenkins/.cache/pip/wheels/a2/6f/9a/9097d00837dae2b5fae0fc5727809e5b2619b3cb393b9463d7
Successfully built exabgp
Installing collected packages: exabgp
Successfully installed exabgp-4.2.4</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:38.021700" elapsed="0.000599"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.023239" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:38.022747" elapsed="0.000623"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.024313" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:38.023842" elapsed="0.000570"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:15:38.020274" elapsed="0.004299"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:38.019100" elapsed="0.005715"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:38.019059" elapsed="0.005799"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:15:38.025118" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:38.024944" elapsed="0.000273"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:38.024918" elapsed="0.000325"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:15:38.025432" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:15:38.025298" elapsed="0.000267"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:38.025281" elapsed="0.000314"/>
</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-06-06T03:15:38.025763" 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-06-06T03:14:45.932591" elapsed="52.093320"/>
</kw>
<msg time="2026-06-06T03:15:38.025974" 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-06-06T03:14:45.931901" elapsed="52.094129"/>
</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/defaultvenv/bin/activate; pip install exabgp==4.2.4; 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-06-06T03:14:45.930581" elapsed="52.095565"/>
</kw>
<msg time="2026-06-06T03:15:38.026207" 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-06-06T03:14:45.926018" elapsed="52.100237"/>
</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-06-06T03:14:45.925426" elapsed="52.100934"/>
</kw>
<msg time="2026-06-06T03:15:38.026415" 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-06-06T03:14:45.924988" elapsed="52.101473"/>
</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-06-06T03:14:45.924451" elapsed="52.102115"/>
</kw>
<msg time="2026-06-06T03:15:38.026614" 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-06-06T03:14:45.923987" elapsed="52.102687"/>
</kw>
<arg>exabgp==4.2.4</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-06-06T03:14:45.923713" elapsed="52.103061"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:38.027230" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5900310&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:15:38.026937" elapsed="0.000519"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.053793" level="INFO">[chan 10] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:15:38.066399" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/exaipv6.cfg' -&gt; '/home/jenkins//exaipv6.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${EXABGP_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:15:38.027940" elapsed="0.038678"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.075126" level="INFO">1 file:
exaipv6.cfg</msg>
<msg time="2026-06-06T03:15:38.075309" level="INFO">@{cfgfiles} = [ exaipv6.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:15:38.067144" elapsed="0.008201"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.076186" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/2607:f0d0:1002:0011:0000:0000:0000:0002/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:15:38.088342" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${IPV6_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.075946" elapsed="0.012560"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.089311" level="INFO">Executing command 'sed -i -e 's/ODLIP/::1/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:15:38.143384" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${CONTROLLER_IPV6}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.088928" elapsed="0.054590"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.144302" level="INFO">Executing command 'sed -i -e 's/ROUTERID/1.2.3.4/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:15:38.191445" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTERID/${EXABGP_ID}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.143922" elapsed="0.047710"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.192488" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:15:38.239023" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.192081" elapsed="0.047052"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.239621" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:15:38.288007" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.239394" elapsed="0.048828"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.289248" level="INFO">Executing command 'cat exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:15:38.335787" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:38.336098" level="INFO">${stdout} = neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        route-refresh disable;
        add-pat...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.288829" elapsed="0.047329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.337581" level="INFO">neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        ipv6 unicast;
    }

    static {
        route 2a04:6d80::1/128 next-hop self;
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:38.336859" elapsed="0.000866"/>
</kw>
<var name="${cfgfile}">exaipv6.cfg</var>
<status status="PASS" start="2026-06-06T03:15:38.075739" elapsed="0.262070"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:15:38.075442" elapsed="0.262443"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:15:38.027709" elapsed="0.310319"/>
</kw>
<kw name="Upload_Config_Files_exabgp_ipv4">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.380111" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/exaipv4.cfg' -&gt; '/home/jenkins//exaipv4.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${EXABGP2_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:15:38.339082" elapsed="0.041166"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.388403" level="INFO">1 file:
exaipv4.cfg</msg>
<msg time="2026-06-06T03:15:38.388574" level="INFO">@{cfgfiles} = [ exaipv4.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*ipv4.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:15:38.380722" elapsed="0.007908"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.389426" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/127.0.0.1/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:15:38.401617" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/127.0.0.1/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.389225" elapsed="0.012555"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.402517" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:15:38.447410" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.402143" elapsed="0.045409"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.448325" level="INFO">Executing command 'sed -i -e 's/ROUTERID/127.0.0.1/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:15:38.495720" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTERID/127.0.0.1/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.447991" elapsed="0.047863"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.496537" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:15:38.543838" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.496223" elapsed="0.047848"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.545272" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:15:38.595531" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.544798" elapsed="0.050900"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.596399" level="INFO">Executing command 'cat exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:15:38.643536" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:38.643784" level="INFO">${stdout} = neighbor 10.30.170.38 {
                  router-id 127.0.0.1;
                  local-address 127.0.0.1;
                  local-as 64496;
                  peer-as 64496;
                  family {
...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.596080" elapsed="0.047765"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.645035" level="INFO">neighbor 10.30.170.38 {
                  router-id 127.0.0.1;
                  local-address 127.0.0.1;
                  local-as 64496;
                  peer-as 64496;
                  family {
                        ipv4 unicast;
                  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:38.644282" elapsed="0.000862"/>
</kw>
<var name="${cfgfile}">exaipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:15:38.389013" elapsed="0.256210"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:15:38.388752" elapsed="0.256547"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:15:38.338507" elapsed="0.306932"/>
</kw>
<kw name="Upload_Config_Files_exabgp_graceful_restart">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.688257" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/exabgp_graceful_restart.cfg' -&gt; '/home/jenkins//exabgp_graceful_restart.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${EXABGP3_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:15:38.646455" elapsed="0.041953"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.696414" level="INFO">1 file:
exabgp_graceful_restart.cfg</msg>
<msg time="2026-06-06T03:15:38.696582" level="INFO">@{cfgfiles} = [ exabgp_graceful_restart.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*restart.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:15:38.688864" elapsed="0.007753"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.697456" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/2607:f0d0:1002:0011:0000:0000:0000:0002/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:15:38.710266" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${IPV6_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.697224" elapsed="0.013171"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.711176" level="INFO">Executing command 'sed -i -e 's/ODLIP/::1/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:15:38.759692" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${CONTROLLER_IPV6}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.710795" elapsed="0.049057"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.760708" level="INFO">Executing command 'sed -i -e 's/ROUTERID/1.2.3.4/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:15:38.807531" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTERID/${EXABGP_ID}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.760267" elapsed="0.047430"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.808375" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:15:38.855055" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.808068" elapsed="0.047119"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.855905" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:15:38.903543" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.855553" elapsed="0.048157"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:38.904397" level="INFO">Executing command 'cat exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:15:38.952019" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:38.952287" level="INFO">${stdout} = neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        graceful-restart 40;
    }

    family...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:38.904086" elapsed="0.048262"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:38.953585" level="INFO">neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        graceful-restart 40;
    }

    family {
        ipv6 unicast;
    }

    static {
        route 2a04:6d80::1/128 next-hop self;
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:38.952912" elapsed="0.000814"/>
</kw>
<var name="${cfgfile}">exabgp_graceful_restart.cfg</var>
<status status="PASS" start="2026-06-06T03:15:38.697019" elapsed="0.256788"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:15:38.696758" elapsed="0.257129"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:15:38.645935" elapsed="0.308091"/>
</kw>
<kw name="Upload_Config_Files_Exabgp_AS_Value_Reconfigured">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.003474" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/exa4.cfg' -&gt; '/home/jenkins//exa4.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${EXABGP4_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:15:38.955049" elapsed="0.048690"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.013326" level="INFO">1 file:
exa4.cfg</msg>
<msg time="2026-06-06T03:15:39.013525" level="INFO">@{cfgfiles} = [ exa4.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*exa4.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:15:39.004276" elapsed="0.009287"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.014469" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/2607:f0d0:1002:0011:0000:0000:0000:0002/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:15:39.027271" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${IPV6_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:39.014212" elapsed="0.013199"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.028542" level="INFO">Executing command 'sed -i -e 's/ODLIP/::1/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:15:39.076075" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${CONTROLLER_IPV6}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:39.028034" elapsed="0.048230"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.077316" level="INFO">Executing command 'sed -i -e 's/ROUTERID/1.2.3.4/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:15:39.127947" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTERID/${EXABGP_ID}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:39.076810" elapsed="0.051280"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.128870" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:15:39.179758" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:39.128481" elapsed="0.051425"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.180736" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:15:39.231908" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:39.180331" elapsed="0.051760"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.233201" level="INFO">Executing command 'cat exa4.cfg'.</msg>
<msg time="2026-06-06T03:15:39.280026" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:39.280396" level="INFO">${stdout} = neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 4210010000;
    peer-as 4210010000;

    capability {
        route-refresh disable;
     ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:39.232766" elapsed="0.047712"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.282312" level="INFO">neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 4210010000;
    peer-as 4210010000;

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        ipv6 unicast;
    }

    static {
        route 2a04:6d80::1/128 next-hop self;
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.281490" elapsed="0.000932"/>
</kw>
<var name="${cfgfile}">exa4.cfg</var>
<status status="PASS" start="2026-06-06T03:15:39.013995" elapsed="0.268506"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:15:39.013701" elapsed="0.268879"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:15:38.954490" elapsed="0.328271"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:13:47.948080" elapsed="111.334820"/>
</kw>
<test id="s1-s5-t1" name="Reconfigure_ODL_To_Accept_Connections" line="61">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:39.290873" elapsed="0.000540"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:39.290210" elapsed="0.001378"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.294382" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.294212" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.294179" elapsed="0.000285"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.300000" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.299880" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.299861" elapsed="0.000228"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.301195" 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-06-06T03:15:39.300742" elapsed="0.000483"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.301721" 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-06-06T03:15:39.301393" elapsed="0.000355"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:39.301796" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:15:39.301965" 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-06-06T03:15:39.300332" elapsed="0.001660"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:39.308024" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.307902" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.307881" elapsed="0.000219"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:39.309488" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.309375" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.309355" elapsed="0.000205"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:39.310062" 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-06-06T03:15:39.309735" elapsed="0.000356"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.310486" level="INFO">${current_connection_index} = 7</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-06-06T03:15:39.310259" elapsed="0.000254"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.345394" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:39.311062" elapsed="0.034456"/>
</kw>
<msg time="2026-06-06T03:15:39.345745" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:39.345796" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:39.310694" elapsed="0.035138"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.376181" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "[K"
[?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-06-06T03:15:39.346509" elapsed="0.029785"/>
</kw>
<msg time="2026-06-06T03:15:39.376459" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:39.376506" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:15:39.346077" elapsed="0.030463"/>
</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-06-06T03:15:39.376933" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.376660" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.376610" elapsed="0.000433"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.377524" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "[K"
[?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-06-06T03:15:39.377198" elapsed="0.000398"/>
</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-06-06T03:15:39.377919" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.377684" elapsed="0.000294"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.377662" elapsed="0.000340"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:39.378039" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:39.380786" elapsed="0.000172"/>
</kw>
<msg time="2026-06-06T03:15:39.381068" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:39.379680" elapsed="0.001545"/>
</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="NOT RUN" start="2026-06-06T03:15:39.381525" elapsed="0.000086"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.381913" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:39.378992" elapsed="0.003113"/>
</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-06-06T03:15:39.378388" elapsed="0.003783"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:39.308974" elapsed="0.073300"/>
</kw>
<msg time="2026-06-06T03:15:39.382374" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:39.382419" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:39.308259" elapsed="0.074200"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:39.382673" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:15:39.382539" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.382520" elapsed="0.000255"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.383210" elapsed="0.000079"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.383613" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.383701" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:39.307532" elapsed="0.076280"/>
</kw>
<msg time="2026-06-06T03:15:39.383908" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:39.383952" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:39.302397" elapsed="0.081591"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.384324" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.384069" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.384049" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:39.302250" elapsed="0.082176"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:39.302062" elapsed="0.082400"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:39.299481" elapsed="0.085039"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:39.293453" elapsed="0.091126"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:39.292111" elapsed="0.092516"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:39.284492" elapsed="0.100209"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.385634" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:0011:0000:0000:0000:0002 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=ex...</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.384900" elapsed="0.000786"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.421495" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.420989" elapsed="0.000543"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:39.422433" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:39.422095" elapsed="0.000425">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:39.422617" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:39.421740" elapsed="0.000919"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.423225" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:39.422835" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:39.423561" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:39.423760" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:39.423415" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.424224" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.423966" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.425453" level="INFO">mapping: {'IP': '2607:f0d0:1002:0011:0000:0000:0000:0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.425159" elapsed="0.000342"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.425963" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.425684" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.426825" level="INFO">${value} = 2607:f0d0:1002:0011:0000:0000:0000:0002</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.426435" elapsed="0.000417"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.427604" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.427372" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.427705" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:15:39.427881" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.427048" elapsed="0.000866"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.428115" elapsed="0.000258"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:0011:0000:0000:0000:0002</var>
<status status="PASS" start="2026-06-06T03:15:39.426255" elapsed="0.002162"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.428991" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.428687" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.430018" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.429798" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.430098" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:39.430261" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.429260" elapsed="0.001034"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.430453" elapsed="0.000269"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:39.428533" elapsed="0.002235"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.431355" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.431019" elapsed="0.000369"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.432152" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.431935" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.432230" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:39.432381" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.431582" elapsed="0.000824"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.432558" elapsed="0.000241"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:39.430883" elapsed="0.001959"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.433414" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.433111" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.434174" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.433962" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.434253" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:39.434402" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.433628" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.434578" elapsed="0.000238"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:39.432956" elapsed="0.001901"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.435401" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.435103" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.436169" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.435945" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.436288" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:39.436444" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.435610" elapsed="0.000859"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.436623" elapsed="0.000243"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:39.434971" elapsed="0.001937"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.437502" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.437198" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.438277" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.438065" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.438354" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:39.438504" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.437734" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.438697" elapsed="0.000227"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:39.437022" elapsed="0.001945"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.439516" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.439216" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.440321" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.440089" elapsed="0.000265"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.440407" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:39.440562" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.439761" elapsed="0.000825"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.440757" elapsed="0.000244"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:39.439081" elapsed="0.001995"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.441880" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:39.441348" elapsed="0.000559"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:39.442656" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.442429" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:39.442737" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:39.442890" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:39.442110" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:39.443067" elapsed="0.000225"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:39.441198" elapsed="0.002137"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:39.426051" elapsed="0.017318"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:39.443412" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:39.443574" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:39.424775" elapsed="0.018826"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.424417" elapsed="0.019217"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.443832" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.443678" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.424390" elapsed="0.019520"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.444815" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:39.444060" elapsed="0.000784"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:39.444895" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:39.420275" elapsed="0.024748"/>
</kw>
<msg time="2026-06-06T03:15:39.445157" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:39.407008" elapsed="0.038205"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.458295" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.471286" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.484379" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.484582" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.484780" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.485210" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.485026" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:39.485010" elapsed="0.000282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.485434" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.485599" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.485784" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:39.484977" elapsed="0.000860"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.484865" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.486010" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.486086" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:39.486217" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:39.402526" elapsed="0.083718"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.514093" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.513708" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:39.514890" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:39.514624" elapsed="0.000389">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:39.515111" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:39.514286" elapsed="0.000850"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.515708" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:39.515303" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:39.516040" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:39.516210" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:39.515899" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.516659" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.516397" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:39.517120" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.516790" elapsed="0.000390"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.517877" level="INFO">${mapping_to_use} = {'IP': '2607:f0d0:1002:0011:0000:0000:0000:0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.517350" elapsed="0.000556"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.517205" elapsed="0.000737"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.516771" elapsed="0.001193"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.518882" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:39.518111" elapsed="0.000802"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:39.518964" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:39.513044" elapsed="0.006052"/>
</kw>
<msg time="2026-06-06T03:15:39.519155" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:39.499826" elapsed="0.019376"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.531978" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.544685" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.557538" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.557805" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.557994" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.558413" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.558262" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:39.558244" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.558657" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.558829" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.558996" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:39.558205" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.558080" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.559231" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.559311" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:39.559476" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:39.496949" elapsed="0.062558"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:39.560967" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:39.560659" elapsed="0.000386">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:39.561175" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:39.560240" elapsed="0.000962"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.561538" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.561275" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.562114" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.561818" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.561619" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.561255" elapsed="0.000941"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.564602" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:39.562349" elapsed="0.002279"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:39.564696" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:39.564852" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:39.559881" elapsed="0.004996"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.566303" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.566049" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.566818" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.566558" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.567276" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.567030" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.567729" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.567471" elapsed="0.000302"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:39.568583" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:39.568382" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:39.568955" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:39.568778" elapsed="0.000202"/>
</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-06-06T03:15:39.569146" elapsed="0.000214"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.569966" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.569517" elapsed="0.000495"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:39.570055" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:39.570210" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:39.567976" elapsed="0.002259"/>
</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-06-06T03:15:39.619997" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '1013', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:39.620149" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:15:39 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:39.620569" 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-06-06T03:15:39.572453" elapsed="0.048179"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.570306" elapsed="0.050474"/>
</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-06-06T03:15:39.621297" elapsed="0.000073"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.620842" elapsed="0.000634"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.570288" elapsed="0.051237"/>
</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-06-06T03:15:39.629332" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.623811" elapsed="0.005619"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.623280" elapsed="0.006230"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.623236" elapsed="0.006330"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.632514" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.630184" elapsed="0.002376"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.629726" elapsed="0.002869"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.629684" elapsed="0.002936"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.633217" 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-06-06T03:15:39.632802" elapsed="0.000442"/>
</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-06-06T03:15:39.633556" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.633317" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.634124" 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-06-06T03:15:39.633817" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.633653" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.633297" elapsed="0.000909"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.634741" 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-06-06T03:15:39.634364" elapsed="0.000404"/>
</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-06-06T03:15:39.635071" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.634838" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.635604" 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-06-06T03:15:39.635310" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.635152" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.634820" elapsed="0.000882"/>
</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-06-06T03:15:39.635853" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:39.636674" 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-06-06T03:15:39.636371" elapsed="0.000330"/>
</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-06-06T03:15:39.636859" elapsed="0.002357"/>
</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-06-06T03:15:39.622355" elapsed="0.016926"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:39.639456" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:39.639348" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.639329" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:39.639710" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.639779" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:39.642121" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:39.565238" elapsed="0.076910"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:39.642213" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:39.642368" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:39.391039" elapsed="0.251354"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.642746" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.642492" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.642475" elapsed="0.000363"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:39.642905" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:39.385961" elapsed="0.257074"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with short ipv6 address.</doc>
<status status="PASS" start="2026-06-06T03:15:39.283037" elapsed="0.360123"/>
</test>
<test id="s1-s5-t2" name="Start_Exabgp" line="77">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:39.646509" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:39.646242" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.647787" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.647675" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.647654" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.652975" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.652864" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.652845" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.654093" 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-06-06T03:15:39.653698" elapsed="0.000422"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.654578" 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-06-06T03:15:39.654283" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:39.654663" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:39.654828" 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-06-06T03:15:39.653298" elapsed="0.001555"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:39.660491" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.660383" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.660364" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:39.661783" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:39.661672" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.661631" elapsed="0.000221"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:39.662302" 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-06-06T03:15:39.662000" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.662730" level="INFO">${current_connection_index} = 7</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-06-06T03:15:39.662494" elapsed="0.000262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.706750" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:39.663257" elapsed="0.043626"/>
</kw>
<msg time="2026-06-06T03:15:39.707072" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:39.707119" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:39.662917" elapsed="0.044236"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.732330" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "[K"
[?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-06-06T03:15:39.707765" elapsed="0.024790"/>
</kw>
<msg time="2026-06-06T03:15:39.732960" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:39.733065" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "[K"
[?1l&gt;[?2004l[?1h=[90...</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-06-06T03:15:39.707360" elapsed="0.025788"/>
</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-06-06T03:15:39.733977" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.733370" elapsed="0.000739"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.733322" elapsed="0.000842"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.735330" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "[K"
[?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-06-06T03:15:39.734488" elapsed="0.000978"/>
</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-06-06T03:15:39.736151" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.735619" elapsed="0.000653"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.735577" elapsed="0.000747"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:39.736401" elapsed="0.000066"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:39.742140" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:15:39.742355" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:39.739766" elapsed="0.002725"/>
</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="NOT RUN" start="2026-06-06T03:15:39.742798" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.743135" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:39.738325" elapsed="0.004994"/>
</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-06-06T03:15:39.737046" elapsed="0.006341"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:39.661341" elapsed="0.082147"/>
</kw>
<msg time="2026-06-06T03:15:39.743581" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:39.743626" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "[K"
[?1l&gt;[?2004l[?1h=[90...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:39.660727" elapsed="0.082953"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:39.743869" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:39.743759" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.743740" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.744362" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.744718" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:39.744790" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:39.660046" elapsed="0.084852"/>
</kw>
<msg time="2026-06-06T03:15:39.744991" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:39.745036" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "[K"
[?1l&gt;[?2004l[?1h=[90...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:39.655233" elapsed="0.089839"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:39.745479" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:39.745148" elapsed="0.000389"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.745131" elapsed="0.000430"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:39.655088" elapsed="0.090497"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:39.654911" elapsed="0.090707"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:39.652470" elapsed="0.093235"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:39.647373" elapsed="0.098390"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:39.646946" elapsed="0.098862"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:39.643830" elapsed="0.102031"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.746364" level="INFO">${cmd} = exaipv6.cfg &gt; exaipv6.log</msg>
<var>${cmd}</var>
<arg>${EXABGP_CFG} &gt; ${EXABGP_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.746029" elapsed="0.000362"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.749849" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exaipv6.cfg &gt; exaipv6.log</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.749491" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.750282" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exaipv6.cfg &gt; exaipv6.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.750034" elapsed="0.000293"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.752828" level="INFO">source /tmp/defaultvenv/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-06-06T03:15:39.751026" elapsed="0.001858"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.758950" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:39.759070" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:15:39.753046" elapsed="0.006057"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.759697" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.759427" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:39.759177" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:39.759157" elapsed="0.000648"/>
</if>
<arg>log_output=${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-06-06T03:15:39.750566" elapsed="0.009284"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:39.761807" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exaipv6.cfg &gt; exaipv6.log</msg>
<msg time="2026-06-06T03:15:39.761898" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exaipv6.cfg &gt; exaipv6.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:39.760001" elapsed="0.001923"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.762345" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exaipv6.cfg &gt; exaipv6.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.762098" elapsed="0.000293"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:39.749146" elapsed="0.013300"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.764571" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:39.764218" elapsed="0.000381"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.766784" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:39.764781" elapsed="0.002031"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:39.774085" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:39.774225" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:15:39.774320" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:39.766978" elapsed="0.007369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.776969" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:39.774517" elapsed="0.002500"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:15:39.780597" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:15:39.777221" elapsed="0.003502">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:15:39.763756" elapsed="0.017133">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.784592" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:42.783432" elapsed="0.001291"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.788941" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:42.785165" elapsed="0.003815"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:42.798703" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:42.800286" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1499'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://1.2.3.4","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:15:42.800444" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:42.789220" elapsed="0.011262"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.804216" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://1.2.3.4","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:42.800749" elapsed="0.003549"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:15:42.804524" elapsed="0.003525"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:15:42.781897" elapsed="0.026247"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:39.763012" elapsed="3.045208"/>
</kw>
<msg time="2026-06-06T03:15:42.808368" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:42.808430" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:39.762608" elapsed="3.045854"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.809040" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:42.808608" elapsed="0.000510"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.808572" elapsed="0.000586"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:15:42.809397" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:15:42.809241" elapsed="0.000260"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.809216" elapsed="0.000336"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:15:39.748967" elapsed="3.060635"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:15:39.748745" elapsed="3.060931"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.809907" elapsed="0.000030"/>
</kw>
<arg>${cmd}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${EXABGP_ID}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:15:39.746722" elapsed="3.063301"/>
</kw>
<doc>Start exabgp with</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:39.643373" elapsed="3.166824"/>
</test>
<test id="s1-s5-t3" name="Verify_Ipv6_Topology_Filled" line="83">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:42.815849" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:42.815557" elapsed="0.000565"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:42.817224" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:42.817060" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.817041" elapsed="0.000258"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:42.822317" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:42.822208" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.822189" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.823461" 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-06-06T03:15:42.823051" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.823998" 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-06-06T03:15:42.823691" elapsed="0.000333"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:42.824070" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:15:42.824236" 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-06-06T03:15:42.822632" elapsed="0.001629"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:42.829945" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:42.829832" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.829811" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:42.831381" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:42.831271" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.831252" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:42.831927" 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-06-06T03:15:42.831598" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:42.832339" level="INFO">${current_connection_index} = 7</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-06-06T03:15:42.832117" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:42.868590" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:42.832889" elapsed="0.035930"/>
</kw>
<msg time="2026-06-06T03:15:42.869051" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:42.869100" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:42.832524" elapsed="0.036612"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:42.895985" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:15:42.869805" elapsed="0.026312"/>
</kw>
<msg time="2026-06-06T03:15:42.896301" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:42.896348" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:42.869379" elapsed="0.027183"/>
</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-06-06T03:15:42.897001" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:42.896692" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.896631" elapsed="0.000474"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.897658" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:15:42.897289" elapsed="0.000439"/>
</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-06-06T03:15:42.898020" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:42.897797" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.897779" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:42.898138" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:42.901417" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:15:42.901672" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:42.900228" elapsed="0.001602"/>
</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="NOT RUN" start="2026-06-06T03:15:42.902123" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.902467" elapsed="0.000124"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:42.899514" elapsed="0.003225"/>
</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-06-06T03:15:42.898784" elapsed="0.004025"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:42.830968" elapsed="0.071944"/>
</kw>
<msg time="2026-06-06T03:15:42.903014" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:42.903058" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:42.830168" elapsed="0.072926"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:42.903310" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:15:42.903187" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.903160" elapsed="0.000242"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.903899" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.904259" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:42.904333" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:42.829470" elapsed="0.074976"/>
</kw>
<msg time="2026-06-06T03:15:42.904547" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:42.904593" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:42.824673" elapsed="0.079959"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.905002" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:42.904734" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.904714" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:42.824509" elapsed="0.080596"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:42.824324" elapsed="0.080817"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:42.821842" elapsed="0.083360"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:42.816765" elapsed="0.088495"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:42.816279" elapsed="0.089028"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:42.812004" elapsed="0.093359"/>
</kw>
<kw name="Verify_Rib_Status_Filled">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.961921" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:42.961470" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:42.962916" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:42.962500" elapsed="0.000503">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:42.963101" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:42.962148" elapsed="0.001058"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.963793" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:42.963380" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:42.964187" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:42.964395" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:42.964016" elapsed="0.000406"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.964865" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:42.964588" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.966031" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:42.965707" elapsed="0.000369"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.966518" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:42.966241" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.966994" elapsed="0.000025"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.967211" elapsed="0.000034"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.967417" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:42.966838" elapsed="0.000638"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:42.966666" elapsed="0.000842"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:42.967558" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:42.967751" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:42.965360" elapsed="0.002416"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:42.965016" elapsed="0.002793"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.967986" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:42.967835" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:42.964986" elapsed="0.003075"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:42.968678" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:42.968209" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:42.968757" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:42.960725" elapsed="0.008158"/>
</kw>
<msg time="2026-06-06T03:15:42.968938" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:42.947071" elapsed="0.021918"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.982705" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:42.995574" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.008717" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.008916" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.009092" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.009461" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.009315" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.009298" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.009696" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.009869" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.010036" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.009269" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.009167" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.010267" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.010343" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.010465" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:42.942386" elapsed="0.068105"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.011826" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.011543" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.011990" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.011194" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.012333" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.012085" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.012909" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.012597" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.012415" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.012066" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.015443" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.013146" elapsed="0.002324"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:43.015522" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:43.015693" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:43.010864" elapsed="0.004854"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.016958" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.016715" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.017158" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.016358" elapsed="0.000825"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:43.017393" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:43.017256" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.017236" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.017628" elapsed="0.000040"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.017824" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.017891" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.020103" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:43.016025" elapsed="0.004105"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.021542" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.021289" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.022010" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.021763" elapsed="0.000292"/>
</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-06-06T03:15:43.036296" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:43.037196" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","node":[{"node-id":"2607:f0d0:1002:11::2","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"2a04:6d80::1/128"}]}}],"server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:43.037496" 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-06-06T03:15:43.024294" elapsed="0.013266"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.022122" elapsed="0.015581"/>
</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-06-06T03:15:43.038187" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.037775" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.022103" elapsed="0.016295"/>
</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-06-06T03:15:43.044975" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","node":[{"node-id":"2607:f0d0:1002:11::2","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"2a04:6d80::1/128"}]}}],"server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.041117" elapsed="0.003908"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.040539" elapsed="0.004521"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.040491" elapsed="0.004594"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.047738" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.045369" elapsed="0.002415"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.045142" elapsed="0.002676"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.045125" elapsed="0.002717"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.048423" 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-06-06T03:15:43.048023" elapsed="0.000427"/>
</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-06-06T03:15:43.048775" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.048520" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.049324" 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-06-06T03:15:43.049022" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.048858" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.048502" elapsed="0.000904"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.049945" 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-06-06T03:15:43.049565" elapsed="0.000406"/>
</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-06-06T03:15:43.050342" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.050104" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.050926" 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-06-06T03:15:43.050586" elapsed="0.000367"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.050423" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.050084" elapsed="0.000925"/>
</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-06-06T03:15:43.051168" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:43.052015" 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-06-06T03:15:43.051704" elapsed="0.000337"/>
</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-06-06T03:15:43.052199" elapsed="0.002351"/>
</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-06-06T03:15:43.039388" elapsed="0.015274"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.054858" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.054746" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.054725" elapsed="0.000201"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:43.058050" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<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="PASS" start="2026-06-06T03:15:43.055074" elapsed="0.003005"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:43.058132" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:43.058295" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:43.020449" elapsed="0.037872"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.058385" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:15:43.058537" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:42.917501" elapsed="0.141062"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.087935" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.087436" elapsed="0.000528"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.088791" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.088471" elapsed="0.000454">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.089106" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.088132" elapsed="0.001000"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.089771" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.089305" elapsed="0.000495"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.090125" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:43.090349" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:43.089963" elapsed="0.000414"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.090856" level="INFO">{
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
                            {
                                "prefix": "2a04:6d80::1/128"
                            }
                        ]
                    },
                    "node-id": "2607:f0d0:1002:11::2"
                }
            ],
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.090538" elapsed="0.000368"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:43.091380" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.090976" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.092137" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.091613" elapsed="0.000551"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.091465" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.090956" elapsed="0.001265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.092869" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:43.092375" elapsed="0.000523"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.092949" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:43.086818" elapsed="0.006259"/>
</kw>
<msg time="2026-06-06T03:15:43.093133" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.073567" elapsed="0.019615"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.106438" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.119323" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.132125" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.132323" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.132500" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.132897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.132754" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.132738" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.133156" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.133331" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.133498" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.132708" elapsed="0.000843"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.132583" elapsed="0.000996"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.133741" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.133819" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:43.133940" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:43.070831" elapsed="0.063137"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.134146" elapsed="0.002316"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:43.137678" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.137216" elapsed="0.000492"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:43.138281" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.137866" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:43.138468" elapsed="0.000374"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:43.136801" elapsed="0.002103"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.136544" elapsed="0.002394"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.139114" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.138963" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.136524" elapsed="0.002667"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:43.059936" elapsed="0.079302"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:43.059098" elapsed="0.080216"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.058819" elapsed="0.080541"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.058796" elapsed="0.080587"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.139417" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:42.910746" elapsed="0.228798"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:42.905860" elapsed="0.233742"/>
</kw>
<doc>Verifies that example-ipv6-topology is filled with ipv6 route</doc>
<status status="PASS" start="2026-06-06T03:15:42.905522" elapsed="0.234165"/>
</kw>
<doc>Verifies that example-ipv6-topology is filled after starting exabgp.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:42.810526" elapsed="0.329277"/>
</test>
<test id="s1-s5-t4" name="Delete_Bgp_Peer_Configuration" line="88">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:43.143127" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:43.142852" elapsed="0.000542"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.144389" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.144279" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.144260" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.149685" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.149562" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.149544" elapsed="0.000209"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.150789" 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-06-06T03:15:43.150356" elapsed="0.000461"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.151279" 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-06-06T03:15:43.150980" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:43.151349" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:43.151502" 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-06-06T03:15:43.149980" elapsed="0.001546"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:43.157168" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.157055" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.157035" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:43.158403" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.158296" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.158277" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:43.158984" 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-06-06T03:15:43.158618" elapsed="0.000393"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.159391" level="INFO">${current_connection_index} = 7</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-06-06T03:15:43.159175" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.193010" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:43.159937" elapsed="0.033229"/>
</kw>
<msg time="2026-06-06T03:15:43.193375" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:43.193423" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:43.159577" elapsed="0.033882"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.234046" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:15:43.194061" elapsed="0.040108"/>
</kw>
<msg time="2026-06-06T03:15:43.234346" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:43.234391" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:15:43.193689" elapsed="0.040737"/>
</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-06-06T03:15:43.235137" elapsed="0.000133"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.234521" elapsed="0.000869"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.234493" elapsed="0.000975"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.236969" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:15:43.235995" elapsed="0.001155"/>
</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-06-06T03:15:43.237905" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.237326" elapsed="0.000886"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.237275" elapsed="0.000997"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:43.238356" elapsed="0.000082"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:43.244294" elapsed="0.000328"/>
</kw>
<msg time="2026-06-06T03:15:43.244823" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.241957" elapsed="0.003158"/>
</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="NOT RUN" start="2026-06-06T03:15:43.245767" elapsed="0.000167"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.246514" elapsed="0.000270"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:43.240451" elapsed="0.006641"/>
</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-06-06T03:15:43.239126" elapsed="0.008127"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:43.157992" elapsed="0.089387"/>
</kw>
<msg time="2026-06-06T03:15:43.247487" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:43.247533" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:43.157397" elapsed="0.090173"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:43.248123" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:15:43.247742" elapsed="0.000446"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.247632" elapsed="0.000581"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.248671" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.249023" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.249097" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:43.156707" elapsed="0.092500"/>
</kw>
<msg time="2026-06-06T03:15:43.249303" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:43.249346" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:43.151910" elapsed="0.097472"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.249733" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.249460" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.249442" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:43.151767" elapsed="0.098070"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:43.151579" elapsed="0.098295"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:43.149196" elapsed="0.100739"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:43.143991" elapsed="0.106005"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:43.143546" elapsed="0.106500"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:43.140565" elapsed="0.109540"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.251053" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:0011:0000:0000:0000:0002 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=ex...</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.250309" elapsed="0.000774"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.295245" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.294861" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.296115" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.295841" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.296295" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.295482" elapsed="0.000838"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.296889" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.296486" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.297225" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:43.297399" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:43.297082" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.297848" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.297584" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.298885" level="INFO">mapping: {'IP': '2607:f0d0:1002:0011:0000:0000:0000:0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.298584" elapsed="0.000349"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.299354" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.299093" elapsed="0.000287"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.300074" level="INFO">${value} = 2607:f0d0:1002:0011:0000:0000:0000:0002</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.299777" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.301035" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.300611" elapsed="0.000452"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.301115" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.301269" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.300291" elapsed="0.001004"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.301453" elapsed="0.000279"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:0011:0000:0000:0000:0002</var>
<status status="PASS" start="2026-06-06T03:15:43.299623" elapsed="0.002150"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.302321" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.302021" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.303111" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.302897" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.303188" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.303344" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.302532" elapsed="0.000837"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.303522" elapsed="0.000239"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:43.301887" elapsed="0.001916"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.304343" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.304047" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.305102" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.304891" elapsed="0.000272"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.305217" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.305369" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.304550" elapsed="0.000844"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.305544" elapsed="0.000242"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:43.303915" elapsed="0.001913"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.306376" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.306070" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.307155" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.306942" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.307232" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.307381" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.306588" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.307556" elapsed="0.000238"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:43.305939" elapsed="0.001896"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.308383" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.308081" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.309134" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.308926" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.309209" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.309362" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.308592" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.309534" elapsed="0.000236"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:43.307947" elapsed="0.001865"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.310344" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.310052" elapsed="0.000317"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.311126" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.310917" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.311201" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:43.311349" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.310551" elapsed="0.000822"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.311522" elapsed="0.000237"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:43.309922" elapsed="0.001878"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.312526" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.312044" elapsed="0.000508"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.313275" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.313068" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.313350" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.313499" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.312752" elapsed="0.000771"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.313691" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:43.311912" elapsed="0.002042"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.314492" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.314195" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.315267" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.315058" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.315381" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.315533" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.314721" elapsed="0.000837"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.315727" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:43.314065" elapsed="0.001926"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:43.299435" elapsed="0.016590"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:43.316068" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:43.316228" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:43.298261" elapsed="0.017993"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.297962" elapsed="0.018329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.316463" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.316315" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.297943" elapsed="0.018596"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.317412" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:43.316699" elapsed="0.000741"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.317491" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:43.294202" elapsed="0.023412"/>
</kw>
<msg time="2026-06-06T03:15:43.317685" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.281110" elapsed="0.036622"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.330497" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.343278" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.355960" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.356155" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.356331" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.356710" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.356548" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.356534" elapsed="0.000290"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.356972" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.357144" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.357310" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.356507" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.356405" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.357534" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.357609" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.357747" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:43.276621" elapsed="0.081152"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.358900" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.358609" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:43.373655" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:43.373707" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:43.373800" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:43.361297" elapsed="0.012529"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.359014" elapsed="0.014852"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.374047" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.373893" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.358996" elapsed="0.015133"/>
</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-06-06T03:15:43.377554" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.375145" elapsed="0.002453"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.374926" elapsed="0.002707"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.374907" elapsed="0.002766"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.380299" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.377953" elapsed="0.002393"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.377730" elapsed="0.002651"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.377713" elapsed="0.002693"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.380966" 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-06-06T03:15:43.380568" elapsed="0.000425"/>
</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-06-06T03:15:43.381302" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.381064" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.381862" 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-06-06T03:15:43.381544" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.381383" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.381045" elapsed="0.000934"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.382507" 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-06-06T03:15:43.382141" elapsed="0.000393"/>
</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-06-06T03:15:43.382891" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.382604" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.383433" 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-06-06T03:15:43.383134" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.382975" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.382585" elapsed="0.000931"/>
</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-06-06T03:15:43.383683" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:43.384481" 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-06-06T03:15:43.384198" elapsed="0.000308"/>
</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-06-06T03:15:43.384679" elapsed="0.002382"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:43.374488" elapsed="0.012638"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:43.387172" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.389464" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:43.358037" elapsed="0.031454"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.389544" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:43.251325" elapsed="0.138358"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:15:43.140021" elapsed="0.249787"/>
</test>
<test id="s1-s5-t5" name="Verify_Ipv6_Topology_Empty" line="101">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:43.393125" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:43.392862" elapsed="0.000528"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.394376" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.394267" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.394247" elapsed="0.000195"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.399780" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.399671" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.399651" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.400845" 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-06-06T03:15:43.400447" elapsed="0.000425"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.401330" 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-06-06T03:15:43.401035" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:43.401400" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.401553" 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-06-06T03:15:43.400071" elapsed="0.001508"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:43.407174" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.407068" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.407048" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:43.408390" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.408282" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.408263" elapsed="0.000230"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:43.408970" 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-06-06T03:15:43.408666" elapsed="0.000331"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.409371" level="INFO">${current_connection_index} = 7</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-06-06T03:15:43.409157" elapsed="0.000239"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.442588" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:43.409917" elapsed="0.032789"/>
</kw>
<msg time="2026-06-06T03:15:43.442894" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:43.442942" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:43.409558" elapsed="0.033419"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.464539" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "[K"
[?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-06-06T03:15:43.443493" elapsed="0.021168"/>
</kw>
<msg time="2026-06-06T03:15:43.464822" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:43.464868" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:43.443151" elapsed="0.021752"/>
</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-06-06T03:15:43.465202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.464980" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.464960" elapsed="0.000320"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.465741" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "[K"
[?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-06-06T03:15:43.465423" elapsed="0.000383"/>
</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-06-06T03:15:43.466092" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.465874" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.465855" elapsed="0.000314"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:43.466202" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:43.468634" elapsed="0.001729"/>
</kw>
<msg time="2026-06-06T03:15:43.470429" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.467630" elapsed="0.002929"/>
</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="NOT RUN" start="2026-06-06T03:15:43.470890" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.471230" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:43.467023" elapsed="0.004569"/>
</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-06-06T03:15:43.466458" elapsed="0.005216"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:43.407981" elapsed="0.063794"/>
</kw>
<msg time="2026-06-06T03:15:43.471866" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:43.471909" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:43.407399" elapsed="0.064546"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:43.472131" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:43.472021" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.472002" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.472623" elapsed="0.000041"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.473011" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.473083" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:43.406702" elapsed="0.066488"/>
</kw>
<msg time="2026-06-06T03:15:43.473282" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:43.473325" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:43.401956" elapsed="0.071403"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.473713" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.473434" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.473417" elapsed="0.000377"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:43.401814" elapsed="0.072003"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:43.401631" elapsed="0.072214"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:43.399295" elapsed="0.074602"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:43.393981" elapsed="0.079971"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:43.393541" elapsed="0.080455"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:43.390607" elapsed="0.083439"/>
</kw>
<kw name="Verify_Rib_Status_Empty">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.526860" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.526438" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.527622" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.527389" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.527833" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.527058" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.528434" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.528043" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.528778" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:43.528918" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:43.528623" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.529343" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.529100" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.530557" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.530084" elapsed="0.000519"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.531078" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.530789" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.531429" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.531633" elapsed="0.000041"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.531825" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.531295" elapsed="0.000623"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.531154" elapsed="0.000795"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:43.531993" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:43.532153" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:43.529761" elapsed="0.002417"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.529453" elapsed="0.002757"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.532385" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.532235" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.529434" elapsed="0.003028"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.533057" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:43.532606" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.533135" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:43.525824" elapsed="0.007436"/>
</kw>
<msg time="2026-06-06T03:15:43.533314" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.512804" elapsed="0.020558"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.546142" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.558969" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.571882" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.572080" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.572256" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.572617" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.572472" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.572457" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.572859" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.573027" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.573192" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.572429" elapsed="0.000850"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.572329" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.573458" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.573534" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:43.573667" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:43.508382" elapsed="0.065313"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.574966" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.574705" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.575123" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.574349" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.575466" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.575219" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.576020" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.575728" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.575548" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.575200" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.578836" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.576254" elapsed="0.002633"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:43.578940" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:15:43.579099" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:43.574021" elapsed="0.005107"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.580364" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.580112" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.580521" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.579774" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:43.580770" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:43.580616" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.580598" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.581001" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.581174" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.581238" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.583259" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:43.579432" elapsed="0.003853"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.584695" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.584429" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.585137" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.584894" elapsed="0.000287"/>
</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-06-06T03:15:43.594415" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:43.594748" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:43.594892" 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-06-06T03:15:43.587458" elapsed="0.007463"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.585246" elapsed="0.009723"/>
</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-06-06T03:15:43.595153" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.594997" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.585228" elapsed="0.010011"/>
</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-06-06T03:15:43.600321" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.596679" elapsed="0.003709"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.596351" elapsed="0.004086"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.596325" elapsed="0.004147"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.603922" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.600885" elapsed="0.003082"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.600550" elapsed="0.003453"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.600527" elapsed="0.003500"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.604567" 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-06-06T03:15:43.604190" elapsed="0.000404"/>
</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-06-06T03:15:43.604929" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.604688" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.605474" 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-06-06T03:15:43.605174" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.605012" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.604668" elapsed="0.000888"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.606095" 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-06-06T03:15:43.605732" elapsed="0.000390"/>
</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-06-06T03:15:43.606542" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.606193" elapsed="0.000410"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.607126" 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-06-06T03:15:43.606812" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.606628" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.606175" elapsed="0.001033"/>
</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-06-06T03:15:43.607359" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:43.608171" 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-06-06T03:15:43.607889" elapsed="0.000308"/>
</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-06-06T03:15:43.608354" elapsed="0.002339"/>
</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-06-06T03:15:43.595756" elapsed="0.015001"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.610962" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.610827" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.610808" elapsed="0.000227"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:43.613934" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:43.611183" elapsed="0.002813"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:43.614051" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.614209" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:43.583595" elapsed="0.030640"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.614297" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:15:43.614446" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:43.485191" elapsed="0.129281"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.643598" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.643142" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.644411" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.644154" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.644719" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.643816" elapsed="0.000928"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.645355" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.644911" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.645717" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:43.645861" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:43.645545" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.646310" level="INFO">{
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.646044" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:43.646834" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.646423" elapsed="0.000488"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.647587" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.647088" elapsed="0.000525"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.646941" elapsed="0.000726"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.646404" elapsed="0.001286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.648299" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:43.647838" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.648377" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:43.642488" elapsed="0.006013"/>
</kw>
<msg time="2026-06-06T03:15:43.648591" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.629294" elapsed="0.019368"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.661675" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.674696" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.687547" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.687758" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.687943" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.688314" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.688170" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.688154" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.688535" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.688719" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.688891" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.688126" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.688020" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.689117" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.689192" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.689311" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:43.626541" elapsed="0.062797"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.689515" elapsed="0.002487"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:43.693100" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.692777" elapsed="0.000395"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:43.693621" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.693333" elapsed="0.000331"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:43.693824" elapsed="0.000330"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:43.692338" elapsed="0.001876"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.692086" elapsed="0.002162"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.694424" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.694274" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.692066" elapsed="0.002434"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:43.615701" elapsed="0.078848"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:43.614812" elapsed="0.079816"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.614555" elapsed="0.080138"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.614537" elapsed="0.080182"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.694753" elapsed="0.000029"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:43.478869" elapsed="0.216014"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:43.474455" elapsed="0.220505"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty</doc>
<status status="PASS" start="2026-06-06T03:15:43.474175" elapsed="0.220850"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty after deconfiguring peer for the first time.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:43.390029" elapsed="0.305105"/>
</test>
<test id="s1-s5-t6" name="Reconfigure_ODL_To_Accept_Connections_2" line="106">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:43.698595" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:43.698332" elapsed="0.000546"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.699907" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.699796" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.699775" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.704966" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.704861" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.704843" elapsed="0.000190"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.706033" 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-06-06T03:15:43.705634" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.706515" 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-06-06T03:15:43.706221" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:43.706586" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.706758" 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-06-06T03:15:43.705260" elapsed="0.001523"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:43.712660" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.712532" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.712513" elapsed="0.000219"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:43.713906" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:43.713800" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.713781" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:43.714485" 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-06-06T03:15:43.714180" elapsed="0.000331"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.714936" level="INFO">${current_connection_index} = 7</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-06-06T03:15:43.714691" elapsed="0.000273"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.746222" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:43.715470" elapsed="0.030885"/>
</kw>
<msg time="2026-06-06T03:15:43.746541" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:43.746588" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:43.715127" elapsed="0.031497"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:43.770971" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "2 "[K"
[?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-06-06T03:15:43.747316" elapsed="0.023911"/>
</kw>
<msg time="2026-06-06T03:15:43.771476" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:43.771523" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:15:43.746848" elapsed="0.024711"/>
</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-06-06T03:15:43.772084" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.771727" elapsed="0.000420"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.771682" elapsed="0.000493"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.772746" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "2 "[K"
[?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-06-06T03:15:43.772326" elapsed="0.000495"/>
</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-06-06T03:15:43.773106" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.772888" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.772869" elapsed="0.000315"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:43.773223" elapsed="0.000045"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:43.775904" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:15:43.776114" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.774848" elapsed="0.001401"/>
</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="NOT RUN" start="2026-06-06T03:15:43.776529" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.776884" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:43.774173" elapsed="0.002899"/>
</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-06-06T03:15:43.773563" elapsed="0.003614"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:43.713471" elapsed="0.063808"/>
</kw>
<msg time="2026-06-06T03:15:43.777377" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:43.777424" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:43.712886" elapsed="0.064579"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:43.777668" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:43.777543" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.777524" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.778174" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.778599" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.778691" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:43.712192" elapsed="0.066611"/>
</kw>
<msg time="2026-06-06T03:15:43.778900" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:43.779004" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:43.707183" elapsed="0.071868"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.779411" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.779144" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.779122" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:43.707039" elapsed="0.072475"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:43.706837" elapsed="0.072711"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:43.704486" elapsed="0.075121"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:43.699488" elapsed="0.080197"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:43.699057" elapsed="0.080677"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:43.695989" elapsed="0.083800"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.780745" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:11:0:0:0:2 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib ...</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP_2}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.779996" elapsed="0.000780"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.816417" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.815965" elapsed="0.000487"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.817470" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.817016" elapsed="0.000535">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.817670" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.816654" elapsed="0.001044"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.818259" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.817871" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.818595" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:43.818796" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:43.818449" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.819261" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.819006" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.820551" level="INFO">mapping: {'IP': '2607:f0d0:1002:11:0:0:0:2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.820286" elapsed="0.000401"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.821129" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.820854" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.821865" level="INFO">${value} = 2607:f0d0:1002:11:0:0:0:2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.821547" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.822628" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.822401" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.822728" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:43.822892" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.822081" elapsed="0.000836"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.823107" elapsed="0.000248"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:11:0:0:0:2</var>
<status status="PASS" start="2026-06-06T03:15:43.821410" elapsed="0.001987"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.823959" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.823660" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.824893" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.824680" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.824971" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:43.825121" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.824169" elapsed="0.000976"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.825298" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:43.823512" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.826123" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.825826" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.826876" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.826662" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.826965" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.827115" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.826333" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.827290" elapsed="0.000219"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:43.825692" elapsed="0.001857"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.828104" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.827808" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.828860" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.828635" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.828935" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.829085" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.828320" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.829259" elapsed="0.000218"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:43.827676" elapsed="0.001841"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.830076" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.829782" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.830846" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.830600" elapsed="0.000273"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.830923" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.831108" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.830286" elapsed="0.000846"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.831324" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:43.829629" elapsed="0.001960"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.832146" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.831851" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.832897" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.832686" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.832974" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:43.833122" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.832355" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.833296" elapsed="0.000220"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:43.831719" elapsed="0.001838"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.834114" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.833818" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.834864" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.834652" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.834940" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:15:43.835114" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.834325" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.835295" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:43.833685" elapsed="0.001873"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.836298" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:43.835818" elapsed="0.000507"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:43.837048" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.836839" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:43.837125" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:43.837271" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:43.836508" elapsed="0.000788"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:43.837446" elapsed="0.000236"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:43.835687" elapsed="0.002037"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:43.821214" elapsed="0.016545"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:43.837803" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:43.837963" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:43.819958" elapsed="0.018031"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.819562" elapsed="0.018459"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.838195" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.838047" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.819535" elapsed="0.018736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.839159" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:43.838414" elapsed="0.000774"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.839238" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:43.815183" elapsed="0.024179"/>
</kw>
<msg time="2026-06-06T03:15:43.839454" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.801891" elapsed="0.037613"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.852440" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.865333" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.878363" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.878562" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.878756" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.879162" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.879010" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.878967" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.879383" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.879549" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.879732" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.878938" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.878833" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.879959" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.880034" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.880158" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:43.797306" elapsed="0.082878"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.907528" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.907145" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.908293" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.908079" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.908495" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.907734" elapsed="0.000785"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.909110" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.908698" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.909460" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:43.909603" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:43.909319" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.910098" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.909825" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:43.910555" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.910238" elapsed="0.000384"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.911335" level="INFO">${mapping_to_use} = {'IP': '2607:f0d0:1002:11:0:0:0:2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_IN...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.910816" elapsed="0.000547"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.910665" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.910215" elapsed="0.001208"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.912339" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11:0:0:0:2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:43.911574" elapsed="0.000796"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.912421" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:43.906474" elapsed="0.006074"/>
</kw>
<msg time="2026-06-06T03:15:43.912612" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:43.893203" elapsed="0.019475"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.925711" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.938841" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.951661" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.951858" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.952032" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.952394" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.952251" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:43.952236" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.952612" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.952798" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.952964" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:43.952208" elapsed="0.000809"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.952105" elapsed="0.000938"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.953187" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.953261" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:43.953391" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11:0:0:0:2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:43.890464" elapsed="0.062955"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:43.954680" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:43.954431" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:43.954838" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:43.954086" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.955279" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.954933" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.955861" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:43.955540" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.955364" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.954914" elapsed="0.001029"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.958315" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:43.956094" elapsed="0.002247"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:43.958393" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:43.958545" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:43.953763" elapsed="0.004806"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.959975" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.959728" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.960452" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11:0:0:0:2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.960212" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.960928" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.960680" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.961363" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.961122" elapsed="0.000284"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:43.962224" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:43.962031" elapsed="0.000219"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:43.962577" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:43.962404" elapsed="0.000198"/>
</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-06-06T03:15:43.962767" elapsed="0.000201"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.963563" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.963143" elapsed="0.000465"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:43.963668" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:43.963825" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:43.961606" elapsed="0.002244"/>
</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-06-06T03:15:43.979288" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '999', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11:0:0:0:2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:43.979354" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:43.979447" 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-06-06T03:15:43.966063" elapsed="0.013410"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.963921" elapsed="0.015599"/>
</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-06-06T03:15:43.979727" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.979547" elapsed="0.000250"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.963903" elapsed="0.015915"/>
</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-06-06T03:15:43.983188" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.980769" elapsed="0.002461"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.980533" elapsed="0.002768"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.980514" elapsed="0.002813"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.985942" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:43.983607" elapsed="0.002381"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.983385" elapsed="0.002637"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.983368" elapsed="0.002679"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.986588" 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-06-06T03:15:43.986212" elapsed="0.000403"/>
</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-06-06T03:15:43.986943" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.986703" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.987516" 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-06-06T03:15:43.987216" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.987052" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.986684" elapsed="0.000916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.988136" 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-06-06T03:15:43.987774" elapsed="0.000389"/>
</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-06-06T03:15:43.988465" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.988232" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:43.989017" 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-06-06T03:15:43.988722" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:43.988546" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.988214" elapsed="0.000885"/>
</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-06-06T03:15:43.989253" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:43.990059" 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-06-06T03:15:43.989780" elapsed="0.000305"/>
</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-06-06T03:15:43.990238" elapsed="0.002342"/>
</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-06-06T03:15:43.980176" elapsed="0.012481"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:43.992832" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:43.992726" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.992707" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:43.993067" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:43.993134" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:15:43.995481" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:43.958911" elapsed="0.036597"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.995571" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:43.995742" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:43.785890" elapsed="0.209877"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:43.996101" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:43.995866" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:43.995848" elapsed="0.000343"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:43.996223" elapsed="0.000025"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:43.781050" elapsed="0.215294"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with ipv6 address without "::" shortened version.</doc>
<status status="PASS" start="2026-06-06T03:15:43.695353" elapsed="0.301151"/>
</test>
<test id="s1-s5-t7" name="Verify_Ipv6_Topology_Filled_2" line="122">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:44.001339" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:44.001071" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.002592" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:44.002482" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.002462" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.007730" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:44.007602" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.007584" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.008794" 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-06-06T03:15:44.008397" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.009278" 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-06-06T03:15:44.008983" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:44.009348" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:44.009501" 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-06-06T03:15:44.008022" elapsed="0.001503"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:44.015108" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:44.014988" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.014968" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:44.016347" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:44.016241" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.016222" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:44.016883" 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-06-06T03:15:44.016560" elapsed="0.000349"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:44.017286" level="INFO">${current_connection_index} = 7</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-06-06T03:15:44.017068" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:44.048941" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:44.017825" elapsed="0.031218"/>
</kw>
<msg time="2026-06-06T03:15:44.049206" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:44.049253" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:44.017471" elapsed="0.031817"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:44.072087" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "F "i "l "l "e "d "_ "2 "[K"
[?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-06-06T03:15:44.049823" elapsed="0.022530"/>
</kw>
<msg time="2026-06-06T03:15:44.072694" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:44.072769" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:44.049458" elapsed="0.023366"/>
</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-06-06T03:15:44.073445" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.072981" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.072936" elapsed="0.000640"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.074397" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "F "i "l "l "e "d "_ "2 "[K"
[?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-06-06T03:15:44.073823" elapsed="0.000756"/>
</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-06-06T03:15:44.075135" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.074731" elapsed="0.000506"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.074699" elapsed="0.000581"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:44.075348" elapsed="0.000066"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:44.078305" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:15:44.078519" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:44.077250" elapsed="0.001529"/>
</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="NOT RUN" start="2026-06-06T03:15:44.079101" elapsed="0.000089"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.079489" elapsed="0.000097"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:44.076579" elapsed="0.003138"/>
</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-06-06T03:15:44.075847" elapsed="0.003939"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:44.015938" elapsed="0.063952"/>
</kw>
<msg time="2026-06-06T03:15:44.079987" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:44.080033" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:44.015328" elapsed="0.064743"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:44.080262" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:44.080151" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.080131" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.080955" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.081332" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.081405" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:44.014652" elapsed="0.066865"/>
</kw>
<msg time="2026-06-06T03:15:44.081615" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:44.081677" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:44.009915" elapsed="0.071800"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.082064" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.081794" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.081777" elapsed="0.000365"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:44.009774" elapsed="0.072392"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:44.009579" elapsed="0.072624"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:44.007241" elapsed="0.075028"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:44.002195" elapsed="0.080131"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:44.001770" elapsed="0.080616"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:43.997305" elapsed="0.085139"/>
</kw>
<kw name="Verify_Rib_Status_Filled">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.137165" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:44.136775" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:44.138038" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.137781" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:44.138216" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:44.137421" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.138817" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:44.138408" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:44.139175" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:44.139362" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:44.139010" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.139832" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.139551" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.140893" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.140586" elapsed="0.000353"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.141376" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:44.141102" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.141773" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.141983" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.142158" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:44.141612" elapsed="0.000603"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.141460" elapsed="0.000786"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:44.142291" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:44.142453" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:44.140260" elapsed="0.002218"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.139950" elapsed="0.002560"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.142701" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.142535" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.139928" elapsed="0.002851"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.143657" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:44.142924" elapsed="0.000763"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:44.143737" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:44.136133" elapsed="0.007731"/>
</kw>
<msg time="2026-06-06T03:15:44.143918" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:44.122604" elapsed="0.021363"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.157222" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.170407" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.190871" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.191088" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.191294" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.191701" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.191533" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:44.191517" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.191927" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.192095" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.192261" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:44.191485" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.191375" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.192484" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.192560" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:44.192706" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:44.118130" elapsed="0.074604"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:44.194052" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.193792" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:44.194221" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:44.193405" elapsed="0.000840"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.194572" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.194316" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.195177" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:44.194850" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.194669" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.194297" elapsed="0.000965"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.197713" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:44.195418" elapsed="0.002322"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:44.197791" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:44.198009" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:44.193067" elapsed="0.004968"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:44.199294" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.199027" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:44.199451" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:44.198687" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:44.199702" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:44.199546" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.199527" elapsed="0.000261"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.199939" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.200112" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.200178" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:44.202314" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:44.198344" elapsed="0.003997"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.203799" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.203521" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.204247" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.204001" elapsed="0.000289"/>
</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-06-06T03:15:44.213246" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:44.213430" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:44.213585" 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-06-06T03:15:44.206501" elapsed="0.007121"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.204357" elapsed="0.009357"/>
</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-06-06T03:15:44.213970" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.213753" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.204339" elapsed="0.009750"/>
</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-06-06T03:15:44.219122" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.215594" elapsed="0.003641"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.215276" elapsed="0.004010"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.215248" elapsed="0.004073"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.223051" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.219741" elapsed="0.003374"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.219401" elapsed="0.003783"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.219377" elapsed="0.003842"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.224033" 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-06-06T03:15:44.223454" elapsed="0.000617"/>
</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-06-06T03:15:44.224505" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.224171" elapsed="0.000415"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.225341" 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-06-06T03:15:44.224909" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.224620" elapsed="0.000878"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.224145" elapsed="0.001383"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.226290" 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-06-06T03:15:44.225776" elapsed="0.000552"/>
</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-06-06T03:15:44.226776" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.226426" elapsed="0.000432"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.227552" 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-06-06T03:15:44.227117" elapsed="0.000472"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.226892" elapsed="0.000765"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.226400" elapsed="0.001290"/>
</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-06-06T03:15:44.227903" elapsed="0.000495"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:44.229117" 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-06-06T03:15:44.228678" elapsed="0.000477"/>
</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-06-06T03:15:44.229381" elapsed="0.003832"/>
</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-06-06T03:15:44.214586" elapsed="0.018695"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.233463" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:44.233353" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.233333" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:44.236616" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:44.233695" elapsed="0.002965"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:44.236713" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:44.236875" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:44.202671" elapsed="0.034231"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:44.236966" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:15:44.237117" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:44.094164" elapsed="0.142979"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.268600" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:44.268080" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:44.269543" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.269232" elapsed="0.000465">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:44.269880" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:44.268863" elapsed="0.001043"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.270594" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:44.270127" elapsed="0.000584"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:44.271110" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:44.271350" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:44.270914" elapsed="0.000475"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.271866" level="INFO">{
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
                            {
                                "prefix": "2a04:6d80::1/128"
                            }
                        ]
                    },
                    "node-id": "2607:f0d0:1002:11::2"
                }
            ],
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:44.271566" elapsed="0.000352"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:44.272449" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.272001" elapsed="0.000513"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.273225" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:44.272710" elapsed="0.000544"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:44.272543" elapsed="0.000751"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:44.271974" elapsed="0.001342"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.273986" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:44.273467" elapsed="0.000549"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:44.274070" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:44.267408" elapsed="0.006801"/>
</kw>
<msg time="2026-06-06T03:15:44.274268" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:44.253425" elapsed="0.020894"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.287600" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.300843" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.313870" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.314116" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.314297" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.314716" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.314549" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:44.314534" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.314941" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.315110" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.315353" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:44.314501" elapsed="0.000917"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.314383" elapsed="0.001065"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.315602" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.315698" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:44.315827" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:44.250559" elapsed="0.065295"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:44.316033" elapsed="0.002297"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:44.319591" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:44.319099" elapsed="0.000521"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:44.320091" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:44.319802" elapsed="0.000317"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:15:44.320595" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
     "node-id": "2607:f0d0:1002:11::2"
    }
   ],
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
   }
  }
 ]
}

!=

{
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
   }
  }
 ]
}</msg>
<msg time="2026-06-06T03:15:44.320802" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.320276" elapsed="0.000598">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.318669" elapsed="0.002343">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<status status="FAIL" start="2026-06-06T03:15:44.318412" elapsed="0.002708">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:44.321309" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:44.321155" elapsed="0.000210"/>
</branch>
<status status="FAIL" start="2026-06-06T03:15:44.318392" elapsed="0.002996">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.238318" elapsed="0.083182">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.237477" elapsed="0.084157">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<status status="FAIL" start="2026-06-06T03:15:44.237228" elapsed="0.084508">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</branch>
<status status="FAIL" start="2026-06-06T03:15:44.237210" elapsed="0.084561">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:44.321818" elapsed="0.000016"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:15:44.087715" elapsed="0.234215">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.381487" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.381065" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.382329" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.382074" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.382505" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.381722" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.383109" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:46.382716" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.383449" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:46.383696" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:46.383300" elapsed="0.000423"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.384148" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.383884" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.385266" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.384959" elapsed="0.000353"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.385772" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.385476" elapsed="0.000323"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.386131" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.386351" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.386528" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:46.385995" elapsed="0.000592"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.385853" elapsed="0.000765"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:46.386683" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:46.386849" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:46.384613" elapsed="0.002262"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.384275" elapsed="0.002632"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.387079" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.386932" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.384251" elapsed="0.002904"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.387760" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:46.387299" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.387839" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:46.380367" elapsed="0.007597"/>
</kw>
<msg time="2026-06-06T03:15:46.388020" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.367003" elapsed="0.021066"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.401256" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.414904" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.427861" elapsed="0.000054"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.428321" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.428516" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.428985" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.428830" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:46.428810" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.429214" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.429382" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.429549" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:46.428766" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.428605" elapsed="0.001027"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.429800" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.429880" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:46.430035" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:46.362528" elapsed="0.067535"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.431537" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.431228" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.431726" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.430819" elapsed="0.000933"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.432091" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.431824" elapsed="0.000342"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.432685" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.432371" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.432191" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.431805" elapsed="0.000965"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.435180" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:46.432926" elapsed="0.002282"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:46.435260" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:46.435418" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:46.430430" elapsed="0.005013"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.436725" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.436466" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.436884" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.436099" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:46.437120" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:46.436981" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.436962" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.437398" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.437574" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.437656" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:46.439826" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:46.435769" elapsed="0.004085"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.441284" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.441026" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.441745" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.441485" elapsed="0.000305"/>
</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-06-06T03:15:46.453236" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:46.453380" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","node":[{"node-id":"2607:f0d0:1002:11::2","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"2a04:6d80::1/128"}]}}],"server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:46.453492" 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-06-06T03:15:46.444020" elapsed="0.009499"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.441858" elapsed="0.011706"/>
</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-06-06T03:15:46.453772" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.453591" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.441839" elapsed="0.012022"/>
</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-06-06T03:15:46.457409" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","node":[{"node-id":"2607:f0d0:1002:11::2","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"2a04:6d80::1/128"}]}}],"server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.454901" elapsed="0.002557"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.454671" elapsed="0.002822"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.454635" elapsed="0.002883"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.460152" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.457816" elapsed="0.002400"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.457574" elapsed="0.002678"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.457557" elapsed="0.002720"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.460860" 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-06-06T03:15:46.460448" elapsed="0.000441"/>
</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-06-06T03:15:46.461199" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.460960" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.461775" 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-06-06T03:15:46.461452" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.461282" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.460942" elapsed="0.000918"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.462388" 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-06-06T03:15:46.462020" elapsed="0.000395"/>
</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-06-06T03:15:46.462739" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.462487" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.463284" 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-06-06T03:15:46.462984" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.462822" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.462468" 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-06-06T03:15:46.463571" elapsed="0.000371"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:46.464435" 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-06-06T03:15:46.464110" elapsed="0.000353"/>
</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-06-06T03:15:46.464622" elapsed="0.002377"/>
</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-06-06T03:15:46.454223" elapsed="0.012842"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.467247" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.467138" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.467119" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:46.470314" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<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="PASS" start="2026-06-06T03:15:46.467463" elapsed="0.002881"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:46.470398" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:46.470559" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:46.440184" elapsed="0.030403"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.470667" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:46.470821" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:46.338262" elapsed="0.132585"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.500226" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.499708" elapsed="0.000548"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.501079" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.500794" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.501382" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.500426" elapsed="0.000982"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.502045" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:46.501577" elapsed="0.000496"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.502403" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:46.502561" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:46.502240" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.503044" level="INFO">{
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
                            {
                                "prefix": "2a04:6d80::1/128"
                            }
                        ]
                    },
                    "node-id": "2607:f0d0:1002:11::2"
                }
            ],
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.502765" elapsed="0.000378"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:46.503635" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.503216" elapsed="0.000495"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.504431" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.503887" elapsed="0.000572"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.503738" elapsed="0.000757"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.503194" elapsed="0.001322"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.505161" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:46.504682" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.505241" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:46.499067" elapsed="0.006303"/>
</kw>
<msg time="2026-06-06T03:15:46.505427" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.485870" elapsed="0.019607"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.518389" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.531349" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.544542" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.544778" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.544965" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.545378" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.545228" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:46.545210" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.545602" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.545787" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.545983" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:46.545172" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.545052" elapsed="0.001030"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.546375" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.546460" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:46.546606" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:46.483129" elapsed="0.063506"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.546841" elapsed="0.002375"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:46.550487" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.549997" elapsed="0.000519"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:46.551105" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.550697" elapsed="0.000437"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:46.551290" elapsed="0.000336"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:46.549548" elapsed="0.002158"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.549298" elapsed="0.002442"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.551915" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.551765" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.549278" elapsed="0.002712"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:46.471997" elapsed="0.080041"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:46.471175" elapsed="0.080940"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.470931" elapsed="0.081231"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.470914" elapsed="0.081272"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.552255" elapsed="0.000034"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:46.331067" elapsed="0.221327"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:44.082902" elapsed="2.469552"/>
</kw>
<doc>Verifies that example-ipv6-topology is filled with ipv6 route</doc>
<status status="PASS" start="2026-06-06T03:15:44.082592" elapsed="2.469928"/>
</kw>
<doc>Verifies that example-ipv6-topology is filled after configuring the peer for the second time.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:43.996732" elapsed="2.555901"/>
</test>
<test id="s1-s5-t8" name="Delete_Bgp_Peer_Configuration_2" line="127">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:46.556699" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:46.556417" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.557978" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.557865" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.557846" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.564819" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.564708" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.564689" elapsed="0.000253"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.565966" 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-06-06T03:15:46.565553" elapsed="0.000440"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.566452" 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-06-06T03:15:46.566155" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:46.566522" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:46.566695" 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-06-06T03:15:46.565176" elapsed="0.001544"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:46.572312" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.572175" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.572155" elapsed="0.000231"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:46.573541" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.573434" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.573415" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:46.574080" 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-06-06T03:15:46.573777" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:46.574482" level="INFO">${current_connection_index} = 7</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-06-06T03:15:46.574265" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:46.606502" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:46.575018" elapsed="0.031704"/>
</kw>
<msg time="2026-06-06T03:15:46.606937" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:46.606984" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:46.574681" elapsed="0.032339"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:46.629932" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "2 "[K"
[?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-06-06T03:15:46.607703" elapsed="0.022455"/>
</kw>
<msg time="2026-06-06T03:15:46.630371" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:46.630419" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:15:46.607257" elapsed="0.023198"/>
</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-06-06T03:15:46.630940" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.630577" elapsed="0.000423"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.630541" elapsed="0.000488"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.631543" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "2 "[K"
[?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-06-06T03:15:46.631177" elapsed="0.000455"/>
</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-06-06T03:15:46.631939" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.631719" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.631699" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:46.632055" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:46.634923" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:15:46.635135" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.633666" elapsed="0.001606"/>
</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="NOT RUN" start="2026-06-06T03:15:46.635612" elapsed="0.000093"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.635970" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:46.633010" elapsed="0.003144"/>
</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-06-06T03:15:46.632416" elapsed="0.003803"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:46.573133" elapsed="0.063204"/>
</kw>
<msg time="2026-06-06T03:15:46.636439" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:46.636485" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:46.572537" elapsed="0.063984"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:46.636955" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:46.636600" elapsed="0.000418"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.636580" elapsed="0.000466"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.637460" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.637819" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.637892" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:46.571837" elapsed="0.066164"/>
</kw>
<msg time="2026-06-06T03:15:46.638094" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:46.638139" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:46.567091" elapsed="0.071083"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.638502" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.638250" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.638231" elapsed="0.000348"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:46.566949" elapsed="0.071654"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:46.566776" elapsed="0.071859"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:46.564314" elapsed="0.074398"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:46.557557" elapsed="0.081212"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:46.557121" elapsed="0.081695"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:46.553808" elapsed="0.085061"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.639786" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:11:0:0:0:2 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib ...</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP_2}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.639074" elapsed="0.000741"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.684167" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.683771" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.685032" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.684763" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.685210" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.684409" elapsed="0.000905"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.685901" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:46.685486" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.686236" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:46.686400" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:46.686093" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.686851" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.686586" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.687886" level="INFO">mapping: {'IP': '2607:f0d0:1002:11:0:0:0:2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.687606" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.688381" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.688093" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.689101" level="INFO">${value} = 2607:f0d0:1002:11:0:0:0:2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.688804" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.690242" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.689802" elapsed="0.000467"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.690322" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:15:46.690483" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.689313" elapsed="0.001195"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.690679" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:11:0:0:0:2</var>
<status status="PASS" start="2026-06-06T03:15:46.688666" elapsed="0.002301"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.691510" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.691213" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.692290" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.692054" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.692370" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:46.692520" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.691736" elapsed="0.000809"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.692713" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:46.691080" elapsed="0.001899"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.693522" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.693223" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.694283" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.694073" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.694360" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:46.694509" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.693753" elapsed="0.000781"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.694705" elapsed="0.000224"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:46.693091" elapsed="0.001881"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.695521" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.695217" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.696342" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.696114" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.696421" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:46.696572" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.695794" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.696766" elapsed="0.000223"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:46.695085" elapsed="0.001946"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.697572" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.697275" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.698334" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.698123" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.698411" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:46.698560" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.697806" elapsed="0.000779"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.698753" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:46.697144" elapsed="0.001873"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.699560" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.699263" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.700343" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.700105" elapsed="0.000265"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.700421" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:46.700571" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.699789" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.700762" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:46.699131" elapsed="0.001896"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.701577" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.701274" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.702520" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.702309" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.702597" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:46.702765" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.701987" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.702940" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:46.701141" elapsed="0.002061"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.703757" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:46.703445" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:46.704520" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.704310" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:46.704597" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:46.704763" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:46.703967" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.704939" elapsed="0.000219"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:46.703314" elapsed="0.001885"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:46.688463" elapsed="0.016771"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:46.705313" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:46.705477" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:46.687283" elapsed="0.018220"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.686975" elapsed="0.018560"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.705726" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.705561" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.686950" elapsed="0.018854"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.706651" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:46.705949" elapsed="0.000733"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.706733" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:46.683137" elapsed="0.023719"/>
</kw>
<msg time="2026-06-06T03:15:46.706913" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.669985" elapsed="0.036975"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.719814" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.732718" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.745515" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.745726" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.745907" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.746272" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.746126" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:46.746111" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.746493" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.746676" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.746847" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:46.746083" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.745983" elapsed="0.000942"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.747069" elapsed="0.000053"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.747183" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:46.747307" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:46.665388" elapsed="0.081946"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.748461" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.748190" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:46.759298" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:46.759347" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A0%3A0%3A0%3A2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:46.759454" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:46.750890" elapsed="0.008591"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.748575" elapsed="0.010947"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.759727" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.759549" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.748557" elapsed="0.011257"/>
</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-06-06T03:15:46.763275" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.760855" elapsed="0.002464"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.760616" elapsed="0.002739"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.760597" elapsed="0.002783"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.766041" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.763679" elapsed="0.002409"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.763436" elapsed="0.002688"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.763419" elapsed="0.002729"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.766720" 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-06-06T03:15:46.766322" elapsed="0.000426"/>
</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-06-06T03:15:46.767059" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.766820" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.767599" 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-06-06T03:15:46.767301" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.767141" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.766801" elapsed="0.000897"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.768220" 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-06-06T03:15:46.767860" elapsed="0.000387"/>
</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-06-06T03:15:46.768580" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.768342" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.769137" 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-06-06T03:15:46.768841" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.768678" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.768322" elapsed="0.000934"/>
</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-06-06T03:15:46.769411" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:46.770227" 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-06-06T03:15:46.769945" elapsed="0.000308"/>
</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-06-06T03:15:46.770410" elapsed="0.002405"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:46.760168" elapsed="0.012712"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:46.772928" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:46.775242" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:46.747599" elapsed="0.027670"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.775324" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:46.640053" elapsed="0.135396"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:15:46.553166" elapsed="0.222402"/>
</test>
<test id="s1-s5-t9" name="Verify_Ipv6_Topology_Empty_2" line="140">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:46.778988" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:46.778721" elapsed="0.000531"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.780247" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.780136" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.780117" elapsed="0.000213"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.785526" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.785419" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.785400" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.786606" 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-06-06T03:15:46.786218" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.787108" 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-06-06T03:15:46.786811" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:46.787178" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:46.787332" 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-06-06T03:15:46.785839" elapsed="0.001517"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:46.793288" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.793151" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.793130" elapsed="0.000232"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:46.794760" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.794478" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.794460" elapsed="0.000369"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:46.795279" 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-06-06T03:15:46.794976" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:46.795706" level="INFO">${current_connection_index} = 7</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-06-06T03:15:46.795469" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:46.826485" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:46.796233" elapsed="0.030357"/>
</kw>
<msg time="2026-06-06T03:15:46.827015" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:46.827064" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:46.795893" elapsed="0.031207"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:46.849580" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "2 "[K"
[?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-06-06T03:15:46.827624" elapsed="0.022140"/>
</kw>
<msg time="2026-06-06T03:15:46.849962" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:46.850009" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:46.827276" elapsed="0.022769"/>
</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-06-06T03:15:46.850465" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.850155" elapsed="0.000373"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.850121" elapsed="0.000437"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.851123" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "2 "[K"
[?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-06-06T03:15:46.850741" elapsed="0.000455"/>
</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-06-06T03:15:46.851509" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.851272" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.851251" elapsed="0.000343"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:46.851635" elapsed="0.000062"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:46.854750" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:15:46.854966" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.853347" elapsed="0.001773"/>
</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="NOT RUN" start="2026-06-06T03:15:46.855406" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.855778" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:46.852669" elapsed="0.003301"/>
</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-06-06T03:15:46.851995" elapsed="0.004044"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:46.794174" elapsed="0.061966"/>
</kw>
<msg time="2026-06-06T03:15:46.856239" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:46.856286" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:46.793529" elapsed="0.062795"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:46.856790" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:46.856434" elapsed="0.000418"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.856414" elapsed="0.000463"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.857282" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.857636" elapsed="0.000051"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.857736" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:46.792803" elapsed="0.065042"/>
</kw>
<msg time="2026-06-06T03:15:46.857940" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:46.857985" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:46.787740" elapsed="0.070280"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.858398" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.858145" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.858126" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:46.787581" elapsed="0.070918"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:46.787410" elapsed="0.071122"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:46.785057" elapsed="0.073529"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:46.779849" elapsed="0.078812"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:46.779404" elapsed="0.079307"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:46.776391" elapsed="0.082375"/>
</kw>
<kw name="Verify_Rib_Status_Empty">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.912065" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.911580" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.912947" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.912672" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.913122" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.912285" elapsed="0.000862"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.913732" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:46.913318" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.914071" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:46.914235" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:46.913929" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.914696" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.914423" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.916008" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.915459" elapsed="0.000607"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.916572" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:46.916246" elapsed="0.000353"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.916968" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.917184" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.917365" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:46.916830" elapsed="0.000594"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.916678" elapsed="0.000777"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:46.917501" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:46.917686" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:46.915132" elapsed="0.002580"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.914823" elapsed="0.002924"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.917925" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.917774" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.914802" elapsed="0.003201"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.918675" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:46.918200" elapsed="0.000506"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:46.918758" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:46.910962" elapsed="0.007926"/>
</kw>
<msg time="2026-06-06T03:15:46.918943" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:46.897930" elapsed="0.021061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.931981" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.944973" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.957945" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.958147" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.958325" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.958710" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.958547" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:46.958531" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.958934" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.959102" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.959267" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:46.958502" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.958401" elapsed="0.000945"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.959491" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.959566" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:46.959742" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:46.893214" elapsed="0.066556"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.961097" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.960855" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.961259" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.960485" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.961602" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.961355" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.962174" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:46.961881" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.961703" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.961336" elapsed="0.000921"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.964692" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:46.962412" elapsed="0.002307"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:46.964772" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:46.964925" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:46.960136" elapsed="0.004814"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:46.966187" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:46.965931" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:46.966368" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:46.965577" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:46.966603" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:46.966465" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.966447" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.966855" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:46.967037" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.967104" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:46.969301" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:46.965254" elapsed="0.004074"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.970757" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.970468" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.971208" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.970961" elapsed="0.000292"/>
</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-06-06T03:15:46.980170" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:46.980316" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:46.980460" 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-06-06T03:15:46.973504" elapsed="0.006984"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.971321" elapsed="0.009210"/>
</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-06-06T03:15:46.980735" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.980557" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.971302" elapsed="0.009558"/>
</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-06-06T03:15:46.985677" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.982128" elapsed="0.003618"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.981812" elapsed="0.003982"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.981785" elapsed="0.004045"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.989514" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:46.986220" elapsed="0.003341"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.985909" elapsed="0.003687"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.985885" elapsed="0.003736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.990197" 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-06-06T03:15:46.989804" elapsed="0.000421"/>
</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-06-06T03:15:46.990534" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.990296" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.991148" 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-06-06T03:15:46.990795" elapsed="0.000380"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.990616" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.990278" elapsed="0.000956"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.991784" 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-06-06T03:15:46.991397" elapsed="0.000415"/>
</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-06-06T03:15:46.992145" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:46.991885" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:46.992731" 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-06-06T03:15:46.992394" elapsed="0.000364"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:46.992230" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.991866" elapsed="0.000952"/>
</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-06-06T03:15:46.992971" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:46.993845" 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-06-06T03:15:46.993525" elapsed="0.000347"/>
</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-06-06T03:15:46.994030" elapsed="0.002521"/>
</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-06-06T03:15:46.981219" elapsed="0.015397"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:46.996812" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:46.996703" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:46.996683" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:47.000139" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:46.997026" elapsed="0.003145"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:47.000229" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:15:47.000440" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:46.969651" elapsed="0.030821"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.000690" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:47.000852" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:46.870016" elapsed="0.130917"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.030287" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.029794" elapsed="0.000522"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.031161" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.030851" elapsed="0.000442">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.031476" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.030486" elapsed="0.001016"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.032140" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.031691" elapsed="0.000478"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.032543" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:47.032739" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:47.032335" elapsed="0.000431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.033203" level="INFO">{
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.032930" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:47.033745" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.033320" elapsed="0.000486"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.034523" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.033978" elapsed="0.000579"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.033831" elapsed="0.000771"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.033299" elapsed="0.001331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.035557" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:47.034891" elapsed="0.000698"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.035675" elapsed="0.000038"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:47.029147" elapsed="0.006670"/>
</kw>
<msg time="2026-06-06T03:15:47.035876" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.016009" elapsed="0.019919"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.049181" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.062333" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.075492" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.075736" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.075920" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.076332" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.076183" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:47.076164" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.076576" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.076767" elapsed="0.000027"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.076947" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:47.076125" elapsed="0.000876"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.076008" elapsed="0.001021"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.077176" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.077253" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:47.077385" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:47.013283" elapsed="0.064130"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.077593" elapsed="0.002348"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:47.081133" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.080787" elapsed="0.000374"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:47.081604" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.081316" elapsed="0.000316"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:47.081814" elapsed="0.000346"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:47.080267" elapsed="0.001955"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.080021" elapsed="0.002234"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.082454" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.082280" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.080002" elapsed="0.002583"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:47.002162" elapsed="0.080474"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:47.001300" elapsed="0.081433"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.001025" elapsed="0.081754"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.001006" elapsed="0.081800"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.082842" elapsed="0.000032"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:46.863709" elapsed="0.219272"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:46.859185" elapsed="0.223859"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty</doc>
<status status="PASS" start="2026-06-06T03:15:46.858906" elapsed="0.224208"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty after deconfiguring peer for the second time.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:46.775795" elapsed="0.307434"/>
</test>
<test id="s1-s5-t10" name="Reconfigure_ODL_To_Accept_Connections_3" line="145">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:47.086917" elapsed="0.000212"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:47.086624" elapsed="0.000560"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.088191" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.088079" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.088059" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.093583" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.093474" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.093456" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.094681" 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-06-06T03:15:47.094280" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.095167" 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-06-06T03:15:47.094871" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:47.095238" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:47.095393" 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-06-06T03:15:47.093900" elapsed="0.001517"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:47.101060" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.100952" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.100932" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:47.102298" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.102191" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.102173" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:47.102837" 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-06-06T03:15:47.102512" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:47.103243" level="INFO">${current_connection_index} = 7</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-06-06T03:15:47.103023" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:47.135487" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:47.103822" elapsed="0.031771"/>
</kw>
<msg time="2026-06-06T03:15:47.135794" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:47.135841" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:47.103431" elapsed="0.032604"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:47.160610" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "3 "[K"
[?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-06-06T03:15:47.136596" elapsed="0.024134"/>
</kw>
<msg time="2026-06-06T03:15:47.160892" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:47.160937" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:15:47.136219" elapsed="0.024754"/>
</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-06-06T03:15:47.161281" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.161052" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.161031" elapsed="0.000329"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.161828" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "3 "[K"
[?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-06-06T03:15:47.161503" elapsed="0.000394"/>
</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-06-06T03:15:47.162181" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.161965" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.161946" elapsed="0.000313"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:47.162293" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:47.164914" elapsed="0.001862"/>
</kw>
<msg time="2026-06-06T03:15:47.166853" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.163809" elapsed="0.003184"/>
</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="NOT RUN" start="2026-06-06T03:15:47.167280" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.167626" elapsed="0.000096"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:47.163170" elapsed="0.004684"/>
</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-06-06T03:15:47.162601" elapsed="0.005334"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:47.101888" elapsed="0.066148"/>
</kw>
<msg time="2026-06-06T03:15:47.168128" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:47.168172" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:47.101278" elapsed="0.066930"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:47.168396" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:47.168286" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.168267" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.168927" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.169261" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.169333" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:47.100600" elapsed="0.068841"/>
</kw>
<msg time="2026-06-06T03:15:47.169534" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:47.169578" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:47.095799" elapsed="0.073815"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.169957" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.169705" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.169687" elapsed="0.000396"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:47.095654" elapsed="0.074454"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:47.095470" elapsed="0.074668"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:47.093107" elapsed="0.077084"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:47.087789" elapsed="0.082457"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:47.087339" elapsed="0.082951"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:47.084199" elapsed="0.086143"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.171264" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:11::2 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP_3}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.170537" elapsed="0.000757"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.206476" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.206082" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.207866" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.207388" elapsed="0.000554">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.208041" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.206886" elapsed="0.001179"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.208655" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.208234" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.208991" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:47.209157" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:47.208848" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.209589" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.209343" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.210635" level="INFO">mapping: {'IP': '2607:f0d0:1002:11::2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.210374" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.211131" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.210860" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.212112" level="INFO">${value} = 2607:f0d0:1002:11::2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.211535" elapsed="0.000602"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.212935" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A11%3A%3A2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.212705" elapsed="0.000258"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.213017" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:47.213179" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A11%3A%3A2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.212328" elapsed="0.000935"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.213423" elapsed="0.000260"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:11::2</var>
<status status="PASS" start="2026-06-06T03:15:47.211399" elapsed="0.002329"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.214316" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.213978" elapsed="0.000366"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.215150" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.214926" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.215234" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:47.215397" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.214560" elapsed="0.000863"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.215586" elapsed="0.000253"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:47.213843" elapsed="0.002043"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.216466" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.216144" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.217289" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.217066" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.217370" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:47.217676" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.216732" elapsed="0.000970"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.217862" elapsed="0.000232"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:47.216002" elapsed="0.002137"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.218715" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.218396" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.219469" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.219251" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.219547" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:47.219716" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.218934" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.219896" elapsed="0.000222"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:47.218253" elapsed="0.001907"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.220770" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.220407" elapsed="0.000391"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.221518" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.221304" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.221596" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:47.221765" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.220987" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.221943" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:47.220274" elapsed="0.001932"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.222774" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.222454" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.223733" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.223305" elapsed="0.000455"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.223812" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:47.223968" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.222986" elapsed="0.001006"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.224185" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:47.222320" elapsed="0.002131"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.225087" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.224731" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.225855" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.225623" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.225933" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:47.226085" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.225304" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.226264" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:47.224582" elapsed="0.001946"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.227089" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.226791" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:47.227845" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.227615" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:47.227924" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:47.228075" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:47.227301" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.228253" elapsed="0.000220"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:47.226654" elapsed="0.001900"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:47.211212" elapsed="0.017399"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:47.228674" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:47.228843" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A11%3A%3A2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'R...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:47.210047" elapsed="0.018824"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.209731" elapsed="0.019172"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.229082" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.228930" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.209706" elapsed="0.019454"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.230030" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:47.229306" elapsed="0.000755"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.230113" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:47.205449" elapsed="0.024791"/>
</kw>
<msg time="2026-06-06T03:15:47.230296" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.192123" elapsed="0.038222"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.243804" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.256908" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.270117" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.270358" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.270551" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.271054" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.270844" elapsed="0.000270"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:47.270824" elapsed="0.000318"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.271290" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.271459" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.271625" elapsed="0.000034"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:47.270782" elapsed="0.000912"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.270656" elapsed="0.001066"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.271871" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.271951" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:15:47.272117" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:47.187664" elapsed="0.084482"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.300090" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.299699" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.300943" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.300669" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.301114" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.300287" elapsed="0.000852"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.301709" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.301304" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.302043" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:47.302269" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:47.301901" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.302727" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.302460" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:47.303159" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.302858" elapsed="0.000360"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.303711" level="INFO">${mapping_to_use} = {'IP': '2607:f0d0:1002:11::2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANC...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.303392" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.303244" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.302838" elapsed="0.000960"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.304734" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11::2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:47.303947" elapsed="0.000818"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.304817" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:47.299060" elapsed="0.005885"/>
</kw>
<msg time="2026-06-06T03:15:47.305005" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.285834" elapsed="0.019219"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.318004" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.330834" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.343819" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.344016" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.344234" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.344621" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.344464" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:47.344449" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.344861" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.345030" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.345196" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:47.344419" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.344313" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.345426" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.345502" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:47.345634" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11::2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:47.283021" elapsed="0.062657"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.346949" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.346707" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.347110" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.346342" elapsed="0.000793"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.347454" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.347206" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.348022" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.347729" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.347535" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.347187" elapsed="0.000918"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.350532" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.348259" elapsed="0.002300"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:47.350611" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:15:47.350783" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:47.346016" elapsed="0.004792"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.352187" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.351940" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.352635" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11::2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.352386" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.353145" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.352899" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.353580" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.353341" elapsed="0.000283"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:47.354447" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:47.354245" elapsed="0.000229"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:47.354818" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:47.354627" elapsed="0.000217"/>
</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-06-06T03:15:47.354995" elapsed="0.000210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.355610" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.355362" elapsed="0.000308"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:47.355714" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:47.355869" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:47.353841" elapsed="0.002053"/>
</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-06-06T03:15:47.411536" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '994', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:11::2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:47.411767" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:47.412072" 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-06-06T03:15:47.358308" elapsed="0.053828"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.355964" elapsed="0.056301"/>
</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-06-06T03:15:47.412859" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.412341" elapsed="0.000685"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.355946" elapsed="0.057133"/>
</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-06-06T03:15:47.420180" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.415799" elapsed="0.004455"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.415197" elapsed="0.005115"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.415148" elapsed="0.005202"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.424295" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.420792" elapsed="0.003570"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.420434" elapsed="0.003979"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.420409" elapsed="0.004040"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.425388" 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-06-06T03:15:47.424785" elapsed="0.000645"/>
</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-06-06T03:15:47.425767" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.425500" elapsed="0.000411"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.426426" 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-06-06T03:15:47.426116" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.425939" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.425481" elapsed="0.001028"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.427052" 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-06-06T03:15:47.426685" elapsed="0.000394"/>
</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-06-06T03:15:47.427383" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.427149" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.427941" 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-06-06T03:15:47.427627" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.427468" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.427130" elapsed="0.000894"/>
</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-06-06T03:15:47.428183" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:47.429057" 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-06-06T03:15:47.428743" elapsed="0.000340"/>
</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-06-06T03:15:47.429242" elapsed="0.002355"/>
</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-06-06T03:15:47.413992" elapsed="0.017691"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:47.431875" elapsed="0.000040"/>
</return>
<status status="PASS" start="2026-06-06T03:15:47.431759" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.431740" elapsed="0.000236"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:47.432127" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.432195" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:47.434561" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:47.351134" elapsed="0.083454"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.434682" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:47.434845" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:47.176264" elapsed="0.258607"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.435315" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.434971" elapsed="0.000418"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.434954" elapsed="0.000459"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.435446" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:47.171572" elapsed="0.263999"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with full text ipv6 address.</doc>
<status status="PASS" start="2026-06-06T03:15:47.083556" elapsed="0.352161"/>
</test>
<test id="s1-s5-t11" name="Verify_Ipv6_Topology_Filled_3" line="161">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:47.439322" elapsed="0.000237"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:47.439055" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.440713" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.440543" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.440523" elapsed="0.000259"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.446365" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.446236" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.446212" elapsed="0.000232"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.447588" 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-06-06T03:15:47.447142" elapsed="0.000474"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.448107" 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-06-06T03:15:47.447800" elapsed="0.000332"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:47.448176" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:47.448340" 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-06-06T03:15:47.446741" elapsed="0.001623"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:47.454083" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.453972" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.453952" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:47.455573" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.455414" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.455386" elapsed="0.000342"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:47.456443" 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-06-06T03:15:47.455975" elapsed="0.000497"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:47.456946" level="INFO">${current_connection_index} = 7</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-06-06T03:15:47.456721" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:47.486778" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:47.457551" elapsed="0.029467"/>
</kw>
<msg time="2026-06-06T03:15:47.487254" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:47.487308" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:47.457143" elapsed="0.030204"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:47.510667" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "F "i "l "l "e "d "_ "3 "[K"
[?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-06-06T03:15:47.488099" elapsed="0.022783"/>
</kw>
<msg time="2026-06-06T03:15:47.511107" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:47.511154" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:47.487605" elapsed="0.023585"/>
</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-06-06T03:15:47.511677" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.511312" elapsed="0.000427"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.511273" elapsed="0.000494"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.512299" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "F "i "l "l "e "d "_ "3 "[K"
[?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-06-06T03:15:47.511916" elapsed="0.000452"/>
</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-06-06T03:15:47.512699" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.512436" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.512418" elapsed="0.000362"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:47.512819" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:47.515464" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:15:47.515806" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.514416" elapsed="0.001534"/>
</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="NOT RUN" start="2026-06-06T03:15:47.516301" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.516636" elapsed="0.000144"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:47.513763" elapsed="0.003135"/>
</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-06-06T03:15:47.513155" elapsed="0.003812"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:47.454996" elapsed="0.062096"/>
</kw>
<msg time="2026-06-06T03:15:47.517214" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:47.517261" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:47.454306" elapsed="0.062991"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:47.517762" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:15:47.517380" elapsed="0.000447"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.517359" elapsed="0.000494"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.518278" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.518628" elapsed="0.000042"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.518720" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:47.453614" elapsed="0.065228"/>
</kw>
<msg time="2026-06-06T03:15:47.518962" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:47.519021" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:47.448808" elapsed="0.070263"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.519423" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.519163" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.519144" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:47.448657" elapsed="0.070868"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:47.448429" elapsed="0.071128"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:47.445665" elapsed="0.073949"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:47.440246" elapsed="0.079464"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:47.439793" elapsed="0.079966"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:47.436797" elapsed="0.083017"/>
</kw>
<kw name="Verify_Rib_Status_Filled">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.573459" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.573059" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.574313" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.574032" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.574498" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.573691" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.575101" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.574714" elapsed="0.000508"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.575552" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:47.575733" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:47.575403" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.576170" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.575920" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.577518" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.576970" elapsed="0.000596"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.578045" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:47.577764" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.578411" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.578621" elapsed="0.000040"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.578820" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:47.578271" elapsed="0.000607"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.578128" elapsed="0.000781"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:47.578956" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:47.579125" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:47.576599" elapsed="0.002551"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.576293" elapsed="0.002890"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.579355" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.579208" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.576269" elapsed="0.003162"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.580038" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:47.579574" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.580118" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:47.572409" elapsed="0.007836"/>
</kw>
<msg time="2026-06-06T03:15:47.580302" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.559235" elapsed="0.021117"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.593420" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.606223" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.619203" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.619418" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.619602" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.620023" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.619870" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:47.619851" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.620249" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.620419" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.620587" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:47.619813" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.619702" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.620863" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.620939" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:47.621065" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:47.554569" elapsed="0.066523"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.622433" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.622155" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.622601" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.621779" elapsed="0.000846"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.623139" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.622876" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.623756" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.623428" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.623222" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.622855" elapsed="0.000986"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.626473" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.623994" elapsed="0.002506"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:47.626554" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:47.626728" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:47.621419" elapsed="0.005335"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.628006" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.627755" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.628226" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.627402" elapsed="0.000850"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:47.628460" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:47.628324" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.628305" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.628720" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.628896" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.628962" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:47.630949" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:47.627067" elapsed="0.003908"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.632383" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.632127" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.632874" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.632584" elapsed="0.000335"/>
</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-06-06T03:15:47.643136" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:47.643276" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:47.643372" 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-06-06T03:15:47.635115" elapsed="0.008284"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.632986" elapsed="0.010455"/>
</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-06-06T03:15:47.643626" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.643470" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.632967" elapsed="0.010771"/>
</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-06-06T03:15:47.647383" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.644779" elapsed="0.002656"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.644512" elapsed="0.002966"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.644493" elapsed="0.003012"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.650182" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.647822" elapsed="0.002406"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.647566" elapsed="0.002697"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.647548" elapsed="0.002740"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.650889" 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-06-06T03:15:47.650471" elapsed="0.000445"/>
</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-06-06T03:15:47.651232" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.650988" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.651800" 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-06-06T03:15:47.651483" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.651315" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.650968" elapsed="0.000916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.652405" 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-06-06T03:15:47.652043" elapsed="0.000389"/>
</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-06-06T03:15:47.652788" elapsed="0.000081"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.652503" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.653397" 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-06-06T03:15:47.653098" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.652934" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.652485" elapsed="0.000995"/>
</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-06-06T03:15:47.653635" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:47.654475" 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-06-06T03:15:47.654173" elapsed="0.000329"/>
</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-06-06T03:15:47.654676" elapsed="0.002349"/>
</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-06-06T03:15:47.644095" elapsed="0.012998"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.657272" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:47.657164" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.657145" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:47.660232" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:47.657494" elapsed="0.002768"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:47.660319" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:47.660495" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:47.631286" elapsed="0.029236"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.660586" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:15:47.660795" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:47.531562" elapsed="0.129261"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.690082" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.689581" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.691095" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.690787" elapsed="0.000436">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:47.691404" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:47.690279" elapsed="0.001150"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.692059" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:47.691597" elapsed="0.000489"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:47.692417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:47.692684" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:47.692251" elapsed="0.000523"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.693219" level="INFO">{
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
                            {
                                "prefix": "2a04:6d80::1/128"
                            }
                        ]
                    },
                    "node-id": "2607:f0d0:1002:11::2"
                }
            ],
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:47.692940" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:47.693767" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.693341" elapsed="0.000488"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.694510" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:47.694003" elapsed="0.000534"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:47.693854" elapsed="0.000719"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:47.693321" elapsed="0.001274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.695248" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:47.694772" elapsed="0.000506"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:47.695328" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:47.688959" elapsed="0.006500"/>
</kw>
<msg time="2026-06-06T03:15:47.695519" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.675688" elapsed="0.019880"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.708391" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.721276" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.734009" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.734203" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.734376" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.734779" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.734613" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:47.734599" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.735000" elapsed="0.000051"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.735208" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.735377" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:47.734569" elapsed="0.000861"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.734462" elapsed="0.000995"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.735605" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.735696" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:47.735816" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:47.672950" elapsed="0.062894"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:47.736020" elapsed="0.004161"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:47.741414" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.740979" elapsed="0.000465"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:47.741913" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:47.741599" elapsed="0.000343"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:15:47.742415" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
     "node-id": "2607:f0d0:1002:11::2"
    }
   ],
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
   }
  }
 ]
}

!=

{
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
   }
  }
 ]
}</msg>
<msg time="2026-06-06T03:15:47.742595" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.742099" elapsed="0.000595">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.740521" elapsed="0.002307">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<status status="FAIL" start="2026-06-06T03:15:47.740271" elapsed="0.002628">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:47.743082" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:47.742932" elapsed="0.000206"/>
</branch>
<status status="FAIL" start="2026-06-06T03:15:47.740251" elapsed="0.002911">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.662020" elapsed="0.081293">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.661175" elapsed="0.082271">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<status status="FAIL" start="2026-06-06T03:15:47.660911" elapsed="0.082615">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</branch>
<status status="FAIL" start="2026-06-06T03:15:47.660892" elapsed="0.082668">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:47.743606" elapsed="0.000016"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:15:47.525092" elapsed="0.218639">Multiline strings are different:
--- first
+++ second
@@ -1,18 +1,6 @@
 {
  "network-topology:topology": [
   {
-   "node": [
-    {
-     "l3-unicast-igp-topology:igp-node-attributes": {
-      "prefix": [
-       {
-        "prefix": "2a04:6d80::1/128"
-       }
-      ]
-     },
-     "node-id": "2607:f0d0:1002:11::2"
-    }
-   ],
    "odl-bgp-topology-config:rib-id": "example-bgp-rib",
    "server-provided": true,
    "topology-id": "example-ipv6-topology",</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.804539" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:49.804112" elapsed="0.000461"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:49.805420" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:49.805148" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:49.805600" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:49.804777" elapsed="0.000848"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.806280" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:49.805870" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:49.806632" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:49.806864" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:49.806476" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.807357" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.807101" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.808492" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.808181" elapsed="0.000357"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.809001" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:49.808725" elapsed="0.000355"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.809423" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.809634" elapsed="0.000046"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.809856" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:49.809283" elapsed="0.000633"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.809138" elapsed="0.000810"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:49.809997" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:49.810175" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:49.807850" elapsed="0.002351"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.807484" elapsed="0.002750"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.810452" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.810261" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.807459" elapsed="0.003077"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.811155" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:49.810705" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:49.811233" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:49.803367" elapsed="0.007989"/>
</kw>
<msg time="2026-06-06T03:15:49.811411" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:49.789606" elapsed="0.021854"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.824904" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.838186" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.851249" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.851482" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.851687" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.852100" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.851950" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:49.851931" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.852400" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.852580" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.852767" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:49.851894" elapsed="0.000928"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.851774" elapsed="0.001076"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.852999" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.853080" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:49.853225" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:49.784850" elapsed="0.068402"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:49.854720" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:49.854406" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:49.854921" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:49.854006" elapsed="0.000950"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.855317" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.855042" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.855912" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:49.855588" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.855404" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.855021" elapsed="0.000988"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.858608" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:49.856168" elapsed="0.002467"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:49.858709" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:49.858893" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:49.853613" elapsed="0.005311"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:49.860181" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:49.859935" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:49.860346" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:49.859571" elapsed="0.000801"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:49.860584" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:49.860445" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.860426" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.860843" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.861042" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.861111" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:49.863633" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:49.859240" elapsed="0.004438"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.865173" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.864911" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.865847" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.865379" elapsed="0.000515"/>
</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-06-06T03:15:49.874921" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:49.875065" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","node":[{"node-id":"2607:f0d0:1002:11::2","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"2a04:6d80::1/128"}]}}],"server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:49.875181" 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-06-06T03:15:49.868134" elapsed="0.007073"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.865962" elapsed="0.009290"/>
</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-06-06T03:15:49.875439" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.875279" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.865944" elapsed="0.009589"/>
</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-06-06T03:15:49.880627" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","node":[{"node-id":"2607:f0d0:1002:11::2","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"2a04:6d80::1/128"}]}}],"server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.877033" elapsed="0.003697"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.876711" elapsed="0.004072"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.876682" elapsed="0.004137"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.884820" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.881224" elapsed="0.003668"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.880901" elapsed="0.004047"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.880876" elapsed="0.004109"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.885989" 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-06-06T03:15:49.885266" elapsed="0.000763"/>
</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-06-06T03:15:49.886493" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.886147" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.887076" 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-06-06T03:15:49.886766" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.886577" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.886117" elapsed="0.001053"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.887768" 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-06-06T03:15:49.887336" elapsed="0.000467"/>
</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-06-06T03:15:49.888129" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.887884" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.888700" 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-06-06T03:15:49.888379" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.888215" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.887864" elapsed="0.000921"/>
</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-06-06T03:15:49.888949" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:49.889858" 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-06-06T03:15:49.889480" elapsed="0.000407"/>
</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-06-06T03:15:49.890067" elapsed="0.002565"/>
</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-06-06T03:15:49.876071" elapsed="0.016725"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.892989" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:49.892872" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.892853" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:49.896194" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<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="PASS" start="2026-06-06T03:15:49.893214" elapsed="0.003011"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:49.896285" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:15:49.896460" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:49.864065" elapsed="0.032422"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:49.896554" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:49.896729" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:49.761144" elapsed="0.135613"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.928666" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:49.928082" elapsed="0.000621"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:49.929614" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:49.929297" elapsed="0.000469">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:49.929988" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:49.928925" elapsed="0.001088"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.930677" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:49.930188" elapsed="0.000519"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:49.931042" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_filled/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:49.931237" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:49.930873" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.931726" level="INFO">{
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
                            {
                                "prefix": "2a04:6d80::1/128"
                            }
                        ]
                    },
                    "node-id": "2607:f0d0:1002:11::2"
                }
            ],
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:49.931429" elapsed="0.000349"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:49.932409" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.931860" elapsed="0.000617"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.933268" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:49.932673" elapsed="0.000623"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.932504" elapsed="0.000830"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.931835" elapsed="0.001522"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.934086" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:49.933514" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:49.934184" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:49.927304" elapsed="0.007021"/>
</kw>
<msg time="2026-06-06T03:15:49.934385" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:49.913135" elapsed="0.021301"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.948057" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.961389" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_filled/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.975163" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.975391" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.975581" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.976022" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.975865" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:49.975846" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.976250" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.976420" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.976587" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:49.975806" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.975683" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.976835" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.976915" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:15:49.977066" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "node": [
                {
                    "l3-unicast-igp-topology:igp-node-attributes": {
                        "prefix": [
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:49.909880" elapsed="0.067281"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:49.977346" elapsed="0.002434"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:49.981032" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:49.980541" elapsed="0.000520"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:49.981632" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "2a04:6d80::1/128"
       }
      ]
     },
...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:49.981218" elapsed="0.000467"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:49.981884" elapsed="0.000344"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:49.980107" elapsed="0.002182"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.979862" elapsed="0.002461"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:49.982500" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:49.982349" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.979842" elapsed="0.002735"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:49.898015" elapsed="0.084610"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:49.897115" elapsed="0.085609"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:49.896844" elapsed="0.085927"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.896825" elapsed="0.085971"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:49.982832" elapsed="0.000034"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:49.754572" elapsed="0.228397"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_filled</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:47.520243" elapsed="2.462786"/>
</kw>
<doc>Verifies that example-ipv6-topology is filled with ipv6 route</doc>
<status status="PASS" start="2026-06-06T03:15:47.519956" elapsed="2.463139"/>
</kw>
<doc>Verifies that example-ipv6-topology is filled after configuring the peer for the third time.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:47.436126" elapsed="2.547083"/>
</test>
<test id="s1-s5-t12" name="Delete_Bgp_Peer_Configuration_3" line="166">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:49.986930" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:49.986561" elapsed="0.000654"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.988272" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:49.988158" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.988137" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:49.993867" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:49.993713" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:49.993694" elapsed="0.000247"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.995003" 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-06-06T03:15:49.994591" elapsed="0.000439"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:49.995553" 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-06-06T03:15:49.995246" elapsed="0.000335"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:49.995627" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:15:49.995806" 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-06-06T03:15:49.994175" elapsed="0.001656"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:50.001636" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.001503" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.001476" elapsed="0.000247"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:50.002972" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.002859" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.002838" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:50.003497" 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-06-06T03:15:50.003191" elapsed="0.000333"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.003926" level="INFO">${current_connection_index} = 7</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-06-06T03:15:50.003706" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.036049" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:50.004451" elapsed="0.031750"/>
</kw>
<msg time="2026-06-06T03:15:50.036399" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:50.036446" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:50.004114" elapsed="0.032368"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.062825" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "3 "[K"
[?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-06-06T03:15:50.037128" elapsed="0.025835"/>
</kw>
<msg time="2026-06-06T03:15:50.063144" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:50.063193" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:15:50.036727" elapsed="0.026502"/>
</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-06-06T03:15:50.063684" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.063334" elapsed="0.000417"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.063302" elapsed="0.000479"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.064275" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "3 "[K"
[?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-06-06T03:15:50.063935" elapsed="0.000411"/>
</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-06-06T03:15:50.064702" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.064417" elapsed="0.000361"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.064397" elapsed="0.000418"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:50.064866" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:50.068196" elapsed="0.000170"/>
</kw>
<msg time="2026-06-06T03:15:50.068442" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.066966" elapsed="0.001621"/>
</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="NOT RUN" start="2026-06-06T03:15:50.069147" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.069494" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:50.066062" elapsed="0.003640"/>
</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-06-06T03:15:50.065218" elapsed="0.004609"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:50.002501" elapsed="0.067482"/>
</kw>
<msg time="2026-06-06T03:15:50.070084" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.070130" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.001913" elapsed="0.068254"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:50.070377" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:15:50.070258" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.070233" elapsed="0.000235"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.070923" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.071273" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.071346" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:50.001143" elapsed="0.070314"/>
</kw>
<msg time="2026-06-06T03:15:50.071577" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.071632" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:49.996229" elapsed="0.075461"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.072026" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.071769" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.071751" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:49.996082" elapsed="0.076047"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:49.995895" elapsed="0.076267"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:49.993325" elapsed="0.078896"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:49.987859" elapsed="0.084420"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:49.987371" elapsed="0.084957"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:49.984240" elapsed="0.088144"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.073371" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:11::2 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP_3}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.072622" elapsed="0.000779"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.120394" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:50.119959" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.121249" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:50.120990" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:50.121488" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:50.120617" elapsed="0.000910"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.122183" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:50.121747" elapsed="0.000465"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.122654" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:50.122827" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:50.122480" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.123277" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.123018" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.124463" level="INFO">mapping: {'IP': '2607:f0d0:1002:11::2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.124191" elapsed="0.000320"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.124972" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.124695" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.125772" level="INFO">${value} = 2607:f0d0:1002:11::2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.125423" elapsed="0.000376"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.126896" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A11%3A%3A2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.126659" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.126982" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:15:50.127151" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A11%3A%3A2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.126039" elapsed="0.001138"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.127339" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:11::2</var>
<status status="PASS" start="2026-06-06T03:15:50.125253" elapsed="0.002375"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.128234" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.127919" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.129016" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.128798" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.129094" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:50.129248" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.128454" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.129428" elapsed="0.000250"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:50.127775" elapsed="0.001945"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.130593" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.130237" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.131409" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.131183" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.131488" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:50.131663" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.130841" elapsed="0.000849"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.131852" elapsed="0.000227"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:50.129837" elapsed="0.002284"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.132685" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.132368" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.133449" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.133236" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.133529" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:50.133764" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.132899" elapsed="0.000891"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.133998" elapsed="0.000234"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:50.132235" elapsed="0.002041"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.134842" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.134524" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.135588" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.135376" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.135682" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:50.135833" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.135058" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.136010" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:50.134390" elapsed="0.001882"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.136834" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.136517" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.137793" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.137370" elapsed="0.000450"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.137873" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:15:50.138039" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.137045" elapsed="0.001019"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.138215" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:50.136385" elapsed="0.002093"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.139036" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.138735" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.139790" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.139563" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.139866" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:50.140014" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.139247" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.140189" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:50.138588" elapsed="0.001862"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.141004" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.140707" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.141760" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.141530" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.141838" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:50.142045" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.141214" elapsed="0.000857"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.142225" elapsed="0.000224"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:50.140561" elapsed="0.001930"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:50.125056" elapsed="0.017470"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:50.142571" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:50.142777" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A11%3A%3A2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'R...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:50.123824" elapsed="0.018981"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.123410" elapsed="0.019429"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.143070" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.142910" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.123383" elapsed="0.019765"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.144152" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:50.143295" elapsed="0.000889"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.144237" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:50.119145" elapsed="0.025223"/>
</kw>
<msg time="2026-06-06T03:15:50.144427" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.105059" elapsed="0.039422"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.158580" elapsed="0.000054"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.171742" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.184515" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.184762" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.184954" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.185373" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.185221" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:50.185202" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.185631" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.185819" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.186018" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:50.185162" elapsed="0.000914"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.185042" elapsed="0.001061"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.186256" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.186339" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:50.186498" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:50.099630" elapsed="0.086966"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.187842" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.187517" elapsed="0.000378"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:50.200124" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:50.200181" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A11%3A%3A2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:50.200305" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:50.190376" elapsed="0.009956"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.187965" elapsed="0.012415"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.200737" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.200411" elapsed="0.000474"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.187946" elapsed="0.012987"/>
</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-06-06T03:15:50.209394" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.203373" elapsed="0.006127"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.202822" elapsed="0.006765"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.202775" elapsed="0.006903"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.212900" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.210459" elapsed="0.002487"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.209820" elapsed="0.003162"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.209779" elapsed="0.003228"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.213632" 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-06-06T03:15:50.213193" elapsed="0.000489"/>
</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-06-06T03:15:50.214056" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.213755" elapsed="0.000362"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.214662" 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-06-06T03:15:50.214304" elapsed="0.000387"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.214141" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.213736" elapsed="0.001012"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.215276" 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-06-06T03:15:50.214910" elapsed="0.000393"/>
</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-06-06T03:15:50.215612" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.215373" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.216166" 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-06-06T03:15:50.215871" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.215711" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.215355" elapsed="0.000892"/>
</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-06-06T03:15:50.216402" elapsed="0.000367"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:50.217379" 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-06-06T03:15:50.216938" elapsed="0.000468"/>
</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-06-06T03:15:50.217566" elapsed="0.002411"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:50.201785" elapsed="0.018268"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:50.220111" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:15:50.222483" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:50.186893" elapsed="0.035619"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.222570" elapsed="0.000029"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:50.073665" elapsed="0.149051"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:15:49.983613" elapsed="0.239233"/>
</test>
<test id="s1-s5-t13" name="Verify_Ipv6_Topology_Empty_3" line="179">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:50.226415" elapsed="0.000281"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:50.226131" elapsed="0.000628"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.227871" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.227737" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.227713" elapsed="0.000232"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.233450" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.233319" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.233298" elapsed="0.000229"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.234771" 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-06-06T03:15:50.234288" elapsed="0.000512"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.235281" 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-06-06T03:15:50.234971" elapsed="0.000336"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:50.235362" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:15:50.235569" 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-06-06T03:15:50.233828" elapsed="0.001775"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:50.241730" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.241560" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.241532" elapsed="0.000288"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:50.243415" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.243293" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.243268" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:50.244013" 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-06-06T03:15:50.243679" elapsed="0.000368"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.244511" level="INFO">${current_connection_index} = 7</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-06-06T03:15:50.244260" elapsed="0.000284"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.274746" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:50.245116" elapsed="0.029865"/>
</kw>
<msg time="2026-06-06T03:15:50.275216" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:50.275265" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:50.244742" elapsed="0.030559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.297115" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "3 "[K"
[?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-06-06T03:15:50.276027" elapsed="0.021383"/>
</kw>
<msg time="2026-06-06T03:15:50.297634" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:50.297708" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:50.275559" elapsed="0.022188"/>
</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-06-06T03:15:50.298213" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.297859" elapsed="0.000414"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.297826" elapsed="0.000473"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.298846" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "3 "[K"
[?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-06-06T03:15:50.298444" elapsed="0.000470"/>
</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-06-06T03:15:50.299202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.298983" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.298963" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:50.299320" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:50.302053" elapsed="0.001981"/>
</kw>
<msg time="2026-06-06T03:15:50.304118" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.300905" elapsed="0.003361"/>
</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="NOT RUN" start="2026-06-06T03:15:50.304566" elapsed="0.000096"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.304924" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:50.300239" elapsed="0.004875"/>
</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-06-06T03:15:50.299663" elapsed="0.005516"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:50.242910" elapsed="0.062369"/>
</kw>
<msg time="2026-06-06T03:15:50.305377" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.305422" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.242049" elapsed="0.063410"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:50.305687" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:15:50.305548" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.305525" elapsed="0.000250"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.306303" elapsed="0.000034"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.306720" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.306800" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:50.241123" elapsed="0.065788"/>
</kw>
<msg time="2026-06-06T03:15:50.307007" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.307051" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:50.236042" elapsed="0.071045"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.307425" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.307165" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.307146" elapsed="0.000358"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:50.235892" elapsed="0.071635"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:50.235687" elapsed="0.071872"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:50.232885" elapsed="0.074811"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:50.227398" elapsed="0.080356"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.226919" elapsed="0.080881"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:50.223843" elapsed="0.084009"/>
</kw>
<kw name="Verify_Rib_Status_Empty">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.362943" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:50.362484" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.363816" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:50.363517" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:50.363992" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:50.363164" elapsed="0.000853"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.364573" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:50.364185" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.364936" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:50.365109" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:50.364782" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.365541" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.365293" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.367020" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.366394" elapsed="0.000674"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.367512" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.367234" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.367910" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.368121" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.368298" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:50.367773" elapsed="0.000583"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.367597" elapsed="0.000789"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:50.368434" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:50.368601" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:50.366066" elapsed="0.002561"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.365681" elapsed="0.002996"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.368852" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.368702" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.365656" elapsed="0.003277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.369536" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:50.369088" elapsed="0.000476"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.369765" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:50.361779" elapsed="0.008121"/>
</kw>
<msg time="2026-06-06T03:15:50.370038" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.348471" elapsed="0.021620"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.383369" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.396309" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.409820" elapsed="0.000043"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.410109" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.410302" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.410771" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.410578" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:50.410557" elapsed="0.000303"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.411008" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.411178" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.411343" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:50.410517" elapsed="0.000880"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.410391" elapsed="0.001034"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.411575" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.411674" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:15:50.411829" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:50.343546" elapsed="0.068311"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.413326" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:50.413028" elapsed="0.000478">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:50.413629" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:50.412571" elapsed="0.001109"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.414074" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.413760" elapsed="0.000385"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.414871" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:50.414426" elapsed="0.000483"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.414179" elapsed="0.000782"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.413739" elapsed="0.001256"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.417884" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:50.415218" elapsed="0.002695"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:50.417968" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:50.418174" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:50.412212" elapsed="0.005989"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.419517" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:50.419234" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:50.419699" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:50.418885" elapsed="0.000842"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:50.419942" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:50.419801" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.419782" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.420180" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.420358" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.420427" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:50.422542" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:50.418524" elapsed="0.004046"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.424013" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.423751" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.424513" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.424218" elapsed="0.000342"/>
</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-06-06T03:15:50.433373" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:50.433519" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:50.433635" 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-06-06T03:15:50.426846" elapsed="0.006844"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.424629" elapsed="0.009119"/>
</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-06-06T03:15:50.433950" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.433786" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.424610" elapsed="0.009525"/>
</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-06-06T03:15:50.438164" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.435398" elapsed="0.002817"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.435167" elapsed="0.003084"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.435146" elapsed="0.003131"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.442170" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.438730" elapsed="0.003507"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.438335" elapsed="0.003952"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.438317" elapsed="0.004005"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.443139" 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-06-06T03:15:50.442569" elapsed="0.000609"/>
</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-06-06T03:15:50.443619" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.443281" elapsed="0.000443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.444412" 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-06-06T03:15:50.443991" elapsed="0.000459"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.443759" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.443253" elapsed="0.001278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.445324" 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-06-06T03:15:50.444782" elapsed="0.000590"/>
</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-06-06T03:15:50.445952" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.445506" elapsed="0.000580"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.446792" 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-06-06T03:15:50.446364" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.446124" elapsed="0.000731"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.445467" elapsed="0.001409"/>
</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-06-06T03:15:50.447034" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:50.447899" 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-06-06T03:15:50.447557" elapsed="0.000368"/>
</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-06-06T03:15:50.448083" elapsed="0.002429"/>
</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-06-06T03:15:50.434614" elapsed="0.015965"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.450777" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.450665" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.450631" elapsed="0.000215"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:50.453769" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:50.450994" elapsed="0.002804"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:50.453852" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:15:50.454014" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:50.422904" elapsed="0.031154"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.454123" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:50.454276" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:50.319604" elapsed="0.134698"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.484143" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:50.483632" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.485053" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:50.484710" elapsed="0.000472">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:50.485360" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:50.484341" elapsed="0.001045"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.486020" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:50.485554" elapsed="0.000494"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.486409" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:50.486574" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:50.486244" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.487069" level="INFO">{
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.486789" elapsed="0.000329"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:50.487656" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.487189" elapsed="0.000533"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.488409" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:50.487898" elapsed="0.000538"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.487749" elapsed="0.000723"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.487168" elapsed="0.001326"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.489141" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:50.488660" elapsed="0.000511"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.489221" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:50.483014" elapsed="0.006361"/>
</kw>
<msg time="2026-06-06T03:15:50.489433" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.469301" elapsed="0.020182"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.504103" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.517816" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.530741" elapsed="0.000036"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.530977" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.531163" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.531585" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.531430" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:50.531413" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.531833" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.532003" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.532170" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:50.531375" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.531253" elapsed="0.000997"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.532398" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.532478" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:50.532693" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:50.466501" elapsed="0.066223"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.532908" elapsed="0.002814"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:50.536892" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.536534" elapsed="0.000386"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:50.537367" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.537077" elapsed="0.000317"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:50.537557" elapsed="0.000363"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:50.536088" elapsed="0.001896"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.535810" elapsed="0.002209"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.538237" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.538045" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.535789" elapsed="0.002594"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:50.455521" elapsed="0.082915"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:50.454708" elapsed="0.083810"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.454439" elapsed="0.084129"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.454420" elapsed="0.084174"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.538631" elapsed="0.000050"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:50.312999" elapsed="0.225788"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:50.308305" elapsed="0.230543"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty</doc>
<status status="PASS" start="2026-06-06T03:15:50.307992" elapsed="0.230923"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty after final deconfiguration.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:50.223182" elapsed="0.315875"/>
</test>
<test id="s1-s5-t14" name="Stop_All_Exabgps" line="184">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:50.542507" elapsed="0.000230"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:50.542241" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.543800" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.543687" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.543667" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.548950" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.548842" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.548823" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.550033" 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-06-06T03:15:50.549631" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.550543" 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-06-06T03:15:50.550245" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:50.550613" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:15:50.550787" 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-06-06T03:15:50.549248" elapsed="0.001564"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:50.556617" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.556507" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.556487" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:50.557912" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.557802" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.557783" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:50.558484" 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-06-06T03:15:50.558172" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.558917" level="INFO">${current_connection_index} = 7</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-06-06T03:15:50.558698" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.588374" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:50.559448" elapsed="0.029038"/>
</kw>
<msg time="2026-06-06T03:15:50.588683" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:50.588745" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:50.559106" elapsed="0.029763"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.607383" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "[K"
[?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-06-06T03:15:50.589449" elapsed="0.018035"/>
</kw>
<msg time="2026-06-06T03:15:50.607668" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:50.607717" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "[K"
[?1l...</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-06-06T03:15:50.589072" elapsed="0.018683"/>
</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-06-06T03:15:50.608073" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.607838" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.607816" elapsed="0.000338"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.608608" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "[K"
[?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-06-06T03:15:50.608301" elapsed="0.000392"/>
</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-06-06T03:15:50.608984" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.608763" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.608744" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:50.609099" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:50.611701" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:15:50.611914" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.610593" elapsed="0.001454"/>
</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="NOT RUN" start="2026-06-06T03:15:50.612323" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.612687" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:50.609948" elapsed="0.002925"/>
</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-06-06T03:15:50.609382" elapsed="0.003558"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:50.557467" elapsed="0.055572"/>
</kw>
<msg time="2026-06-06T03:15:50.613135" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.613180" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "[K"
[?1l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.556856" elapsed="0.056362"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:50.613406" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:50.613296" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.613276" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.613911" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.614278" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.614353" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:50.556163" elapsed="0.058301"/>
</kw>
<msg time="2026-06-06T03:15:50.614559" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.614604" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "[K"
[?1l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:50.551181" elapsed="0.063476"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.614990" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.614736" elapsed="0.000345"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.614718" elapsed="0.000390"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:50.551039" elapsed="0.064094"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:50.550867" elapsed="0.064298"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:50.548464" elapsed="0.066757"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:50.543377" elapsed="0.071901"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.542945" elapsed="0.072379"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:50.539954" elapsed="0.075423"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.624886" level="INFO">Executing command 'cat exaipv6.log'.</msg>
<msg time="2026-06-06T03:15:50.637496" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:50.637661" level="INFO">${output_log} = 03:15:39 | 4145   | welcome         | Thank you for using ExaBGP
03:15:39 | 4145   | version         | 4.2.4
03:15:39 | 4145   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:50.624739" elapsed="0.012963"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.638348" level="INFO">03:15:39 | 4145   | welcome         | Thank you for using ExaBGP
03:15:39 | 4145   | version         | 4.2.4
03:15:39 | 4145   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03:15:39 | 4145   | os              | Linux releng-26932-288-0-builder-0 5.15.0-173-generic #183-Ubuntu SMP Fri Mar 6 13:29:34 UTC 2026 x86_64
03:15:39 | 4145   | installation    | /tmp/defaultvenv
03:15:39 | 4145   | advice          | environment file missing
03:15:39 | 4145   | advice          | generate it using "exabgp --fi &gt; /tmp/defaultvenv/etc/exabgp/exabgp.env"
03:15:41 | 4145   | advice          | 
03:15:41 | 4145   | advice          | Your OS is very slow when returning the host FQDN
03:15:41 | 4145   | advice          | Most likely you do not have valid forward/reverse DNS setup
03:15:41 | 4145   | advice          | Adding your hostname to the /etc/hosts file should fix the issue
03:15:41 | 4145   | advice          | 
03:15:41 | 4145   | cli             | could not find the named pipes (exabgp.in and exabgp.out) required for the cli
03:15:41 | 4145   | cli             | we scanned the following folders (the number is your PID):
03:15:41 | 4145   | cli control     |  - /run/exabgp/
03:15:41 | 4145   | cli control     |  - /run/1001/
03:15:41 | 4145   | cli control     |  - /run/
03:15:41 | 4145   | cli control     |  - /var/run/exabgp/
03:15:41 | 4145   | cli control     |  - /var/run/1001/
03:15:41 | 4145   | cli control     |  - /var/run/
03:15:41 | 4145   | cli control     |  - /tmp/defaultvenv/run/exabgp/
03:15:41 | 4145   | cli control     |  - /tmp/defaultvenv/run/1001/
03:15:41 | 4145   | cli control     |  - /tmp/defaultvenv/run/
03:15:41 | 4145   | cli control     |  - /tmp/defaultvenv/var/run/exabgp/
03:15:41 | 4145   | cli control     |  - /tmp/defaultvenv/var/run/1001/
03:15:41 | 4145   | cli control     |  - /tmp/defaultvenv/var/run/
03:15:41 | 4145   | cli control     | please make them in one of the folder with the following commands:
03:15:41 | 4145   | cli control     | &gt; mkfifo /home/jenkins/run/exabgp.{in,out}
03:15:41 | 4145   | cli control     | &gt; chmod 600 /home/jenkins/run/exabgp.{in,out}
03:15:41 | 4145   | cli control     | &gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}
03:15:41 | 4145   | configuration   | performing reload of exabgp 4.2.4
03:15:41 | 4145   | configuration   | &gt; neighbor         | '::1'
03:15:41 | 4145   | configuration   | . router-id        | '1.2.3.4'
03:15:41 | 4145   | configuration   | . local-address    | '2607:f0d0:1002:0011:0000:0000:0000:0002'
03:15:41 | 4145   | configuration   | . local-as         | '64496'
03:15:41 | 4145   | configuration   | . peer-as          | '64496'
03:15:41 | 4145   | configuration   | &gt; capability       | 
03:15:41 | 4145   | configuration   | . route-refresh    | 'disable'
03:15:41 | 4145   | configuration   | . add-path         | 'disable'
03:15:41 | 4145   | configuration   | &lt; capability       | 
03:15:41 | 4145   | configuration   | &gt; family           | 
03:15:41 | 4145   | configuration   | . ipv6             | 'unicast'
03:15:41 | 4145   | configuration   | &lt; family           | 
03:15:41 | 4145   | configuration   | &gt; static           | 
03:15:41 | 4145   | configuration   | . route            | '2a04:6d80::1/128' 'next-hop' 'self'
03:15:41 | 4145   | configuration   | &lt; static           | 
03:15:41 | 4145   | configuration   | &lt; neighbor         | 
03:15:41 | 4145   | reactor         | new peer: neighbor ::1 local-ip 2607:f0d0:1002:0011:0000:0000:0000:0002 local-as 64496 peer-as 64496 router-id 1.2.3.4 family-allowed in-open
03:15:41 | 4145   | reactor         | loaded new configuration successfully
03:15:41 | 4145   | reactor         | initialising connection to peer-1
03:15:41 | 4145   | outgoing-1      | attempting connection to ::1:1790
03:15:41 | 4145   | outgoing-1      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0102 0304 1402 0601 0400 0200 0102 0641 0400 00FB F002 0206 00
03:15:41 | 4145   | outgoing-1      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), ASN4(64496)]
03:15:41 | 4145   | ka-outgoing-1   | receive-timer 60 second(s) left
03:15:41 | 4145   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:15:41 | 4145   | outgoing-1      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 00B4 4700
03:15:41 | 4145   | outgoing-1      | &lt;&lt; message of type OPEN
03:15:41 | 4145   | outgoing-1      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:41 | 4145   | outgoing-1      | --------------------------------------------------------------------
03:15:41 | 4145   | outgoing-1      | the connection can not carry the following family/families
03:15:41 | 4145   | outgoing-1      |  - exabgp is not configured for ipv4/unicast
03:15:41 | 4145   | outgoing-1      | therefore no routes of this kind can be announced on the connection
03:15:41 | 4145   | outgoing-1      | --------------------------------------------------------------------
03:15:41 | 4145   | outgoing-1      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:41 | 4145   | outgoing-1      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:41 | 4145   | ka-outgoing-1   | receive-timer 180 second(s) left
03:15:41 | 4145   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:41 | 4145   | outgoing-1      | &lt;&lt; message of type KEEPALIVE
03:15:41 | 4145   | reactor         | connected to peer-1 with outgoing-1 2607:f0d0:1002:0011:0000:0000:0000:0002-::1
03:15:41 | 4145   | outgoing-1      | sending TCP payload (  78) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004E 0200 0000 3740 0101 0040 0200 4005 0400 0000 6480 0E26 0002 0110 2607 F0D0 1002 0011 0000 0000 0000 0002 0080 2A04 6D80 0000 0000 0000 0000 0000 0001
03:15:41 | 4145   | outgoing-1      | &gt;&gt; 1 UPDATE(s)
03:15:41 | 4145   | outgoing-1      | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0201
03:15:41 | 4145   | outgoing-1      | &gt;&gt; EOR ipv6 unicast
03:15:41 | 4145   | peer-1          | &gt;&gt; EOR(s)
03:15:41 | 4145   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:41 | 4145   | outgoing-1      | received TCP payload (   4) 0000 0000
03:15:41 | 4145   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:41 | 4145   | parser          | parsing UPDATE (   4) 0000 0000
03:15:41 | 4145   | peer-1          | &lt;&lt; UPDATE #1
03:15:41 | 4145   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:41 | 4145   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:41 | 4145   | outgoing-1      | received TCP payload (   4) 0000 0000
03:15:41 | 4145   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:41 | 4145   | parser          | parsing UPDATE (   4) 0000 0000
03:15:41 | 4145   | peer-1          | &lt;&lt; UPDATE #2
03:15:41 | 4145   | peer-1          |    UPDATE #2 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:41 | 4145   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02
03:15:41 | 4145   | outgoing-1      | received TCP payload (  10) 0000 0006 800F 0300 0201
03:15:41 | 4145   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:41 | 4145   | parser          | parsing UPDATE (  10) 0000 0006 800F 0300 0201
03:15:41 | 4145   | routes          | withdrawn NLRI none
03:15:41 | 4145   | parser          | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0002 01
03:15:41 | 4145   | routes          | announced NLRI none
03:15:41 | 4145   | peer-1          | &lt;&lt; UPDATE #3
03:15:41 | 4145   | peer-1          |    UPDATE #3 nlri  (  11) eor 2/1 (ipv6 unicast)
03:15:41 | 4145   | ka-outgoing-1   | receive-timer 179 second(s) left
03:15:41 | 4145   | ka-outgoing-1   | send-timer 59 second(s) left
03:15:42 | 4145   | ka-outgoing-1   | receive-timer 178 second(s) left
03:15:42 | 4145   | ka-outgoing-1   | send-timer 58 second(s) left
03:15:43 | 4145   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:43 | 4145   | outgoing-1      | received TCP payload (   2) 0600
03:15:43 | 4145   | outgoing-1      | &lt;&lt; message of type NOTIFICATION
03:15:43 | 4145   | outgoing-1      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:43 | 4145   | outgoing-1      | outgoing-1 2607:f0d0:1002:0011:0000:0000:0000:0002-::1, closing connection
03:15:43 | 4145   | reactor         | initialising connection to peer-1
03:15:43 | 4145   | outgoing-2      | attempting connection to ::1:1790
03:15:43 | 4145   | outgoing-2      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0102 0304 1402 0601 0400 0200 0102 0641 0400 00FB F002 0206 00
03:15:43 | 4145   | outgoing-2      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), ASN4(64496)]
03:15:43 | 4145   | ka-outgoing-2   | receive-timer 60 second(s) left
03:15:43 | 4145   | outgoing-2      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:43 | 4145   | outgoing-2      | received TCP payload (   2) 0605
03:15:43 | 4145   | outgoing-2      | &lt;&lt; message of type NOTIFICATION
03:15:43 | 4145   | outgoing-2      | peer reset, message [notification received (6,5)] error[Cease / Connection Rejected]
03:15:43 | 4145   | outgoing-2      | outgoing-2 2607:f0d0:1002:0011:0000:0000:0000:0002-::1, closing connection
03:15:44 | 4145   | reactor         | initialising connection to peer-1
03:15:44 | 4145   | outgoing-3      | attempting connection to ::1:1790
03:15:44 | 4145   | outgoing-3      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0102 0304 1402 0601 0400 0200 0102 0641 0400 00FB F002 0206 00
03:15:44 | 4145   | outgoing-3      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), ASN4(64496)]
03:15:44 | 4145   | ka-outgoing-3   | receive-timer 60 second(s) left
03:15:44 | 4145   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:15:44 | 4145   | outgoing-3      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 00B4 4700
03:15:44 | 4145   | outgoing-3      | &lt;&lt; message of type OPEN
03:15:44 | 4145   | outgoing-3      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:44 | 4145   | outgoing-3      | --------------------------------------------------------------------
03:15:44 | 4145   | outgoing-3      | the connection can not carry the following family/families
03:15:44 | 4145   | outgoing-3      |  - exabgp is not configured for ipv4/unicast
03:15:44 | 4145   | outgoing-3      | therefore no routes of this kind can be announced on the connection
03:15:44 | 4145   | outgoing-3      | --------------------------------------------------------------------
03:15:44 | 4145   | outgoing-3      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:44 | 4145   | outgoing-3      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:44 | 4145   | ka-outgoing-3   | receive-timer 180 second(s) left
03:15:44 | 4145   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:44 | 4145   | outgoing-3      | &lt;&lt; message of type KEEPALIVE
03:15:44 | 4145   | reactor         | connected to peer-1 with outgoing-3 2607:f0d0:1002:0011:0000:0000:0000:0002-::1
03:15:44 | 4145   | outgoing-3      | sending TCP payload (  78) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004E 0200 0000 3740 0101 0040 0200 4005 0400 0000 6480 0E26 0002 0110 2607 F0D0 1002 0011 0000 0000 0000 0002 0080 2A04 6D80 0000 0000 0000 0000 0000 0001
03:15:44 | 4145   | outgoing-3      | &gt;&gt; 1 UPDATE(s)
03:15:44 | 4145   | outgoing-3      | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0201
03:15:44 | 4145   | outgoing-3      | &gt;&gt; EOR ipv6 unicast
03:15:44 | 4145   | peer-1          | &gt;&gt; EOR(s)
03:15:44 | 4145   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:44 | 4145   | outgoing-3      | received TCP payload (   4) 0000 0000
03:15:44 | 4145   | outgoing-3      | &lt;&lt; message of type UPDATE
03:15:44 | 4145   | parser          | parsing UPDATE (   4) 0000 0000
03:15:44 | 4145   | peer-1          | &lt;&lt; UPDATE #1
03:15:44 | 4145   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:44 | 4145   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:44 | 4145   | outgoing-3      | received TCP payload (   4) 0000 0000
03:15:44 | 4145   | outgoing-3      | &lt;&lt; message of type UPDATE
03:15:44 | 4145   | parser          | parsing UPDATE (   4) 0000 0000
03:15:44 | 4145   | peer-1          | &lt;&lt; UPDATE #2
03:15:44 | 4145   | peer-1          |    UPDATE #2 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:44 | 4145   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02
03:15:44 | 4145   | outgoing-3      | received TCP payload (  10) 0000 0006 800F 0300 0201
03:15:44 | 4145   | outgoing-3      | &lt;&lt; message of type UPDATE
03:15:44 | 4145   | parser          | parsing UPDATE (  10) 0000 0006 800F 0300 0201
03:15:44 | 4145   | routes          | withdrawn NLRI none
03:15:44 | 4145   | parser          | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0002 01
03:15:44 | 4145   | routes          | announced NLRI none
03:15:44 | 4145   | peer-1          | &lt;&lt; UPDATE #3
03:15:44 | 4145   | peer-1          |    UPDATE #3 nlri  (  11) eor 2/1 (ipv6 unicast)
03:15:44 | 4145   | ka-outgoing-3   | receive-timer 179 second(s) left
03:15:44 | 4145   | ka-outgoing-3   | send-timer 59 second(s) left
03:15:45 | 4145   | ka-outgoing-3   | receive-timer 178 second(s) left
03:15:45 | 4145   | ka-outgoing-3   | send-timer 58 second(s) left
03:15:46 | 4145   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:46 | 4145   | outgoing-3      | received TCP payload (   2) 0600
03:15:46 | 4145   | outgoing-3      | &lt;&lt; message of type NOTIFICATION
03:15:46 | 4145   | outgoing-3      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:46 | 4145   | outgoing-3      | outgoing-3 2607:f0d0:1002:0011:0000:0000:0000:0002-::1, closing connection
03:15:48 | 4145   | reactor         | initialising connection to peer-1
03:15:48 | 4145   | outgoing-4      | attempting connection to ::1:1790
03:15:48 | 4145   | outgoing-4      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0102 0304 1402 0601 0400 0200 0102 0641 0400 00FB F002 0206 00
03:15:48 | 4145   | outgoing-4      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), ASN4(64496)]
03:15:48 | 4145   | ka-outgoing-4   | receive-timer 60 second(s) left
03:15:48 | 4145   | outgoing-4      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:15:48 | 4145   | outgoing-4      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 00B4 4700
03:15:48 | 4145   | outgoing-4      | &lt;&lt; message of type OPEN
03:15:48 | 4145   | outgoing-4      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:48 | 4145   | outgoing-4      | --------------------------------------------------------------------
03:15:48 | 4145   | outgoing-4      | the connection can not carry the following family/families
03:15:48 | 4145   | outgoing-4      |  - exabgp is not configured for ipv4/unicast
03:15:48 | 4145   | outgoing-4      | therefore no routes of this kind can be announced on the connection
03:15:48 | 4145   | outgoing-4      | --------------------------------------------------------------------
03:15:48 | 4145   | outgoing-4      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:48 | 4145   | outgoing-4      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:48 | 4145   | outgoing-4      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:48 | 4145   | outgoing-4      | &lt;&lt; message of type KEEPALIVE
03:15:48 | 4145   | ka-outgoing-4   | receive-timer 180 second(s) left
03:15:48 | 4145   | reactor         | connected to peer-1 with outgoing-4 2607:f0d0:1002:0011:0000:0000:0000:0002-::1
03:15:48 | 4145   | outgoing-4      | sending TCP payload (  78) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004E 0200 0000 3740 0101 0040 0200 4005 0400 0000 6480 0E26 0002 0110 2607 F0D0 1002 0011 0000 0000 0000 0002 0080 2A04 6D80 0000 0000 0000 0000 0000 0001
03:15:48 | 4145   | outgoing-4      | &gt;&gt; 1 UPDATE(s)
03:15:48 | 4145   | outgoing-4      | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0201
03:15:48 | 4145   | outgoing-4      | &gt;&gt; EOR ipv6 unicast
03:15:48 | 4145   | peer-1          | &gt;&gt; EOR(s)
03:15:48 | 4145   | outgoing-4      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:48 | 4145   | outgoing-4      | received TCP payload (   4) 0000 0000
03:15:48 | 4145   | outgoing-4      | &lt;&lt; message of type UPDATE
03:15:48 | 4145   | parser          | parsing UPDATE (   4) 0000 0000
03:15:48 | 4145   | peer-1          | &lt;&lt; UPDATE #1
03:15:48 | 4145   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:48 | 4145   | outgoing-4      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:48 | 4145   | outgoing-4      | received TCP payload (   4) 0000 0000
03:15:48 | 4145   | outgoing-4      | &lt;&lt; message of type UPDATE
03:15:48 | 4145   | parser          | parsing UPDATE (   4) 0000 0000
03:15:48 | 4145   | peer-1          | &lt;&lt; UPDATE #2
03:15:48 | 4145   | peer-1          |    UPDATE #2 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:48 | 4145   | outgoing-4      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02
03:15:48 | 4145   | outgoing-4      | received TCP payload (  10) 0000 0006 800F 0300 0201
03:15:48 | 4145   | outgoing-4      | &lt;&lt; message of type UPDATE
03:15:48 | 4145   | parser          | parsing UPDATE (  10) 0000 0006 800F 0300 0201
03:15:48 | 4145   | routes          | withdrawn NLRI none
03:15:48 | 4145   | parser          | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0002 01
03:15:48 | 4145   | routes          | announced NLRI none
03:15:48 | 4145   | peer-1          | &lt;&lt; UPDATE #3
03:15:48 | 4145   | peer-1          |    UPDATE #3 nlri  (  11) eor 2/1 (ipv6 unicast)
03:15:48 | 4145   | ka-outgoing-4   | receive-timer 179 second(s) left
03:15:48 | 4145   | ka-outgoing-4   | send-timer 59 second(s) left
03:15:49 | 4145   | ka-outgoing-4   | receive-timer 178 second(s) left
03:15:49 | 4145   | ka-outgoing-4   | send-timer 58 second(s) left
03:15:50 | 4145   | outgoing-4      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:50 | 4145   | outgoing-4      | received TCP payload (   2) 0600
03:15:50 | 4145   | outgoing-4      | &lt;&lt; message of type NOTIFICATION
03:15:50 | 4145   | outgoing-4      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:50 | 4145   | outgoing-4      | outgoing-4 2607:f0d0:1002:0011:0000:0000:0000:0002-::1, closing connection</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.637933" elapsed="0.000894"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.640058" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exaipv6.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exaipv6.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:15:50.639230" elapsed="0.000961"/>
</kw>
<arg>${EXABGP_LOG}</arg>
<arg>${EXABGP_LOG}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:50.624332" elapsed="0.015999"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.641769" level="INFO">[?2004l</msg>
<msg time="2026-06-06T03:15:50.641949" level="INFO">${output} = [?2004l</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:15:50.641498" elapsed="0.000508"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.642980" level="INFO">[?2004l</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.642374" elapsed="0.000709"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.644938" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:50.644196" elapsed="0.000804"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:50.645367" elapsed="0.000457"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:15:50.643539" elapsed="0.002422"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.797616" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:50.797972" level="INFO">${output} = ^C[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:15:50.646339" elapsed="0.151699"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.799303" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.798621" elapsed="0.000754"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.801857" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:50.800451" elapsed="0.001505"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.803315" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:50.803447" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-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-06-06T03:15:50.802237" elapsed="0.001249"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.804430" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.804036" elapsed="0.000463"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.803613" elapsed="0.000944"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.803578" elapsed="0.001019"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:15:50.799825" elapsed="0.004859"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:15:50.640877" elapsed="0.163884"/>
</kw>
<doc>Save exabgp logs as exaipv6.log, and stop exabgp with ctrl-c bash signal</doc>
<status status="PASS" start="2026-06-06T03:15:50.539387" elapsed="0.265525"/>
</test>
<test id="s1-s5-t15" name="Configure_App_Peer" line="189">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:50.808896" elapsed="0.000223"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:50.808604" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.810201" elapsed="0.000033"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.810084" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.810064" elapsed="0.000226"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.815758" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.815631" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.815612" elapsed="0.000218"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.816860" 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-06-06T03:15:50.816453" elapsed="0.000434"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.817351" 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-06-06T03:15:50.817050" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:50.817424" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:50.817590" 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-06-06T03:15:50.816066" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:50.823375" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.823199" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.823179" elapsed="0.000268"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:50.824687" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:50.824552" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.824533" elapsed="0.000237"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:50.825244" 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-06-06T03:15:50.824917" elapsed="0.000354"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.825673" level="INFO">${current_connection_index} = 7</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-06-06T03:15:50.825438" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.855595" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:50.826262" elapsed="0.029458"/>
</kw>
<msg time="2026-06-06T03:15:50.855891" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:50.855939" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:50.825862" elapsed="0.030115"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:50.875813" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:15:50.856509" elapsed="0.019404"/>
</kw>
<msg time="2026-06-06T03:15:50.876074" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:50.876120" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K...</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-06-06T03:15:50.856155" elapsed="0.020001"/>
</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-06-06T03:15:50.876470" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.876237" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.876216" elapsed="0.000333"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.877032" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:15:50.876715" elapsed="0.000381"/>
</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-06-06T03:15:50.877397" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.877166" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.877146" elapsed="0.000330"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:50.877511" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:50.880143" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:15:50.880353" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.879052" elapsed="0.001434"/>
</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="NOT RUN" start="2026-06-06T03:15:50.880956" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.881300" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:50.878400" elapsed="0.003086"/>
</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-06-06T03:15:50.877818" elapsed="0.003736"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:50.824231" elapsed="0.057446"/>
</kw>
<msg time="2026-06-06T03:15:50.881772" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.881818" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.823608" elapsed="0.058248"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:50.882053" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:15:50.881934" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.881915" elapsed="0.000295"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.882749" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.883097" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.883171" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:50.822858" elapsed="0.060423"/>
</kw>
<msg time="2026-06-06T03:15:50.883377" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:50.883422" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:50.818014" elapsed="0.065444"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.883830" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.883542" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.883521" elapsed="0.000389"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:50.817871" elapsed="0.066062"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:50.817694" elapsed="0.066271"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:50.815259" elapsed="0.068762"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:50.809790" elapsed="0.074287"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:50.809328" elapsed="0.074796"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:50.806050" elapsed="0.078126"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.885100" level="INFO">&amp;{mapping} = { IP=127.0.0.12 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.12</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.884385" elapsed="0.000754"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.921109" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:50.920703" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.922012" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:50.921700" elapsed="0.000390">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:50.922186" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:50.921339" elapsed="0.000871"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.922796" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:50.922391" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:50.923130" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:50.923318" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:50.922986" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.923769" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.923503" elapsed="0.000368"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.924860" level="INFO">mapping: {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:50.924577" elapsed="0.000330"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.925538" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.925069" elapsed="0.000496"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.926285" level="INFO">${value} = 127.0.0.12</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.925962" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.927073" level="INFO">${encoded} = 127.0.0.12</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.926848" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.927151" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:50.927308" level="INFO">${encoded_value} = 127.0.0.12</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.926505" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.927491" elapsed="0.000254"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.12</var>
<status status="PASS" start="2026-06-06T03:15:50.925823" elapsed="0.001966"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.928366" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.928057" elapsed="0.000335"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.929125" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.928914" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.929201" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:50.929349" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.928578" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.929525" elapsed="0.000237"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:50.927921" elapsed="0.001882"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.930416" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.930044" elapsed="0.000399"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.931176" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.930966" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.931251" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:50.931399" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.930631" elapsed="0.000792"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.931572" elapsed="0.000237"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:50.929912" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.932390" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.932094" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.933155" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.932934" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.933231" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:50.933380" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.932600" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.933555" elapsed="0.000237"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:50.931961" elapsed="0.001873"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.934389" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.934075" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.935139" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.934930" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.935251" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:50.935418" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.934597" elapsed="0.000847"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.935604" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:50.933944" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.936601" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.936125" elapsed="0.000502"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.937374" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.937159" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.937450" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:50.937606" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.936831" elapsed="0.001000"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.937987" elapsed="0.000227"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:50.935993" elapsed="0.002262"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.938858" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.938533" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.939602" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.939391" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.939693" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:50.939844" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.939073" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.940018" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:50.938398" elapsed="0.001879"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.940844" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:50.940520" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:50.941610" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.941394" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:50.941706" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:50.941857" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:50.941051" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:50.942032" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:50.940388" elapsed="0.001936"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:50.925619" elapsed="0.016742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:50.942405" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:50.942568" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:50.924250" elapsed="0.018345"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:50.923945" elapsed="0.018684"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.942828" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.942672" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:50.923924" elapsed="0.018981"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:50.943776" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:50.943050" elapsed="0.000756"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:50.943856" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:50.920061" elapsed="0.023920"/>
</kw>
<msg time="2026-06-06T03:15:50.944083" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:50.906526" elapsed="0.037611"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.958176" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.972735" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.985589" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.985809" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.985991" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.986441" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:50.986234" elapsed="0.000271"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:50.986217" elapsed="0.000314"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.986697" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.986868" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.987033" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:50.986181" elapsed="0.000904"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.986074" elapsed="0.001038"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:50.987257" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:50.987334" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:50.987475" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:50.901950" elapsed="0.085552"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.014708" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.014256" elapsed="0.000481"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.015488" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:51.015239" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:51.015730" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:51.014902" elapsed="0.000854"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.016314" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:51.015921" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.016660" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:51.016831" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:51.016503" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.017268" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
        &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.017020" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:51.017718" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.017386" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.018263" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.017958" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.017809" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.017367" elapsed="0.001006"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.019312" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.12&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
   ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:51.018523" elapsed="0.000821"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.019395" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:51.013629" elapsed="0.005896"/>
</kw>
<msg time="2026-06-06T03:15:51.019584" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:51.000530" elapsed="0.019101"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.069363" elapsed="0.000053"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.082319" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.095384" elapsed="0.000102"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.095703" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.095895" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.096309" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.096157" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:51.096139" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.096535" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.096721" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.096891" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:51.096101" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.095981" elapsed="0.000991"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.097121" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.097201" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:51.097353" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.12&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
   ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:50.997784" elapsed="0.099599"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.098829" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:51.098508" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:51.098999" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:51.098099" elapsed="0.000925"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.099366" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.099097" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.099940" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.099624" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.099448" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.099078" elapsed="0.000945"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.102477" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:51.100176" elapsed="0.002328"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:51.102557" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:51.102786" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:51.097742" elapsed="0.005069"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.104208" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.103951" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.104721" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.12&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
        &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.104453" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.105174" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.104926" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.105611" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.105370" elapsed="0.000300"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:51.106491" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:51.106279" elapsed="0.000238"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:51.106862" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:51.106686" elapsed="0.000202"/>
</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-06-06T03:15:51.107038" elapsed="0.000211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.107824" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.107403" elapsed="0.000467"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:51.107913" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.108070" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:51.105872" elapsed="0.002223"/>
</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-06-06T03:15:51.122279" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '395', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.12&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
        &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:51.122443" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:51.122726" 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-06-06T03:15:51.110317" elapsed="0.012472"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.108166" elapsed="0.014726"/>
</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-06-06T03:15:51.123299" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.122951" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.108147" elapsed="0.015351"/>
</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-06-06T03:15:51.131169" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.125628" elapsed="0.005639"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.125135" elapsed="0.006212"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.125093" elapsed="0.006310"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.135134" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.131863" elapsed="0.003336"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.131527" elapsed="0.003720"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.131491" elapsed="0.003790"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.136070" 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-06-06T03:15:51.135510" elapsed="0.000598"/>
</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-06-06T03:15:51.136546" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.136209" elapsed="0.000422"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.137400" 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-06-06T03:15:51.136973" elapsed="0.000465"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.136732" elapsed="0.000756"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.136182" elapsed="0.001337"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.138281" 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-06-06T03:15:51.137768" elapsed="0.000551"/>
</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-06-06T03:15:51.138809" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.138456" elapsed="0.000436"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.139566" 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-06-06T03:15:51.139149" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.138926" elapsed="0.000710"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.138429" elapsed="0.001244"/>
</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-06-06T03:15:51.139827" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:51.140624" 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-06-06T03:15:51.140345" elapsed="0.000325"/>
</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-06-06T03:15:51.140830" elapsed="0.002398"/>
</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-06-06T03:15:51.124310" elapsed="0.018989"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:51.143483" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:15:51.143371" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.143350" elapsed="0.000223"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:51.143755" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.143827" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:51.146167" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:51.103136" elapsed="0.043059"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.146261" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:51.146445" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:50.890485" elapsed="0.255986"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.146843" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.146574" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.146557" elapsed="0.000379"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.146968" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/application_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:50.885442" elapsed="0.261648"/>
</kw>
<doc>Configures bgp application peer.</doc>
<status status="PASS" start="2026-06-06T03:15:50.805335" elapsed="0.341878"/>
</test>
<test id="s1-s5-t16" name="Reconfigure_ODL_To_Accept_Connections_4" line="206">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:51.150897" elapsed="0.000223"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:51.150607" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.152187" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.152077" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.152058" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.157348" elapsed="0.000058"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.157239" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.157221" elapsed="0.000245"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.158516" 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-06-06T03:15:51.158102" elapsed="0.000443"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.159194" 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-06-06T03:15:51.158881" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:51.159282" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:51.159445" 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-06-06T03:15:51.157716" elapsed="0.001754"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:51.165213" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.165101" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.165080" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:51.166493" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.166367" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.166347" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:51.167049" 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-06-06T03:15:51.166746" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.167456" level="INFO">${current_connection_index} = 7</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-06-06T03:15:51.167239" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.195133" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:51.168002" elapsed="0.027236"/>
</kw>
<msg time="2026-06-06T03:15:51.195404" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:51.195450" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:51.167662" elapsed="0.027823"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.220770" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "4 "[K"
[?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-06-06T03:15:51.196187" elapsed="0.024704"/>
</kw>
<msg time="2026-06-06T03:15:51.221062" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:51.221109" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:15:51.195690" elapsed="0.025455"/>
</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-06-06T03:15:51.221490" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.221235" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.221209" elapsed="0.000369"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.222067" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "4 "[K"
[?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-06-06T03:15:51.221750" elapsed="0.000388"/>
</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-06-06T03:15:51.222462" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.222208" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.222189" elapsed="0.000355"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:51.222578" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:51.225253" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:15:51.225465" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:51.224123" elapsed="0.001476"/>
</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="NOT RUN" start="2026-06-06T03:15:51.225956" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.226295" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:51.223460" elapsed="0.003037"/>
</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-06-06T03:15:51.222900" elapsed="0.003663"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:51.166062" elapsed="0.060623"/>
</kw>
<msg time="2026-06-06T03:15:51.226782" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:51.226828" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:51.165437" elapsed="0.061427"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:51.227051" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:51.226942" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.226922" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.227544" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.227908" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.227980" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:51.164733" elapsed="0.063355"/>
</kw>
<msg time="2026-06-06T03:15:51.228182" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:51.228226" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:51.159901" elapsed="0.068360"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.228591" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.228338" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.228320" elapsed="0.000367"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:51.159750" elapsed="0.068962"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:51.159530" elapsed="0.069214"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:51.156877" elapsed="0.071923"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:51.151785" elapsed="0.077071"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:51.151331" elapsed="0.077571"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:51.148133" elapsed="0.080822"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.229867" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV4_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.229152" elapsed="0.000745"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.264961" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.264564" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.265767" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:51.265490" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:51.265977" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:51.265155" elapsed="0.000848"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.266600" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:51.266171" elapsed="0.000457"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.266949" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:51.267109" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:51.266809" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.267537" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.267293" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.268541" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.268283" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.269030" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.268765" elapsed="0.000291"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.269737" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.269425" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.270499" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.270266" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.270577" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.270743" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.269949" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.270922" elapsed="0.000241"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:15:51.269288" elapsed="0.001915"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.271762" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.271447" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.272503" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.272292" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.272580" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.272744" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.271976" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.272921" elapsed="0.000220"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:51.271314" elapsed="0.001867"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.273902" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.273421" elapsed="0.000507"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.274690" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.274460" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.274767" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.274916" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.274114" elapsed="0.000827"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.275093" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:51.273291" elapsed="0.002067"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.275956" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.275655" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.276711" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.276483" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.276788" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.276938" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.276168" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.277113" elapsed="0.000221"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:51.275507" elapsed="0.001869"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.277930" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.277618" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.278699" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.278474" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.278775" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.278925" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.278141" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.279099" elapsed="0.000218"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:51.277487" elapsed="0.001871"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.279914" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.279601" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.280669" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.280443" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.280747" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.280898" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.280124" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.281071" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:51.279470" elapsed="0.001865"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.281893" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.281577" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.282662" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.282417" elapsed="0.000273"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.282742" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:51.282892" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.282102" elapsed="0.000815"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.283066" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:51.281447" elapsed="0.001883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.283889" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:51.283573" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:51.284831" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.284599" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:51.284909" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.285059" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:51.284102" elapsed="0.000982"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:51.285235" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:51.283442" elapsed="0.002055"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:51.269107" elapsed="0.016458"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:51.285612" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:15:51.285789" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'e...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:51.267961" elapsed="0.017854"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.267665" elapsed="0.018183"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.286021" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.285872" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.267631" elapsed="0.018466"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.286964" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:51.286241" elapsed="0.000752"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.287043" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:51.263946" elapsed="0.023223"/>
</kw>
<msg time="2026-06-06T03:15:51.287225" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:51.250756" elapsed="0.036517"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.300136" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.313087" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.326107" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.326306" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.326519" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.326915" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.326769" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:51.326753" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.327141" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.327310" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.327479" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:51.326722" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.326601" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.327766" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.327844" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:51.327971" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:51.246255" elapsed="0.081744"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.355241" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.354860" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.356017" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:51.355786" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:51.356185" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:51.355434" elapsed="0.000775"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.356774" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:51.356373" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.357098" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:51.357248" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
  &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
  &lt;route-reflector&gt;
    &lt;config&gt;
      &lt;route-reflecto...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:51.356961" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.357700" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
  &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
  &lt;route-reflector&gt;
    &lt;config&gt;
      &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
    &lt;/config&gt;
  &lt;/route-reflector&gt;
  &lt;timers&gt;
    &lt;config&gt;
      &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
      &lt;connect-retry&gt;5&lt;/connect-retry&gt;
    &lt;/config&gt;
  &lt;/timers&gt;
  &lt;transport&gt;
    &lt;config&gt;
      &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
      &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
    &lt;/config&gt;
  &lt;/transport&gt;
  &lt;config&gt;
    &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
  &lt;/config&gt;
  &lt;afi-safis&gt;
    &lt;afi-safi&gt;
      &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
    &lt;/afi-safi&gt;
  &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.357432" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:51.358116" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.357826" elapsed="0.000349"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.358874" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'e...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.358344" elapsed="0.000559"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.358200" elapsed="0.000740"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.357807" elapsed="0.001154"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.359860" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
  &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
  &lt;route-reflector&gt;
    &lt;config&gt;
      &lt;route-re...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:51.359108" elapsed="0.000784"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.359942" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:51.354208" elapsed="0.005861"/>
</kw>
<msg time="2026-06-06T03:15:51.360159" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:51.341113" elapsed="0.019095"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.373199" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.386006" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.398851" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.399050" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.399227" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.399595" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.399451" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:51.399436" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.399833" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.400000" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.400167" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:51.399406" elapsed="0.000815"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.399305" elapsed="0.000941"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.400392" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.400468" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:51.400601" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
  &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
  &lt;route-reflector&gt;
    &lt;config&gt;
      &lt;route-re...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:51.338342" elapsed="0.062288"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:51.401979" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:51.401718" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:51.402141" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:51.401349" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.402486" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.402238" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.403086" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.402791" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.402598" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.402218" elapsed="0.000950"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.405560" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:51.403321" elapsed="0.002266"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:51.405650" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:51.405807" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:51.400977" elapsed="0.004856"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.407236" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.406986" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.407687" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
  &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
  &lt;route-reflector&gt;
    &lt;config&gt;
      &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
    &lt;/config&gt;
  &lt;/route-reflector&gt;
  &lt;timers&gt;
    &lt;config&gt;
      &lt;hold-time&gt;180&lt;/hold-time&gt;
      &lt;connect-retry&gt;5&lt;/connect-retry&gt;
    &lt;/config&gt;
  &lt;/timers&gt;
  &lt;transport&gt;
    &lt;config&gt;
      &lt;remote-port&gt;17900&lt;/remote-port&gt;
      &lt;passive-mode&gt;true&lt;/passive-mode&gt;
    &lt;/config&gt;
  &lt;/transport&gt;
  &lt;config&gt;
    &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
  &lt;/config&gt;
  &lt;afi-safis&gt;
    &lt;afi-safi&gt;
      &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
    &lt;/afi-safi&gt;
  &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.407435" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.408136" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.407894" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.408583" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.408328" elapsed="0.000308"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:51.409469" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:51.409272" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:51.409837" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:51.409661" elapsed="0.000202"/>
</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-06-06T03:15:51.410011" elapsed="0.000202"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.410825" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.410367" elapsed="0.000505"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:51.410915" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:51.411071" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:51.408868" elapsed="0.002229"/>
</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-06-06T03:15:51.428914" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '767', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
  &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
  &lt;route-reflector&gt;
    &lt;config&gt;
      &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
    &lt;/config&gt;
  &lt;/route-reflector&gt;
  &lt;timers&gt;
    &lt;config&gt;
      &lt;hold-time&gt;180&lt;/hold-time&gt;
      &lt;connect-retry&gt;5&lt;/connect-retry&gt;
    &lt;/config&gt;
  &lt;/timers&gt;
  &lt;transport&gt;
    &lt;config&gt;
      &lt;remote-port&gt;17900&lt;/remote-port&gt;
      &lt;passive-mode&gt;true&lt;/passive-mode&gt;
    &lt;/config&gt;
  &lt;/transport&gt;
  &lt;config&gt;
    &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
  &lt;/config&gt;
  &lt;afi-safis&gt;
    &lt;afi-safi&gt;
      &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
    &lt;/afi-safi&gt;
  &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:51.429177" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:51.429387" 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-06-06T03:15:51.413304" elapsed="0.016142"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.411167" elapsed="0.018381"/>
</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-06-06T03:15:51.429986" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.429608" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.411149" elapsed="0.019036"/>
</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-06-06T03:15:51.437920" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.432430" elapsed="0.005587"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.431940" elapsed="0.006155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.431898" elapsed="0.006255"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.441602" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.438853" elapsed="0.002810"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.438280" elapsed="0.003419"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.438241" elapsed="0.003483"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.442267" 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-06-06T03:15:51.441886" elapsed="0.000409"/>
</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-06-06T03:15:51.442622" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.442365" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.443185" 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-06-06T03:15:51.442883" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.442721" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.442347" elapsed="0.000922"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.443810" 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-06-06T03:15:51.443428" elapsed="0.000409"/>
</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-06-06T03:15:51.444142" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.443908" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.444696" 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-06-06T03:15:51.444381" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.444223" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.443890" elapsed="0.000889"/>
</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-06-06T03:15:51.444930" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:51.445739" 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-06-06T03:15:51.445439" elapsed="0.000326"/>
</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-06-06T03:15:51.445922" elapsed="0.002357"/>
</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-06-06T03:15:51.431080" elapsed="0.017262"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:51.448516" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:51.448410" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.448390" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:51.448767" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.448836" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:51.451162" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:51.406156" elapsed="0.045033"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.451287" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:51.451447" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:51.234812" elapsed="0.216660"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.451836" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.451577" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.451557" elapsed="0.000374"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:51.451964" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_neighbor_rib</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:51.230172" elapsed="0.221918"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:51.452619" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={'Content-Type': 'application/json'},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5a44690&gt;, timeout=5, proxies=None, verify=False,                     debug=0 </msg>
<arg>session</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<arg>headers=${HEADERS}</arg>
<arg>timeout=5</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:15:51.452255" elapsed="0.000539"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with short ipv6 address.</doc>
<status status="PASS" start="2026-06-06T03:15:51.147547" elapsed="0.305374"/>
</test>
<test id="s1-s5-t17" name="Start_Exabgp_2" line="228">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:51.456433" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:51.456167" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.457722" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.457595" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.457576" elapsed="0.000216"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.462858" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.462750" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.462732" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.463936" 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-06-06T03:15:51.463528" elapsed="0.000435"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.464418" 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-06-06T03:15:51.464123" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:51.464488" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:51.464657" 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-06-06T03:15:51.463151" elapsed="0.001532"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:51.470264" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.470154" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.470134" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:51.471538" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:51.471432" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.471413" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:51.472076" 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-06-06T03:15:51.471777" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.472475" level="INFO">${current_connection_index} = 7</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-06-06T03:15:51.472261" elapsed="0.000240"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.505221" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:51.473016" elapsed="0.032314"/>
</kw>
<msg time="2026-06-06T03:15:51.505501" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:51.505596" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:51.472678" elapsed="0.032956"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.532394" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "2 "[K"
[?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-06-06T03:15:51.506198" elapsed="0.026313"/>
</kw>
<msg time="2026-06-06T03:15:51.532702" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:51.532751" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "2 "[K"
[?1l&gt;[?2004l...</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-06-06T03:15:51.505837" elapsed="0.026951"/>
</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-06-06T03:15:51.533127" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.532876" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.532852" elapsed="0.000356"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.533691" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "2 "[K"
[?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-06-06T03:15:51.533351" elapsed="0.000403"/>
</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-06-06T03:15:51.534042" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.533822" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.533803" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:51.534156" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:51.536763" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:15:51.536975" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:51.535670" elapsed="0.001439"/>
</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="NOT RUN" start="2026-06-06T03:15:51.537411" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.537776" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:51.535029" elapsed="0.002936"/>
</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-06-06T03:15:51.534441" elapsed="0.003590"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:51.471126" elapsed="0.067004"/>
</kw>
<msg time="2026-06-06T03:15:51.538225" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:51.538270" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "2 "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:51.470486" elapsed="0.067823"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:51.538496" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:51.538387" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.538368" elapsed="0.000241"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.539031" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.539375" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:51.539447" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:51.469811" elapsed="0.069745"/>
</kw>
<msg time="2026-06-06T03:15:51.539665" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:51.539713" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "2 "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:51.465050" elapsed="0.074701"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:51.540125" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:51.539829" elapsed="0.000351"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.539811" elapsed="0.000394"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:51.464909" elapsed="0.075321"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:51.464736" elapsed="0.075525"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:51.462348" elapsed="0.077968"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:51.457303" elapsed="0.083069"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:51.456875" elapsed="0.083543"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:51.453751" elapsed="0.086722"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.540985" level="INFO">${cmd} = exaipv4.cfg &gt; exaipv4.log</msg>
<var>${cmd}</var>
<arg>${EXABGP2_CFG} &gt; ${EXABGP2_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.540651" elapsed="0.000362"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.544429" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exaipv4.cfg &gt; exaipv4.log</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.544105" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.544878" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exaipv4.cfg &gt; exaipv4.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.544615" elapsed="0.000309"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.547427" level="INFO">source /tmp/defaultvenv/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-06-06T03:15:51.545526" elapsed="0.001957"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.552085" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:51.552174" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:15:51.547663" elapsed="0.004536"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.552777" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.552513" elapsed="0.000311"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:51.552267" elapsed="0.000591"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:51.552248" elapsed="0.000635"/>
</if>
<arg>log_output=${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-06-06T03:15:51.545164" elapsed="0.007763"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:51.555139" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exaipv4.cfg &gt; exaipv4.log</msg>
<msg time="2026-06-06T03:15:51.555229" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exaipv4.cfg &gt; exaipv4.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:51.553075" elapsed="0.002180"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.555684" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exaipv4.cfg &gt; exaipv4.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.555416" elapsed="0.000315"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:51.543783" elapsed="0.012005"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.557888" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:51.557516" elapsed="0.000399"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.560076" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:51.558081" elapsed="0.002022"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:51.564991" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:51.565123" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:15:51.565216" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:51.560270" elapsed="0.004972"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.569055" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:51.565451" elapsed="0.003674"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:15:51.573153" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:15:51.569360" elapsed="0.003899">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:15:51.557059" elapsed="0.016363">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.576436" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:54.575505" elapsed="0.000999"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.581207" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:54.576925" elapsed="0.004324"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:54.588866" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:54.589610" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '607'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:15:54.589780" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:54.581496" elapsed="0.008323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.593763" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.590074" elapsed="0.003767"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:15:54.594079" elapsed="0.003735"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:15:54.574259" elapsed="0.023652"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:51.556542" elapsed="3.041450"/>
</kw>
<msg time="2026-06-06T03:15:54.598150" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:54.598219" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:51.555947" elapsed="3.042307"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.598831" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.598398" elapsed="0.000516"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.598364" elapsed="0.000589"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:15:54.599196" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:15:54.599035" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.599011" elapsed="0.000314"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:15:51.543581" elapsed="3.055784"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:15:51.543363" elapsed="3.056054"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.599668" elapsed="0.000034"/>
</kw>
<arg>${cmd}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>127.0.0.1</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:15:51.541325" elapsed="3.058464"/>
</kw>
<doc>Start exabgp and Verify BGP connection</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:51.453241" elapsed="3.146716"/>
</test>
<test id="s1-s5-t18" name="Inject_Ipv6_Route_1" line="234">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:54.605190" elapsed="0.000293"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:54.604914" elapsed="0.000627"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.606569" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.606455" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.606435" elapsed="0.000217"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.611669" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.611548" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.611530" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.612771" 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-06-06T03:15:54.612365" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.613257" 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-06-06T03:15:54.612959" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:54.613327" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:54.613484" 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-06-06T03:15:54.611971" elapsed="0.001537"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:54.619105" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.618997" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.618976" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:54.620362" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.620253" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.620234" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:54.620904" 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-06-06T03:15:54.620578" elapsed="0.000353"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:54.621311" level="INFO">${current_connection_index} = 7</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-06-06T03:15:54.621094" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:54.650191" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:54.621855" elapsed="0.028513"/>
</kw>
<msg time="2026-06-06T03:15:54.650596" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:54.650662" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:54.621500" elapsed="0.029202"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:54.672142" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "1 "[K"
[?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-06-06T03:15:54.651367" elapsed="0.020883"/>
</kw>
<msg time="2026-06-06T03:15:54.672416" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:54.672463" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "1 "...</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-06-06T03:15:54.650943" elapsed="0.021557"/>
</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-06-06T03:15:54.672879" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.672596" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.672568" elapsed="0.000394"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.673427" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "1 "[K"
[?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-06-06T03:15:54.673108" elapsed="0.000386"/>
</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-06-06T03:15:54.673801" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.673562" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.673543" elapsed="0.000394"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:54.673978" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:54.676624" elapsed="0.000163"/>
</kw>
<msg time="2026-06-06T03:15:54.676851" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:54.675511" elapsed="0.001476"/>
</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="NOT RUN" start="2026-06-06T03:15:54.677266" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.677602" elapsed="0.000097"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:54.674868" elapsed="0.002943"/>
</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-06-06T03:15:54.674290" elapsed="0.003588"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:54.619935" elapsed="0.058042"/>
</kw>
<msg time="2026-06-06T03:15:54.678071" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:54.678116" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "1 "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:54.619328" elapsed="0.058825"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:54.678341" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:54.678231" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.678212" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.678860" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.679206" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.679278" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:54.618652" elapsed="0.060735"/>
</kw>
<msg time="2026-06-06T03:15:54.679482" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:54.679526" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "1 "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:54.613896" elapsed="0.065669"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.679911" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.679656" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.679624" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:54.613754" elapsed="0.066261"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:54.613564" elapsed="0.066483"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:54.611188" elapsed="0.068948"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:54.606163" elapsed="0.074032"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:54.605717" elapsed="0.074526"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:54.601008" elapsed="0.079289"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.681163" level="INFO">&amp;{mapping} = { IP=127.0.0.12 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.12</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.680491" elapsed="0.000702"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.716805" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:54.716397" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:54.717705" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:54.717425" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:54.717874" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:54.717066" elapsed="0.000833"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.718459" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:54.718068" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:54.718811" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:54.718997" level="INFO">${template} = rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:54.718667" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.719437" level="INFO">rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.719185" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.720496" level="INFO">mapping: {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.720231" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.720993" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.720721" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.721715" level="INFO">${value} = 127.0.0.12</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.721393" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.722473" level="INFO">${encoded} = 127.0.0.12</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.722251" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.722551" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:54.722721" level="INFO">${encoded_value} = 127.0.0.12</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.721930" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.722903" elapsed="0.000240"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.12</var>
<status status="PASS" start="2026-06-06T03:15:54.721255" elapsed="0.001929"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.723748" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.723430" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.724511" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.724298" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.724590" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:54.724758" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.723962" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.724936" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:54.723297" elapsed="0.001904"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.725760" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.725447" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.726677" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.726450" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.726756" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:54.726907" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.725971" elapsed="0.000994"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.727122" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:54.725314" elapsed="0.002073"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.727950" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.727633" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.728743" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.728508" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.728821" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:54.728972" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.728190" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.729149" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:54.727499" elapsed="0.001911"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.729970" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.729671" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.730721" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.730492" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.730796" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:54.730946" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.730179" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.731121" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:54.729522" elapsed="0.001859"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.731935" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.731624" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.732705" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.732477" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.732782" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:54.732932" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.732162" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.733110" elapsed="0.000255"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:54.731492" elapsed="0.001924"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.734014" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.733713" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.734775" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.734545" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.734852" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:54.735003" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.734227" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.735179" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:54.733559" elapsed="0.001882"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.735997" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:54.735701" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:54.736782" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.736556" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:54.736859" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:54.737009" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:54.736238" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.737222" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:54.735554" elapsed="0.001932"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:54.721072" elapsed="0.016449"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:54.737564" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:54.737739" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:54.719876" elapsed="0.017889"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.719556" elapsed="0.018242"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.737972" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.737823" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.719535" elapsed="0.018513"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.739092" level="INFO">${final_text} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:54.738189" elapsed="0.000933"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:54.739174" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:54.715756" elapsed="0.023543"/>
</kw>
<msg time="2026-06-06T03:15:54.739355" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:54.702431" elapsed="0.036971"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.752207" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.764959" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.777751" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.777946" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.778122" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.778482" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.778341" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:54.778325" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.778713" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.778918" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.779084" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:54.778298" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.778197" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.779308" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.779383" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:54.779502" level="INFO">${uri} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:54.697738" elapsed="0.081790"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.805674" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:54.805280" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:54.806421" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:54.806204" elapsed="0.000285">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:54.806583" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:54.805867" elapsed="0.000741"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.807174" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:54.806787" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:54.807498" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:54.807656" level="INFO">${template} = &lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testi...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:54.807363" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.808095" level="INFO">&lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testing --&gt;
  &lt;!-- 1:1:1::1/128 should look like the following example: 1.1.1.1/32 --&gt;
  &lt;path-id&gt;1&lt;/path-id&gt;
  &lt;route-key&gt;1:1:1::1/128&lt;/route-key&gt;
  &lt;prefix&gt;1:1:1::1/128&lt;/prefix&gt;
  &lt;attributes&gt;
    &lt;ipv6-next-hop&gt;
      &lt;global&gt;2:1:1:1::1&lt;/global&gt;
    &lt;/ipv6-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;origin&gt;
      &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
  &lt;/attributes&gt;
&lt;/ipv6-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.807850" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:54.808527" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.808234" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.809081" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:54.808781" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.808611" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.808215" elapsed="0.000951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.809805" level="INFO">${final_text} = &lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:54.809311" elapsed="0.000557"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:54.809920" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:54.803777" elapsed="0.006271"/>
</kw>
<msg time="2026-06-06T03:15:54.810106" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:54.790847" elapsed="0.019307"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.823300" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.836259" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.849175" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.849384" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.849566" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.849978" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.849831" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:54.849814" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.850205" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.850376" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.850543" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:54.849780" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.849661" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.850793" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.850872" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:54.851018" level="INFO">${data} = &lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testi...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:54.789984" elapsed="0.061064"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:54.852476" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:54.852197" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:54.852658" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:54.851810" elapsed="0.000875"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.853016" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.852758" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.853568" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:54.853273" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.853098" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.852739" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.856130" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:54.853823" elapsed="0.002334"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:54.856235" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:54.856394" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:54.851445" elapsed="0.004975"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.857983" level="INFO">rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.857728" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.858426" level="INFO">&lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testing --&gt;
  &lt;!-- 1:1:1::1/128 should look like the following example: 1.1.1.1/32 --&gt;
  &lt;path-id&gt;1&lt;/path-id&gt;
  &lt;route-key&gt;1:1:1::1/128&lt;/route-key&gt;
  &lt;prefix&gt;1:1:1::1/128&lt;/prefix&gt;
  &lt;attributes&gt;
    &lt;ipv6-next-hop&gt;
      &lt;global&gt;2:1:1:1::1&lt;/global&gt;
    &lt;/ipv6-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;origin&gt;
      &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
  &lt;/attributes&gt;
&lt;/ipv6-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.858184" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.858903" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.858635" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.859340" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.859098" elapsed="0.000287"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:54.860222" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:54.860011" elapsed="0.000238"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:54.860581" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:54.860405" elapsed="0.000202"/>
</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-06-06T03:15:54.860776" elapsed="0.000205"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.861386" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.861137" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:54.861472" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:54.861627" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:54.859587" elapsed="0.002080"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:54.883676" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 path_url=/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '759', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testing --&gt;
  &lt;!-- 1:1:1::1/128 should look like the following example: 1.1.1.1/32 --&gt;
  &lt;path-id&gt;1&lt;/path-id&gt;
  &lt;route-key&gt;1:1:1::1/128&lt;/route-key&gt;
  &lt;prefix&gt;1:1:1::1/128&lt;/prefix&gt;
  &lt;attributes&gt;
    &lt;ipv6-next-hop&gt;
      &lt;global&gt;2:1:1:1::1&lt;/global&gt;
    &lt;/ipv6-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;origin&gt;
      &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
  &lt;/attributes&gt;
&lt;/ipv6-route&gt; 
 </msg>
<msg time="2026-06-06T03:15:54.883895" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes/ipv6-route=1%3A1%3A1%3A%3A1%2F128,1', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:54.884133" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:54.864138" elapsed="0.020090"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.861742" elapsed="0.022594"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.884779" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.884397" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.861722" elapsed="0.023264"/>
</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-06-06T03:15:54.892833" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.887357" elapsed="0.005520"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.886856" elapsed="0.006057"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.886813" elapsed="0.006127"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.895612" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:54.893220" elapsed="0.002455"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.892997" elapsed="0.002714"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.892980" elapsed="0.002756"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.896306" 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-06-06T03:15:54.895903" elapsed="0.000432"/>
</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-06-06T03:15:54.896663" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.896407" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.897224" 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-06-06T03:15:54.896919" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.896755" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.896388" elapsed="0.000923"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.897860" 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-06-06T03:15:54.897474" elapsed="0.000413"/>
</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-06-06T03:15:54.898197" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.897959" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.898759" 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-06-06T03:15:54.898442" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:54.898280" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.897941" elapsed="0.000903"/>
</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-06-06T03:15:54.898995" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:54.899976" 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-06-06T03:15:54.899512" elapsed="0.000491"/>
</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-06-06T03:15:54.900163" elapsed="0.002433"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:15:54.885823" elapsed="0.016855"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:54.902862" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:54.902754" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.902734" elapsed="0.000217"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:54.903101" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.903170" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:54.905660" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:15:54.856766" elapsed="0.048924"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:54.905820" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:54.905982" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:54.686203" elapsed="0.219804"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.906370" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.906116" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.906098" elapsed="0.000368"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:54.906500" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_route_injection</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:54.681469" elapsed="0.225156"/>
</kw>
<doc>Inject the Ipv6 route from controller</doc>
<status status="PASS" start="2026-06-06T03:15:54.600435" elapsed="0.306329"/>
</test>
<test id="s1-s5-t19" name="Check_Ipv6_Prefix_In_Bgp_Rib_1" line="250">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:54.910244" elapsed="0.000227"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:54.909974" elapsed="0.000554"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.911549" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.911437" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.911418" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.917059" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.916949" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.916930" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.918136" 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-06-06T03:15:54.917748" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.918621" 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-06-06T03:15:54.918326" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:54.918710" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:54.918867" 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-06-06T03:15:54.917354" elapsed="0.001539"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:54.924578" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.924469" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.924449" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:54.925856" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:54.925748" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.925729" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:54.926368" 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-06-06T03:15:54.926071" elapsed="0.000324"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:54.926793" level="INFO">${current_connection_index} = 7</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-06-06T03:15:54.926557" elapsed="0.000262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:54.956556" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:54.927317" elapsed="0.029396"/>
</kw>
<msg time="2026-06-06T03:15:54.956907" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:54.956954" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:54.926980" elapsed="0.030157"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:54.979028" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "n "_ "B "g "p "_ "R "i "b "_ "1 "[K"
[?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-06-06T03:15:54.957767" elapsed="0.021386"/>
</kw>
<msg time="2026-06-06T03:15:54.979328" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:54.979376" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "...</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-06-06T03:15:54.957355" elapsed="0.022057"/>
</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-06-06T03:15:54.979800" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.979507" elapsed="0.000351"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.979481" elapsed="0.000403"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.980401" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "n "_ "B "g "p "_ "R "i "b "_ "1 "[K"
[?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-06-06T03:15:54.980031" elapsed="0.000440"/>
</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-06-06T03:15:54.980778" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.980541" elapsed="0.000294"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.980522" elapsed="0.000337"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:54.980896" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:54.983542" elapsed="0.000167"/>
</kw>
<msg time="2026-06-06T03:15:54.983774" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:54.982429" elapsed="0.001478"/>
</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="NOT RUN" start="2026-06-06T03:15:54.984183" elapsed="0.000091"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.984535" elapsed="0.000279"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:54.981788" elapsed="0.003142"/>
</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-06-06T03:15:54.981204" elapsed="0.003793"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:54.925419" elapsed="0.059677"/>
</kw>
<msg time="2026-06-06T03:15:54.985190" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:54.985235" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:54.924823" elapsed="0.060448"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:54.985460" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:54.985350" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.985330" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.985974" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.986319" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:54.986392" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:54.924103" elapsed="0.062399"/>
</kw>
<msg time="2026-06-06T03:15:54.986597" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:54.986656" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:54.919268" elapsed="0.067428"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:54.987029" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:54.986773" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:54.986755" elapsed="0.000403"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:54.919126" elapsed="0.068057"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:54.918951" elapsed="0.068265"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:54.916565" elapsed="0.070709"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:54.911143" elapsed="0.076190"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:54.910699" elapsed="0.076681"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:54.907658" elapsed="0.079777"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:54.988381" level="INFO">&amp;{mapping} = { IP=10.30.170.38 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${CONTROLLER_IPV4}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:54.987633" elapsed="0.000778"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.039363" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:55.038948" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:55.040179" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:55.039922" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:55.040384" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:55.039563" elapsed="0.000847"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.040994" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:55.040581" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:55.041351" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:55.041515" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:55.041206" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.041977" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.041727" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.043190" level="INFO">mapping: {'IP': '10.30.170.38', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.042739" elapsed="0.000500"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.043710" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.043409" elapsed="0.000329"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.044501" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.044126" elapsed="0.000402"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.045469" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.045109" elapsed="0.000387"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.045549" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:15:55.045727" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.044752" elapsed="0.001003"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.045917" elapsed="0.000290"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:15:55.043985" elapsed="0.002314"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.046908" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.046556" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.047886" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.047529" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.047964" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:55.048117" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.047171" elapsed="0.000970"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.048333" elapsed="0.000278"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:55.046418" elapsed="0.002252"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.049282" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.048926" elapsed="0.000384"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.050199" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.049864" elapsed="0.000361"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.050277" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.050427" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.049501" elapsed="0.000950"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.050602" elapsed="0.000291"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:55.048791" elapsed="0.002145"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.051494" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.051179" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.052410" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.052064" elapsed="0.000373"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.052488" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:55.052635" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.051725" elapsed="0.000951"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.052827" elapsed="0.000266"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:55.051047" elapsed="0.002088"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.053727" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.053378" elapsed="0.000375"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.054603" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.054277" elapsed="0.000352"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.054695" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:55.054845" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.053939" elapsed="0.000930"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.055021" elapsed="0.000265"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:55.053247" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.056134" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.055619" elapsed="0.000541"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.057060" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.056729" elapsed="0.000357"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.057136" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.057284" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.056374" elapsed="0.000935"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.057461" elapsed="0.000302"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:55.055484" elapsed="0.002357"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.058413" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.058093" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.059304" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.058979" elapsed="0.000351"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.059380" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.059529" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.058625" elapsed="0.000928"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.059720" elapsed="0.000269"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:55.057959" elapsed="0.002072"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.060615" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.060295" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.061510" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.061181" elapsed="0.000356"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.061588" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.061775" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.060845" elapsed="0.000954"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.061949" elapsed="0.000266"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:55.060143" elapsed="0.002115"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:55.043793" elapsed="0.018500"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:55.062336" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:55.062494" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME':...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:55.042393" elapsed="0.020127"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.042093" elapsed="0.020459"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.062748" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.062579" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.042073" elapsed="0.020754"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.063674" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:55.062971" elapsed="0.000732"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:55.063755" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:55.038302" elapsed="0.025576"/>
</kw>
<msg time="2026-06-06T03:15:55.063932" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:55.025163" elapsed="0.038818"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.077083" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.089827" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.102568" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.102776" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.102957" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.103322" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.103177" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:55.103161" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.103542" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.103726" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.103896" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:55.103133" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.103033" elapsed="0.000943"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.104123" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.104198" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:55.104341" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:55.020775" elapsed="0.083592"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:55.105694" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:55.105377" elapsed="0.000397">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:55.106014" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:55.105034" elapsed="0.001005"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.106356" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.106109" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.106919" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:55.106610" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.106437" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.106091" elapsed="0.000911"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.109416" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:55.107153" elapsed="0.002290"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:55.109496" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:55.109663" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:55.104708" elapsed="0.004982"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:55.110926" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:55.110681" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:55.111118" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:55.110326" elapsed="0.000818"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:55.111356" elapsed="0.000052"/>
</return>
<status status="PASS" start="2026-06-06T03:15:55.111217" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.111198" elapsed="0.000271"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.111623" elapsed="0.000037"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.111958" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.112025" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:55.115604" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:55.109999" elapsed="0.005633"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.117111" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.116843" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.117627" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.117349" elapsed="0.000341"/>
</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-06-06T03:15:55.134891" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:55.139021" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://127.0.0.12","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:15:55.139508" 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-06-06T03:15:55.119910" elapsed="0.019659"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.117759" elapsed="0.021938"/>
</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-06-06T03:15:55.140112" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.139761" elapsed="0.000495"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.117741" elapsed="0.022562"/>
</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-06-06T03:15:55.146595" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://127.0.0.12","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv6-routes":{"ipv6-route":[{"route-key":"1:1:1::1/128","path-id":1,"prefix":"1:1:1::1/128","attributes":{"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2:1:1:1::1"}}}]}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv6-routes":{"ipv6-route":[{"route-key":"1:1:1::1/128","path-id":1,"prefix":"1:1:1::1/128","attributes":{"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2:1:1:1::1"}}}]}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"peer-role":"ibgp"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"1:1:1::1/128","prefix":"1:1:1::1/128","attributes":{"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2:1:1:1::1"}}}]}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.142629" elapsed="0.004211"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.142129" elapsed="0.004749"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.142086" elapsed="0.004818"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.149555" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.147189" elapsed="0.002412"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.146962" elapsed="0.002674"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.146944" elapsed="0.002733"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.150241" 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-06-06T03:15:55.149850" elapsed="0.000419"/>
</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-06-06T03:15:55.150580" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.150340" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.151150" 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-06-06T03:15:55.150845" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.150680" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.150322" elapsed="0.000914"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.151780" 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-06-06T03:15:55.151395" elapsed="0.000412"/>
</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-06-06T03:15:55.152116" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.151880" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.152768" 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-06-06T03:15:55.152436" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.152199" elapsed="0.000635"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.151861" elapsed="0.000994"/>
</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-06-06T03:15:55.153010" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:55.153834" 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-06-06T03:15:55.153529" elapsed="0.000331"/>
</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-06-06T03:15:55.154017" elapsed="0.002405"/>
</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-06-06T03:15:55.141143" elapsed="0.015346"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.156684" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.156560" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.156541" elapsed="0.000212"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:55.165882" level="INFO">${text_normalized} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<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="PASS" start="2026-06-06T03:15:55.156902" elapsed="0.009011"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:55.165968" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:55.166131" level="INFO">${response_text} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:55.115973" elapsed="0.050185"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:55.166221" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:55.166371" level="INFO">${response_text} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:54.997531" elapsed="0.168866"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.166738" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.166480" elapsed="0.000368"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.166462" elapsed="0.000412"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:55.166908" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_rib</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:54.993091" elapsed="0.173969"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/bgp_rib</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>mapping=${mapping}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:54.988601" elapsed="0.178522"/>
</kw>
<doc>Check for the presence of Ipv6 Prefix in the BGP RIB</doc>
<status status="PASS" start="2026-06-06T03:15:54.907106" elapsed="0.260141"/>
</test>
<test id="s1-s5-t20" name="Delete_Injected_Ipv6_Routes_1" line="269">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:55.170579" elapsed="0.000250"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:55.170311" elapsed="0.000575"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.171896" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.171784" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.171764" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.177036" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.176927" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.176908" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.178174" 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-06-06T03:15:55.177729" elapsed="0.000472"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.178679" 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-06-06T03:15:55.178363" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:55.178751" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:55.178906" 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-06-06T03:15:55.177330" elapsed="0.001601"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:55.184751" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.184626" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.184606" elapsed="0.000213"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:55.185980" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.185872" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.185852" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:55.186493" 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-06-06T03:15:55.186194" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.186919" level="INFO">${current_connection_index} = 7</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-06-06T03:15:55.186698" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.235494" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:55.187442" elapsed="0.048167"/>
</kw>
<msg time="2026-06-06T03:15:55.235847" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:55.235896" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:55.187106" elapsed="0.048828"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.258946" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "6 "_ "R "o "u "t "e "s "_ "1 "[K"
[?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-06-06T03:15:55.236526" elapsed="0.022557"/>
</kw>
<msg time="2026-06-06T03:15:55.259259" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:55.259305" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "...</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-06-06T03:15:55.236133" elapsed="0.023299"/>
</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-06-06T03:15:55.259838" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.259534" elapsed="0.000365"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.259504" elapsed="0.000423"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.260457" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "6 "_ "R "o "u "t "e "s "_ "1 "[K"
[?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-06-06T03:15:55.260089" elapsed="0.000443"/>
</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-06-06T03:15:55.260853" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.260605" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.260585" elapsed="0.000353"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:55.260975" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:55.263791" elapsed="0.000167"/>
</kw>
<msg time="2026-06-06T03:15:55.264023" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:55.262577" elapsed="0.001587"/>
</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="NOT RUN" start="2026-06-06T03:15:55.264482" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.264902" elapsed="0.000086"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:55.261896" elapsed="0.003220"/>
</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-06-06T03:15:55.261301" elapsed="0.003892"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:55.185544" elapsed="0.079776"/>
</kw>
<msg time="2026-06-06T03:15:55.265430" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:55.265482" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:55.184973" elapsed="0.080556"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:55.265783" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:15:55.265622" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.265598" elapsed="0.000278"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.266304" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.266679" elapsed="0.000029"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.266758" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:55.184268" elapsed="0.082606"/>
</kw>
<msg time="2026-06-06T03:15:55.266986" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:55.267033" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:55.179301" elapsed="0.087771"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.267410" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.267151" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.267133" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:55.179159" elapsed="0.088357"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:55.178987" elapsed="0.088562"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:55.176545" elapsed="0.091063"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:55.171476" elapsed="0.096206"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:55.171039" elapsed="0.096730"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:55.168082" elapsed="0.099747"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.268796" level="INFO">&amp;{mapping} = { IP=127.0.0.12 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.12</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.268041" elapsed="0.000787"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.313718" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:55.313316" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:55.314495" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:55.314254" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:55.314684" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:55.313914" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.315269" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:55.314879" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:55.315598" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:55.315767" level="INFO">${template} = rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:55.315459" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.316196" level="INFO">rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.315950" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.317231" level="INFO">mapping: {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.316968" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.317714" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.317437" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.318405" level="INFO">${value} = 127.0.0.12</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.318108" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.319232" level="INFO">${encoded} = 127.0.0.12</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.319009" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.319338" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:55.319495" level="INFO">${encoded_value} = 127.0.0.12</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.318615" elapsed="0.000906"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.319694" elapsed="0.000238"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.12</var>
<status status="PASS" start="2026-06-06T03:15:55.317973" elapsed="0.002000"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.320537" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.320219" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.321446" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.321234" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.321567" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:55.321745" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.320768" elapsed="0.001003"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.322054" elapsed="0.000402"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:55.320088" elapsed="0.002411"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.323071" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.322765" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.323850" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.323617" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.323927" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.324079" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.323285" elapsed="0.000818"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.324267" elapsed="0.000250"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:55.322613" elapsed="0.001946"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.325128" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.324827" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.325897" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.325682" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.325973" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.326134" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.325351" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.326310" elapsed="0.000222"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:55.324687" elapsed="0.001886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.327129" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.326835" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.327892" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.327679" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.327968" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:55.328121" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.327335" elapsed="0.000811"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.328308" elapsed="0.000240"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:55.326703" elapsed="0.001888"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.329156" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.328857" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.329925" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.329714" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.330001" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.330161" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.329370" elapsed="0.000816"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.330335" elapsed="0.000219"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:55.328724" elapsed="0.001873"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.331171" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.330859" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.331942" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.331730" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.332020" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.332213" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.331381" elapsed="0.000857"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.332391" elapsed="0.000280"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:55.330726" elapsed="0.001989"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.333260" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:55.332961" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:55.334211" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.333999" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:55.334288" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:55.334439" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:55.333488" elapsed="0.000976"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.334629" elapsed="0.000238"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:55.332830" elapsed="0.002080"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:55.317792" elapsed="0.017153"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:55.334989" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:55.335149" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:55.316627" elapsed="0.018548"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.316307" elapsed="0.018900"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.335394" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.335232" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.316288" elapsed="0.019183"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.336333" level="INFO">${final_text} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:55.335614" elapsed="0.000748"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:55.336427" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:55.312699" elapsed="0.023852"/>
</kw>
<msg time="2026-06-06T03:15:55.336605" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:55.299541" elapsed="0.037125"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.349686" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.362526" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.375297" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.375531" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.375727" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.376099" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.375953" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:55.375938" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.376320" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.376505" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.376688" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:55.375908" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.375807" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.376919" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.376995" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:55.377114" level="INFO">${uri} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:55.295027" elapsed="0.082113"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.378260" level="INFO">rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.378005" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:55.389310" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 path_url=/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:55.389415" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:55.389629" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:55.380525" elapsed="0.009221"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.378375" elapsed="0.011481"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:55.390278" elapsed="0.000075"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.389917" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.378356" elapsed="0.012136"/>
</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-06-06T03:15:55.397693" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.392859" elapsed="0.004884"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.392273" elapsed="0.005507"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.392231" elapsed="0.005575"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.400496" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.398090" elapsed="0.002453"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.397863" elapsed="0.002715"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.397846" elapsed="0.002769"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.401203" 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-06-06T03:15:55.400818" elapsed="0.000413"/>
</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-06-06T03:15:55.401542" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.401303" elapsed="0.000372"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.402194" 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-06-06T03:15:55.401872" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.401705" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.401284" elapsed="0.000996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.402825" 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-06-06T03:15:55.402441" elapsed="0.000411"/>
</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-06-06T03:15:55.403160" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.402924" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.403738" 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-06-06T03:15:55.403417" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:55.403243" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.402905" elapsed="0.000919"/>
</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-06-06T03:15:55.403976" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:55.404834" 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-06-06T03:15:55.404534" elapsed="0.000328"/>
</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-06-06T03:15:55.405021" elapsed="0.002424"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:55.391302" elapsed="0.016210"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:55.407559" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:55.409908" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:55.377404" elapsed="0.032532"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:55.409991" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_route_injection</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:55.269077" elapsed="0.141040"/>
</kw>
<kw name="Fail If Exceptions Found During Test" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.411005" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.410897" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.410878" elapsed="0.000196"/>
</if>
<for flavor="IN RANGE">
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.411874" level="INFO">${cmd} = sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_1/d' /tmp/karaf-0.24.0/data/log/karaf.log</msg>
<var>${cmd}</var>
<arg>sed '1,/ROBOT MESSAGE: Starting test ${test_name}/d' ${log_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:55.411524" elapsed="0.000378"/>
</kw>
<kw name="Get Karaf Log Lines From Test Start" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:55.416278" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:55.416170" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.416151" elapsed="0.000195"/>
</if>
<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-06-06T03:15:55.418480" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:55.418203" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:55.418171" elapsed="0.000390"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.418864" level="INFO">index=7
host=10.30.170.38
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:15:55.418968" level="INFO">${current_ssh_connection} = index=7
host=10.30.170.38
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:15:55.418727" elapsed="0.000268"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.419527" level="INFO">Attempting to execute command "sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_1/d' /tmp/karaf-0.24.0/data/log/karaf.log" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.419148" elapsed="0.000426"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.420184" level="INFO">${conn_id} = 8</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:15:55.419747" elapsed="0.000464"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:15:55.421342" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:15:55.421421" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:15:55.420926" elapsed="0.000519"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:55.421619" elapsed="0.000474"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.423151" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:15:55.985232" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:15:55 UTC 2026

  System load:  0.01               Processes:             126
  Usage of /:   11.3% of 77.35GB   Users logged in:       1
  Memory usage: 11%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:13:49 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:15:55.422673" elapsed="0.562699"/>
</kw>
<msg time="2026-06-06T03:15:55.985454" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:55.422269" elapsed="0.563262"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:15:55.420441" elapsed="0.565218"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:55.986137" level="INFO">Executing command 'sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_1/d' /tmp/karaf-0.24.0/data/log/karaf.log'.</msg>
<msg time="2026-06-06T03:15:55.998363" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:55.998516" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:15:55.998579" level="INFO">${stderr} = </msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:55.985897" elapsed="0.012715"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:15:55.998953" elapsed="0.000446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.000450" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:55.999846" elapsed="0.000698"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.001069" elapsed="0.000039"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.000778" elapsed="0.000399"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.000696" elapsed="0.000533"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:15:56.001585" elapsed="0.000087"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.001349" elapsed="0.000403"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.001314" elapsed="0.000494"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.001886" elapsed="0.000032"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:56.009257" elapsed="0.000316"/>
</kw>
<msg time="2026-06-06T03:15:56.009704" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.007954" elapsed="0.001838"/>
</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="NOT RUN" start="2026-06-06T03:15:56.009954" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.010118" elapsed="0.000021"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:56.002569" elapsed="0.007630"/>
</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-06-06T03:15:55.417665" elapsed="0.592625"/>
</kw>
<msg time="2026-06-06T03:15:56.010344" 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-06-06T03:15:55.417087" elapsed="0.593304"/>
</kw>
<msg time="2026-06-06T03:15:56.010503" level="INFO">${output} = </msg>
<var>${output}</var>
<arg>${ip}</arg>
<arg>${cmd}</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>${prompt}</arg>
<doc>Call Run Comand On Remote System, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:15:55.416546" elapsed="0.593984"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:15:56.011065" level="INFO">@{log_lines} = [  ]</msg>
<var>@{log_lines}</var>
<arg>${output}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.010800" elapsed="0.000292"/>
</kw>
<return>
<value>${log_lines}</value>
<status status="PASS" start="2026-06-06T03:15:56.011140" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:56.011296" level="INFO">${output} = ['']</msg>
<var>${output}</var>
<arg>${ODL_SYSTEM_${i}_IP}</arg>
<arg>${test_name}</arg>
<arg>${cmd}</arg>
<doc>Scrapes all log messages that match regexp ${type} which fall after a point given by a log message that
contains bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_1. This is useful if your test cases are marking karaf.log with a message indicating when
that test case has started; such that you can easily pull out any extra log messsages to parse/log/etc in the
test logic itself. For example, you can grab all ERRORS that occur during your test case.</doc>
<status status="PASS" start="2026-06-06T03:15:55.415634" elapsed="0.595687"/>
</kw>
<kw name="Verify Exceptions" owner="excepts">
<msg time="2026-06-06T03:15:56.011719" level="INFO">${exlist} = []</msg>
<msg time="2026-06-06T03:15:56.011765" level="INFO">${matchlist} = []</msg>
<var>${exlist}</var>
<var>${matchlist}</var>
<arg>${output}</arg>
<doc>Return a list of exceptions not in the whitelist for the given lines.</doc>
<status status="PASS" start="2026-06-06T03:15:56.011513" elapsed="0.000279"/>
</kw>
<kw name="Write Exceptions Map To File" owner="excepts">
<arg>${SUITE_NAME}.${TEST_NAME}</arg>
<arg>/tmp/odl${i}_exceptions.txt</arg>
<doc>Write the exceptions map to a file under the testname header. The output
will include all lines in the exception itself as well as any previous
contextual warning or error lines. The output will be appended or overwritten
depending on the mode parameter. It is assumed that the caller has called
verify_exceptions() earlier to populate the exceptions map, otherwise only
the testname and header will be printed to the file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.011976" elapsed="0.000404"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.012872" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:15:56.012949" level="INFO">${listlength} = 0</msg>
<var>${listlength}</var>
<arg>${exlist}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:15:56.012549" elapsed="0.000424"/>
</kw>
<if>
<branch type="IF" condition="&quot;${fail}&quot;==&quot;True&quot; and ${listlength} != 0">
<kw name="Log And Fail Exceptions" owner="KarafKeywords">
<arg>${exlist}</arg>
<arg>${listlength}</arg>
<doc>Print the list of failed exceptions and fail the test</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.013396" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.013046" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Log List" owner="Collections">
<msg time="2026-06-06T03:15:56.013778" level="INFO">List is empty.</msg>
<arg>${matchlist}</arg>
<doc>Logs contents of the ``list`` using the given ``level``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.013626" elapsed="0.000196"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.013483" elapsed="0.000372"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.013026" elapsed="0.000850"/>
</if>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-06T03:15:55.411368" elapsed="0.602534"/>
</iter>
<var>${i}</var>
<value>1</value>
<value>${NUM_ODL_SYSTEM} + 1</value>
<status status="PASS" start="2026-06-06T03:15:55.411113" elapsed="0.602820"/>
</for>
<arg>${SUITE_NAME}.${TEST_NAME}</arg>
<arg>fail=${True}</arg>
<doc>Create a failure if an Exception is found in the karaf.log that has not been whitelisted.
Will work for single controller jobs as well as 3node cluster jobs</doc>
<status status="PASS" start="2026-06-06T03:15:55.410467" elapsed="0.603526"/>
</kw>
<doc>Delete the injected IPV6 routes</doc>
<status status="PASS" start="2026-06-06T03:15:55.167564" elapsed="0.846548"/>
</test>
<test id="s1-s5-t21" name="Delete_Bgp_Peer_Configuration_4" line="286">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:56.017747" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:56.017464" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.019037" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.018924" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.018904" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.024148" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.024040" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.024022" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.025241" 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-06-06T03:15:56.024858" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.025740" 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-06-06T03:15:56.025428" elapsed="0.000338"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:56.025810" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.025963" 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-06-06T03:15:56.024444" elapsed="0.001544"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:56.031534" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.031425" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.031406" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:56.032823" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.032696" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.032676" elapsed="0.000256"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:56.033384" 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-06-06T03:15:56.033081" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.033804" level="INFO">${current_connection_index} = 7</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-06-06T03:15:56.033570" elapsed="0.000261"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.058828" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:56.034335" elapsed="0.024608"/>
</kw>
<msg time="2026-06-06T03:15:56.059119" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:56.059165" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:56.033993" elapsed="0.025208"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.077804" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "4 "[K"
[?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-06-06T03:15:56.059775" elapsed="0.018149"/>
</kw>
<msg time="2026-06-06T03:15:56.078095" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:56.078144" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:15:56.059391" elapsed="0.018789"/>
</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-06-06T03:15:56.078548" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.078280" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.078255" elapsed="0.000378"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.079121" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "4 "[K"
[?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-06-06T03:15:56.078809" elapsed="0.000380"/>
</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-06-06T03:15:56.079476" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.079256" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.079237" elapsed="0.000317"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:56.079590" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:56.082400" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:15:56.082613" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.081164" elapsed="0.001641"/>
</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="NOT RUN" start="2026-06-06T03:15:56.083122" elapsed="0.000090"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.083505" elapsed="0.000086"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:56.080465" elapsed="0.003287"/>
</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-06-06T03:15:56.079911" elapsed="0.003920"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:56.032365" elapsed="0.051579"/>
</kw>
<msg time="2026-06-06T03:15:56.084050" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.084294" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.031776" elapsed="0.052569"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:56.084574" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.084443" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.084418" elapsed="0.000274"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.085216" elapsed="0.000030"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.085694" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.085777" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:56.031087" elapsed="0.054836"/>
</kw>
<msg time="2026-06-06T03:15:56.086030" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.086081" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:56.026355" elapsed="0.059763"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.086507" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.086220" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.086199" elapsed="0.000395"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:56.026213" elapsed="0.060418"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:56.026041" elapsed="0.060641"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:56.023674" elapsed="0.063075"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:56.018606" elapsed="0.068206"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.018174" elapsed="0.068692"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:56.014982" elapsed="0.071945"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.088025" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV4_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.087175" elapsed="0.000884"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.133666" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.133265" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.134465" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.134207" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.134637" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.133864" elapsed="0.000814"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.135232" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.134846" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.135567" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_neighbor_rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:56.135742" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.135424" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.136180" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.135927" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.137266" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.136998" elapsed="0.000356"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.137815" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.137520" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.138533" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.138230" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.139319" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.139096" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.139397" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:56.139550" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.138769" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.139750" elapsed="0.000243"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:15:56.138083" elapsed="0.001953"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.140586" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.140283" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.141375" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.141153" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.141452" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.141602" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.140829" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.141805" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:56.140150" elapsed="0.001920"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.142628" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.142315" elapsed="0.000359"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.143396" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.143183" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.143473" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.143626" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.142865" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.143822" elapsed="0.000400"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:56.142183" elapsed="0.002081"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.144852" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.144508" elapsed="0.000372"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.145598" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.145385" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.145691" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.145844" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.145068" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.146020" elapsed="0.000221"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:56.144376" elapsed="0.001906"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.146849" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.146531" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.147591" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.147380" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.147685" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.147836" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.147064" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.148053" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.146397" elapsed="0.001922"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.149137" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.148563" elapsed="0.000601"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.149918" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.149705" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.149994" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:56.150148" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.149363" elapsed="0.000810"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.150325" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:56.148431" elapsed="0.002158"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.151159" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.150860" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.151926" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.151709" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.152010" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:15:56.152217" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.151372" elapsed="0.000880"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.152462" elapsed="0.000254"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.150728" elapsed="0.002032"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.153363" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.153062" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.154123" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.153911" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.154201" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.154349" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.153575" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.154525" elapsed="0.000237"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.152924" elapsed="0.001878"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.137894" elapsed="0.016943"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.154883" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:56.155046" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'e...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:56.136592" elapsed="0.018480"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.136294" elapsed="0.018811"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.155288" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.155134" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.136275" elapsed="0.019090"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.156247" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:56.155512" elapsed="0.000764"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.156325" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:56.132607" elapsed="0.023845"/>
</kw>
<msg time="2026-06-06T03:15:56.156573" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.119070" elapsed="0.037556"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.171513" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.184880" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_neighbor_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.198031" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.198264" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.198451" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.198883" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.198727" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:56.198708" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.199120" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.199289" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.199455" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:56.198669" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.198536" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.199697" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.199788" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:56.199937" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:56.114494" elapsed="0.085471"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.201197" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.200909" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:56.212260" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:56.212390" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:56.212518" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:56.203499" elapsed="0.009047"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.201314" elapsed="0.011278"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.212861" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.212623" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.201296" elapsed="0.011652"/>
</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-06-06T03:15:56.216521" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.214048" elapsed="0.002517"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.213804" elapsed="0.002796"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.213784" elapsed="0.002841"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.219332" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.216985" elapsed="0.002392"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.216698" elapsed="0.002714"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.216680" elapsed="0.002756"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.220025" 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-06-06T03:15:56.219614" elapsed="0.000439"/>
</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-06-06T03:15:56.220362" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.220124" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.220940" 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-06-06T03:15:56.220605" elapsed="0.000363"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.220443" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.220105" elapsed="0.000920"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.221546" 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-06-06T03:15:56.221183" elapsed="0.000390"/>
</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-06-06T03:15:56.221902" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.221658" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.222438" 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-06-06T03:15:56.222141" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.221982" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.221625" elapsed="0.000897"/>
</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-06-06T03:15:56.222703" elapsed="0.000384"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:56.223569" 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-06-06T03:15:56.223256" elapsed="0.000340"/>
</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-06-06T03:15:56.223798" elapsed="0.002559"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:56.213345" elapsed="0.013079"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:56.226473" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:15:56.228826" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:56.200242" elapsed="0.028626"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.228930" elapsed="0.000033"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_neighbor_rib</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:56.088321" elapsed="0.140743"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:15:56.014383" elapsed="0.214802"/>
</test>
<test id="s1-s5-t22" name="Verify_Ipv6_Topology_Empty_4" line="302">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:56.233429" elapsed="0.000257"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:56.233146" elapsed="0.000667"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.234871" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.234754" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.234733" elapsed="0.000207"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.240112" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.240004" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.239986" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.241280" 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-06-06T03:15:56.240886" elapsed="0.000421"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.241797" 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-06-06T03:15:56.241469" elapsed="0.000367"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:56.241881" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:56.242037" 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-06-06T03:15:56.240410" elapsed="0.001652"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:56.247919" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.247810" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.247789" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:56.249230" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.249121" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.249102" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:56.249763" 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-06-06T03:15:56.249443" elapsed="0.000349"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.250183" level="INFO">${current_connection_index} = 7</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-06-06T03:15:56.249967" elapsed="0.000241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.278903" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:56.250720" elapsed="0.028292"/>
</kw>
<msg time="2026-06-06T03:15:56.279204" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:56.279251" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:56.250367" elapsed="0.028921"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.300034" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "4 "[K"
[?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-06-06T03:15:56.279855" elapsed="0.020304"/>
</kw>
<msg time="2026-06-06T03:15:56.300330" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:56.300377" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:56.279470" elapsed="0.020944"/>
</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-06-06T03:15:56.300931" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.300507" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.300480" elapsed="0.000566"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.301580" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "4 "[K"
[?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-06-06T03:15:56.301234" elapsed="0.000438"/>
</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-06-06T03:15:56.301977" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.301746" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.301726" elapsed="0.000334"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:56.302161" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:56.304910" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:15:56.305143" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.303749" elapsed="0.001533"/>
</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="NOT RUN" start="2026-06-06T03:15:56.305568" elapsed="0.000105"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.305942" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:56.303069" elapsed="0.003065"/>
</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-06-06T03:15:56.302476" elapsed="0.003725"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:56.248775" elapsed="0.057528"/>
</kw>
<msg time="2026-06-06T03:15:56.306401" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.306447" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.248153" elapsed="0.058332"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:56.306701" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.306566" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.306546" elapsed="0.000252"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.307239" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.307590" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.307691" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:56.247451" elapsed="0.060355"/>
</kw>
<msg time="2026-06-06T03:15:56.307903" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.307949" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:56.242441" elapsed="0.065547"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.308327" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.308068" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.308050" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:56.242296" elapsed="0.066139"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:56.242120" elapsed="0.066348"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:56.239611" elapsed="0.068916"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:56.234429" elapsed="0.074158"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.233973" elapsed="0.074665"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:56.230408" elapsed="0.078307"/>
</kw>
<kw name="Verify_Rib_Status_Empty">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.363308" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.362875" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.364162" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.363906" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.364412" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.363526" elapsed="0.000912"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.365037" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.364609" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.365372" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:56.365534" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.365229" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.365986" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.365734" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.367183" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.366812" elapsed="0.000417"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.367697" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.367394" elapsed="0.000330"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.368059" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.368268" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.368444" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:56.367923" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.367778" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.368579" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:56.368765" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:56.366465" elapsed="0.002326"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.366112" elapsed="0.002712"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.369065" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.368850" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.366087" elapsed="0.003069"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.369784" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:56.369307" elapsed="0.000505"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.369861" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:56.362103" elapsed="0.007882"/>
</kw>
<msg time="2026-06-06T03:15:56.370040" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.348568" elapsed="0.021522"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.383324" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.396267" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.409232" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.409476" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.409676" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.410088" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.409936" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:56.409918" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.410315" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.410484" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.410669" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:56.409882" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.409763" elapsed="0.000991"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.410905" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.410983" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:56.411124" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:56.344134" elapsed="0.067018"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.412512" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.412236" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.412695" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.411858" elapsed="0.000863"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.413089" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.412798" elapsed="0.000350"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.413664" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.413352" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.413173" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.412779" elapsed="0.000971"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.416180" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.413905" elapsed="0.002303"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:56.416263" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:56.416426" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:56.411494" elapsed="0.004958"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.417768" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.417498" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.418016" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.417152" elapsed="0.000890"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:56.418255" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.418115" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.418095" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.418490" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.418681" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.418749" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:56.421138" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:56.416793" elapsed="0.004373"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.422573" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.422319" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.423033" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.422789" elapsed="0.000289"/>
</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-06-06T03:15:56.432006" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:56.432200" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:56.432363" 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-06-06T03:15:56.425295" elapsed="0.007108"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.423144" elapsed="0.009330"/>
</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-06-06T03:15:56.432817" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.432520" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.423126" elapsed="0.009817"/>
</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-06-06T03:15:56.438153" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.434547" elapsed="0.003674"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.434210" elapsed="0.004061"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.434180" elapsed="0.004127"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.442002" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.438719" elapsed="0.003329"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.438385" elapsed="0.003697"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.438361" elapsed="0.003745"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.442707" 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-06-06T03:15:56.442290" elapsed="0.000445"/>
</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-06-06T03:15:56.443045" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.442805" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.443598" 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-06-06T03:15:56.443295" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.443128" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.442787" elapsed="0.000917"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.444232" 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-06-06T03:15:56.443866" elapsed="0.000393"/>
</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-06-06T03:15:56.444566" elapsed="0.000107"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.444330" elapsed="0.000383"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.445227" 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-06-06T03:15:56.444908" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.444738" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.444311" elapsed="0.001000"/>
</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-06-06T03:15:56.445467" elapsed="0.000367"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:56.446298" 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-06-06T03:15:56.446003" elapsed="0.000321"/>
</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-06-06T03:15:56.446483" elapsed="0.002519"/>
</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-06-06T03:15:56.433533" elapsed="0.015536"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.449251" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.449140" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.449121" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:56.452204" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:56.449468" elapsed="0.002765"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:56.452286" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:15:56.452449" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:56.421486" elapsed="0.030989"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.452539" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:15:56.452708" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:56.320698" elapsed="0.132037"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.481874" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.481371" elapsed="0.000677"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.482863" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.482549" elapsed="0.000442">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.483169" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.482213" elapsed="0.000982"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.483821" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.483361" elapsed="0.000487"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.484174" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:56.484333" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.484013" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.484859" level="INFO">{
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.484561" elapsed="0.000346"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:56.485394" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.484991" elapsed="0.000463"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.486145" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.485627" elapsed="0.000545"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.485479" elapsed="0.000730"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.484957" elapsed="0.001274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.486873" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:56.486379" elapsed="0.000523"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.486953" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:56.480723" elapsed="0.006356"/>
</kw>
<msg time="2026-06-06T03:15:56.487135" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.467669" elapsed="0.019515"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.500445" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.513409" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.526292" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.526487" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.526680" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.527061" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.526917" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:56.526902" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.527278" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.527444" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.527665" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:56.526873" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.526762" elapsed="0.000987"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.527897" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.527974" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:56.528093" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:56.464907" elapsed="0.063213"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.528296" elapsed="0.002304"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:56.531671" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.531355" elapsed="0.000346"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:56.532137" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.531855" elapsed="0.000310"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:56.532319" elapsed="0.000343"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:56.530943" elapsed="0.001781"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.530698" elapsed="0.002059"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.532931" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.532783" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.530678" elapsed="0.002344"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:56.454024" elapsed="0.079045"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:56.453085" elapsed="0.080058"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.452820" elapsed="0.080369"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.452802" elapsed="0.080411"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.533247" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:56.314122" elapsed="0.219251"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:56.309201" elapsed="0.224231"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty</doc>
<status status="PASS" start="2026-06-06T03:15:56.308860" elapsed="0.224638"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty after deconfiguring peer for the first time.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:56.229700" elapsed="0.303909"/>
</test>
<test id="s1-s5-t23" name="Reconfigure_ODL_To_Accept_Connections_5" line="307">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:56.536919" elapsed="0.000242"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:56.536636" elapsed="0.000581"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.538245" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.538099" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.538080" elapsed="0.000238"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.543517" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.543409" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.543390" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.544590" 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-06-06T03:15:56.544206" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.545121" 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-06-06T03:15:56.544797" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:56.545194" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.545350" 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-06-06T03:15:56.543828" elapsed="0.001548"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:56.550965" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.550857" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.550837" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:56.552206" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.552099" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.552080" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:56.552739" 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-06-06T03:15:56.552421" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.553174" level="INFO">${current_connection_index} = 7</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-06-06T03:15:56.552927" elapsed="0.000274"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.582395" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:56.553718" elapsed="0.028866"/>
</kw>
<msg time="2026-06-06T03:15:56.582831" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:56.582878" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:56.553362" elapsed="0.029552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.606708" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "5 "[K"
[?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-06-06T03:15:56.583569" elapsed="0.023248"/>
</kw>
<msg time="2026-06-06T03:15:56.606976" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:56.607022" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:15:56.583154" elapsed="0.023903"/>
</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-06-06T03:15:56.607395" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.607146" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.607121" elapsed="0.000355"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.607957" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "5 "[K"
[?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-06-06T03:15:56.607621" elapsed="0.000408"/>
</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-06-06T03:15:56.608323" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.608097" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.608078" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:56.608439" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:56.611106" elapsed="0.000321"/>
</kw>
<msg time="2026-06-06T03:15:56.611490" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.610081" elapsed="0.001543"/>
</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="NOT RUN" start="2026-06-06T03:15:56.612022" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.612359" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:56.609342" elapsed="0.003203"/>
</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-06-06T03:15:56.608763" elapsed="0.003848"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:56.551793" elapsed="0.060942"/>
</kw>
<msg time="2026-06-06T03:15:56.612836" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.612881" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.551185" elapsed="0.061732"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:56.613147" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.612995" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.612976" elapsed="0.000257"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.613658" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.614002" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.614073" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:56.550502" elapsed="0.063677"/>
</kw>
<msg time="2026-06-06T03:15:56.614273" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.614316" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:56.545754" elapsed="0.068599"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.614696" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.614428" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.614411" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:56.545595" elapsed="0.069208"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:56.545427" elapsed="0.069408"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:56.543043" elapsed="0.071848"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:56.537812" elapsed="0.077136"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.537369" elapsed="0.077625"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:56.534409" elapsed="0.080640"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.615957" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV4_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.615243" elapsed="0.000744"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.650590" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.650201" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.651488" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.651235" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.651676" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.650810" elapsed="0.000893"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.652267" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.651877" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.652603" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:56.652785" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.652459" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.653237" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.652972" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.654267" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.654007" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.655008" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.654474" elapsed="0.000561"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.655737" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.655419" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.656495" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.656275" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.656573" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:56.656749" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.655953" elapsed="0.000822"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.656931" elapsed="0.000277"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:15:56.655281" elapsed="0.001970"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.657814" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.657499" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.658554" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.658344" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.658629" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:15:56.658796" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.658026" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.658973" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:56.657367" elapsed="0.001869"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.659792" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.659479" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.660531" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.660319" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.660610" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:15:56.660781" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.660004" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.661001" elapsed="0.000244"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:56.659349" elapsed="0.001940"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.661859" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.661538" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.662609" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.662395" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.662702" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.662855" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.662074" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.663032" elapsed="0.000223"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:56.661404" elapsed="0.001893"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.663862" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.663543" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.664605" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.664394" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.664697" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.664848" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.664076" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.665025" elapsed="0.000573"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.663411" elapsed="0.002255"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.666412" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.665924" elapsed="0.000515"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.667177" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.666964" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.667254" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.667404" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.666627" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.667583" elapsed="0.000240"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:56.665785" elapsed="0.002079"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.668416" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.668110" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.669201" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.668973" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.669278" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:56.669432" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.668630" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.669610" elapsed="0.000247"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.667978" elapsed="0.001921"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.670445" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.670145" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.671206" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.670996" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.671282" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.671431" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.670679" elapsed="0.000777"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.671687" elapsed="0.000225"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.670013" elapsed="0.001941"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.655090" elapsed="0.016899"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.672032" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:56.672191" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'e...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:56.653681" elapsed="0.018537"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.653361" elapsed="0.018890"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.672424" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.672276" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.653338" elapsed="0.019162"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.673383" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:56.672657" elapsed="0.000755"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.673463" elapsed="0.000027"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:56.649567" elapsed="0.024019"/>
</kw>
<msg time="2026-06-06T03:15:56.673657" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.636494" elapsed="0.037213"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.688163" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.700935" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.713929" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.714125" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.714301" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.714681" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.714523" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:56.714508" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.714906" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.715074" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.715282" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:56.714479" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.714378" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.715508" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.715585" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:56.715728" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:56.632083" elapsed="0.083672"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.742946" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.742549" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.743718" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.743473" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.743882" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.743137" elapsed="0.000769"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.744456" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.744070" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.744797" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:56.744938" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.744658" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.745395" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.745151" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:56.745826" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.745521" elapsed="0.000363"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.746351" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'e...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.746054" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.745909" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.745502" elapsed="0.000933"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.747324" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:56.746578" elapsed="0.000806"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.747436" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:56.741937" elapsed="0.005625"/>
</kw>
<msg time="2026-06-06T03:15:56.747620" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.728807" elapsed="0.018876"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.760628" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.773509" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.786493" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.786728" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.786917" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.787329" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.787177" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:56.787159" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.787555" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.787737" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.787906" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:56.787120" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.787004" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.788132" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.788211" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:15:56.788373" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:56.726078" elapsed="0.062325"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.789892" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.789598" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.790059" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.789204" elapsed="0.000880"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.790418" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.790156" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.790989" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.790694" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.790500" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.790137" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.793525" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.791225" elapsed="0.002327"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:56.793603" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:56.793776" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:56.788822" elapsed="0.004979"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.795202" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.794947" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.795663" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.795405" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.796126" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.795878" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.796565" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.796322" elapsed="0.000287"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:56.797464" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:56.797264" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:56.797840" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:56.797658" elapsed="0.000211"/>
</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-06-06T03:15:56.798020" elapsed="0.000207"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.798632" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.798384" elapsed="0.000309"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:56.798735" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:56.798893" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:56.796829" elapsed="0.002090"/>
</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-06-06T03:15:56.814978" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '983', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:56.815207" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:56.815441" 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-06-06T03:15:56.801355" elapsed="0.014146"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.798990" elapsed="0.016615"/>
</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-06-06T03:15:56.816081" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.815712" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.798972" elapsed="0.017311"/>
</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-06-06T03:15:56.824021" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.818512" elapsed="0.005614"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.818014" elapsed="0.006195"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.817972" elapsed="0.006295"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.827799" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.824937" elapsed="0.002909"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.824396" elapsed="0.003485"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.824357" elapsed="0.003549"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.828501" 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-06-06T03:15:56.828095" elapsed="0.000435"/>
</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-06-06T03:15:56.828859" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.828600" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.829422" 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-06-06T03:15:56.829107" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.828942" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.828582" elapsed="0.000923"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.830049" 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-06-06T03:15:56.829679" elapsed="0.000396"/>
</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-06-06T03:15:56.830380" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.830146" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.830930" 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-06-06T03:15:56.830620" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.830461" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.830127" elapsed="0.000884"/>
</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-06-06T03:15:56.831164" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:56.831993" 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-06-06T03:15:56.831693" elapsed="0.000326"/>
</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-06-06T03:15:56.832175" elapsed="0.002355"/>
</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-06-06T03:15:56.817135" elapsed="0.017460"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:56.834792" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.834680" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.834660" elapsed="0.000229"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:56.835041" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.835109" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:56.837616" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:56.794128" elapsed="0.043534"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.837825" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:15:56.838016" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:56.620936" elapsed="0.217111"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.838429" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.838175" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.838152" elapsed="0.000371"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.838556" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:56.616259" elapsed="0.222439"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with short ipv6 address.</doc>
<status status="PASS" start="2026-06-06T03:15:56.533842" elapsed="0.304983"/>
</test>
<test id="s1-s5-t24" name="Inject_Ipv6_Route_2" line="323">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:56.842220" elapsed="0.000223"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:56.841953" elapsed="0.000548"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.843535" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.843421" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.843400" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.848868" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.848756" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.848736" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.849994" 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-06-06T03:15:56.849564" elapsed="0.000467"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.850518" 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-06-06T03:15:56.850203" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:56.850591" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.850767" 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-06-06T03:15:56.849183" elapsed="0.001609"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:56.856372" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.856263" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.856243" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:56.857687" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:56.857555" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.857535" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:56.858346" 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-06-06T03:15:56.857903" elapsed="0.000469"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.858768" level="INFO">${current_connection_index} = 7</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-06-06T03:15:56.858532" elapsed="0.000262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.888299" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:56.859290" elapsed="0.029109"/>
</kw>
<msg time="2026-06-06T03:15:56.888578" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:56.888624" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:56.858955" elapsed="0.029724"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:56.907321" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "2 "[K"
[?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-06-06T03:15:56.889214" elapsed="0.018260"/>
</kw>
<msg time="2026-06-06T03:15:56.907635" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:56.907704" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "2 "...</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-06-06T03:15:56.888855" elapsed="0.018897"/>
</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-06-06T03:15:56.908055" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.907830" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.907810" elapsed="0.000324"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.908571" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "2 "[K"
[?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-06-06T03:15:56.908274" elapsed="0.000362"/>
</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-06-06T03:15:56.908946" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.908724" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.908704" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:56.909058" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:56.911623" elapsed="0.000169"/>
</kw>
<msg time="2026-06-06T03:15:56.911855" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.910532" elapsed="0.001454"/>
</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="NOT RUN" start="2026-06-06T03:15:56.912260" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.912595" elapsed="0.000096"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:56.909900" elapsed="0.002906"/>
</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-06-06T03:15:56.909348" elapsed="0.003523"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:56.857251" elapsed="0.055718"/>
</kw>
<msg time="2026-06-06T03:15:56.913063" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.913108" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "2 "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.856592" elapsed="0.056553"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:56.913537" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:56.913260" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.913240" elapsed="0.000385"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.914050" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.914398" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:56.914470" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:56.855925" elapsed="0.058654"/>
</kw>
<msg time="2026-06-06T03:15:56.914702" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:56.914749" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "I "n "j "e "c "t "_ "I "p "v "6 "_ "R "o "u "t "e "_ "2 "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:56.851173" elapsed="0.063614"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.915116" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.914865" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.914847" elapsed="0.000347"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:56.851028" elapsed="0.064190"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:56.850852" elapsed="0.064396"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:56.848377" elapsed="0.066959"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:56.843126" elapsed="0.072269"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:56.842672" elapsed="0.072769"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:56.839691" elapsed="0.075803"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.916362" level="INFO">&amp;{mapping} = { IP=127.0.0.12 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.12</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.915708" elapsed="0.000683"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.951191" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:56.950812" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.951980" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:56.951738" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:56.952150" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:56.951387" elapsed="0.000789"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.952744" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:56.952341" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:56.953071" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:56.953237" level="INFO">${template} = rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:56.952933" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.953683" level="INFO">rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.953424" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.954682" level="INFO">mapping: {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:56.954407" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.955149" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.954888" elapsed="0.000286"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.955849" level="INFO">${value} = 127.0.0.12</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.955536" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.956798" level="INFO">${encoded} = 127.0.0.12</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.956561" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.956878" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.957031" level="INFO">${encoded_value} = 127.0.0.12</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.956238" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.957237" elapsed="0.000243"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.12</var>
<status status="PASS" start="2026-06-06T03:15:56.955403" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.958194" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.957787" elapsed="0.000433"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.958954" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.958739" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.959031" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.959180" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.958407" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.959356" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:56.957635" elapsed="0.001985"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.960193" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.959889" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.960958" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.960743" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.961036" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.961187" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.960408" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.961381" elapsed="0.000225"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:56.959750" elapsed="0.001915"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.962217" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.961917" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.962975" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.962762" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.963052" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.963202" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.962428" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.963378" elapsed="0.000221"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:56.961782" elapsed="0.001872"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.964206" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.963905" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.964983" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.964761" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.965064" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:56.965262" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.964416" elapsed="0.000873"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.965441" elapsed="0.000243"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.963772" elapsed="0.001956"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.966288" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.965983" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.967403" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.966840" elapsed="0.000589"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.967482" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.967634" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.966501" elapsed="0.001174"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.967833" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:56.965851" elapsed="0.002246"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.968662" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.968345" elapsed="0.000395"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.969488" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.969274" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.969564" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.969730" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.968936" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.969908" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.968212" elapsed="0.001958"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.970726" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:56.970414" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:56.971463" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.971252" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:56.971539" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:56.971706" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:56.970936" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:56.971889" elapsed="0.000221"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:56.970282" elapsed="0.001869"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.955223" elapsed="0.016964"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:56.972231" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:56.972392" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:56.954089" elapsed="0.018330"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:56.953800" elapsed="0.018652"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.972630" elapsed="0.000044"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:56.972479" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:56.953780" elapsed="0.018952"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:56.973598" level="INFO">${final_text} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:56.972878" elapsed="0.000749"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:56.973695" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:56.950182" elapsed="0.023640"/>
</kw>
<msg time="2026-06-06T03:15:56.973880" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:56.937123" elapsed="0.036806"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.987035" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:56.999887" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.012941" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.013145" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.013357" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.013764" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.013600" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:57.013582" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.013991" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.014159" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.014327" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:57.013548" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.013443" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.014553" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.014630" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:57.014779" level="INFO">${uri} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:56.932700" elapsed="0.082106"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.040797" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.040379" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.041653" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:57.041379" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:57.041831" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:57.041002" elapsed="0.000856"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.042413" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:57.042024" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.042761" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:57.042926" level="INFO">${template} = &lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testi...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:57.042602" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.043361" level="INFO">&lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testing --&gt;
  &lt;!-- 1:1:1::1/128 should look like the following example: 1.1.1.1/32 --&gt;
  &lt;path-id&gt;1&lt;/path-id&gt;
  &lt;route-key&gt;1:1:1::1/128&lt;/route-key&gt;
  &lt;prefix&gt;1:1:1::1/128&lt;/prefix&gt;
  &lt;attributes&gt;
    &lt;ipv6-next-hop&gt;
      &lt;global&gt;2:1:1:1::1&lt;/global&gt;
    &lt;/ipv6-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;origin&gt;
      &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
  &lt;/attributes&gt;
&lt;/ipv6-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.043112" elapsed="0.000368"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:57.043899" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.043556" elapsed="0.000403"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.044440" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.044133" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.043985" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.043534" elapsed="0.000991"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.045189" level="INFO">${final_text} = &lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:57.044690" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.045286" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:57.039747" elapsed="0.005676"/>
</kw>
<msg time="2026-06-06T03:15:57.045481" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.026454" elapsed="0.019077"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.058455" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.071487" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.084489" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.084702" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.084885" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.085367" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.085138" elapsed="0.000291"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:57.085122" elapsed="0.000331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.085596" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.085781" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.085950" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:57.085084" elapsed="0.000918"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.084973" elapsed="0.001113"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.086240" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.086316" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:57.086452" level="INFO">${data} = &lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testi...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:57.025512" elapsed="0.060969"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.087800" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:57.087524" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:57.087968" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:57.087174" elapsed="0.000819"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.088313" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.088064" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.088886" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.088567" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.088394" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.088046" elapsed="0.000923"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.091406" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:57.089122" elapsed="0.002311"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:57.091485" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.091652" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:57.086835" elapsed="0.004845"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.093224" level="INFO">rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.092970" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.093708" level="INFO">&lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testing --&gt;
  &lt;!-- 1:1:1::1/128 should look like the following example: 1.1.1.1/32 --&gt;
  &lt;path-id&gt;1&lt;/path-id&gt;
  &lt;route-key&gt;1:1:1::1/128&lt;/route-key&gt;
  &lt;prefix&gt;1:1:1::1/128&lt;/prefix&gt;
  &lt;attributes&gt;
    &lt;ipv6-next-hop&gt;
      &lt;global&gt;2:1:1:1::1&lt;/global&gt;
    &lt;/ipv6-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;origin&gt;
      &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
  &lt;/attributes&gt;
&lt;/ipv6-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.093450" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.094311" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.093916" elapsed="0.000439"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.094765" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.094507" elapsed="0.000302"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:57.095611" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:57.095415" elapsed="0.000222"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:57.095982" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:57.095806" elapsed="0.000202"/>
</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-06-06T03:15:57.096159" elapsed="0.000209"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.096835" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.096565" elapsed="0.000315"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:57.096923" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.097079" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:57.095012" elapsed="0.002093"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:57.112092" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 path_url=/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '759', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" encoding="UTF-8" standalone="no"?&gt;
&lt;ipv6-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
  &lt;!-- the prefix is a bogus value - just needs to be the same for n-path testing --&gt;
  &lt;!-- 1:1:1::1/128 should look like the following example: 1.1.1.1/32 --&gt;
  &lt;path-id&gt;1&lt;/path-id&gt;
  &lt;route-key&gt;1:1:1::1/128&lt;/route-key&gt;
  &lt;prefix&gt;1:1:1::1/128&lt;/prefix&gt;
  &lt;attributes&gt;
    &lt;ipv6-next-hop&gt;
      &lt;global&gt;2:1:1:1::1&lt;/global&gt;
    &lt;/ipv6-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
      &lt;!--- This is a bogus value --&gt;
      &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;origin&gt;
      &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
  &lt;/attributes&gt;
&lt;/ipv6-route&gt; 
 </msg>
<msg time="2026-06-06T03:15:57.112179" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes/ipv6-route=1%3A1%3A1%3A%3A1%2F128,1', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:57.112307" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:57.099529" elapsed="0.012815"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.097175" elapsed="0.015233"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.112687" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.112445" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.097157" elapsed="0.015657"/>
</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-06-06T03:15:57.120188" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.114669" elapsed="0.005617"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.114141" elapsed="0.006225"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.114099" elapsed="0.006324"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.123946" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.121084" elapsed="0.002908"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.120550" elapsed="0.003477"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.120512" elapsed="0.003539"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.124610" 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-06-06T03:15:57.124222" elapsed="0.000416"/>
</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-06-06T03:15:57.124968" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.124727" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.125525" 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-06-06T03:15:57.125211" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.125049" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.124707" elapsed="0.000901"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.126146" 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-06-06T03:15:57.125781" 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-06-06T03:15:57.126480" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.126245" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.127039" 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-06-06T03:15:57.126734" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.126560" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.126226" elapsed="0.000941"/>
</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-06-06T03:15:57.127325" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:57.128150" 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-06-06T03:15:57.127864" elapsed="0.000313"/>
</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-06-06T03:15:57.128334" elapsed="0.002365"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:15:57.113356" elapsed="0.017409"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:57.130950" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:15:57.130840" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.130821" elapsed="0.000217"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:57.131189" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.131258" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:57.133616" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:15:57.092009" elapsed="0.041647"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.133729" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.133886" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:56.921339" elapsed="0.212572"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.134252" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.134014" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.133997" elapsed="0.000347"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.134377" elapsed="0.000025"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_route_injection</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:56.916684" elapsed="0.217816"/>
</kw>
<doc>Inject the Ipv6 route from controller</doc>
<status status="PASS" start="2026-06-06T03:15:56.839185" elapsed="0.295437"/>
</test>
<test id="s1-s5-t25" name="Check_Ipv6_Prefix_In_Bgp_Rib_2" line="339">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:57.138170" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:57.137904" elapsed="0.000539"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.139459" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.139349" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.139329" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.144586" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.144479" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.144461" elapsed="0.000209"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.145696" 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-06-06T03:15:57.145279" elapsed="0.000445"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.146191" 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-06-06T03:15:57.145888" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:57.146261" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:57.146416" 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-06-06T03:15:57.144899" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:57.152156" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.152047" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.152028" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:57.153422" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.153299" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.153280" elapsed="0.000211"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:57.153960" 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-06-06T03:15:57.153636" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.154365" level="INFO">${current_connection_index} = 7</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-06-06T03:15:57.154146" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.186163" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:57.154910" elapsed="0.031406"/>
</kw>
<msg time="2026-06-06T03:15:57.186515" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:57.186562" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:57.154551" elapsed="0.032049"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.209025" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "n "_ "B "g "p "_ "R "i "b "_ "2 "[K"
[?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-06-06T03:15:57.187238" elapsed="0.021911"/>
</kw>
<msg time="2026-06-06T03:15:57.209325" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:57.209394" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "...</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-06-06T03:15:57.186842" elapsed="0.022594"/>
</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-06-06T03:15:57.209856" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.209537" elapsed="0.000387"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.209507" elapsed="0.000446"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.210435" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "n "_ "B "g "p "_ "R "i "b "_ "2 "[K"
[?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-06-06T03:15:57.210098" elapsed="0.000407"/>
</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-06-06T03:15:57.210808" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.210572" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.210553" elapsed="0.000334"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:57.210926" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:57.213710" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:15:57.213933" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.212478" elapsed="0.001588"/>
</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="NOT RUN" start="2026-06-06T03:15:57.214342" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.214696" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:57.211819" elapsed="0.003068"/>
</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-06-06T03:15:57.211242" elapsed="0.003710"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:57.152994" elapsed="0.062056"/>
</kw>
<msg time="2026-06-06T03:15:57.215145" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:57.215190" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:57.152379" elapsed="0.062850"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:57.215473" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:57.215362" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.215342" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.215998" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.216340" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.216412" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:57.151708" elapsed="0.064814"/>
</kw>
<msg time="2026-06-06T03:15:57.216620" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:57.216686" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "p "v "6 "_ "P "r "e "f "i "x "_ "I "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:57.146893" elapsed="0.069833"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.217056" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.216804" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.216786" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:57.146747" elapsed="0.070412"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:57.146545" elapsed="0.070647"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:57.144119" elapsed="0.073129"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:57.139059" elapsed="0.078245"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:57.138596" elapsed="0.078776"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:57.135502" elapsed="0.081924"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.218368" level="INFO">&amp;{mapping} = { IP=10.30.170.38 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${CONTROLLER_IPV4}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.217623" elapsed="0.000775"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.271263" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.270877" elapsed="0.000416"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.272072" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:57.271823" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:57.272242" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:57.271462" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.272836" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:57.272434" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.273164" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:57.273328" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:57.273024" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.273861" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.273589" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.274896" level="INFO">mapping: {'IP': '10.30.170.38', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.274612" elapsed="0.000331"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.275371" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.275104" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.276118" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.275783" elapsed="0.000362"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.277058" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.276706" elapsed="0.000379"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.277137" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:57.277292" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.276332" elapsed="0.000985"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.277485" elapsed="0.000308"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:15:57.275630" elapsed="0.002207"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.278399" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.278082" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.279295" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.278966" elapsed="0.000356"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.279374" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.279522" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.278610" elapsed="0.000937"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.279713" elapsed="0.000276"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:57.277948" elapsed="0.002082"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.280589" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.280273" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.281695" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.281333" elapsed="0.000390"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.281782" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:15:57.281964" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.280989" elapsed="0.000999"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.282139" elapsed="0.000271"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:57.280140" elapsed="0.002312"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.283040" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.282720" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.283942" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.283588" elapsed="0.000381"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.284019" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.284169" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.283251" elapsed="0.000942"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.284344" elapsed="0.000270"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:57.282565" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.285255" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.284934" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.286252" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.285923" elapsed="0.000356"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.286329" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.286478" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.285504" elapsed="0.000999"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.286671" elapsed="0.000272"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:57.284800" elapsed="0.002185"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.287551" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.287232" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.288451" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.288121" elapsed="0.000356"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.288529" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.288709" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.287782" elapsed="0.000953"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.288888" elapsed="0.000271"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:57.287099" elapsed="0.002101"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.289824" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.289465" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.290729" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.290378" elapsed="0.000377"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.290806" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.290956" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.290037" elapsed="0.000943"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.291132" elapsed="0.000270"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:57.289313" elapsed="0.002130"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.292026" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.291705" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.292941" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.292577" elapsed="0.000391"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.293018" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:57.293170" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.292239" elapsed="0.000955"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.293371" elapsed="0.000527"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:57.291557" elapsed="0.002383"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:57.275448" elapsed="0.018528"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:57.294020" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:57.294181" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME':...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:57.274285" elapsed="0.019923"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.273985" elapsed="0.020254"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.294414" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.294264" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.273964" elapsed="0.020527"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.295328" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:57.294635" elapsed="0.000721"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.295406" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:57.270239" elapsed="0.025292"/>
</kw>
<msg time="2026-06-06T03:15:57.295621" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.257201" elapsed="0.038486"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.308680" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.321708" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.334551" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.334763" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.334943" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.335312" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.335167" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:57.335151" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.335537" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.335723" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.335894" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:57.335122" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.335021" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.336123" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.336200" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:57.336316" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:57.252779" elapsed="0.083563"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.337616" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:57.337360" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:57.337829" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:57.337014" elapsed="0.000840"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.338188" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.337926" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.338756" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.338442" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.338271" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.337907" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.341257" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:57.339002" elapsed="0.002283"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:57.341338" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:57.341521" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:57.336684" elapsed="0.004863"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.342782" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:57.342533" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:57.342940" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:57.342194" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:57.343172" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:57.343037" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.343018" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.343403" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.343575" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.343657" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:57.345873" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:57.341868" elapsed="0.004032"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.347311" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.347058" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.347778" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.347513" elapsed="0.000310"/>
</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-06-06T03:15:57.365402" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:57.366370" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://127.0.0.12","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:15:57.366894" 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-06-06T03:15:57.350083" elapsed="0.016873"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.347890" elapsed="0.019164"/>
</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-06-06T03:15:57.367461" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.367114" elapsed="0.000494"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.347872" elapsed="0.019815"/>
</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-06-06T03:15:57.376237" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://127.0.0.12","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv6-routes":{"ipv6-route":[{"route-key":"1:1:1::1/128","path-id":1,"prefix":"1:1:1::1/128","attributes":{"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2:1:1:1::1"}}}]}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv6-routes":{"ipv6-route":[{"route-key":"1:1:1::1/128","path-id":1,"prefix":"1:1:1::1/128","attributes":{"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2:1:1:1::1"}}}]}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}}]},"peer-role":"ibgp"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"1:1:1::1/128","prefix":"1:1:1::1/128","attributes":{"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2:1:1:1::1"}}}]}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.370028" elapsed="0.006755"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.369502" elapsed="0.007366"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.369457" elapsed="0.007469"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.380074" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.377616" elapsed="0.002505"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.377057" elapsed="0.003098"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.377017" elapsed="0.003164"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.380747" 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-06-06T03:15:57.380347" elapsed="0.000428"/>
</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-06-06T03:15:57.381085" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.380846" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.381663" 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-06-06T03:15:57.381328" elapsed="0.000364"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.381168" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.380828" elapsed="0.000921"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.382282" 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-06-06T03:15:57.381915" elapsed="0.000394"/>
</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-06-06T03:15:57.382614" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.382380" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.383174" 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-06-06T03:15:57.382876" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.382714" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.382361" elapsed="0.000896"/>
</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-06-06T03:15:57.383409" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:57.384223" 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-06-06T03:15:57.383942" elapsed="0.000308"/>
</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-06-06T03:15:57.384405" elapsed="0.002373"/>
</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-06-06T03:15:57.368486" elapsed="0.018357"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.387022" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.386915" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.386896" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:57.396299" level="INFO">${text_normalized} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<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="PASS" start="2026-06-06T03:15:57.387236" elapsed="0.009094"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:57.396383" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:57.396548" level="INFO">${response_text} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:57.346215" elapsed="0.050360"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.396666" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:57.396826" level="INFO">${response_text} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:57.227531" elapsed="0.169322"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.397180" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.396938" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.396920" elapsed="0.000396"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.397350" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_rib</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:57.223089" elapsed="0.174415"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/bgp_rib</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>mapping=${mapping}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:57.218585" elapsed="0.178977"/>
</kw>
<doc>Check for the presence of Ipv6 Prefix in the BGP RIB</doc>
<status status="PASS" start="2026-06-06T03:15:57.134973" elapsed="0.262732"/>
</test>
<test id="s1-s5-t26" name="Delete_Injected_Ipv6_Routes_2" line="358">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:57.401217" elapsed="0.000238"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:57.400946" elapsed="0.000573"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.402551" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.402436" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.402415" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.407715" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.407592" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.407575" elapsed="0.000209"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.408942" 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-06-06T03:15:57.408537" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.409427" 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-06-06T03:15:57.409131" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:57.409513" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:15:57.409689" 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-06-06T03:15:57.408159" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:57.415497" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.415390" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.415370" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:57.416753" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.416618" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.416600" elapsed="0.000223"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:57.417266" 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-06-06T03:15:57.416967" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.417703" level="INFO">${current_connection_index} = 7</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-06-06T03:15:57.417469" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.447054" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:57.418241" elapsed="0.028928"/>
</kw>
<msg time="2026-06-06T03:15:57.447336" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:57.447383" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:57.417903" elapsed="0.029517"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.469841" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "6 "_ "R "o "u "t "e "s "_ "2 "[K"
[?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-06-06T03:15:57.447977" elapsed="0.021970"/>
</kw>
<msg time="2026-06-06T03:15:57.470110" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:57.470158" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "...</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-06-06T03:15:57.447595" elapsed="0.022646"/>
</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-06-06T03:15:57.470545" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.470321" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.470301" elapsed="0.000325"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.471251" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "6 "_ "R "o "u "t "e "s "_ "2 "[K"
[?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-06-06T03:15:57.470791" elapsed="0.000527"/>
</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-06-06T03:15:57.471601" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.471386" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.471367" elapsed="0.000334"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:57.471735" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:57.474304" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:15:57.474509" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.473177" elapsed="0.001479"/>
</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="NOT RUN" start="2026-06-06T03:15:57.474939" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.475274" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:57.472537" elapsed="0.002921"/>
</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-06-06T03:15:57.472005" elapsed="0.003516"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:57.416317" elapsed="0.059302"/>
</kw>
<msg time="2026-06-06T03:15:57.475729" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:57.475773" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:57.415733" elapsed="0.060077"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:57.475998" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:15:57.475891" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.475872" elapsed="0.000210"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.476478" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.476843" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.476916" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:57.415047" elapsed="0.061976"/>
</kw>
<msg time="2026-06-06T03:15:57.477116" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:57.477161" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "I "n "j "e "c "t "e "d "_ "I "p "v "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:57.410087" elapsed="0.067110"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.477544" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.477271" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.477254" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:57.409944" elapsed="0.067718"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:57.409770" elapsed="0.067924"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:57.407230" elapsed="0.070517"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:57.402139" elapsed="0.075664"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:57.401695" elapsed="0.076188"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:57.398501" elapsed="0.079436"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.478807" level="INFO">&amp;{mapping} = { IP=127.0.0.12 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.12</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.478133" elapsed="0.000704"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.525389" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.524872" elapsed="0.000558"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.526504" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:57.526160" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:57.526753" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:57.525714" elapsed="0.001072"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.527528" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:57.527011" elapsed="0.000554"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:57.527993" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_route_injection/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:57.528194" level="INFO">${template} = rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:57.527810" elapsed="0.000417"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.528787" level="INFO">rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.528435" elapsed="0.000412"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.530153" level="INFO">mapping: {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.529807" elapsed="0.000407"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.530810" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.530434" elapsed="0.000410"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.531735" level="INFO">${value} = 127.0.0.12</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.531349" elapsed="0.000414"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.532526" level="INFO">${encoded} = 127.0.0.12</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.532296" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.532608" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:15:57.532791" level="INFO">${encoded_value} = 127.0.0.12</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.531957" elapsed="0.000859"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.532977" elapsed="0.000252"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.12</var>
<status status="PASS" start="2026-06-06T03:15:57.531165" elapsed="0.002106"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.533881" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.533551" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.534666" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.534437" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.534795" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:57.534953" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.534113" elapsed="0.000868"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.535151" elapsed="0.000408"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:57.533386" elapsed="0.002216"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.536199" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.535875" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.536987" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.536764" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.537075" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:57.537234" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.536421" elapsed="0.000839"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.537415" elapsed="0.000265"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:57.535737" elapsed="0.001988"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.538351" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.537979" elapsed="0.000405"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.539178" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.538954" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.539255" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:57.539407" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.538611" elapsed="0.000821"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.539587" elapsed="0.000258"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:57.537841" elapsed="0.002047"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.540452" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.540146" elapsed="0.000333"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.541271" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.541036" elapsed="0.000270"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.541370" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:57.541596" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.540685" elapsed="0.000945"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.541835" elapsed="0.000286"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:57.540009" elapsed="0.002166"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.542828" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.542488" elapsed="0.000366"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.543593" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.543378" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.543689" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:57.543848" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.543052" elapsed="0.000822"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.544036" elapsed="0.000228"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:57.542315" elapsed="0.001992"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.544879" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.544553" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.545685" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.545433" elapsed="0.000279"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.545765" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:57.545964" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.545105" elapsed="0.000889"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.546159" elapsed="0.000228"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:57.544421" elapsed="0.002008"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.547008" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.546694" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:57.547964" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.547749" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:57.548050" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:57.548205" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:57.547234" elapsed="0.000996"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.548383" elapsed="0.000224"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:57.546544" elapsed="0.002119"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:57.530917" elapsed="0.017784"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:57.548745" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:57.548915" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:57.529336" elapsed="0.019614"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.528941" elapsed="0.020047"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.549176" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.549020" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.528912" elapsed="0.020350"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.550184" level="INFO">${final_text} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:57.549419" elapsed="0.000794"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.550265" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:57.523937" elapsed="0.026457"/>
</kw>
<msg time="2026-06-06T03:15:57.550451" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.509743" elapsed="0.040757"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.563592" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.576877" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_route_injection/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.590072" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.590311" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.590510" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.590915" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.590766" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:57.590751" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.591152" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.591323" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.591508" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:57.590719" elapsed="0.000851"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.590595" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.591763" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.591842" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:57.591967" level="INFO">${uri} = rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:57.505005" elapsed="0.086996"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.593157" level="INFO">rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.592883" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:57.603942" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 path_url=/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:57.604018" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=127.0.0.12/tables=bgp-types%3Aipv6-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv6-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:57.604149" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:57.595449" elapsed="0.008737"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.593270" elapsed="0.010972"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.604494" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.604280" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.593252" elapsed="0.011357"/>
</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-06-06T03:15:57.610250" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.606325" elapsed="0.003991"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.605926" elapsed="0.004443"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.605893" elapsed="0.004512"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.614175" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.610857" elapsed="0.003365"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.610487" elapsed="0.003770"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.610462" elapsed="0.003821"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.614912" 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-06-06T03:15:57.614477" elapsed="0.000463"/>
</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-06-06T03:15:57.615272" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.615022" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.615920" 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-06-06T03:15:57.615580" elapsed="0.000367"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.615409" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.615001" elapsed="0.001016"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.616564" 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-06-06T03:15:57.616185" elapsed="0.000407"/>
</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-06-06T03:15:57.616923" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.616682" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.617495" 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-06-06T03:15:57.617187" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.617019" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.616661" elapsed="0.000941"/>
</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-06-06T03:15:57.617778" elapsed="0.000374"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:57.618616" 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-06-06T03:15:57.618323" elapsed="0.000336"/>
</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-06-06T03:15:57.618838" elapsed="0.002408"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:57.605177" elapsed="0.016135"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:57.621360" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:15:57.623759" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:57.592273" elapsed="0.031514"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:57.623843" elapsed="0.000029"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_route_injection</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:57.479079" elapsed="0.144893"/>
</kw>
<kw name="Fail If Exceptions Found During Test" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.624898" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.624786" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.624766" elapsed="0.000200"/>
</if>
<for flavor="IN RANGE">
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.625824" level="INFO">${cmd} = sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_2/d' /tmp/karaf-0.24.0/data/log/karaf.log</msg>
<var>${cmd}</var>
<arg>sed '1,/ROBOT MESSAGE: Starting test ${test_name}/d' ${log_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:57.625445" elapsed="0.000412"/>
</kw>
<kw name="Get Karaf Log Lines From Test Start" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.630423" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.630312" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.630292" elapsed="0.000199"/>
</if>
<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-06-06T03:15:57.632662" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.632373" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.632353" elapsed="0.000393"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.633048" level="INFO">index=7
host=10.30.170.38
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:15:57.633155" level="INFO">${current_ssh_connection} = index=7
host=10.30.170.38
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:15:57.632900" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.633763" level="INFO">Attempting to execute command "sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_2/d' /tmp/karaf-0.24.0/data/log/karaf.log" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.633340" elapsed="0.000472"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.634470" level="INFO">${conn_id} = 9</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.633976" elapsed="0.000522"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.635576" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:15:57.635672" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:15:57.635158" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.635870" elapsed="0.000362"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.637142" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:15:57.956715" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:15:55 UTC 2026

  System load:  0.01               Processes:             126
  Usage of /:   11.3% of 77.35GB   Users logged in:       1
  Memory usage: 11%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:15:55 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:15:57.636801" elapsed="0.320163"/>
</kw>
<msg time="2026-06-06T03:15:57.957134" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.636411" elapsed="0.320867"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:15:57.634740" elapsed="0.322748"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:57.958461" level="INFO">Executing command 'sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_2/d' /tmp/karaf-0.24.0/data/log/karaf.log'.</msg>
<msg time="2026-06-06T03:15:57.971198" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:57.971457" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:15:57.971563" level="INFO">${stderr} = </msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:57.958013" elapsed="0.013606"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:15:57.972072" elapsed="0.000504"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.973804" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:57.973071" elapsed="0.000843"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.974417" elapsed="0.000044"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.974104" elapsed="0.000431"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.974050" elapsed="0.000541"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:15:57.975025" elapsed="0.000064"/>
</return>
<status status="PASS" start="2026-06-06T03:15:57.974762" elapsed="0.000409"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.974722" elapsed="0.000509"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.975312" elapsed="0.000035"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:57.981523" elapsed="0.000246"/>
</kw>
<msg time="2026-06-06T03:15:57.981833" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:57.980724" elapsed="0.001198"/>
</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="NOT RUN" start="2026-06-06T03:15:57.982148" elapsed="0.000031"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.982378" elapsed="0.000029"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:57.976089" elapsed="0.006403"/>
</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-06-06T03:15:57.631827" elapsed="0.350793"/>
</kw>
<msg time="2026-06-06T03:15:57.982717" 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-06-06T03:15:57.631242" elapsed="0.351542"/>
</kw>
<msg time="2026-06-06T03:15:57.982945" level="INFO">${output} = </msg>
<var>${output}</var>
<arg>${ip}</arg>
<arg>${cmd}</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>${prompt}</arg>
<doc>Call Run Comand On Remote System, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:15:57.630680" elapsed="0.352300"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:15:57.983712" level="INFO">@{log_lines} = [  ]</msg>
<var>@{log_lines}</var>
<arg>${output}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:15:57.983323" elapsed="0.000428"/>
</kw>
<return>
<value>${log_lines}</value>
<status status="PASS" start="2026-06-06T03:15:57.983819" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:15:57.984035" level="INFO">${output} = ['']</msg>
<var>${output}</var>
<arg>${ODL_SYSTEM_${i}_IP}</arg>
<arg>${test_name}</arg>
<arg>${cmd}</arg>
<doc>Scrapes all log messages that match regexp ${type} which fall after a point given by a log message that
contains bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Delete_Injected_Ipv6_Routes_2. This is useful if your test cases are marking karaf.log with a message indicating when
that test case has started; such that you can easily pull out any extra log messsages to parse/log/etc in the
test logic itself. For example, you can grab all ERRORS that occur during your test case.</doc>
<status status="PASS" start="2026-06-06T03:15:57.629765" elapsed="0.354304"/>
</kw>
<kw name="Verify Exceptions" owner="excepts">
<msg time="2026-06-06T03:15:57.984581" level="INFO">${exlist} = []</msg>
<msg time="2026-06-06T03:15:57.984663" level="INFO">${matchlist} = []</msg>
<var>${exlist}</var>
<var>${matchlist}</var>
<arg>${output}</arg>
<doc>Return a list of exceptions not in the whitelist for the given lines.</doc>
<status status="PASS" start="2026-06-06T03:15:57.984328" elapsed="0.000371"/>
</kw>
<kw name="Write Exceptions Map To File" owner="excepts">
<arg>${SUITE_NAME}.${TEST_NAME}</arg>
<arg>/tmp/odl${i}_exceptions.txt</arg>
<doc>Write the exceptions map to a file under the testname header. The output
will include all lines in the exception itself as well as any previous
contextual warning or error lines. The output will be appended or overwritten
depending on the mode parameter. It is assumed that the caller has called
verify_exceptions() earlier to populate the exceptions map, otherwise only
the testname and header will be printed to the file.</doc>
<status status="PASS" start="2026-06-06T03:15:57.984952" elapsed="0.000444"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.986087" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:15:57.986195" level="INFO">${listlength} = 0</msg>
<var>${listlength}</var>
<arg>${exlist}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:15:57.985629" elapsed="0.000600"/>
</kw>
<if>
<branch type="IF" condition="&quot;${fail}&quot;==&quot;True&quot; and ${listlength} != 0">
<kw name="Log And Fail Exceptions" owner="KarafKeywords">
<arg>${exlist}</arg>
<arg>${listlength}</arg>
<doc>Print the list of failed exceptions and fail the test</doc>
<status status="NOT RUN" start="2026-06-06T03:15:57.986826" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:57.986330" elapsed="0.000559"/>
</branch>
<branch type="ELSE">
<kw name="Log List" owner="Collections">
<msg time="2026-06-06T03:15:57.987354" level="INFO">List is empty.</msg>
<arg>${matchlist}</arg>
<doc>Logs contents of the ``list`` using the given ``level``.</doc>
<status status="PASS" start="2026-06-06T03:15:57.987217" elapsed="0.000181"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:57.986914" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.986303" elapsed="0.001150"/>
</if>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-06T03:15:57.625288" elapsed="0.362191"/>
</iter>
<var>${i}</var>
<value>1</value>
<value>${NUM_ODL_SYSTEM} + 1</value>
<status status="PASS" start="2026-06-06T03:15:57.625018" elapsed="0.362495"/>
</for>
<arg>${SUITE_NAME}.${TEST_NAME}</arg>
<arg>fail=${True}</arg>
<doc>Create a failure if an Exception is found in the karaf.log that has not been whitelisted.
Will work for single controller jobs as well as 3node cluster jobs</doc>
<status status="PASS" start="2026-06-06T03:15:57.624350" elapsed="0.363223"/>
</kw>
<doc>Delete the injected IPV6 routes</doc>
<status status="PASS" start="2026-06-06T03:15:57.398010" elapsed="0.589698"/>
</test>
<test id="s1-s5-t27" name="Delete_App_Peer" line="375">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:57.991143" elapsed="0.000224"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:57.990877" elapsed="0.000546"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.992455" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.992344" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.992324" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:57.997702" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:57.997579" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:57.997560" elapsed="0.000232"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.998822" 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-06-06T03:15:57.998417" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:57.999427" 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-06-06T03:15:57.999114" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:57.999498" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:57.999668" 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-06-06T03:15:57.998035" elapsed="0.001659"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:58.005342" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.005233" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.005213" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:58.006625" elapsed="0.000036"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.006519" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.006500" elapsed="0.000265"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:58.007221" 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-06-06T03:15:58.006915" elapsed="0.000333"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.007805" level="INFO">${current_connection_index} = 7</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-06-06T03:15:58.007563" elapsed="0.000271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.039487" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:58.008338" elapsed="0.031262"/>
</kw>
<msg time="2026-06-06T03:15:58.039790" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:58.039837" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:58.007998" elapsed="0.031874"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.060056" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:15:58.040398" elapsed="0.019819"/>
</kw>
<msg time="2026-06-06T03:15:58.060469" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:58.060540" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "A "p "p "_ "P "e "e "r "[K"
[?1l&gt;[?2...</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-06-06T03:15:58.040049" elapsed="0.020549"/>
</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-06-06T03:15:58.061119" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.060756" elapsed="0.000449"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.060720" elapsed="0.000522"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.061991" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:15:58.061457" elapsed="0.000644"/>
</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-06-06T03:15:58.062538" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.062205" elapsed="0.000415"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.062177" elapsed="0.000503"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:58.062736" elapsed="0.000046"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:58.066468" elapsed="0.000277"/>
</kw>
<msg time="2026-06-06T03:15:58.066841" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.064839" elapsed="0.002135"/>
</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="NOT RUN" start="2026-06-06T03:15:58.067253" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.067589" elapsed="0.000093"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:58.063938" elapsed="0.003859"/>
</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-06-06T03:15:58.063139" elapsed="0.004728"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:58.006217" elapsed="0.061749"/>
</kw>
<msg time="2026-06-06T03:15:58.068059" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.068103" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "A "p "p "_ "P "e "e "r "[K"
[?1l&gt;[?2...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.005573" elapsed="0.062569"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:58.068328" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:58.068220" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.068200" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.068835" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.069219" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.069292" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:58.004888" elapsed="0.064513"/>
</kw>
<msg time="2026-06-06T03:15:58.069494" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.069537" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "A "p "p "_ "P "e "e "r "[K"
[?1l&gt;[?2...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:58.000084" elapsed="0.069492"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.069954" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.069678" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.069633" elapsed="0.000399"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:57.999940" elapsed="0.070115"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:57.999751" elapsed="0.070334"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:57.997208" elapsed="0.072931"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:57.992044" elapsed="0.078150"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:57.991576" elapsed="0.078662"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:57.988341" elapsed="0.081950"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.071211" level="INFO">&amp;{mapping} = { IP=127.0.0.12 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.12</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.070478" elapsed="0.000762"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.115881" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:58.115417" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.116689" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:58.116421" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:58.116866" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:58.116081" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.117480" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:58.117087" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.117852" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/application_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:58.118014" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:58.117687" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.118448" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.118201" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.119459" level="INFO">mapping: {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.119199" elapsed="0.000358"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.120050" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.119736" elapsed="0.000341"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.120802" level="INFO">${value} = 127.0.0.12</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.120453" elapsed="0.000380"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.121564" level="INFO">${encoded} = 127.0.0.12</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.121344" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.121655" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:58.121842" level="INFO">${encoded_value} = 127.0.0.12</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.121024" elapsed="0.000844"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.122024" elapsed="0.000241"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.12</var>
<status status="PASS" start="2026-06-06T03:15:58.120316" elapsed="0.001990"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.122867" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.122550" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.123610" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.123398" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.123702" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.123853" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.123081" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.124029" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:58.122418" elapsed="0.001874"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.124851" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.124535" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.125589" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.125379" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.125681" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.125844" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.125063" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.126021" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:58.124404" elapsed="0.001881"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.127034" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.126527" elapsed="0.000534"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.127793" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.127566" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.127868" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.128018" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.127248" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.128193" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:58.126396" elapsed="0.002057"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.129013" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.128711" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.129847" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.129579" elapsed="0.000297"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.129927" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.130079" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.129226" elapsed="0.000878"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.130297" elapsed="0.000227"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:58.128565" elapsed="0.002002"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.131143" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.130839" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.131941" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.131699" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.132020" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.132175" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.131359" elapsed="0.000841"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.132354" elapsed="0.000226"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:58.130697" elapsed="0.001925"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.133195" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.132889" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.133983" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.133746" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.134060" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.134211" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.133410" elapsed="0.000825"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.134390" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:58.132754" elapsed="0.001917"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.135237" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.134934" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.136004" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.135790" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.136082" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.136233" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.135451" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.136410" elapsed="0.000226"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:58.134797" elapsed="0.001897"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:58.120130" elapsed="0.016601"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:58.136776" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.136946" level="INFO">${mapping_to_use} = {'IP': '127.0.0.12', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:58.118877" elapsed="0.018095"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.118564" elapsed="0.018440"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.137182" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.137030" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.118544" elapsed="0.018716"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.138186" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:58.137406" elapsed="0.000817"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.138276" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:58.114747" elapsed="0.023658"/>
</kw>
<msg time="2026-06-06T03:15:58.138499" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.101196" elapsed="0.037354"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.151678" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.164818" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.177756" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.177970" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.178149" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.178514" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.178369" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:58.178353" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.178754" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.178928" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.179093" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:58.178325" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.178224" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.179317" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.179391" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:58.179513" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:58.096717" elapsed="0.082823"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.180659" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.180393" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:58.191499" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:58.191583" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.12 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:58.191714" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:58.182929" elapsed="0.008812"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.180775" elapsed="0.011008"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.192034" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.191813" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.180757" elapsed="0.011393"/>
</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-06-06T03:15:58.196983" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.193551" elapsed="0.003492"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.193240" elapsed="0.003852"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.193214" elapsed="0.003913"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.200815" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.197514" elapsed="0.003365"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.197205" elapsed="0.003723"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.197181" elapsed="0.003781"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.201748" 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-06-06T03:15:58.201195" elapsed="0.000591"/>
</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-06-06T03:15:58.202252" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.201919" elapsed="0.000414"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.202976" 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-06-06T03:15:58.202592" elapsed="0.000410"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.202368" elapsed="0.000670"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.201891" elapsed="0.001168"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.203583" 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-06-06T03:15:58.203218" 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-06-06T03:15:58.203937" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.203701" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.204470" 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-06-06T03:15:58.204175" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.204017" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.203680" elapsed="0.000872"/>
</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-06-06T03:15:58.204718" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:58.205512" 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-06-06T03:15:58.205231" elapsed="0.000306"/>
</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-06-06T03:15:58.205707" elapsed="0.002516"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:58.192668" elapsed="0.015619"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:58.208334" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.210703" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:58.179820" elapsed="0.030911"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.210786" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/application_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:58.071481" elapsed="0.139431"/>
</kw>
<doc>Deletes bgp application peer.</doc>
<status status="PASS" start="2026-06-06T03:15:57.987911" elapsed="0.223119"/>
</test>
<test id="s1-s5-t28" name="Delete_Bgp_Peer_Configuration_5" line="392">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:58.214528" elapsed="0.000231"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:58.214264" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.215875" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.215765" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.215745" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.221107" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.220997" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.220979" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.222385" 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-06-06T03:15:58.221803" elapsed="0.000610"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.222901" 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-06-06T03:15:58.222576" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:58.222973" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.223129" 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-06-06T03:15:58.221403" elapsed="0.001751"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:58.228937" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.228823" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.228801" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:58.230232" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.230124" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.230105" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:58.230797" 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-06-06T03:15:58.230467" elapsed="0.000357"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.231214" level="INFO">${current_connection_index} = 7</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-06-06T03:15:58.230994" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.262220" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:58.231798" elapsed="0.030532"/>
</kw>
<msg time="2026-06-06T03:15:58.262498" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:58.262545" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:58.231433" elapsed="0.031147"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.286715" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "5 "[K"
[?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-06-06T03:15:58.263140" elapsed="0.023843"/>
</kw>
<msg time="2026-06-06T03:15:58.287272" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:58.287323" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:15:58.262785" elapsed="0.024575"/>
</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-06-06T03:15:58.287911" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.287505" elapsed="0.000477"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.287459" elapsed="0.000559"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.288629" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "5 "[K"
[?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-06-06T03:15:58.288179" elapsed="0.000548"/>
</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-06-06T03:15:58.289053" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.288801" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.288780" elapsed="0.000360"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:58.289273" elapsed="0.000054"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:58.292341" elapsed="0.000161"/>
</kw>
<msg time="2026-06-06T03:15:58.292568" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.291090" elapsed="0.001646"/>
</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="NOT RUN" start="2026-06-06T03:15:58.293051" elapsed="0.000083"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.293404" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:58.290356" elapsed="0.003428"/>
</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-06-06T03:15:58.289676" elapsed="0.004233"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:58.229794" elapsed="0.064250"/>
</kw>
<msg time="2026-06-06T03:15:58.294156" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.294204" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.229161" elapsed="0.065082"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:58.294444" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:58.294328" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.294306" elapsed="0.000227"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.295017" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.295385" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.295460" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:58.228455" elapsed="0.067124"/>
</kw>
<msg time="2026-06-06T03:15:58.295702" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.295750" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:58.223517" elapsed="0.072272"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.296162" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.295879" elapsed="0.000340"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.295858" elapsed="0.000385"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:58.223376" elapsed="0.072894"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:58.223207" elapsed="0.073102"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:58.220606" elapsed="0.075771"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:58.215452" elapsed="0.080991"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.215019" elapsed="0.081477"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:58.212018" elapsed="0.084540"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.297531" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV4_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.296793" elapsed="0.000769"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.344749" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:58.344346" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.345598" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:58.345345" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:58.345790" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:58.345000" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.346599" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:58.346204" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.346954" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:58.347117" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:58.346809" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.347553" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.347302" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.348581" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.348315" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.349080" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.348804" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.349814" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.349496" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.350609" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.350381" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.350704" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:58.350860" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.350058" elapsed="0.000826"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.351041" elapsed="0.000254"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:15:58.349355" elapsed="0.001980"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.351899" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.351582" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.352823" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.352431" elapsed="0.000419"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.352901" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.353054" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.352112" elapsed="0.000967"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.353232" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:58.351449" elapsed="0.002047"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.354081" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.353763" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.354844" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.354614" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.354922" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.355072" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.354294" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.355290" elapsed="0.000225"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:58.353609" elapsed="0.001948"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.356130" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.355822" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.356902" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.356682" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.356982" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.357134" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.356341" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.357313" elapsed="0.000225"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:58.355685" elapsed="0.001894"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.358188" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.357846" elapsed="0.000369"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.358960" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.358741" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.359039" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.359192" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.358403" elapsed="0.000814"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.359368" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:58.357710" elapsed="0.001920"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.360191" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.359893" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.360947" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.360735" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.361023" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:58.361172" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.360402" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.361346" elapsed="0.000220"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:58.359760" elapsed="0.001846"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.362203" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.361868" elapsed="0.000361"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.362965" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.362752" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.363041" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.363189" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.362416" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.363363" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:58.361734" elapsed="0.001890"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.364379" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.363886" elapsed="0.000519"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:58.365136" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.364926" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:58.365213" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.365364" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:58.364591" elapsed="0.000840"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.365606" elapsed="0.000248"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:58.363755" elapsed="0.002141"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:58.349163" elapsed="0.016805"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:58.366015" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:58.366180" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'e...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:58.347990" elapsed="0.018217"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.347687" elapsed="0.018554"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.366423" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.366269" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.347665" elapsed="0.018836"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.367380" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:58.366664" elapsed="0.000746"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.367460" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:58.343720" elapsed="0.023864"/>
</kw>
<msg time="2026-06-06T03:15:58.367657" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.330666" elapsed="0.037042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.380635" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.393715" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.406493" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.406709" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.406903" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.407292" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.407140" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:58.407124" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.407515" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.407699" elapsed="0.000057"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.407914" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:58.407091" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.406984" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.408144" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.408221" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:58.408350" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:58.325784" elapsed="0.082593"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.409504" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.409249" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:58.420337" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:58.420388" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:58.420480" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:58.411792" elapsed="0.008715"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.409619" elapsed="0.010929"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.420751" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.420574" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.409601" elapsed="0.011239"/>
</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-06-06T03:15:58.426562" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.421857" elapsed="0.004837"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.421616" elapsed="0.005160"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.421597" elapsed="0.005236"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.431820" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.427465" elapsed="0.004401"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.426963" elapsed="0.004939"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.426924" elapsed="0.005003"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.432504" 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-06-06T03:15:58.432109" elapsed="0.000422"/>
</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-06-06T03:15:58.432862" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.432602" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.433413" 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-06-06T03:15:58.433110" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.432945" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.432583" elapsed="0.000913"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.434058" 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-06-06T03:15:58.433671" elapsed="0.000414"/>
</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-06-06T03:15:58.434438" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.434196" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.435003" 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-06-06T03:15:58.434697" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.434520" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.434175" elapsed="0.000911"/>
</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-06-06T03:15:58.435238" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:58.436065" 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-06-06T03:15:58.435775" elapsed="0.000316"/>
</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-06-06T03:15:58.436250" elapsed="0.002372"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:15:58.421211" elapsed="0.017497"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:58.438757" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:58.441087" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:15:58.408662" elapsed="0.032453"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.441174" elapsed="0.000031"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:15:58.297838" elapsed="0.143470"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:15:58.211417" elapsed="0.230022"/>
</test>
<test id="s1-s5-t29" name="Verify_Ipv6_Topology_Empty_5" line="405">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:58.445817" elapsed="0.000431"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:58.445452" elapsed="0.000856"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.447387" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.447267" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.447246" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.452618" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.452506" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.452487" elapsed="0.000217"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.453756" 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-06-06T03:15:58.453340" elapsed="0.000445"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.454292" 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-06-06T03:15:58.453972" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:58.454366" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.454523" 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-06-06T03:15:58.452942" elapsed="0.001606"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:58.460523" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.460412" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.460390" elapsed="0.000205"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:58.461851" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.461740" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.461720" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:58.462421" 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-06-06T03:15:58.462105" elapsed="0.000344"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.462866" level="INFO">${current_connection_index} = 7</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-06-06T03:15:58.462615" elapsed="0.000322"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.491871" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:58.463559" elapsed="0.028486"/>
</kw>
<msg time="2026-06-06T03:15:58.492260" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:58.492309" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:58.463140" elapsed="0.029205"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.514776" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "5 "[K"
[?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-06-06T03:15:58.493067" elapsed="0.021818"/>
</kw>
<msg time="2026-06-06T03:15:58.515046" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:58.515094" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</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-06-06T03:15:58.492568" elapsed="0.022561"/>
</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-06-06T03:15:58.515473" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.515223" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.515195" elapsed="0.000360"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.516032" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "y "_ "E "m "p "t "y "_ "5 "[K"
[?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-06-06T03:15:58.515727" elapsed="0.000372"/>
</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-06-06T03:15:58.516383" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.516167" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.516148" elapsed="0.000315"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:58.516501" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:58.519266" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:15:58.519480" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.518085" elapsed="0.001532"/>
</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="NOT RUN" start="2026-06-06T03:15:58.519915" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.520250" elapsed="0.000106"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:58.517409" elapsed="0.003064"/>
</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-06-06T03:15:58.516841" elapsed="0.003697"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:58.461403" elapsed="0.059233"/>
</kw>
<msg time="2026-06-06T03:15:58.520762" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.520807" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.460767" elapsed="0.060078"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:58.521032" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:58.520925" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.520906" elapsed="0.000210"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.521531" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.521964" elapsed="0.000051"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.522067" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:58.460046" elapsed="0.062134"/>
</kw>
<msg time="2026-06-06T03:15:58.522331" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.522376" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "V "e "r "i "f "y "_ "I "p "v "6 "_ "T "o "p "o "l "o "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:58.454961" elapsed="0.067451"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.522763" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.522490" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.522472" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:58.454812" elapsed="0.068056"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:58.454609" elapsed="0.068295"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:58.452136" elapsed="0.070827"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:58.446953" elapsed="0.076065"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.446468" elapsed="0.076596"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:58.442805" elapsed="0.080314"/>
</kw>
<kw name="Verify_Rib_Status_Empty">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.576845" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:58.576421" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.577703" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:58.577403" elapsed="0.000394">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:58.577896" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:58.577059" elapsed="0.000862"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.578506" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:58.578116" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.578865" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:58.579044" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:58.578719" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.579475" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.579230" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.580554" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.580256" elapsed="0.000345"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.581069" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:58.580789" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.581434" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.581659" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.581837" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:15:58.581297" elapsed="0.000598"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.581151" elapsed="0.000774"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:58.581973" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:15:58.582232" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:58.579934" elapsed="0.002324"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.579600" elapsed="0.002691"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.582468" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.582317" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.579575" elapsed="0.002971"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.583160" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:58.582708" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.583237" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:58.575782" elapsed="0.007578"/>
</kw>
<msg time="2026-06-06T03:15:58.583415" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.562685" elapsed="0.020778"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.598282" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.611345" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.624310" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.624512" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.624704" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.625082" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.624936" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:58.624920" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.625304" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.625472" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.625652" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:58.624890" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.624783" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.625879" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.625996" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:58.626145" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:58.557923" elapsed="0.068248"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.627454" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:58.627205" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:58.627616" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:58.626854" elapsed="0.000802"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.627982" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.627729" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.628537" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:58.628243" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.628064" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.627710" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.631172" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:58.628788" elapsed="0.002410"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:58.631249" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:58.631404" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:58.626502" elapsed="0.004927"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.632663" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:58.632414" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:58.632823" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:58.632078" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:15:58.633054" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:15:58.632918" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.632899" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.633283" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.633454" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.633520" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:58.635721" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:58.631752" elapsed="0.003997"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.637159" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv6-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.636906" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.637601" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.637359" elapsed="0.000306"/>
</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-06-06T03:15:58.646379" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:58.646558" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv6-topology 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:15:58.646691" 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-06-06T03:15:58.639933" elapsed="0.006787"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.637734" elapsed="0.009030"/>
</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-06-06T03:15:58.646951" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.646791" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.637716" elapsed="0.009322"/>
</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-06-06T03:15:58.650755" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv6-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv6-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.648120" elapsed="0.002685"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.647888" elapsed="0.002952"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.647866" elapsed="0.002999"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.654603" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.651262" elapsed="0.003432"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.650948" elapsed="0.003796"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.650921" elapsed="0.003858"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.655584" 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-06-06T03:15:58.655023" elapsed="0.000599"/>
</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-06-06T03:15:58.656084" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.655748" elapsed="0.000417"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.656866" 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-06-06T03:15:58.656424" elapsed="0.000479"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.656199" elapsed="0.000754"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.655721" elapsed="0.001261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.657731" 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-06-06T03:15:58.657206" elapsed="0.000562"/>
</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-06-06T03:15:58.658239" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.657867" elapsed="0.000454"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.658991" 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-06-06T03:15:58.658581" elapsed="0.000435"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.658355" elapsed="0.000697"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.657841" elapsed="0.001232"/>
</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-06-06T03:15:58.659229" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:58.660071" 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-06-06T03:15:58.659761" elapsed="0.000336"/>
</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-06-06T03:15:58.660256" elapsed="0.002383"/>
</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-06-06T03:15:58.647406" elapsed="0.015312"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.662901" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.662790" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.662770" elapsed="0.000201"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:58.666009" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:15:58.663120" elapsed="0.002917"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:15:58.666128" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:15:58.666343" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:15:58.636066" elapsed="0.030304"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.666436" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:15:58.666588" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:58.534692" elapsed="0.131922"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.695852" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:58.695354" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.696699" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:58.696386" elapsed="0.000445">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:58.697010" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:58.696047" elapsed="0.000988"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.697665" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:58.697205" elapsed="0.000489"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.698022" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/ipv6_topology_empty/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:58.698225" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:58.697861" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.698705" level="INFO">{
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv6-reachability-topology": {}
            }
        }
    ]
}

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.698418" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:58.699224" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.698820" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.699979" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:58.699457" elapsed="0.000549"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.699310" elapsed="0.000731"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.698800" elapsed="0.001264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.700707" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:58.700212" elapsed="0.000525"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.700787" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:58.694732" elapsed="0.006181"/>
</kw>
<msg time="2026-06-06T03:15:58.701002" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.681479" elapsed="0.019574"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.714241" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.727266" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/ipv6_topology_empty/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.740313" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.740512" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.740704" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.741100" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.740952" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:58.740937" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.741323" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.741492" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.741674" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:58.740906" elapsed="0.000824"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.740794" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.741909" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.741986" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:15:58.742118" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-id": "example-ipv6-topology",...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:58.678751" elapsed="0.063394"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.742323" elapsed="0.002360"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:58.745744" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.745417" elapsed="0.000356"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:15:58.746320" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv6-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:15:58.745977" elapsed="0.000371"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:15:58.746510" elapsed="0.000354"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:15:58.745005" elapsed="0.001920"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.744764" elapsed="0.002194"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.747132" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.746983" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.744745" elapsed="0.002464"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:15:58.667826" elapsed="0.079429"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:15:58.666968" elapsed="0.080361"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:58.666720" elapsed="0.080654"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.666702" elapsed="0.080696"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:58.747431" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:15:58.528207" elapsed="0.219350"/>
</kw>
<arg>5x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VAR_FOLDER}/ipv6_topology_empty</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:58.523549" elapsed="0.224066"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty</doc>
<status status="PASS" start="2026-06-06T03:15:58.523265" elapsed="0.224434"/>
</kw>
<doc>Verifies that example-ipv6-topology is empty after deconfiguring peer for the first time.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:58.441973" elapsed="0.305845"/>
</test>
<test id="s1-s5-t30" name="Stop_All_Exabgps_2" line="410">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:58.751635" elapsed="0.000227"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:58.751369" elapsed="0.000548"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.752916" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.752805" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.752785" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.758258" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.758150" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.758131" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.759328" 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-06-06T03:15:58.758947" elapsed="0.000407"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.759834" 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-06-06T03:15:58.759516" elapsed="0.000349"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:58.759910" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:58.760064" 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-06-06T03:15:58.758552" elapsed="0.001536"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:58.765721" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.765597" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.765577" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:58.766995" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:58.766883" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.766864" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:58.767559" 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-06-06T03:15:58.767214" elapsed="0.000372"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.767996" level="INFO">${current_connection_index} = 7</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-06-06T03:15:58.767770" elapsed="0.000252"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.792409" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:58.768524" elapsed="0.024009"/>
</kw>
<msg time="2026-06-06T03:15:58.792755" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:58.792802" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:58.768185" elapsed="0.024652"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.811557" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "2 "[K"
[?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-06-06T03:15:58.793416" elapsed="0.018259"/>
</kw>
<msg time="2026-06-06T03:15:58.811839" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:58.811886" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "2 "[K...</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-06-06T03:15:58.793036" elapsed="0.018885"/>
</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-06-06T03:15:58.812245" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.812006" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.811982" elapsed="0.000346"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.812793" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "2 "[K"
[?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-06-06T03:15:58.812476" elapsed="0.000382"/>
</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-06-06T03:15:58.813146" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.812926" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.812907" elapsed="0.000317"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:58.813261" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:58.816021" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:15:58.816234" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:58.814814" elapsed="0.001558"/>
</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="NOT RUN" start="2026-06-06T03:15:58.816689" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.817028" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:58.814130" elapsed="0.003166"/>
</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-06-06T03:15:58.813556" elapsed="0.003816"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:58.766548" elapsed="0.050926"/>
</kw>
<msg time="2026-06-06T03:15:58.817569" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.817614" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "2 "[K...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.765951" elapsed="0.051724"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:58.818068" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:15:58.817755" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.817736" elapsed="0.000440"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.818584" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.818955" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:58.819070" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:58.765256" elapsed="0.053925"/>
</kw>
<msg time="2026-06-06T03:15:58.819275" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:58.819319" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "2 "[K...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:58.760454" elapsed="0.058901"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:58.819697" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:58.819430" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:58.819413" elapsed="0.000364"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:58.760310" elapsed="0.059491"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:58.760139" elapsed="0.059695"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:58.757773" elapsed="0.062121"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:58.752501" elapsed="0.067449"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:58.752071" elapsed="0.067924"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:58.748958" elapsed="0.071090"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.829306" level="INFO">Executing command 'cat exaipv4.log'.</msg>
<msg time="2026-06-06T03:15:58.842363" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:15:58.842580" level="INFO">${output_log} = 03:15:51 | 4153   | welcome         | Thank you for using ExaBGP
03:15:51 | 4153   | version         | 4.2.4
03:15:51 | 4153   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:15:58.829161" elapsed="0.013514"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.843622" level="INFO">03:15:51 | 4153   | welcome         | Thank you for using ExaBGP
03:15:51 | 4153   | version         | 4.2.4
03:15:51 | 4153   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03:15:51 | 4153   | os              | Linux releng-26932-288-0-builder-0 5.15.0-173-generic #183-Ubuntu SMP Fri Mar 6 13:29:34 UTC 2026 x86_64
03:15:51 | 4153   | installation    | /tmp/defaultvenv
03:15:51 | 4153   | advice          | environment file missing
03:15:51 | 4153   | advice          | generate it using "exabgp --fi &gt; /tmp/defaultvenv/etc/exabgp/exabgp.env"
03:15:51 | 4153   | cli             | could not find the named pipes (exabgp.in and exabgp.out) required for the cli
03:15:51 | 4153   | cli             | we scanned the following folders (the number is your PID):
03:15:51 | 4153   | cli control     |  - /run/exabgp/
03:15:51 | 4153   | cli control     |  - /run/1001/
03:15:51 | 4153   | cli control     |  - /run/
03:15:51 | 4153   | cli control     |  - /var/run/exabgp/
03:15:51 | 4153   | cli control     |  - /var/run/1001/
03:15:51 | 4153   | cli control     |  - /var/run/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/run/exabgp/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/run/1001/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/run/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/var/run/exabgp/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/var/run/1001/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/var/run/
03:15:51 | 4153   | cli control     | please make them in one of the folder with the following commands:
03:15:51 | 4153   | cli control     | &gt; mkfifo /home/jenkins/run/exabgp.{in,out}
03:15:51 | 4153   | cli control     | &gt; chmod 600 /home/jenkins/run/exabgp.{in,out}
03:15:51 | 4153   | cli control     | &gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}
03:15:51 | 4153   | configuration   | performing reload of exabgp 4.2.4
03:15:51 | 4153   | configuration   | &gt; neighbor         | '10.30.170.38'
03:15:51 | 4153   | configuration   | . router-id        | '127.0.0.1'
03:15:51 | 4153   | configuration   | . local-address    | '127.0.0.1'
03:15:51 | 4153   | configuration   | . local-as         | '64496'
03:15:51 | 4153   | configuration   | . peer-as          | '64496'
03:15:51 | 4153   | configuration   | &gt; family           | 
03:15:51 | 4153   | configuration   | . ipv4             | 'unicast'
03:15:51 | 4153   | configuration   | &lt; family           | 
03:15:51 | 4153   | configuration   | &lt; neighbor         | 
03:15:51 | 4153   | reactor         | new peer: neighbor 10.30.170.38 local-ip 127.0.0.1 local-as 64496 peer-as 64496 router-id 127.0.0.1 family-allowed in-open
03:15:51 | 4153   | reactor         | loaded new configuration successfully
03:15:51 | 4153   | reactor         | initialising connection to peer-1
03:15:51 | 4153   | outgoing-1      | attempting connection to 10.30.170.38:1790
03:15:51 | 4153   | outgoing-1      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 7F00 0001 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00
03:15:51 | 4153   | outgoing-1      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=127.0.0.1 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)]
03:15:51 | 4153   | ka-outgoing-1   | receive-timer 60 second(s) left
03:15:51 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0035 01
03:15:51 | 4153   | outgoing-1      | received TCP payload (  34) 04FB F000 B4C0 0002 0218 0216 4104 0000 FBF0 0600 0200 0104 0001 0001 4002 00B4 4700
03:15:51 | 4153   | outgoing-1      | &lt;&lt; message of type OPEN
03:15:51 | 4153   | outgoing-1      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:51 | 4153   | outgoing-1      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:51 | 4153   | outgoing-1      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:51 | 4153   | ka-outgoing-1   | receive-timer 180 second(s) left
03:15:51 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:51 | 4153   | outgoing-1      | &lt;&lt; message of type KEEPALIVE
03:15:51 | 4153   | reactor         | connected to peer-1 with outgoing-1 127.0.0.1-10.30.170.38
03:15:51 | 4153   | outgoing-1      | sending TCP payload (  23) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 0200 0000 00
03:15:51 | 4153   | outgoing-1      | &gt;&gt; EOR ipv4 unicast
03:15:51 | 4153   | peer-1          | &gt;&gt; EOR(s)
03:15:51 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:51 | 4153   | outgoing-1      | received TCP payload (   4) 0000 0000
03:15:51 | 4153   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:51 | 4153   | parser          | parsing UPDATE (   4) 0000 0000
03:15:51 | 4153   | peer-1          | &lt;&lt; UPDATE #1
03:15:51 | 4153   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:51 | 4153   | ka-outgoing-1   | receive-timer 179 second(s) left
03:15:51 | 4153   | ka-outgoing-1   | send-timer 59 second(s) left
03:15:52 | 4153   | ka-outgoing-1   | receive-timer 178 second(s) left
03:15:52 | 4153   | ka-outgoing-1   | send-timer 58 second(s) left
03:15:53 | 4153   | ka-outgoing-1   | receive-timer 177 second(s) left
03:15:53 | 4153   | ka-outgoing-1   | send-timer 57 second(s) left
03:15:54 | 4153   | ka-outgoing-1   | receive-timer 176 second(s) left
03:15:54 | 4153   | ka-outgoing-1   | send-timer 56 second(s) left
03:15:55 | 4153   | ka-outgoing-1   | receive-timer 175 second(s) left
03:15:55 | 4153   | ka-outgoing-1   | send-timer 55 second(s) left
03:15:56 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:56 | 4153   | outgoing-1      | received TCP payload (   2) 0600
03:15:56 | 4153   | outgoing-1      | &lt;&lt; message of type NOTIFICATION
03:15:56 | 4153   | outgoing-1      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:56 | 4153   | outgoing-1      | outgoing-1 127.0.0.1-10.30.170.38, closing connection
03:15:56 | 4153   | reactor         | initialising connection to peer-1
03:15:56 | 4153   | outgoing-2      | attempting connection to 10.30.170.38:1790
03:15:56 | 4153   | outgoing-2      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 7F00 0001 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00
03:15:56 | 4153   | outgoing-2      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=127.0.0.1 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)]
03:15:56 | 4153   | outgoing-2      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:56 | 4153   | outgoing-2      | received TCP payload (   2) 0605
03:15:56 | 4153   | outgoing-2      | &lt;&lt; message of type NOTIFICATION
03:15:56 | 4153   | outgoing-2      | peer reset, message [notification received (6,5)] error[Cease / Connection Rejected]
03:15:56 | 4153   | outgoing-2      | outgoing-2 127.0.0.1-10.30.170.38, closing connection
03:15:57 | 4153   | reactor         | initialising connection to peer-1
03:15:57 | 4153   | outgoing-3      | attempting connection to 10.30.170.38:1790
03:15:57 | 4153   | outgoing-3      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 7F00 0001 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00
03:15:57 | 4153   | outgoing-3      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=127.0.0.1 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)]
03:15:57 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:15:57 | 4153   | outgoing-3      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 00B4 4700
03:15:57 | 4153   | outgoing-3      | &lt;&lt; message of type OPEN
03:15:57 | 4153   | outgoing-3      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:57 | 4153   | ka-outgoing-3   | receive-timer 60 second(s) left
03:15:57 | 4153   | outgoing-3      | --------------------------------------------------------------------
03:15:57 | 4153   | outgoing-3      | the connection can not carry the following family/families
03:15:57 | 4153   | outgoing-3      |  - exabgp is not configured for ipv6/unicast
03:15:57 | 4153   | outgoing-3      | therefore no routes of this kind can be announced on the connection
03:15:57 | 4153   | outgoing-3      | --------------------------------------------------------------------
03:15:57 | 4153   | outgoing-3      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:57 | 4153   | outgoing-3      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:57 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:57 | 4153   | outgoing-3      | &lt;&lt; message of type KEEPALIVE
03:15:57 | 4153   | ka-outgoing-3   | receive-timer 180 second(s) left
03:15:57 | 4153   | reactor         | connected to peer-1 with outgoing-3 127.0.0.1-10.30.170.38
03:15:57 | 4153   | outgoing-3      | sending TCP payload (  23) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 0200 0000 00
03:15:57 | 4153   | outgoing-3      | &gt;&gt; EOR ipv4 unicast
03:15:57 | 4153   | peer-1          | &gt;&gt; EOR(s)
03:15:57 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:57 | 4153   | outgoing-3      | received TCP payload (   4) 0000 0000
03:15:57 | 4153   | outgoing-3      | &lt;&lt; message of type UPDATE
03:15:57 | 4153   | parser          | parsing UPDATE (   4) 0000 0000
03:15:57 | 4153   | peer-1          | &lt;&lt; UPDATE #1
03:15:57 | 4153   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:57 | 4153   | ka-outgoing-3   | receive-timer 179 second(s) left
03:15:57 | 4153   | ka-outgoing-3   | send-timer 59 second(s) left
03:15:58 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:58 | 4153   | outgoing-3      | received TCP payload (   2) 0600
03:15:58 | 4153   | outgoing-3      | &lt;&lt; message of type NOTIFICATION
03:15:58 | 4153   | outgoing-3      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:58 | 4153   | outgoing-3      | outgoing-3 127.0.0.1-10.30.170.38, closing connection</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.843048" elapsed="0.000991"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:58.845232" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exaipv4.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exaipv4.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:15:58.844434" elapsed="0.000925"/>
</kw>
<arg>${EXABGP2_LOG}</arg>
<arg>${EXABGP2_LOG}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:58.828774" elapsed="0.016719"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:15:58.846938" level="INFO">[?2004l</msg>
<msg time="2026-06-06T03:15:58.847049" level="INFO">${output} = [?2004l</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:15:58.846725" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.847669" level="INFO">[?2004l</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:58.847300" elapsed="0.000436"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:58.848860" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:58.848399" elapsed="0.000499"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:58.849110" elapsed="0.000266"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:15:58.848023" elapsed="0.001436"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.000510" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:59.000834" level="INFO">${output} = ^C[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:15:58.849692" elapsed="0.151208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.001970" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.001311" elapsed="0.000765"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.005175" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:59.003615" elapsed="0.001682"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.007087" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:59.007177" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-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-06-06T03:15:59.005687" elapsed="0.001516"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.007826" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.007555" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.007286" elapsed="0.000623"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.007260" elapsed="0.000677"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:15:59.002760" elapsed="0.005225"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:15:58.846032" elapsed="0.162006"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:59.008352" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exaipv4.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exaipv4.log&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:59.008550" level="INFO">${Log_Content} = 03:15:51 | 4153   | welcome         | Thank you for using ExaBGP
03:15:51 | 4153   | version         | 4.2.4
03:15:51 | 4153   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03...</msg>
<var>${Log_Content}</var>
<arg>${EXABGP2_LOG}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:59.008194" elapsed="0.000384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.009048" level="INFO">03:15:51 | 4153   | welcome         | Thank you for using ExaBGP
03:15:51 | 4153   | version         | 4.2.4
03:15:51 | 4153   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03:15:51 | 4153   | os              | Linux releng-26932-288-0-builder-0 5.15.0-173-generic #183-Ubuntu SMP Fri Mar 6 13:29:34 UTC 2026 x86_64
03:15:51 | 4153   | installation    | /tmp/defaultvenv
03:15:51 | 4153   | advice          | environment file missing
03:15:51 | 4153   | advice          | generate it using "exabgp --fi &gt; /tmp/defaultvenv/etc/exabgp/exabgp.env"
03:15:51 | 4153   | cli             | could not find the named pipes (exabgp.in and exabgp.out) required for the cli
03:15:51 | 4153   | cli             | we scanned the following folders (the number is your PID):
03:15:51 | 4153   | cli control     |  - /run/exabgp/
03:15:51 | 4153   | cli control     |  - /run/1001/
03:15:51 | 4153   | cli control     |  - /run/
03:15:51 | 4153   | cli control     |  - /var/run/exabgp/
03:15:51 | 4153   | cli control     |  - /var/run/1001/
03:15:51 | 4153   | cli control     |  - /var/run/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/run/exabgp/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/run/1001/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/run/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/var/run/exabgp/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/var/run/1001/
03:15:51 | 4153   | cli control     |  - /tmp/defaultvenv/var/run/
03:15:51 | 4153   | cli control     | please make them in one of the folder with the following commands:
03:15:51 | 4153   | cli control     | &gt; mkfifo /home/jenkins/run/exabgp.{in,out}
03:15:51 | 4153   | cli control     | &gt; chmod 600 /home/jenkins/run/exabgp.{in,out}
03:15:51 | 4153   | cli control     | &gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}
03:15:51 | 4153   | configuration   | performing reload of exabgp 4.2.4
03:15:51 | 4153   | configuration   | &gt; neighbor         | '10.30.170.38'
03:15:51 | 4153   | configuration   | . router-id        | '127.0.0.1'
03:15:51 | 4153   | configuration   | . local-address    | '127.0.0.1'
03:15:51 | 4153   | configuration   | . local-as         | '64496'
03:15:51 | 4153   | configuration   | . peer-as          | '64496'
03:15:51 | 4153   | configuration   | &gt; family           | 
03:15:51 | 4153   | configuration   | . ipv4             | 'unicast'
03:15:51 | 4153   | configuration   | &lt; family           | 
03:15:51 | 4153   | configuration   | &lt; neighbor         | 
03:15:51 | 4153   | reactor         | new peer: neighbor 10.30.170.38 local-ip 127.0.0.1 local-as 64496 peer-as 64496 router-id 127.0.0.1 family-allowed in-open
03:15:51 | 4153   | reactor         | loaded new configuration successfully
03:15:51 | 4153   | reactor         | initialising connection to peer-1
03:15:51 | 4153   | outgoing-1      | attempting connection to 10.30.170.38:1790
03:15:51 | 4153   | outgoing-1      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 7F00 0001 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00
03:15:51 | 4153   | outgoing-1      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=127.0.0.1 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)]
03:15:51 | 4153   | ka-outgoing-1   | receive-timer 60 second(s) left
03:15:51 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0035 01
03:15:51 | 4153   | outgoing-1      | received TCP payload (  34) 04FB F000 B4C0 0002 0218 0216 4104 0000 FBF0 0600 0200 0104 0001 0001 4002 00B4 4700
03:15:51 | 4153   | outgoing-1      | &lt;&lt; message of type OPEN
03:15:51 | 4153   | outgoing-1      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:51 | 4153   | outgoing-1      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:51 | 4153   | outgoing-1      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:51 | 4153   | ka-outgoing-1   | receive-timer 180 second(s) left
03:15:51 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:51 | 4153   | outgoing-1      | &lt;&lt; message of type KEEPALIVE
03:15:51 | 4153   | reactor         | connected to peer-1 with outgoing-1 127.0.0.1-10.30.170.38
03:15:51 | 4153   | outgoing-1      | sending TCP payload (  23) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 0200 0000 00
03:15:51 | 4153   | outgoing-1      | &gt;&gt; EOR ipv4 unicast
03:15:51 | 4153   | peer-1          | &gt;&gt; EOR(s)
03:15:51 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:51 | 4153   | outgoing-1      | received TCP payload (   4) 0000 0000
03:15:51 | 4153   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:51 | 4153   | parser          | parsing UPDATE (   4) 0000 0000
03:15:51 | 4153   | peer-1          | &lt;&lt; UPDATE #1
03:15:51 | 4153   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:51 | 4153   | ka-outgoing-1   | receive-timer 179 second(s) left
03:15:51 | 4153   | ka-outgoing-1   | send-timer 59 second(s) left
03:15:52 | 4153   | ka-outgoing-1   | receive-timer 178 second(s) left
03:15:52 | 4153   | ka-outgoing-1   | send-timer 58 second(s) left
03:15:53 | 4153   | ka-outgoing-1   | receive-timer 177 second(s) left
03:15:53 | 4153   | ka-outgoing-1   | send-timer 57 second(s) left
03:15:54 | 4153   | ka-outgoing-1   | receive-timer 176 second(s) left
03:15:54 | 4153   | ka-outgoing-1   | send-timer 56 second(s) left
03:15:55 | 4153   | ka-outgoing-1   | receive-timer 175 second(s) left
03:15:55 | 4153   | ka-outgoing-1   | send-timer 55 second(s) left
03:15:56 | 4153   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:56 | 4153   | outgoing-1      | received TCP payload (   2) 0600
03:15:56 | 4153   | outgoing-1      | &lt;&lt; message of type NOTIFICATION
03:15:56 | 4153   | outgoing-1      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:56 | 4153   | outgoing-1      | outgoing-1 127.0.0.1-10.30.170.38, closing connection
03:15:56 | 4153   | reactor         | initialising connection to peer-1
03:15:56 | 4153   | outgoing-2      | attempting connection to 10.30.170.38:1790
03:15:56 | 4153   | outgoing-2      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 7F00 0001 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00
03:15:56 | 4153   | outgoing-2      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=127.0.0.1 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)]
03:15:56 | 4153   | outgoing-2      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:56 | 4153   | outgoing-2      | received TCP payload (   2) 0605
03:15:56 | 4153   | outgoing-2      | &lt;&lt; message of type NOTIFICATION
03:15:56 | 4153   | outgoing-2      | peer reset, message [notification received (6,5)] error[Cease / Connection Rejected]
03:15:56 | 4153   | outgoing-2      | outgoing-2 127.0.0.1-10.30.170.38, closing connection
03:15:57 | 4153   | reactor         | initialising connection to peer-1
03:15:57 | 4153   | outgoing-3      | attempting connection to 10.30.170.38:1790
03:15:57 | 4153   | outgoing-3      | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 7F00 0001 1402 0601 0400 0100 0102 0641 0400 00FB F002 0206 00
03:15:57 | 4153   | outgoing-3      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=127.0.0.1 capabilities=[Multiprotocol(ipv4 unicast), Extended Message(65535), ASN4(64496)]
03:15:57 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:15:57 | 4153   | outgoing-3      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 00B4 4700
03:15:57 | 4153   | outgoing-3      | &lt;&lt; message of type OPEN
03:15:57 | 4153   | outgoing-3      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71]
03:15:57 | 4153   | ka-outgoing-3   | receive-timer 60 second(s) left
03:15:57 | 4153   | outgoing-3      | --------------------------------------------------------------------
03:15:57 | 4153   | outgoing-3      | the connection can not carry the following family/families
03:15:57 | 4153   | outgoing-3      |  - exabgp is not configured for ipv6/unicast
03:15:57 | 4153   | outgoing-3      | therefore no routes of this kind can be announced on the connection
03:15:57 | 4153   | outgoing-3      | --------------------------------------------------------------------
03:15:57 | 4153   | outgoing-3      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:57 | 4153   | outgoing-3      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:57 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:57 | 4153   | outgoing-3      | &lt;&lt; message of type KEEPALIVE
03:15:57 | 4153   | ka-outgoing-3   | receive-timer 180 second(s) left
03:15:57 | 4153   | reactor         | connected to peer-1 with outgoing-3 127.0.0.1-10.30.170.38
03:15:57 | 4153   | outgoing-3      | sending TCP payload (  23) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 0200 0000 00
03:15:57 | 4153   | outgoing-3      | &gt;&gt; EOR ipv4 unicast
03:15:57 | 4153   | peer-1          | &gt;&gt; EOR(s)
03:15:57 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:57 | 4153   | outgoing-3      | received TCP payload (   4) 0000 0000
03:15:57 | 4153   | outgoing-3      | &lt;&lt; message of type UPDATE
03:15:57 | 4153   | parser          | parsing UPDATE (   4) 0000 0000
03:15:57 | 4153   | peer-1          | &lt;&lt; UPDATE #1
03:15:57 | 4153   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:57 | 4153   | ka-outgoing-3   | receive-timer 179 second(s) left
03:15:57 | 4153   | ka-outgoing-3   | send-timer 59 second(s) left
03:15:58 | 4153   | outgoing-3      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:15:58 | 4153   | outgoing-3      | received TCP payload (   2) 0600
03:15:58 | 4153   | outgoing-3      | &lt;&lt; message of type NOTIFICATION
03:15:58 | 4153   | outgoing-3      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:15:58 | 4153   | outgoing-3      | outgoing-3 127.0.0.1-10.30.170.38, closing connection</msg>
<arg>${Log_Content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.008797" elapsed="0.000459"/>
</kw>
<doc>Save exabgp logs as exaipv6.log, and stop exabgp with ctrl-c bash signal</doc>
<status status="PASS" start="2026-06-06T03:15:58.748273" elapsed="0.261104"/>
</test>
<test id="s1-s5-t31" name="Reconfigure_ODL_To_Accept_Connections_6" line="417">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:59.013721" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:59.013441" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.015035" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.014919" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.014899" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.020286" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.020179" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.020161" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.021368" 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-06-06T03:15:59.020981" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.021875" 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-06-06T03:15:59.021557" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:59.021946" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:15:59.022108" 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-06-06T03:15:59.020587" elapsed="0.001545"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:59.027881" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.027758" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.027738" elapsed="0.000229"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:59.029192" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.029083" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.029064" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:59.029727" 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-06-06T03:15:59.029408" elapsed="0.000346"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.030129" level="INFO">${current_connection_index} = 7</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-06-06T03:15:59.029913" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.059875" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:59.030688" elapsed="0.029300"/>
</kw>
<msg time="2026-06-06T03:15:59.060163" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:59.060211" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:59.030333" elapsed="0.029915"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.084240" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "6 "[K"
[?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-06-06T03:15:59.060823" elapsed="0.023535"/>
</kw>
<msg time="2026-06-06T03:15:59.084530" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:59.084578" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:15:59.060431" elapsed="0.024183"/>
</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-06-06T03:15:59.084984" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.084729" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.084704" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.085534" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "_ "6 "[K"
[?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-06-06T03:15:59.085215" elapsed="0.000457"/>
</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-06-06T03:15:59.085974" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.085743" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.085724" elapsed="0.000331"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:59.086091" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:59.088858" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:15:59.089074" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:59.087622" elapsed="0.001589"/>
</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="NOT RUN" start="2026-06-06T03:15:59.089493" elapsed="0.000100"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.089917" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:59.086986" elapsed="0.003114"/>
</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-06-06T03:15:59.086411" elapsed="0.003755"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:59.028743" elapsed="0.061523"/>
</kw>
<msg time="2026-06-06T03:15:59.090378" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:59.090423" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:59.028125" elapsed="0.062334"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:59.090664" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:15:59.090536" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.090516" elapsed="0.000236"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.091165" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.091512" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.091583" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:59.027401" elapsed="0.064308"/>
</kw>
<msg time="2026-06-06T03:15:59.091806" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:59.091851" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:59.022548" elapsed="0.069345"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.092226" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.091970" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.091952" elapsed="0.000351"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:59.022402" elapsed="0.069925"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:59.022193" elapsed="0.070168"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:59.019817" elapsed="0.072601"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:59.014612" elapsed="0.077863"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:59.014148" elapsed="0.078373"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:59.010497" elapsed="0.082079"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.093494" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:0011:0000:0000:0000:0002 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=ex...</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.092788" elapsed="0.000736"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.128700" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.128297" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:59.129508" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:59.129241" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:59.129703" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:59.128898" elapsed="0.000831"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.130314" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:59.129899" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:59.130671" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:59.130846" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:59.130513" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.131284" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.131035" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.132312" level="INFO">mapping: {'IP': '2607:f0d0:1002:0011:0000:0000:0000:0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.132046" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.132807" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.132521" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.133517" level="INFO">${value} = 2607:f0d0:1002:0011:0000:0000:0000:0002</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.133215" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.134314" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.134071" elapsed="0.000275"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.134405" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:59.134560" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.133748" elapsed="0.000837"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.134757" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:0011:0000:0000:0000:0002</var>
<status status="PASS" start="2026-06-06T03:15:59.133078" elapsed="0.001965"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.135591" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.135291" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.136360" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.136145" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.136437" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:59.136588" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.135818" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.136783" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:15:59.135158" elapsed="0.001889"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.137627" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.137292" elapsed="0.000377"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.138588" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.138371" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.138682" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:15:59.138835" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.137860" elapsed="0.001000"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.139018" elapsed="0.000226"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:15:59.137161" elapsed="0.002124"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.139854" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.139531" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.140597" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.140385" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.140689" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:59.140839" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.140067" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.141014" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:15:59.139398" elapsed="0.001876"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.141833" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.141518" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.142586" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.142373" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.142677" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:59.142827" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.142043" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.143001" elapsed="0.000219"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:59.141387" elapsed="0.001872"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.143813" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.143501" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.144551" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.144339" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.144628" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:15:59.144797" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.144022" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.144973" elapsed="0.000220"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:15:59.143371" elapsed="0.001863"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.145793" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.145479" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.146565" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.146351" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.146658" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:59.146813" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.146005" elapsed="0.000832"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.146989" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:59.145348" elapsed="0.001904"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.147860" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:15:59.147499" elapsed="0.000389"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:15:59.148603" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.148392" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:15:59.148697" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:15:59.148850" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:15:59.148076" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:15:59.149026" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:15:59.147366" elapsed="0.001923"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:15:59.132886" elapsed="0.016437"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:15:59.149366" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:59.149526" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:15:59.131716" elapsed="0.017836"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.131398" elapsed="0.018186"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.149775" elapsed="0.000207"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.149609" elapsed="0.000412"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.131379" elapsed="0.018663"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.150934" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:59.150193" elapsed="0.000771"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:59.151014" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:59.127664" elapsed="0.023476"/>
</kw>
<msg time="2026-06-06T03:15:59.151196" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:59.114505" elapsed="0.036739"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.164123" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.176984" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.190014" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.190212" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.190410" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.190834" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.190685" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:59.190668" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.191056" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.191225" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.191394" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:59.190625" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.190523" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.191621" elapsed="0.000034"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.191714" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:15:59.191838" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:59.109748" elapsed="0.082117"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.219128" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.218748" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:59.219876" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:59.219668" elapsed="0.000272">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:59.220034" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:59.219319" elapsed="0.000739"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.220607" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:59.220222" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:15:59.220952" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:15:59.221086" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:15:59.220817" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.221516" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;graceful-restart&gt;
        &lt;config&gt;
            &lt;restart-time&gt;30&lt;/restart-time&gt;
        &lt;/config&gt;
    &lt;/graceful-restart&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.221271" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:15:59.221989" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.221696" elapsed="0.000351"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.222549" level="INFO">${mapping_to_use} = {'IP': '2607:f0d0:1002:0011:0000:0000:0000:0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.222218" elapsed="0.000359"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.222072" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.221675" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.223549" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:15:59.222801" elapsed="0.000779"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:15:59.223630" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:15:59.218104" elapsed="0.005670"/>
</kw>
<msg time="2026-06-06T03:15:59.223833" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:59.204897" elapsed="0.018982"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.236962" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.249844" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.262679" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.262880" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.263061" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.263424" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.263282" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:15:59.263267" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.263659" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.263830" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.263997" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:15:59.263238" elapsed="0.000811"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.263136" elapsed="0.000970"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.264258" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.264334" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:59.264468" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:15:59.202162" elapsed="0.062335"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:15:59.265789" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:15:59.265525" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:15:59.265947" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:15:59.265185" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.266289" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.266043" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.266881" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.266565" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.266399" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.266024" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.269361" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:59.267115" elapsed="0.002272"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:15:59.269440" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:15:59.269591" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:15:59.264855" elapsed="0.004761"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.271121" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.270781" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.271636" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;graceful-restart&gt;
        &lt;config&gt;
            &lt;restart-time&gt;30&lt;/restart-time&gt;
        &lt;/config&gt;
    &lt;/graceful-restart&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.271385" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.272140" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.271894" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.272575" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.272335" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:59.273445" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:15:59.273251" elapsed="0.000219"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:15:59.273862" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:15:59.273682" elapsed="0.000214"/>
</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-06-06T03:15:59.274046" elapsed="0.000200"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.274702" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.274428" elapsed="0.000318"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:15:59.274790" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:15:59.274955" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:15:59.272841" elapsed="0.002139"/>
</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-06-06T03:15:59.291270" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '1139', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;2607:f0d0:1002:0011:0000:0000:0000:0002&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;graceful-restart&gt;
        &lt;config&gt;
            &lt;restart-time&gt;30&lt;/restart-time&gt;
        &lt;/config&gt;
    &lt;/graceful-restart&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:15:59.291363" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:59.291505" 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-06-06T03:15:59.278669" elapsed="0.012872"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.275053" elapsed="0.016551"/>
</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-06-06T03:15:59.291906" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.291669" elapsed="0.000392"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.275034" elapsed="0.017075"/>
</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-06-06T03:15:59.299974" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.294275" elapsed="0.005797"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.293774" elapsed="0.006378"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.293732" elapsed="0.006477"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.304442" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.300866" elapsed="0.003622"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.300335" elapsed="0.004189"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.300297" elapsed="0.004251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.305285" 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-06-06T03:15:59.304736" elapsed="0.000577"/>
</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-06-06T03:15:59.305623" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.305385" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.306191" 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-06-06T03:15:59.305884" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.305722" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.305366" elapsed="0.000908"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.306834" 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-06-06T03:15:59.306450" elapsed="0.000411"/>
</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-06-06T03:15:59.307208" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.306971" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.307761" 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-06-06T03:15:59.307448" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.307288" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.306952" elapsed="0.000893"/>
</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-06-06T03:15:59.307997" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:15:59.308813" 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-06-06T03:15:59.308511" elapsed="0.000329"/>
</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-06-06T03:15:59.309000" elapsed="0.002352"/>
</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-06-06T03:15:59.292946" elapsed="0.018469"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:15:59.311589" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:15:59.311483" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.311463" elapsed="0.000227"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:15:59.311841" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.311910" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:15:59.314229" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:15:59.269962" elapsed="0.044294"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:59.314319" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:15:59.314503" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:15:59.098471" elapsed="0.216056"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.314883" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.314625" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.314609" elapsed="0.000368"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:15:59.315009" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/graceful_restart</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:15:59.093869" elapsed="0.221261"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with short ipv6 address.</doc>
<status status="PASS" start="2026-06-06T03:15:59.009889" elapsed="0.305362"/>
</test>
<test id="s1-s5-t32" name="Start_Exabgp_3" line="433">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:15:59.318599" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:15:59.318319" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.319874" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.319763" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.319743" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.325259" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.325150" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.325131" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.326335" 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-06-06T03:15:59.325950" elapsed="0.000412"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.326901" 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-06-06T03:15:59.326580" elapsed="0.000348"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:15:59.326974" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:15:59.327130" 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-06-06T03:15:59.325555" elapsed="0.001600"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:15:59.332771" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.332660" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.332627" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:15:59.334027" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:15:59.333919" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.333900" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:15:59.334554" 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-06-06T03:15:59.334243" elapsed="0.000337"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.334984" level="INFO">${current_connection_index} = 7</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-06-06T03:15:59.334760" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.369824" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:59.335510" elapsed="0.034422"/>
</kw>
<msg time="2026-06-06T03:15:59.370115" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:15:59.370162" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:15:59.335173" elapsed="0.035026"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.388802" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "3 "[K"
[?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-06-06T03:15:59.371436" elapsed="0.017469"/>
</kw>
<msg time="2026-06-06T03:15:59.389068" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:15:59.389115" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "3 "[K"
[?1l&gt;[?2004l...</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-06-06T03:15:59.370376" elapsed="0.018777"/>
</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-06-06T03:15:59.389464" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.389234" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.389211" elapsed="0.000333"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.390038" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "3 "[K"
[?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-06-06T03:15:59.389709" elapsed="0.000393"/>
</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-06-06T03:15:59.390394" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.390172" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.390152" elapsed="0.000359"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:15:59.390546" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:15:59.393218" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:15:59.393428" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:59.392131" elapsed="0.001431"/>
</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="NOT RUN" start="2026-06-06T03:15:59.393861" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.394205" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:15:59.391460" elapsed="0.002938"/>
</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-06-06T03:15:59.390869" elapsed="0.003612"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:15:59.333585" elapsed="0.061038"/>
</kw>
<msg time="2026-06-06T03:15:59.394738" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:59.394782" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "3 "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:59.332994" elapsed="0.061828"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:15:59.395193" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:15:59.394904" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.394885" elapsed="0.000396"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.395716" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.396057" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:15:59.396131" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:15:59.332308" elapsed="0.063941"/>
</kw>
<msg time="2026-06-06T03:15:59.396355" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:15:59.396400" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "3 "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:15:59.327532" elapsed="0.068907"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:15:59.396806" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:15:59.396517" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.396499" elapsed="0.000390"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:15:59.327388" elapsed="0.069525"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:15:59.327211" elapsed="0.069733"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:15:59.324776" elapsed="0.072222"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:15:59.319458" elapsed="0.077596"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:59.319034" elapsed="0.078064"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:15:59.316052" elapsed="0.081098"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.397661" level="INFO">${cmd} = exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<var>${cmd}</var>
<arg>${EXABGP3_CFG} &gt; ${EXABGP3_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.397313" elapsed="0.000377"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.401527" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.401165" elapsed="0.000391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.402004" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.401739" elapsed="0.000313"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.404595" level="INFO">source /tmp/defaultvenv/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-06-06T03:15:59.402738" elapsed="0.001932"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.408882" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:15:59.408974" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:15:59.404838" elapsed="0.004162"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.409576" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.409324" elapsed="0.000299"/>
</kw>
<status status="PASS" start="2026-06-06T03:15:59.409070" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:15:59.409050" elapsed="0.000650"/>
</if>
<arg>log_output=${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-06-06T03:15:59.402300" elapsed="0.007447"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:15:59.412134" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<msg time="2026-06-06T03:15:59.412227" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:15:59.409955" elapsed="0.002299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.412689" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.412418" elapsed="0.000320"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:15:59.400787" elapsed="0.012007"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.414729" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:15:59.414319" elapsed="0.000438"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.417132" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:15:59.414922" elapsed="0.002238"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:15:59.422539" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:15:59.422706" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:15:59.422804" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:15:59.417329" elapsed="0.005502"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.426787" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:15:59.423057" elapsed="0.003803"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:15:59.430981" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:15:59.427099" elapsed="0.003988">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:15:59.413856" elapsed="0.017398">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.434314" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:02.433403" elapsed="0.000980"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.439764" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:02.434805" elapsed="0.005037"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:02.449128" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:02.449425" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1499'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://1.2.3.4","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:16:02.449624" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:16:02.440364" elapsed="0.009420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.454068" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://1.2.3.4","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:02.450118" elapsed="0.004044"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:16:02.454436" elapsed="0.003846"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:16:02.432161" elapsed="0.026229"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:15:59.413344" elapsed="3.045130"/>
</kw>
<msg time="2026-06-06T03:16:02.458636" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:02.458732" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:15:59.412955" elapsed="3.045842"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:16:02.459482" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:02.459008" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.458959" elapsed="0.000649"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:16:02.459882" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-06-06T03:16:02.459717" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.459692" elapsed="0.000395"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:15:59.400583" elapsed="3.059545"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:15:59.400357" elapsed="3.059824"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:02.460430" elapsed="0.000032"/>
</kw>
<arg>${cmd}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${EXABGP_ID}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:15:59.398007" elapsed="3.062544"/>
</kw>
<doc>Start exabgp with</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:15:59.315576" elapsed="3.145172"/>
</test>
<test id="s1-s5-t33" name="Stop_All_Exabgps_3" line="439">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:16:02.464340" elapsed="0.000261"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:16:02.464066" elapsed="0.000610"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:02.465818" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:02.465686" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.465662" elapsed="0.000234"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:02.471364" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:02.471242" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.471223" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.472567" 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-06-06T03:16:02.472139" elapsed="0.000459"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.473090" 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-06-06T03:16:02.472783" elapsed="0.000333"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:02.473161" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:16:02.473325" 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-06-06T03:16:02.471702" elapsed="0.001648"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:02.479241" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:02.479127" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.479107" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:02.480625" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:02.480514" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.480495" elapsed="0.000226"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:02.481208" 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-06-06T03:16:02.480871" elapsed="0.000364"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.481659" level="INFO">${current_connection_index} = 7</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-06-06T03:16:02.481404" elapsed="0.000285"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.511663" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:02.482209" elapsed="0.029560"/>
</kw>
<msg time="2026-06-06T03:16:02.511934" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:02.511981" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:16:02.481854" elapsed="0.030197"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.531797" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "3 "[K"
[?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-06-06T03:16:02.512597" elapsed="0.019303"/>
</kw>
<msg time="2026-06-06T03:16:02.532084" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:02.532132" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "3 "[K...</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-06-06T03:16:02.512247" elapsed="0.019922"/>
</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-06-06T03:16:02.532479" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:02.532249" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.532228" elapsed="0.000330"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.533056" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "3 "[K"
[?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-06-06T03:16:02.532742" elapsed="0.000382"/>
</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-06-06T03:16:02.533413" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:02.533192" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.533173" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:02.533526" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:02.536229" elapsed="0.000292"/>
</kw>
<msg time="2026-06-06T03:16:02.536585" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:02.535064" elapsed="0.001681"/>
</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="NOT RUN" start="2026-06-06T03:16:02.537038" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:02.537383" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:02.534409" elapsed="0.003162"/>
</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-06-06T03:16:02.533854" elapsed="0.003784"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:02.480184" elapsed="0.057575"/>
</kw>
<msg time="2026-06-06T03:16:02.537851" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:02.537896" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "3 "[K...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:02.479488" elapsed="0.058446"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:02.538138" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:16:02.538014" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.537992" elapsed="0.000274"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:02.538687" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:02.539026" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:02.539097" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:02.478682" elapsed="0.060522"/>
</kw>
<msg time="2026-06-06T03:16:02.539299" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:02.539344" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "3 "[K...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:02.473755" elapsed="0.065627"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:02.539748" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:02.539459" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.539441" elapsed="0.000389"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:02.473592" elapsed="0.066262"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:02.473411" elapsed="0.066474"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:02.470829" elapsed="0.069110"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:16:02.465326" elapsed="0.074671"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:02.464837" elapsed="0.075234"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:16:02.461752" elapsed="0.078377"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.549447" level="INFO">Executing command 'cat exabgp_graceful_restart.log'.</msg>
<msg time="2026-06-06T03:16:02.561957" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:16:02.562097" level="INFO">${output_log} = 03:15:59 | 4300   | welcome         | Thank you for using ExaBGP
03:15:59 | 4300   | version         | 4.2.4
03:15:59 | 4300   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:02.549304" elapsed="0.012831"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.562785" level="INFO">03:15:59 | 4300   | welcome         | Thank you for using ExaBGP
03:15:59 | 4300   | version         | 4.2.4
03:15:59 | 4300   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03:15:59 | 4300   | os              | Linux releng-26932-288-0-builder-0 5.15.0-173-generic #183-Ubuntu SMP Fri Mar 6 13:29:34 UTC 2026 x86_64
03:15:59 | 4300   | installation    | /tmp/defaultvenv
03:15:59 | 4300   | advice          | environment file missing
03:15:59 | 4300   | advice          | generate it using "exabgp --fi &gt; /tmp/defaultvenv/etc/exabgp/exabgp.env"
03:15:59 | 4300   | cli             | could not find the named pipes (exabgp.in and exabgp.out) required for the cli
03:15:59 | 4300   | cli             | we scanned the following folders (the number is your PID):
03:15:59 | 4300   | cli control     |  - /run/exabgp/
03:15:59 | 4300   | cli control     |  - /run/1001/
03:15:59 | 4300   | cli control     |  - /run/
03:15:59 | 4300   | cli control     |  - /var/run/exabgp/
03:15:59 | 4300   | cli control     |  - /var/run/1001/
03:15:59 | 4300   | cli control     |  - /var/run/
03:15:59 | 4300   | cli control     |  - /tmp/defaultvenv/run/exabgp/
03:15:59 | 4300   | cli control     |  - /tmp/defaultvenv/run/1001/
03:15:59 | 4300   | cli control     |  - /tmp/defaultvenv/run/
03:15:59 | 4300   | cli control     |  - /tmp/defaultvenv/var/run/exabgp/
03:15:59 | 4300   | cli control     |  - /tmp/defaultvenv/var/run/1001/
03:15:59 | 4300   | cli control     |  - /tmp/defaultvenv/var/run/
03:15:59 | 4300   | cli control     | please make them in one of the folder with the following commands:
03:15:59 | 4300   | cli control     | &gt; mkfifo /home/jenkins/run/exabgp.{in,out}
03:15:59 | 4300   | cli control     | &gt; chmod 600 /home/jenkins/run/exabgp.{in,out}
03:15:59 | 4300   | cli control     | &gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}
03:15:59 | 4300   | configuration   | performing reload of exabgp 4.2.4
03:15:59 | 4300   | configuration   | &gt; neighbor         | '::1'
03:15:59 | 4300   | configuration   | . router-id        | '1.2.3.4'
03:15:59 | 4300   | configuration   | . local-address    | '2607:f0d0:1002:0011:0000:0000:0000:0002'
03:15:59 | 4300   | configuration   | . local-as         | '64496'
03:15:59 | 4300   | configuration   | . peer-as          | '64496'
03:15:59 | 4300   | configuration   | &gt; capability       | 
03:15:59 | 4300   | configuration   | . graceful-restart | '40'
03:15:59 | 4300   | configuration   | &lt; capability       | 
03:15:59 | 4300   | configuration   | &gt; family           | 
03:15:59 | 4300   | configuration   | . ipv6             | 'unicast'
03:15:59 | 4300   | configuration   | &lt; family           | 
03:15:59 | 4300   | configuration   | &gt; static           | 
03:15:59 | 4300   | configuration   | . route            | '2a04:6d80::1/128' 'next-hop' 'self'
03:15:59 | 4300   | configuration   | &lt; static           | 
03:15:59 | 4300   | configuration   | &lt; neighbor         | 
03:15:59 | 4300   | reactor         | new peer: neighbor ::1 local-ip 2607:f0d0:1002:0011:0000:0000:0000:0002 local-as 64496 peer-as 64496 router-id 1.2.3.4 family-allowed in-open
03:15:59 | 4300   | reactor         | loaded new configuration successfully
03:15:59 | 4300   | reactor         | initialising connection to peer-1
03:15:59 | 4300   | outgoing-1      | attempting connection to ::1:1790
03:15:59 | 4300   | outgoing-1      | sending TCP payload (  59) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 0104 FBF0 00B4 0102 0304 1E02 0601 0400 0200 0102 0641 0400 00FB F002 0840 0680 2800 0201 8002 0206 00
03:15:59 | 4300   | outgoing-1      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), Graceful Restart Flags 0x8 Time 40 ipv6/unicast=0x80, ASN4(64496)]
03:15:59 | 4300   | ka-outgoing-1   | receive-timer 60 second(s) left
03:15:59 | 4300   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:15:59 | 4300   | outgoing-1      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 001E 4700
03:15:59 | 4300   | outgoing-1      | &lt;&lt; message of type OPEN
03:15:59 | 4300   | outgoing-1      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 30 , ASN4(64496), Unassigned 71]
03:15:59 | 4300   | outgoing-1      | --------------------------------------------------------------------
03:15:59 | 4300   | outgoing-1      | the connection can not carry the following family/families
03:15:59 | 4300   | outgoing-1      |  - exabgp is not configured for ipv4/unicast
03:15:59 | 4300   | outgoing-1      | therefore no routes of this kind can be announced on the connection
03:15:59 | 4300   | outgoing-1      | --------------------------------------------------------------------
03:15:59 | 4300   | outgoing-1      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:59 | 4300   | outgoing-1      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:15:59 | 4300   | ka-outgoing-1   | receive-timer 180 second(s) left
03:15:59 | 4300   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:15:59 | 4300   | outgoing-1      | &lt;&lt; message of type KEEPALIVE
03:15:59 | 4300   | reactor         | connected to peer-1 with outgoing-1 2607:f0d0:1002:0011:0000:0000:0000:0002-::1
03:15:59 | 4300   | outgoing-1      | sending TCP payload (  78) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004E 0200 0000 3740 0101 0040 0200 4005 0400 0000 6480 0E26 0002 0110 2607 F0D0 1002 0011 0000 0000 0000 0002 0080 2A04 6D80 0000 0000 0000 0000 0000 0001
03:15:59 | 4300   | outgoing-1      | &gt;&gt; 1 UPDATE(s)
03:15:59 | 4300   | outgoing-1      | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0201
03:15:59 | 4300   | outgoing-1      | &gt;&gt; EOR ipv6 unicast
03:15:59 | 4300   | peer-1          | &gt;&gt; EOR(s)
03:15:59 | 4300   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:59 | 4300   | outgoing-1      | received TCP payload (   4) 0000 0000
03:15:59 | 4300   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:59 | 4300   | parser          | parsing UPDATE (   4) 0000 0000
03:15:59 | 4300   | peer-1          | &lt;&lt; UPDATE #1
03:15:59 | 4300   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:59 | 4300   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:15:59 | 4300   | outgoing-1      | received TCP payload (   4) 0000 0000
03:15:59 | 4300   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:59 | 4300   | parser          | parsing UPDATE (   4) 0000 0000
03:15:59 | 4300   | peer-1          | &lt;&lt; UPDATE #2
03:15:59 | 4300   | peer-1          |    UPDATE #2 nlri  (   4) eor 1/1 (ipv4 unicast)
03:15:59 | 4300   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02
03:15:59 | 4300   | outgoing-1      | received TCP payload (  10) 0000 0006 800F 0300 0201
03:15:59 | 4300   | outgoing-1      | &lt;&lt; message of type UPDATE
03:15:59 | 4300   | parser          | parsing UPDATE (  10) 0000 0006 800F 0300 0201
03:15:59 | 4300   | routes          | withdrawn NLRI none
03:15:59 | 4300   | parser          | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0002 01
03:15:59 | 4300   | routes          | announced NLRI none
03:15:59 | 4300   | peer-1          | &lt;&lt; UPDATE #3
03:15:59 | 4300   | peer-1          |    UPDATE #3 nlri  (  11) eor 2/1 (ipv6 unicast)
03:15:59 | 4300   | ka-outgoing-1   | receive-timer 179 second(s) left
03:15:59 | 4300   | ka-outgoing-1   | send-timer 59 second(s) left
03:16:00 | 4300   | ka-outgoing-1   | receive-timer 178 second(s) left
03:16:00 | 4300   | ka-outgoing-1   | send-timer 58 second(s) left
03:16:01 | 4300   | ka-outgoing-1   | receive-timer 177 second(s) left
03:16:01 | 4300   | ka-outgoing-1   | send-timer 57 second(s) left</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:02.562383" elapsed="0.000627"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:16:02.564350" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exabgp_graceful_restart.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exabgp_graceful_restart.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:16:02.563416" elapsed="0.001066"/>
</kw>
<arg>${EXABGP3_LOG}</arg>
<arg>${EXABGP3_LOG}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:16:02.548907" elapsed="0.015713"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.566045" level="INFO">[?2004l</msg>
<msg time="2026-06-06T03:16:02.566219" level="INFO">${output} = [?2004l</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:16:02.565810" elapsed="0.000465"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.567260" level="INFO">[?2004l</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:02.566617" elapsed="0.000748"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.569390" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:16:02.568570" elapsed="0.000885"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:02.569847" elapsed="0.000436"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:16:02.567860" elapsed="0.002585"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.724975" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:16:02.725175" level="INFO">${output} = ^C[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:16:02.570874" elapsed="0.154332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.725827" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:02.725461" elapsed="0.000415"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.727730" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:02.726582" elapsed="0.001205"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:02.728699" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:16:02.728791" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-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-06-06T03:16:02.727966" elapsed="0.000851"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:02.729431" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:02.729176" elapsed="0.000302"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:02.728895" elapsed="0.000618"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:02.728871" elapsed="0.000669"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:16:02.726172" elapsed="0.003416"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:16:02.565166" elapsed="0.164491"/>
</kw>
<kw name="Sleep" owner="BuiltIn">
<msg time="2026-06-06T03:16:42.730569" level="INFO">Slept 40 seconds.</msg>
<arg>40s</arg>
<doc>Pauses the test executed for the given time.</doc>
<status status="PASS" start="2026-06-06T03:16:02.729862" elapsed="40.001137"/>
</kw>
<kw name="Fail If Exceptions Found During Test" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:42.733706" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:42.733401" elapsed="0.000419"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:42.733351" elapsed="0.000524"/>
</if>
<for flavor="IN RANGE">
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:42.735482" level="INFO">${cmd} = sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Stop_All_Exabgps_3/d' /tmp/karaf-0.24.0/data/log/karaf.log</msg>
<var>${cmd}</var>
<arg>sed '1,/ROBOT MESSAGE: Starting test ${test_name}/d' ${log_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:42.734927" elapsed="0.000596"/>
</kw>
<kw name="Get Karaf Log Lines From Test Start" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:42.742707" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:42.742563" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:42.742532" elapsed="0.000249"/>
</if>
<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-06-06T03:16:42.744955" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:42.744653" elapsed="0.000361"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:42.744630" elapsed="0.000408"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:42.745326" level="INFO">index=7
host=10.30.170.38
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:16:42.745436" level="INFO">${current_ssh_connection} = index=7
host=10.30.170.38
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:16:42.745192" elapsed="0.000272"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:42.746031" level="INFO">Attempting to execute command "sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Stop_All_Exabgps_3/d' /tmp/karaf-0.24.0/data/log/karaf.log" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:42.745624" elapsed="0.000538"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:42.746768" level="INFO">${conn_id} = 10</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:42.746326" elapsed="0.000469"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:16:42.747720" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:16:42.747798" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:16:42.747420" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:42.747982" elapsed="0.000326"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:16:42.749185" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:16:43.104184" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:15:55 UTC 2026

  System load:  0.01               Processes:             126
  Usage of /:   11.3% of 77.35GB   Users logged in:       1
  Memory usage: 11%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:15:57 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:16:42.748867" elapsed="0.355535"/>
</kw>
<msg time="2026-06-06T03:16:43.104527" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:42.748480" elapsed="0.356192"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:16:42.747016" elapsed="0.357823"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.105536" level="INFO">Executing command 'sed '1,/ROBOT MESSAGE: Starting test bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Stop_All_Exabgps_3/d' /tmp/karaf-0.24.0/data/log/karaf.log'.</msg>
<msg time="2026-06-06T03:16:43.118748" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:16:43.118946" level="INFO">${stdout} = 2026-06-06T03:16:02,608 | INFO  | bgp-worker-5     | BGPSessionImpl                   | 229 - org.opendaylight.bgpcep.bgp-rib-impl - 2.0.0 | End of input detected. Close the session.
2026-06-06T03:16:...</msg>
<msg time="2026-06-06T03:16:43.119019" level="INFO">${stderr} = </msg>
<var>${stdout}</var>
<var>${stderr}</var>
<arg>${cmd}</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:43.105192" elapsed="0.013864"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:16:43.119315" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.120539" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:43.119997" elapsed="0.000616"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:16:43.120989" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:43.120773" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.120732" elapsed="0.000374"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:16:43.121350" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:16:43.121191" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.121167" elapsed="0.000312"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:16:43.121530" elapsed="0.000021"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:43.128572" elapsed="0.000260"/>
</kw>
<msg time="2026-06-06T03:16:43.128903" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:43.127672" elapsed="0.001329"/>
</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="NOT RUN" start="2026-06-06T03:16:43.129254" elapsed="0.000035"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:43.129541" elapsed="0.000036"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:43.122754" elapsed="0.006950"/>
</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-06-06T03:16:42.744121" elapsed="0.385726"/>
</kw>
<msg time="2026-06-06T03:16:43.129948" 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-06-06T03:16:42.743500" elapsed="0.386601"/>
</kw>
<msg time="2026-06-06T03:16:43.130350" level="INFO">${output} = 2026-06-06T03:16:02,608 | INFO  | bgp-worker-5     | BGPSessionImpl                   | 229 - org.opendaylight.bgpcep.bgp-rib-impl - 2.0.0 | End of input detected. Close the session.
2026-06-06T03:16:...</msg>
<var>${output}</var>
<arg>${ip}</arg>
<arg>${cmd}</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>${prompt}</arg>
<doc>Call Run Comand On Remote System, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:16:42.742962" elapsed="0.387429"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:16:43.131119" level="INFO">@{log_lines} = [ 2026-06-06T03:16:02,608 | INFO  | bgp-worker-5     | BGPSessionImpl                   | 229 - org.opendaylight.bgpcep.bgp-rib-impl - 2.0.0 | End of input detected. Close the session. | 2026-06-06T03...</msg>
<var>@{log_lines}</var>
<arg>${output}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:16:43.130713" elapsed="0.000449"/>
</kw>
<return>
<value>${log_lines}</value>
<status status="PASS" start="2026-06-06T03:16:43.131250" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:16:43.131511" level="INFO">${output} = ['2026-06-06T03:16:02,608 | INFO  | bgp-worker-5     | BGPSessionImpl                   | 229 - org.opendaylight.bgpcep.bgp-rib-impl - 2.0.0 | End of input detected. Close the session.', '2026-06-06T0...</msg>
<var>${output}</var>
<arg>${ODL_SYSTEM_${i}_IP}</arg>
<arg>${test_name}</arg>
<arg>${cmd}</arg>
<doc>Scrapes all log messages that match regexp ${type} which fall after a point given by a log message that
contains bgpcep-userfeatures.txt.Bgp Ipv6 Basic.Stop_All_Exabgps_3. This is useful if your test cases are marking karaf.log with a message indicating when
that test case has started; such that you can easily pull out any extra log messsages to parse/log/etc in the
test logic itself. For example, you can grab all ERRORS that occur during your test case.</doc>
<status status="PASS" start="2026-06-06T03:16:42.741705" elapsed="0.389847"/>
</kw>
<kw name="Verify Exceptions" owner="excepts">
<msg time="2026-06-06T03:16:43.132198" level="INFO">${exlist} = []</msg>
<msg time="2026-06-06T03:16:43.132269" level="INFO">${matchlist} = []</msg>
<var>${exlist}</var>
<var>${matchlist}</var>
<arg>${output}</arg>
<doc>Return a list of exceptions not in the whitelist for the given lines.</doc>
<status status="PASS" start="2026-06-06T03:16:43.131862" elapsed="0.000451"/>
</kw>
<kw name="Write Exceptions Map To File" owner="excepts">
<arg>${SUITE_NAME}.${TEST_NAME}</arg>
<arg>/tmp/odl${i}_exceptions.txt</arg>
<doc>Write the exceptions map to a file under the testname header. The output
will include all lines in the exception itself as well as any previous
contextual warning or error lines. The output will be appended or overwritten
depending on the mode parameter. It is assumed that the caller has called
verify_exceptions() earlier to populate the exceptions map, otherwise only
the testname and header will be printed to the file.</doc>
<status status="PASS" start="2026-06-06T03:16:43.132706" elapsed="0.000501"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.133875" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:16:43.133961" level="INFO">${listlength} = 0</msg>
<var>${listlength}</var>
<arg>${exlist}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:16:43.133493" elapsed="0.000493"/>
</kw>
<if>
<branch type="IF" condition="&quot;${fail}&quot;==&quot;True&quot; and ${listlength} != 0">
<kw name="Log And Fail Exceptions" owner="KarafKeywords">
<arg>${exlist}</arg>
<arg>${listlength}</arg>
<doc>Print the list of failed exceptions and fail the test</doc>
<status status="NOT RUN" start="2026-06-06T03:16:43.134427" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:43.134064" elapsed="0.000432"/>
</branch>
<branch type="ELSE">
<kw name="Log List" owner="Collections">
<msg time="2026-06-06T03:16:43.134918" level="INFO">List is empty.</msg>
<arg>${matchlist}</arg>
<doc>Logs contents of the ``list`` using the given ``level``.</doc>
<status status="PASS" start="2026-06-06T03:16:43.134747" elapsed="0.000230"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:43.134530" elapsed="0.000491"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.134044" elapsed="0.001006"/>
</if>
<var name="${i}">1</var>
<status status="PASS" start="2026-06-06T03:16:42.734614" elapsed="0.400465"/>
</iter>
<var>${i}</var>
<value>1</value>
<value>${NUM_ODL_SYSTEM} + 1</value>
<status status="PASS" start="2026-06-06T03:16:42.733971" elapsed="0.401144"/>
</for>
<arg>${SUITE_NAME}.${TEST_NAME}</arg>
<arg>fail=${True}</arg>
<doc>Create a failure if an Exception is found in the karaf.log that has not been whitelisted.
Will work for single controller jobs as well as 3node cluster jobs</doc>
<status status="PASS" start="2026-06-06T03:16:42.732322" elapsed="0.402856"/>
</kw>
<doc>Save exabgp logs as exabgp_graceful_restart.log, and stop exabgp with ctrl-c bash signal</doc>
<status status="PASS" start="2026-06-06T03:16:02.461153" elapsed="40.674151"/>
</test>
<test id="s1-s5-t34" name="Start_Exabgp_4" line="446">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:16:43.138995" elapsed="0.000245"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:16:43.138701" elapsed="0.000612"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:43.140440" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:43.140310" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.140287" elapsed="0.000229"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:43.146003" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:43.145880" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.145861" elapsed="0.000233"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.147201" 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-06-06T03:16:43.146772" elapsed="0.000457"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.147727" 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-06-06T03:16:43.147400" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:43.147800" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:16:43.147965" 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-06-06T03:16:43.146355" elapsed="0.001636"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:43.156433" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:43.156233" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.156204" elapsed="0.000336"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:43.158205" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:43.158093" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.158074" elapsed="0.000205"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:43.158775" 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-06-06T03:16:43.158438" elapsed="0.000365"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.159228" level="INFO">${current_connection_index} = 7</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-06-06T03:16:43.158987" elapsed="0.000270"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.190418" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:43.159824" elapsed="0.030737"/>
</kw>
<msg time="2026-06-06T03:16:43.190776" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:43.190823" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:16:43.159451" elapsed="0.031410"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.211741" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "4 "[K"
[?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-06-06T03:16:43.191461" elapsed="0.020518"/>
</kw>
<msg time="2026-06-06T03:16:43.212225" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:43.212273" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "4 "[K"
[?1l&gt;[?2004l...</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-06-06T03:16:43.191065" elapsed="0.021249"/>
</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-06-06T03:16:43.212813" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:43.212436" elapsed="0.000442"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.212398" elapsed="0.000507"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.213472" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "4 "[K"
[?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-06-06T03:16:43.213058" elapsed="0.000492"/>
</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-06-06T03:16:43.213968" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:43.213630" elapsed="0.000411"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.213605" elapsed="0.000466"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:43.214120" elapsed="0.000049"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:43.217020" elapsed="0.000392"/>
</kw>
<msg time="2026-06-06T03:16:43.217482" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:43.215825" elapsed="0.001796"/>
</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="NOT RUN" start="2026-06-06T03:16:43.217992" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:43.218346" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:43.215113" elapsed="0.003419"/>
</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-06-06T03:16:43.214481" elapsed="0.004118"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:43.157783" elapsed="0.060944"/>
</kw>
<msg time="2026-06-06T03:16:43.218826" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:43.218929" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "4 "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:43.156798" elapsed="0.062175"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:43.219168" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:16:43.219053" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.219034" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:43.219698" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:43.220049" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:43.220123" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:43.155716" elapsed="0.064517"/>
</kw>
<msg time="2026-06-06T03:16:43.220331" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:43.220375" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "a "r "t "_ "E "x "a "b "g "p "_ "4 "[K"
[?1l&gt;[?2004l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:43.148463" elapsed="0.071953"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:43.220771" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:43.220493" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.220475" elapsed="0.000377"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:43.148316" elapsed="0.072562"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:43.148124" elapsed="0.072788"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:43.145483" elapsed="0.075486"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:16:43.140000" elapsed="0.081029"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:43.139497" elapsed="0.081581"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:16:43.136207" elapsed="0.084926"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.221724" level="INFO">${cmd} = exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<var>${cmd}</var>
<arg>${EXABGP3_CFG} &gt; ${EXABGP3_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:43.221336" elapsed="0.000417"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.225333" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:43.224967" elapsed="0.000395"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.225918" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:43.225536" elapsed="0.000430"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.228794" level="INFO">source /tmp/defaultvenv/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-06-06T03:16:43.226779" elapsed="0.002073"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.233242" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:16:43.233339" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:16:43.229018" elapsed="0.004357"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.234026" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:43.233768" elapsed="0.000306"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:43.233457" elapsed="0.000687"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:43.233430" elapsed="0.000742"/>
</if>
<arg>log_output=${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-06-06T03:16:43.226323" elapsed="0.007897"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:43.236604" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log</msg>
<msg time="2026-06-06T03:16:43.236743" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:43.234376" elapsed="0.002411"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.237348" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exabgp_graceful_restart.cfg &gt; exabgp_graceful_restart.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:43.237037" elapsed="0.000362"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:43.224623" elapsed="0.012833"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.239866" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:43.239469" elapsed="0.000426"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.242459" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:43.240063" elapsed="0.002425"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:43.248898" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:43.249048" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:16:43.249169" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:16:43.242678" elapsed="0.006519"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.252644" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:43.249372" elapsed="0.003367"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:16:43.256952" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:16:43.252982" elapsed="0.004079">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:16:43.238876" elapsed="0.018356">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.260384" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:46.259458" elapsed="0.001002"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.264102" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:46.260944" elapsed="0.003200"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:46.272737" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:46.273002" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F1.2.3.4?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1499'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://1.2.3.4","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:16:46.273150" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:16:46.264382" elapsed="0.008805"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.276895" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://1.2.3.4","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":true},"bgp-inet:ipv6-routes":{"ipv6-route":[{"path-id":0,"route-key":"2a04:6d80::1/128","prefix":"2a04:6d80::1/128","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2607:f0d0:1002:11::2"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.273430" elapsed="0.003669"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:16:46.277328" elapsed="0.003504"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:16:46.258188" elapsed="0.022737"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:16:43.238226" elapsed="3.042774"/>
</kw>
<msg time="2026-06-06T03:16:46.281175" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:46.281238" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:43.237646" elapsed="3.043624"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.281845" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.281409" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.281376" elapsed="0.000585"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:16:46.282192" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:16:46.282037" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.282015" elapsed="0.000301"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:16:43.224441" elapsed="3.057914"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:16:43.224217" elapsed="3.058185"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.282623" elapsed="0.000055"/>
</kw>
<arg>${cmd}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${EXABGP_ID}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:16:43.222133" elapsed="3.060631"/>
</kw>
<doc>Start exabgp with</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:16:43.135624" elapsed="3.147304"/>
</test>
<test id="s1-s5-t35" name="Delete_Bgp_Peer_Configuration_6" line="452">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:16:46.287172" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:16:46.286905" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.288468" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.288356" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.288336" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.293854" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.293743" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.293724" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.294966" 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-06-06T03:16:46.294540" elapsed="0.000455"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.295463" 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-06-06T03:16:46.295161" elapsed="0.000329"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:46.295535" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:16:46.295716" 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-06-06T03:16:46.294155" elapsed="0.001588"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:46.301535" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.301424" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.301403" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:46.302831" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.302721" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.302702" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:46.303354" 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-06-06T03:16:46.303049" elapsed="0.000332"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.303783" level="INFO">${current_connection_index} = 7</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-06-06T03:16:46.303544" elapsed="0.000265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.331699" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:46.304316" elapsed="0.027592"/>
</kw>
<msg time="2026-06-06T03:16:46.332093" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:46.332142" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:16:46.303973" elapsed="0.028207"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.371716" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "6 "[K"
[?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-06-06T03:16:46.332782" elapsed="0.039059"/>
</kw>
<msg time="2026-06-06T03:16:46.372010" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:46.372056" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:16:46.332374" elapsed="0.039720"/>
</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-06-06T03:16:46.372465" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.372193" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.372167" elapsed="0.000383"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.373045" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "_ "6 "[K"
[?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-06-06T03:16:46.372719" elapsed="0.000398"/>
</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-06-06T03:16:46.373412" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.373187" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.373168" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:46.373528" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:46.376253" elapsed="0.002238"/>
</kw>
<msg time="2026-06-06T03:16:46.378561" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:46.375133" elapsed="0.003582"/>
</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="NOT RUN" start="2026-06-06T03:16:46.379000" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.379344" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:46.374468" elapsed="0.005062"/>
</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-06-06T03:16:46.373865" elapsed="0.005731"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:46.302389" elapsed="0.077325"/>
</kw>
<msg time="2026-06-06T03:16:46.379808" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:46.379853" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:46.301782" elapsed="0.078109"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:46.380080" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:16:46.379969" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.379950" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.380587" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.380950" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.381023" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:46.301051" elapsed="0.080081"/>
</kw>
<msg time="2026-06-06T03:16:46.381227" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:46.381271" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:46.296115" elapsed="0.085194"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.381730" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.381442" elapsed="0.000345"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.381423" elapsed="0.000388"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:46.295971" elapsed="0.085865"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:46.295798" elapsed="0.086069"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:46.293350" elapsed="0.088571"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:16:46.288061" elapsed="0.093916"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:46.287597" elapsed="0.094425"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:16:46.284189" elapsed="0.097980"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.383114" level="INFO">&amp;{mapping} = { IP=2607:f0d0:1002:0011:0000:0000:0000:0002 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=ex...</msg>
<var>&amp;{mapping}</var>
<arg>IP=${IPV6_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.382383" elapsed="0.000761"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.429349" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:46.428966" elapsed="0.000412"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:16:46.430152" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.429900" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:16:46.430327" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:16:46.429542" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.430953" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:46.430517" elapsed="0.000462"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:16:46.431281" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/graceful_restart/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:16:46.431435" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:16:46.431144" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.431880" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.431617" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.432895" level="INFO">mapping: {'IP': '2607:f0d0:1002:0011:0000:0000:0000:0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.432614" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.433361" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.433100" elapsed="0.000287"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.434086" level="INFO">${value} = 2607:f0d0:1002:0011:0000:0000:0000:0002</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.433778" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.435197" level="INFO">${encoded} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.434961" elapsed="0.000319"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.435334" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:16:46.435498" level="INFO">${encoded_value} = 2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.434314" elapsed="0.001209"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.435699" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">2607:f0d0:1002:0011:0000:0000:0000:0002</var>
<status status="PASS" start="2026-06-06T03:16:46.433621" elapsed="0.002366"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.436542" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.436238" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.437311" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.437095" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.437388" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:46.437539" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.436774" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.437737" elapsed="0.000227"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:16:46.436104" elapsed="0.001901"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.438553" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.438254" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.439343" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.439130" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.439419" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:16:46.439573" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.438809" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.439804" elapsed="0.000238"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:16:46.438119" elapsed="0.001965"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.440631" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.440331" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.441394" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.441184" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.441469" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:46.441619" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.440865" elapsed="0.000782"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.441815" elapsed="0.000222"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:16:46.440198" elapsed="0.001880"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.442620" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.442322" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.443401" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.443186" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.443477" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:46.443660" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.442865" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.443843" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:16:46.442191" elapsed="0.001914"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.444668" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.444349" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.445421" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.445206" elapsed="0.000287"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.445547" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:16:46.445721" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.444885" elapsed="0.000861"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.445899" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:16:46.444218" elapsed="0.001945"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.446941" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.446408" elapsed="0.000559"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.447709" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.447480" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.447786" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:46.447936" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.447159" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.448111" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:16:46.446275" elapsed="0.002097"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.448934" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:46.448617" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:46.449692" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.449463" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:46.449774" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:46.449926" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:46.449146" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:46.450104" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:16:46.448485" elapsed="0.001883"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:16:46.433438" elapsed="0.016964"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:16:46.450445" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:16:46.450607" level="INFO">${mapping_to_use} = {'IP': '2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:16:46.432290" elapsed="0.018343"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.431994" elapsed="0.018794"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.450975" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.450818" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.431974" elapsed="0.019077"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.451951" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:16:46.451194" elapsed="0.000786"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:16:46.452029" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:16:46.428327" elapsed="0.023828"/>
</kw>
<msg time="2026-06-06T03:16:46.452210" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:46.415259" elapsed="0.037001"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.465310" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.478319" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/graceful_restart/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.491209" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.491406" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.491583" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.491983" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.491838" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:16:46.491822" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.492202" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.492369" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.492534" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:16:46.491792" elapsed="0.000794"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.491683" elapsed="0.000929"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.492777" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.492852" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:16:46.492974" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:16:46.410621" elapsed="0.082380"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.494105" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.493852" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:46.510976" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010j13iyll804yyhlhu4ycox9l5.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:46.511043" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=2607%3Af0d0%3A1002%3A0011%3A0000%3A0000%3A0000%3A0002 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:46.511186" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:16:46.496554" elapsed="0.014668"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.494219" elapsed="0.017103"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.511624" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.511361" elapsed="0.000383"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.494201" elapsed="0.017591"/>
</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-06-06T03:16:46.519644" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.514122" elapsed="0.005636"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.513584" elapsed="0.006210"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.513542" elapsed="0.006278"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.522446" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.520102" elapsed="0.002390"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.519877" elapsed="0.002649"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.519859" elapsed="0.002691"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.523124" 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-06-06T03:16:46.522742" elapsed="0.000410"/>
</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-06-06T03:16:46.523461" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.523222" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.524049" 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-06-06T03:16:46.523748" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.523569" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.523204" elapsed="0.000928"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.524671" 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-06-06T03:16:46.524291" elapsed="0.000408"/>
</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-06-06T03:16:46.525005" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.524770" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.525542" 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-06-06T03:16:46.525245" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.525086" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.524751" elapsed="0.000873"/>
</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-06-06T03:16:46.525790" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:16:46.526585" 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-06-06T03:16:46.526305" elapsed="0.000306"/>
</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-06-06T03:16:46.526786" elapsed="0.002400"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:16:46.512575" elapsed="0.016675"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:16:46.529297" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:16:46.531616" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:16:46.493262" elapsed="0.038381"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:16:46.531711" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/graceful_restart</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:16:46.383386" elapsed="0.148452"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:16:46.283354" elapsed="0.248599"/>
</test>
<test id="s1-s5-t36" name="Stop_All_Exabgps_4" line="468">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:16:46.535345" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:16:46.535081" elapsed="0.000529"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.536633" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.536522" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.536503" elapsed="0.000219"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.542038" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.541928" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.541909" elapsed="0.000208"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.543169" 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-06-06T03:16:46.542784" elapsed="0.000412"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.543680" 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-06-06T03:16:46.543358" elapsed="0.000350"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:46.543783" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:16:46.543941" 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-06-06T03:16:46.542384" elapsed="0.001582"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:46.549539" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.549430" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.549411" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:46.550813" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.550699" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.550678" elapsed="0.000203"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:46.551327" 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-06-06T03:16:46.551025" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.551748" level="INFO">${current_connection_index} = 7</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-06-06T03:16:46.551513" elapsed="0.000261"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.583131" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:46.552295" elapsed="0.030942"/>
</kw>
<msg time="2026-06-06T03:16:46.583403" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:46.583449" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:16:46.551959" elapsed="0.031526"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.604323" level="INFO">". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "4 "[K"
[?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-06-06T03:16:46.584049" elapsed="0.020405"/>
</kw>
<msg time="2026-06-06T03:16:46.604613" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:46.604679" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "4 "[K...</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-06-06T03:16:46.583683" elapsed="0.021035"/>
</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-06-06T03:16:46.605024" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.604797" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.604776" elapsed="0.000327"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.605549" level="INFO"> ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "4 "[K"
[?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-06-06T03:16:46.605247" elapsed="0.000367"/>
</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-06-06T03:16:46.605937" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.605715" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.605695" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:46.606049" elapsed="0.000027"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:46.608589" elapsed="0.000168"/>
</kw>
<msg time="2026-06-06T03:16:46.608821" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:46.607481" elapsed="0.001507"/>
</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="NOT RUN" start="2026-06-06T03:16:46.609267" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.609603" elapsed="0.000105"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:46.606865" elapsed="0.002958"/>
</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-06-06T03:16:46.606310" elapsed="0.003577"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:46.550370" elapsed="0.059616"/>
</kw>
<msg time="2026-06-06T03:16:46.610078" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:46.610122" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "4 "[K...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:46.549776" elapsed="0.060384"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:46.610514" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:16:46.610238" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.610219" elapsed="0.000382"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.611031" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.611368" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.611440" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:46.549092" elapsed="0.062456"/>
</kw>
<msg time="2026-06-06T03:16:46.611645" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:46.611704" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "I "p "v "6 "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "E "x "a "b "g "p "s "_ "4 "[K...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:46.544330" elapsed="0.067413"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:46.612076" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.611821" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.611803" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:46.544187" elapsed="0.067993"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:46.544018" elapsed="0.068191"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:46.541543" elapsed="0.070719"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:16:46.536234" elapsed="0.076084"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:46.535805" elapsed="0.076557"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:16:46.532839" elapsed="0.079619"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.621800" level="INFO">Executing command 'cat exabgp_graceful_restart.log'.</msg>
<msg time="2026-06-06T03:16:46.645011" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:16:46.645264" level="INFO">${output_log} = 03:16:43 | 4375   | welcome         | Thank you for using ExaBGP
03:16:43 | 4375   | version         | 4.2.4
03:16:43 | 4375   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:46.621644" elapsed="0.023681"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.646419" level="INFO">03:16:43 | 4375   | welcome         | Thank you for using ExaBGP
03:16:43 | 4375   | version         | 4.2.4
03:16:43 | 4375   | interpreter     | 3.10.12 (main, Mar  3 2026, 11:56:32) [GCC 11.4.0]
03:16:43 | 4375   | os              | Linux releng-26932-288-0-builder-0 5.15.0-173-generic #183-Ubuntu SMP Fri Mar 6 13:29:34 UTC 2026 x86_64
03:16:43 | 4375   | installation    | /tmp/defaultvenv
03:16:43 | 4375   | advice          | environment file missing
03:16:43 | 4375   | advice          | generate it using "exabgp --fi &gt; /tmp/defaultvenv/etc/exabgp/exabgp.env"
03:16:43 | 4375   | cli             | could not find the named pipes (exabgp.in and exabgp.out) required for the cli
03:16:43 | 4375   | cli             | we scanned the following folders (the number is your PID):
03:16:43 | 4375   | cli control     |  - /run/exabgp/
03:16:43 | 4375   | cli control     |  - /run/1001/
03:16:43 | 4375   | cli control     |  - /run/
03:16:43 | 4375   | cli control     |  - /var/run/exabgp/
03:16:43 | 4375   | cli control     |  - /var/run/1001/
03:16:43 | 4375   | cli control     |  - /var/run/
03:16:43 | 4375   | cli control     |  - /tmp/defaultvenv/run/exabgp/
03:16:43 | 4375   | cli control     |  - /tmp/defaultvenv/run/1001/
03:16:43 | 4375   | cli control     |  - /tmp/defaultvenv/run/
03:16:43 | 4375   | cli control     |  - /tmp/defaultvenv/var/run/exabgp/
03:16:43 | 4375   | cli control     |  - /tmp/defaultvenv/var/run/1001/
03:16:43 | 4375   | cli control     |  - /tmp/defaultvenv/var/run/
03:16:43 | 4375   | cli control     | please make them in one of the folder with the following commands:
03:16:43 | 4375   | cli control     | &gt; mkfifo /home/jenkins/run/exabgp.{in,out}
03:16:43 | 4375   | cli control     | &gt; chmod 600 /home/jenkins/run/exabgp.{in,out}
03:16:43 | 4375   | cli control     | &gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}
03:16:43 | 4375   | configuration   | performing reload of exabgp 4.2.4
03:16:43 | 4375   | configuration   | &gt; neighbor         | '::1'
03:16:43 | 4375   | configuration   | . router-id        | '1.2.3.4'
03:16:43 | 4375   | configuration   | . local-address    | '2607:f0d0:1002:0011:0000:0000:0000:0002'
03:16:43 | 4375   | configuration   | . local-as         | '64496'
03:16:43 | 4375   | configuration   | . peer-as          | '64496'
03:16:43 | 4375   | configuration   | &gt; capability       | 
03:16:43 | 4375   | configuration   | . graceful-restart | '40'
03:16:43 | 4375   | configuration   | &lt; capability       | 
03:16:43 | 4375   | configuration   | &gt; family           | 
03:16:43 | 4375   | configuration   | . ipv6             | 'unicast'
03:16:43 | 4375   | configuration   | &lt; family           | 
03:16:43 | 4375   | configuration   | &gt; static           | 
03:16:43 | 4375   | configuration   | . route            | '2a04:6d80::1/128' 'next-hop' 'self'
03:16:43 | 4375   | configuration   | &lt; static           | 
03:16:43 | 4375   | configuration   | &lt; neighbor         | 
03:16:43 | 4375   | reactor         | new peer: neighbor ::1 local-ip 2607:f0d0:1002:0011:0000:0000:0000:0002 local-as 64496 peer-as 64496 router-id 1.2.3.4 family-allowed in-open
03:16:43 | 4375   | reactor         | loaded new configuration successfully
03:16:43 | 4375   | reactor         | initialising connection to peer-1
03:16:43 | 4375   | outgoing-1      | attempting connection to ::1:1790
03:16:43 | 4375   | outgoing-1      | sending TCP payload (  59) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 0104 FBF0 00B4 0102 0304 1E02 0601 0400 0200 0102 0641 0400 00FB F002 0840 0680 2800 0201 8002 0206 00
03:16:43 | 4375   | outgoing-1      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), Graceful Restart Flags 0x8 Time 40 ipv6/unicast=0x80, ASN4(64496)]
03:16:43 | 4375   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 01
03:16:43 | 4375   | outgoing-1      | received TCP payload (  40) 04FB F000 B4C0 0002 021E 021C 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0001 4002 001E 4700
03:16:43 | 4375   | outgoing-1      | &lt;&lt; message of type OPEN
03:16:43 | 4375   | outgoing-1      | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 30 , ASN4(64496), Unassigned 71]
03:16:43 | 4375   | ka-outgoing-1   | receive-timer 60 second(s) left
03:16:43 | 4375   | outgoing-1      | --------------------------------------------------------------------
03:16:43 | 4375   | outgoing-1      | the connection can not carry the following family/families
03:16:43 | 4375   | outgoing-1      |  - exabgp is not configured for ipv4/unicast
03:16:43 | 4375   | outgoing-1      | therefore no routes of this kind can be announced on the connection
03:16:43 | 4375   | outgoing-1      | --------------------------------------------------------------------
03:16:43 | 4375   | outgoing-1      | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:16:43 | 4375   | outgoing-1      | &gt;&gt; KEEPALIVE (OPENCONFIRM)
03:16:43 | 4375   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04
03:16:43 | 4375   | outgoing-1      | &lt;&lt; message of type KEEPALIVE
03:16:43 | 4375   | ka-outgoing-1   | receive-timer 180 second(s) left
03:16:43 | 4375   | reactor         | connected to peer-1 with outgoing-1 2607:f0d0:1002:0011:0000:0000:0000:0002-::1
03:16:43 | 4375   | outgoing-1      | sending TCP payload (  78) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004E 0200 0000 3740 0101 0040 0200 4005 0400 0000 6480 0E26 0002 0110 2607 F0D0 1002 0011 0000 0000 0000 0002 0080 2A04 6D80 0000 0000 0000 0000 0000 0001
03:16:43 | 4375   | outgoing-1      | &gt;&gt; 1 UPDATE(s)
03:16:43 | 4375   | outgoing-1      | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0201
03:16:43 | 4375   | outgoing-1      | &gt;&gt; EOR ipv6 unicast
03:16:43 | 4375   | peer-1          | &gt;&gt; EOR(s)
03:16:43 | 4375   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:16:43 | 4375   | outgoing-1      | received TCP payload (   4) 0000 0000
03:16:43 | 4375   | outgoing-1      | &lt;&lt; message of type UPDATE
03:16:43 | 4375   | parser          | parsing UPDATE (   4) 0000 0000
03:16:43 | 4375   | peer-1          | &lt;&lt; UPDATE #1
03:16:43 | 4375   | peer-1          |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)
03:16:43 | 4375   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02
03:16:43 | 4375   | outgoing-1      | received TCP payload (   4) 0000 0000
03:16:43 | 4375   | outgoing-1      | &lt;&lt; message of type UPDATE
03:16:43 | 4375   | parser          | parsing UPDATE (   4) 0000 0000
03:16:43 | 4375   | peer-1          | &lt;&lt; UPDATE #2
03:16:43 | 4375   | peer-1          |    UPDATE #2 nlri  (   4) eor 1/1 (ipv4 unicast)
03:16:43 | 4375   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02
03:16:43 | 4375   | outgoing-1      | received TCP payload (  10) 0000 0006 800F 0300 0201
03:16:43 | 4375   | outgoing-1      | &lt;&lt; message of type UPDATE
03:16:43 | 4375   | parser          | parsing UPDATE (  10) 0000 0006 800F 0300 0201
03:16:43 | 4375   | routes          | withdrawn NLRI none
03:16:43 | 4375   | parser          | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0002 01
03:16:43 | 4375   | routes          | announced NLRI none
03:16:43 | 4375   | peer-1          | &lt;&lt; UPDATE #3
03:16:43 | 4375   | peer-1          |    UPDATE #3 nlri  (  11) eor 2/1 (ipv6 unicast)
03:16:43 | 4375   | ka-outgoing-1   | receive-timer 179 second(s) left
03:16:43 | 4375   | ka-outgoing-1   | send-timer 59 second(s) left
03:16:44 | 4375   | ka-outgoing-1   | receive-timer 178 second(s) left
03:16:44 | 4375   | ka-outgoing-1   | send-timer 58 second(s) left
03:16:45 | 4375   | ka-outgoing-1   | receive-timer 177 second(s) left
03:16:45 | 4375   | ka-outgoing-1   | send-timer 57 second(s) left
03:16:46 | 4375   | outgoing-1      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:16:46 | 4375   | outgoing-1      | received TCP payload (   2) 0600
03:16:46 | 4375   | outgoing-1      | &lt;&lt; message of type NOTIFICATION
03:16:46 | 4375   | outgoing-1      | peer reset, message [notification received (6,0)] error[Cease / Unspecific]
03:16:46 | 4375   | outgoing-1      | outgoing-1 2607:f0d0:1002:0011:0000:0000:0000:0002-::1, closing connection
03:16:46 | 4375   | reactor         | initialising connection to peer-1
03:16:46 | 4375   | outgoing-2      | attempting connection to ::1:1790
03:16:46 | 4375   | outgoing-2      | sending TCP payload (  59) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 003B 0104 FBF0 00B4 0102 0304 1E02 0601 0400 0200 0102 0641 0400 00FB F002 0840 0680 2800 0201 8002 0206 00
03:16:46 | 4375   | outgoing-2      | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=1.2.3.4 capabilities=[Multiprotocol(ipv6 unicast), Extended Message(65535), Graceful Restart Flags 0x8 Time 40 ipv6/unicast=0x80, ASN4(64496)]
03:16:46 | 4375   | outgoing-2      | received TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0015 03
03:16:46 | 4375   | outgoing-2      | received TCP payload (   2) 0605
03:16:46 | 4375   | outgoing-2      | &lt;&lt; message of type NOTIFICATION
03:16:46 | 4375   | outgoing-2      | peer reset, message [notification received (6,5)] error[Cease / Connection Rejected]
03:16:46 | 4375   | outgoing-2      | outgoing-2 2607:f0d0:1002:0011:0000:0000:0000:0002-::1, closing connection</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.645792" elapsed="0.001072"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:16:46.648152" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exabgp_graceful_restart.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exabgp_graceful_restart.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:16:46.647273" elapsed="0.001012"/>
</kw>
<arg>${EXABGP3_LOG}</arg>
<arg>${EXABGP3_LOG}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:16:46.621252" elapsed="0.027179"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.650031" level="INFO">[?2004l</msg>
<msg time="2026-06-06T03:16:46.650209" level="INFO">${output} = [?2004l</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:16:46.649790" elapsed="0.000475"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.651213" level="INFO">[?2004l</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.650610" elapsed="0.000706"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.653328" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:16:46.652412" elapsed="0.000982"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:46.653781" elapsed="0.000221"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:16:46.651803" elapsed="0.002261"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.800771" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:16:46.800872" level="INFO">${output} = ^C[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:16:46.654217" elapsed="0.146682"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.801320" level="INFO">^C[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.801066" elapsed="0.000301"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.803197" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:46.802023" elapsed="0.001232"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.804196" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:16:46.804284" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-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-06-06T03:16:46.803418" elapsed="0.000892"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.804922" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.804670" elapsed="0.000300"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.804390" elapsed="0.000615"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.804366" elapsed="0.000665"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:16:46.801630" elapsed="0.003448"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:16:46.649078" elapsed="0.156051"/>
</kw>
<doc>Save exabgp logs as exabgp_graceful_restart.log, and stop exabgp with ctrl-c bash signal</doc>
<status status="PASS" start="2026-06-06T03:16:46.532261" elapsed="0.272976"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Virtual_Env_Delete" 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-06-06T03:16:46.812055" level="INFO">${cd_and_command} = cd '.' &amp;&amp; rm -rf /tmp/defaultvenv</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-06-06T03:16:46.811726" elapsed="0.000357"/>
</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-06-06T03:16:46.813519" level="INFO">Executing command 'cd '.' &amp;&amp; rm -rf /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:16:46.856804" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:16:46.857060" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:16:46.857157" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:16:46.857246" 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-06-06T03:16:46.813335" elapsed="0.043962"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.859232" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:16:46.858521" elapsed="0.000812"/>
</kw>
<msg time="2026-06-06T03:16:46.859545" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:16:46.859647" 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-06-06T03:16:46.857752" elapsed="0.001982"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.861083" 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-06-06T03:16:46.860114" elapsed="0.001029"/>
</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-06-06T03:16:46.863534" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.862936" elapsed="0.000693"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.864752" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.864132" elapsed="0.000724"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.865784" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.865204" elapsed="0.000680"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:16:46.862107" elapsed="0.003898"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.861315" elapsed="0.004770"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.861271" elapsed="0.004870"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.866493" elapsed="0.000035"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.866267" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.866229" elapsed="0.000447"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:16:46.867000" elapsed="0.000114"/>
</return>
<status status="PASS" start="2026-06-06T03:16:46.866799" elapsed="0.000392"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.866764" elapsed="0.000481"/>
</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-06-06T03:16:46.867574" elapsed="0.000048"/>
</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-06-06T03:16:46.812788" elapsed="0.055032"/>
</kw>
<msg time="2026-06-06T03:16:46.867873" 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-06-06T03:16:46.812245" elapsed="0.055689"/>
</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 rm -rf /tmp/defaultvenv.
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-06-06T03:16:46.811097" elapsed="0.056915"/>
</kw>
<msg time="2026-06-06T03:16:46.868062" 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-06-06T03:16:46.806764" elapsed="0.061352"/>
</kw>
<arg>rm -rf ${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-06-06T03:16:46.806376" elapsed="0.061814"/>
</kw>
<doc>Deletes a directory with virtual env.</doc>
<status status="PASS" start="2026-06-06T03:16:46.806146" elapsed="0.062095"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:16:46.868387" elapsed="0.000425"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:46.869047" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:16:46.868970" elapsed="0.000185"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.870199" level="INFO">${output} = None</msg>
<msg time="2026-06-06T03:16:46.870241" level="FAIL">No open connection.</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.870036" elapsed="0.000611">No open connection.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.871109" level="INFO">None</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.870835" elapsed="0.000321"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.871902" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:16:46.871573" elapsed="0.000357"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.872253" level="FAIL">No open connection.</msg>
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.872082" elapsed="0.000413">No open connection.</status>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.871358" elapsed="0.001261">No open connection.</status>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.872970" level="INFO">${output} = None</msg>
<msg time="2026-06-06T03:16:46.873011" level="FAIL">No open connection.</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.872816" elapsed="0.000406">No open connection.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.873648" level="INFO">None</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.873392" elapsed="0.000318"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.874417" level="FAIL">No open connection.</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.874273" elapsed="0.000424">No open connection.</status>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.875300" level="INFO">${output} = None</msg>
<msg time="2026-06-06T03:16:46.875343" level="FAIL">No open connection.</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.874868" elapsed="0.000682">No open connection.</status>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.876205" level="INFO">None</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.875947" elapsed="0.000305"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:46.875634" elapsed="0.000653"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.875614" elapsed="0.000699"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="FAIL" start="2026-06-06T03:16:46.873957" elapsed="0.002466">Several failures occurred:

1) No open connection.

2) No open connection.</status>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="FAIL" start="2026-06-06T03:16:46.869820" elapsed="0.006726">Several failures occurred:

1) No open connection.

2) No open connection.

3) No open connection.

4) No open connection.

5) No open connection.</status>
</kw>
<arg>ExaBgpLib.Stop_ExaBgp</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:46.869382" elapsed="0.007217"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:16:46.805889" elapsed="0.070792"/>
</kw>
<doc>Functional test for ipv6 connection with bgp.

Copyright (c) 2018 AT&amp;T Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests simple connection between one ibgp peer (exabgp) and Odl.
Peer is configured with ipv6, and exabgp connectes to odl via ipv6.
Exabgp sends one ipv6 unicast route, which presence is verified in
example-ipv6-topology. Tests this connection multiple times, with
different ipv6 accepted formats, e.g. (::1, 0:0:0:0:0:0:0:1, full text)
This suite also tests a combination of afi-safis on odl and exabgp.
ipv6 route injection is carried out from odl to the ibgp peer without
ipv6 family enabled on the peer device and checked for exceptions</doc>
<status status="PASS" start="2026-06-06T03:13:47.853393" elapsed="179.023322"/>
</suite>
<suite id="s1-s6" name="Bgp Llgr Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/bgp_llgr_basic.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.967716" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:16:46.963410" elapsed="0.004364"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:16:46.963168" elapsed="0.004679"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.972696" 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-06-06T03:16:46.968982" elapsed="0.003743"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:16:46.972938" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.972813" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.972788" elapsed="0.000219"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.973519" 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-06-06T03:16:46.973162" elapsed="0.000401"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.974062" 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-06-06T03:16:46.973745" elapsed="0.000344"/>
</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-06-06T03:16:46.974605" elapsed="0.000306"/>
</kw>
<msg time="2026-06-06T03:16:46.975016" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:46.975065" 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-06-06T03:16:46.974254" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.975643" 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-06-06T03:16:46.975259" elapsed="0.000427"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.976763" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:16:46.976469" elapsed="0.000323"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.977217" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:16:46.976947" elapsed="0.000297"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.977731" 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-06-06T03:16:46.977407" elapsed="0.000353"/>
</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-06-06T03:16:46.981070" elapsed="0.000222"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.981803" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:16:46.981456" elapsed="0.000373"/>
</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-06-06T03:16:46.982175" elapsed="0.000230"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.983211" 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-06-06T03:16:46.982915" elapsed="0.000323"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:16:46.983283" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:16:46.983544" 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-06-06T03:16:46.982602" elapsed="0.000968"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:46.984190" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5d37e50&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-06-06T03:16:46.983747" elapsed="0.000617"/>
</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-06-06T03:16:46.984531" elapsed="0.000212"/>
</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-06-06T03:16:46.980465" elapsed="0.004339"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:46.980269" elapsed="0.004579"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:16:46.977817" elapsed="0.007064"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.985448" 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-06-06T03:16:46.985046" elapsed="0.000446"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.986069" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:16:46.985670" elapsed="0.000441"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.986672" 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-06-06T03:16:46.986274" elapsed="0.000442"/>
</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-06-06T03:16:46.975958" elapsed="0.010820"/>
</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-06-06T03:16:46.968613" elapsed="0.018221"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:46.987016" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:46.986902" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.986882" elapsed="0.000201"/>
</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-06-06T03:16:46.990261" 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-06-06T03:16:46.989876" elapsed="0.000412"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:46.990767" 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-06-06T03:16:46.990450" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:46.990839" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:46.990994" 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-06-06T03:16:46.989520" elapsed="0.001500"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:46.992019" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:16:46.991750" elapsed="0.000295"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.992849" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:16:46.992950" 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-06-06T03:16:46.992678" elapsed="0.000299"/>
</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-06-06T03:16:46.998200" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:46.997603" elapsed="0.000684"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:46.997580" elapsed="0.000747"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:46.998995" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:16:46.998532" elapsed="0.000809"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.000299" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:46.999609" elapsed="0.000834"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.001663" 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-06-06T03:16:47.000750" elapsed="0.000968"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.003451" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:16:47.003630" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:16:47.003076" elapsed="0.000616"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:47.004038" elapsed="0.000488"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.005826" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:16:47.356230" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:15:55 UTC 2026

  System load:  0.01               Processes:             126
  Usage of /:   11.3% of 77.35GB   Users logged in:       1
  Memory usage: 11%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:16:43 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:16:47.005363" elapsed="0.351024"/>
</kw>
<msg time="2026-06-06T03:16:47.356473" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:47.004914" elapsed="0.351724"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:16:47.002161" elapsed="0.354693"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.357736" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:16:47.370912" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:16:47.371147" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:16:47.371289" 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-06-06T03:16:47.357232" elapsed="0.014125"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:16:47.371858" elapsed="0.000693"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.375182" 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-06-06T03:16:47.373822" elapsed="0.001593"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:16:47.376401" elapsed="0.000111"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:47.375855" elapsed="0.000883"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.375795" elapsed="0.001034"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:16:47.377501" elapsed="0.000134"/>
</return>
<status status="PASS" start="2026-06-06T03:16:47.377010" elapsed="0.000950"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.376970" elapsed="0.001080"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:16:47.378179" elapsed="0.000037"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:47.383229" elapsed="0.000481"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:47.384177" elapsed="0.000293"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:16:47.384765" elapsed="0.000224"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:47.379255" elapsed="0.005805"/>
</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-06-06T03:16:46.996612" elapsed="0.388623"/>
</kw>
<msg time="2026-06-06T03:16:47.385355" 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-06-06T03:16:46.994140" elapsed="0.391272"/>
</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-06-06T03:16:46.993643" elapsed="0.391853"/>
</kw>
<msg time="2026-06-06T03:16:47.385538" 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-06-06T03:16:46.993131" elapsed="0.392453"/>
</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-06-06T03:16:47.388307" elapsed="0.000308"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:47.388809" elapsed="0.000148"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:16:47.389106" elapsed="0.000098"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:47.385942" elapsed="0.003313"/>
</kw>
<msg time="2026-06-06T03:16:47.389348" 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-06-06T03:16:46.992297" elapsed="0.397075"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.389881" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:47.389557" elapsed="0.000366"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:16:47.389966" elapsed="0.000030"/>
</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-06-06T03:16:46.991375" elapsed="0.398718"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:46.991200" elapsed="0.398931"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:46.991073" elapsed="0.399093"/>
</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-06-06T03:16:46.987301" elapsed="0.402921"/>
</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-06-06T03:16:47.390378" elapsed="0.000210"/>
</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-06-06T03:16:47.404314" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:47.404186" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.404165" elapsed="0.000219"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.404701" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:16:47.404808" 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-06-06T03:16:47.404544" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.405252" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:47.404991" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.405722" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:47.405452" elapsed="0.000317"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:47.406536" 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-06-06T03:16:47.406306" elapsed="0.000357">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:16:47.406774" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:16:47.406819" 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-06-06T03:16:47.405934" elapsed="0.000908"/>
</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-06-06T03:16:47.407146" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:47.406920" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.406901" elapsed="0.000344"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:47.408007" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:16:47.407738" elapsed="0.000332"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:16:47.408119" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:16:47.408272" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:16:47.407447" elapsed="0.000909"/>
</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-06-06T03:16:47.408515" elapsed="0.000454"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.409254" level="INFO">index=4
host=10.30.170.38
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-06-06T03:16:47.409356" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:16:47.409143" elapsed="0.000239"/>
</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-06-06T03:16:47.409532" elapsed="0.002462"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.412475" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:16:47.610567" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:16:47.412206" elapsed="0.198531"/>
</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-06-06T03:16:47.614257" elapsed="0.000431"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:47.614878" elapsed="0.000186"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:16:47.615217" elapsed="0.000106"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:47.611892" elapsed="0.003485"/>
</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-06-06T03:16:47.611165" elapsed="0.004263"/>
</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-06-06T03:16:47.403882" elapsed="0.211601"/>
</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-06-06T03:16:47.391335" elapsed="0.224198"/>
</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-06-06T03:16:47.390959" elapsed="0.224629"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:47.390810" elapsed="0.224820"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:16:47.390648" elapsed="0.225065"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:16:46.968171" elapsed="0.647608"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:47.618501" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:47.618377" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.618339" elapsed="0.000240"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:47.623395" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:47.623287" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.623269" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.624445" 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-06-06T03:16:47.624051" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.624954" 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-06-06T03:16:47.624636" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:47.625026" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:16:47.625189" 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-06-06T03:16:47.623709" elapsed="0.001505"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:47.631117" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:47.631007" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.630988" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:47.632402" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:47.632273" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.632255" elapsed="0.000217"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:47.632980" 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-06-06T03:16:47.632620" elapsed="0.000386"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.633395" 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-06-06T03:16:47.633168" elapsed="0.000253"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.668405" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:47.634127" elapsed="0.034417"/>
</kw>
<msg time="2026-06-06T03:16:47.668770" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:47.668821" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:16:47.633583" elapsed="0.035275"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.737111" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "l "l "[78Cg "[A[78Cr
 "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:16:47.669582" elapsed="0.067764"/>
</kw>
<msg time="2026-06-06T03:16:47.737535" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:47.737582" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:16:47.669042" elapsed="0.068578"/>
</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-06-06T03:16:47.738137" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:47.737803" elapsed="0.000489"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.737768" elapsed="0.000552"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.738916" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "l "l "[78Cg "[A[78Cr
 "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:16:47.738471" elapsed="0.000572"/>
</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-06-06T03:16:47.739358" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:47.739115" elapsed="0.000391"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.739096" elapsed="0.000436"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:47.739570" elapsed="0.000039"/>
</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-06-06T03:16:47.741761" elapsed="0.000459"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:47.742571" elapsed="0.000327"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:16:47.743254" elapsed="0.000240"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:47.740946" elapsed="0.002639"/>
</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-06-06T03:16:47.740016" elapsed="0.003949"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:47.631983" elapsed="0.112087"/>
</kw>
<msg time="2026-06-06T03:16:47.744169" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:47.744280" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:47.631343" elapsed="0.112978"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:47.744512" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:16:47.744403" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.744383" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:47.745023" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:47.745367" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:47.745440" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:47.630708" elapsed="0.114842"/>
</kw>
<msg time="2026-06-06T03:16:47.745663" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:47.745711" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:47.625703" elapsed="0.120046"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:47.746083" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:47.745828" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:47.745810" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:47.625539" elapsed="0.120648"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:47.625358" elapsed="0.120862"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:47.622994" elapsed="0.123282"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:16:47.616398" elapsed="0.129936"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:47.615942" elapsed="0.130435"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:16:46.962847" elapsed="0.783583"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.746959" level="INFO">${tools_system_conn_id} = 7</msg>
<var>${tools_system_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:47.746583" elapsed="0.000403"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:47.747510" level="INFO">${tools_system_conn_id} = 7</msg>
<arg>${tools_system_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:16:47.747182" elapsed="0.000371"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:16:47.749500" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:16:47.749579" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:16:47.749222" elapsed="0.000382"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:47.749780" elapsed="0.000557"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:16:47.751237" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:16:48.512547" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:16:48 UTC 2026

  System load:  0.0                Processes:             108
  Usage of /:   19.6% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:12:31 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:16:47.750899" elapsed="0.761819"/>
</kw>
<msg time="2026-06-06T03:16:48.512805" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:47.750513" elapsed="0.762375"/>
</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-06-06T03:16:47.748783" elapsed="0.764314"/>
</kw>
<msg time="2026-06-06T03:16:48.513155" 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-06-06T03:16:47.748377" elapsed="0.764824"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:16:47.747822" elapsed="0.765459"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:48.513912" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e592c210&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:16:48.513531" elapsed="0.000559"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.524243" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:16:48.532338" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/gobgp/gobgp.cfg' -&gt; '/home/jenkins//gobgp.cfg'</msg>
<arg>${GOBGP_FOLDER}/${GOBGP_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:16:48.514590" elapsed="0.017833"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.541526" level="INFO">2 files:
exa-md5.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:16:48.541900" level="INFO">@{cfgfiles} = [ exa-md5.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:16:48.532682" elapsed="0.009282"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.543329" level="INFO">Executing command 'sed -i -e 's/GOBGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:16:48.556369" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/GOBGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.542915" elapsed="0.013616"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.557379" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:16:48.605544" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.556972" elapsed="0.048853"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.606985" level="INFO">Executing command 'sed -i -e 's/ROUTERID/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:16:48.657295" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTERID/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.606416" elapsed="0.051046"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.658484" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:16:48.709389" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.658042" elapsed="0.051526"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.710463" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:16:48.771585" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.710077" elapsed="0.061745"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.772870" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:16:48.817328" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:16:48.817589" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.772379" elapsed="0.045291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:48.818585" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:48.818084" elapsed="0.000598"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:16:48.542532" elapsed="0.276218"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.819598" level="INFO">Executing command 'sed -i -e 's/GOBGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:16:48.865530" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/GOBGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.819282" elapsed="0.046386"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.866260" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:16:48.918299" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.865965" elapsed="0.052501"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.919265" level="INFO">Executing command 'sed -i -e 's/ROUTERID/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:16:48.969819" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTERID/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.918884" elapsed="0.051100"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:48.970851" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:16:49.021987" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:48.970423" elapsed="0.051737"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.023183" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:16:49.074014" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:49.022801" elapsed="0.051390"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.075092" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:16:49.125327" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:16:49.125617" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:49.074685" elapsed="0.051050"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:49.127067" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:49.126336" elapsed="0.000844"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:16:48.818998" elapsed="0.308261"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:16:48.542113" elapsed="0.585220"/>
</for>
<doc>Uploads gobgp config files</doc>
<status status="PASS" start="2026-06-06T03:16:48.514332" elapsed="0.613137"/>
</kw>
<kw name="Download_Gobgp_Binary">
<kw name="Open_Connection_To_Tools_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.136096" level="INFO">${tools_connection} = 8</msg>
<var>${tools_connection}</var>
<arg>${ip_address}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:16:49.135526" elapsed="0.000608"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:16:49.138514" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:16:49.138622" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:16:49.138087" elapsed="0.000589"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:49.138905" elapsed="0.000348"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.140111" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:16:49.480305" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:16:48 UTC 2026

  System load:  0.0                Processes:             108
  Usage of /:   19.6% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:16:48 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:16:49.139794" elapsed="0.340666"/>
</kw>
<msg time="2026-06-06T03:16:49.480544" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:49.139423" elapsed="0.341203"/>
</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-06-06T03:16:49.137455" elapsed="0.343348"/>
</kw>
<msg time="2026-06-06T03:16:49.480856" 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-06-06T03:16:49.136891" elapsed="0.344013"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:16:49.136393" elapsed="0.344757"/>
</kw>
<return>
<value>${tools_connection}</value>
<status status="PASS" start="2026-06-06T03:16:49.481205" elapsed="0.000046"/>
</return>
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Open a connection to the tools system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:16:49.134994" elapsed="0.346391"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.481828" level="INFO">Executing command 'wget https://github.com/osrg/gobgp/releases/download/v2.18.0/gobgp_2.18.0_linux_386.tar.gz'.</msg>
<msg time="2026-06-06T03:16:49.802550" level="INFO">Command exited with return code 0.</msg>
<arg>wget ${GOBGP_BINARY_URL}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:49.481617" elapsed="0.321193"/>
</kw>
<kw name="File Should Exist" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.847928" level="INFO">[chan 2] Opened sftp connection (server version 3)</msg>
<arg>./${FILE_NAME}</arg>
<doc>Fails if the given ``path`` does NOT point to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:16:49.803337" elapsed="0.046691"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:16:49.851131" level="INFO">Executing command 'tar -xzf gobgp_2.18.0_linux_386.tar.gz'.</msg>
<msg time="2026-06-06T03:16:50.068432" level="INFO">Command exited with return code 0.</msg>
<arg>tar -xzf ${FILE_NAME}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:16:49.850532" elapsed="0.218148"/>
</kw>
<doc>Downloads gobgp binary and untar the binary zip file</doc>
<status status="PASS" start="2026-06-06T03:16:49.127864" elapsed="0.941195"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:46.962486" elapsed="3.106694"/>
</kw>
<test id="s1-s6-t1" name="Reconfigure_ODL_To_Accept_Connections" line="40">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:16:50.076921" elapsed="0.000530"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:16:50.076183" elapsed="0.001394"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.078916" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.078772" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.078745" elapsed="0.000249"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.084535" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.084408" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.084386" elapsed="0.000227"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.085825" 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-06-06T03:16:50.085364" elapsed="0.000491"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.086400" 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-06-06T03:16:50.086038" elapsed="0.000405"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:50.086511" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:16:50.086725" 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-06-06T03:16:50.084943" elapsed="0.001809"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:50.092833" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.092709" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.092630" elapsed="0.000315"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:50.094225" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.094116" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.094096" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:50.094773" 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-06-06T03:16:50.094442" elapsed="0.000358"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.095181" level="INFO">${current_connection_index} = 8</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-06-06T03:16:50.094962" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.127625" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:50.095772" elapsed="0.032136"/>
</kw>
<msg time="2026-06-06T03:16:50.128140" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:50.128190" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:16:50.095384" elapsed="0.032860"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.154214" level="INFO">". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "[K"
[?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-06-06T03:16:50.129144" elapsed="0.025291"/>
</kw>
<msg time="2026-06-06T03:16:50.154688" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:50.154738" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</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-06-06T03:16:50.128559" elapsed="0.026217"/>
</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-06-06T03:16:50.155201" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.154887" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.154855" elapsed="0.000433"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.155836" level="INFO"> ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "[K"
[?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-06-06T03:16:50.155437" elapsed="0.000549"/>
</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-06-06T03:16:50.156279" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.156056" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.156037" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:50.156395" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:50.159082" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:16:50.159294" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:50.158039" elapsed="0.001390"/>
</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="NOT RUN" start="2026-06-06T03:16:50.159725" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.160064" elapsed="0.000087"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:50.157371" elapsed="0.002895"/>
</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-06-06T03:16:50.156744" elapsed="0.003588"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:50.093776" elapsed="0.066657"/>
</kw>
<msg time="2026-06-06T03:16:50.160530" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:50.160576" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:50.093106" elapsed="0.067508"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:50.160833" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:16:50.160722" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.160702" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.161354" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.161714" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.161786" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:50.092282" elapsed="0.069614"/>
</kw>
<msg time="2026-06-06T03:16:50.161996" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:50.162041" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:50.087170" elapsed="0.074908"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.162408" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.162155" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.162137" elapsed="0.000347"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:50.087017" elapsed="0.075491"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:50.086818" elapsed="0.075724"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:50.083971" elapsed="0.078630"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:16:50.078387" elapsed="0.084287"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:50.077909" elapsed="0.084814"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:16:50.071050" elapsed="0.091732"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.163722" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.162986" elapsed="0.000767"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.185752" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.185317" elapsed="0.000467"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:16:50.186559" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:16:50.186293" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:16:50.186751" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:16:50.185955" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.187330" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:50.186945" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:16:50.187676" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:16:50.187855" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:16:50.187519" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.188298" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.188047" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.189335" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.189072" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.189848" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.189559" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.190549" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.190253" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.191321" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.191100" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.191399" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:16:50.191555" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.190779" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.191751" elapsed="0.000241"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:16:50.190114" elapsed="0.001919"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.192574" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.192278" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.193482" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.193270" elapsed="0.000274"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.193597" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:16:50.193767" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.192803" elapsed="0.000988"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.193950" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:16:50.192145" elapsed="0.002067"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.194774" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.194456" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.195568" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.195357" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.195660" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:16:50.195812" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.195040" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.195987" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:16:50.194322" elapsed="0.001927"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.196808" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.196490" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.197563" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.197339" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.197640" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:16:50.197808" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.197023" elapsed="0.000809"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.197983" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:16:50.196359" elapsed="0.001884"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.198800" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.198485" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.199531" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.199324" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.199606" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:50.199775" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.199011" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.199956" elapsed="0.000219"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:16:50.198354" elapsed="0.001862"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.200774" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.200460" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.201507" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.201300" elapsed="0.000232"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.201610" elapsed="0.000136"/>
</return>
<msg time="2026-06-06T03:16:50.201875" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.200985" elapsed="0.000914"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.202050" elapsed="0.000221"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:16:50.200327" elapsed="0.001984"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.202878" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.202554" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.203609" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.203401" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.203701" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:16:50.203853" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.203087" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.204027" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:16:50.202423" elapsed="0.001866"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.205029" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:16:50.204532" elapsed="0.000522"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:16:50.205841" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.205615" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:16:50.205918" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:16:50.206065" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:16:50.205284" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:16:50.206240" elapsed="0.000220"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:16:50.204401" elapsed="0.002099"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:16:50.189928" elapsed="0.016607"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:16:50.206577" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:16:50.206756" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:16:50.188740" elapsed="0.018043"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.188416" elapsed="0.018400"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.206990" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.206841" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.188395" elapsed="0.018671"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.208005" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:16:50.207207" elapsed="0.000828"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:16:50.208086" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="PASS" start="2026-06-06T03:16:50.184706" elapsed="0.023508"/>
</kw>
<msg time="2026-06-06T03:16:50.208273" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:50.183859" elapsed="0.024466"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.208880" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.209394" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.209955" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.210158" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.210340" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.210799" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.210632" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:16:50.210616" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.211022" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.211190" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.211357" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:16:50.210582" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.210471" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.211584" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.211677" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:16:50.211807" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:16:50.179671" elapsed="0.032163"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.226339" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.225956" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:16:50.227127" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:16:50.226885" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:16:50.227296" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:16:50.226531" elapsed="0.000789"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.227889" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:50.227485" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:16:50.228216" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:16:50.228379" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:16:50.228078" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.228833" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.228564" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:16:50.229260" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.228961" elapsed="0.000359"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.230093" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.229534" elapsed="0.000588"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.229382" elapsed="0.000777"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.228941" elapsed="0.001241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.231135" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:16:50.230352" elapsed="0.000814"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:16:50.231217" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="PASS" start="2026-06-06T03:16:50.225307" elapsed="0.006038"/>
</kw>
<msg time="2026-06-06T03:16:50.231404" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:50.224458" elapsed="0.006992"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.231968" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.232482" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.233014" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.233209" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.233391" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.233834" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.233629" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:16:50.233612" elapsed="0.000305"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.234182" elapsed="0.000035"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.234365" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.234530" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:16:50.233581" elapsed="0.001002"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.233472" elapsed="0.001139"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.234775" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.234902" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:16:50.235043" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:16:50.221814" elapsed="0.013257"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:16:50.236381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:16:50.236120" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:16:50.236548" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:16:50.235762" elapsed="0.000811"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.236913" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.236660" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.237459" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.237169" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.236994" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.236624" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.239907" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:50.237708" elapsed="0.002225"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:16:50.239984" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:50.240137" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:16:50.235403" elapsed="0.004759"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.241549" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.241299" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.242026" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.241762" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.242476" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.242235" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.242923" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.242683" elapsed="0.000283"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:50.243925" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:16:50.243727" elapsed="0.000224"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:16:50.244276" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:16:50.244102" elapsed="0.000200"/>
</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-06-06T03:16:50.244450" elapsed="0.000227"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.246718" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.244875" elapsed="0.001889"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:16:50.246809" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:16:50.246967" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:16:50.243308" elapsed="0.003684"/>
</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-06-06T03:16:50.272803" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '987', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:16:50.272876" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node078yadnmgxpoujdsm6zrbfeku6.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:16:50 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:50.272994" 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-06-06T03:16:50.249138" elapsed="0.023883"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.247064" elapsed="0.026006"/>
</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-06-06T03:16:50.273267" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.273100" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.247046" elapsed="0.026313"/>
</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-06-06T03:16:50.276779" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.274404" elapsed="0.002419"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.274174" elapsed="0.002685"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.274155" elapsed="0.002730"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.279475" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.277166" elapsed="0.002356"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.276941" elapsed="0.002616"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.276924" elapsed="0.002658"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.280167" 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-06-06T03:16:50.279771" elapsed="0.000423"/>
</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-06-06T03:16:50.280502" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.280264" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.281068" 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-06-06T03:16:50.280764" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.280584" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.280245" elapsed="0.000907"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.281695" 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-06-06T03:16:50.281312" elapsed="0.000411"/>
</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-06-06T03:16:50.282035" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.281794" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.282646" 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-06-06T03:16:50.282295" elapsed="0.000392"/>
</kw>
<status status="PASS" start="2026-06-06T03:16:50.282135" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.281776" elapsed="0.000969"/>
</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-06-06T03:16:50.282899" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:16:50.283729" 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-06-06T03:16:50.283417" elapsed="0.000339"/>
</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-06-06T03:16:50.283913" elapsed="0.002434"/>
</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-06-06T03:16:50.273767" elapsed="0.012647"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:16:50.286598" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:16:50.286485" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.286465" elapsed="0.000247"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:16:50.286869" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.286939" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:16:50.289183" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:16:50.240488" elapsed="0.048722"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:16:50.289277" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:16:50.289434" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:16:50.168970" elapsed="0.120490"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.289823" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.289560" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.289543" elapsed="0.000375"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:16:50.289951" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:16:50.164166" elapsed="0.125912"/>
</kw>
<doc>Configure BGP peer modules with initiate-connection set to false with short ipv6 address.</doc>
<status status="PASS" start="2026-06-06T03:16:50.069326" elapsed="0.220905"/>
</test>
<test id="s1-s6-t2" name="Start_Gobgp" line="56">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:16:50.336873" elapsed="0.000265"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:16:50.336539" elapsed="0.000671"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.338291" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.338156" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.338131" elapsed="0.000232"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.343452" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.343344" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.343326" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.344531" 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-06-06T03:16:50.344141" elapsed="0.000419"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.345039" 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-06-06T03:16:50.344739" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:16:50.345109" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:16:50.345268" 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-06-06T03:16:50.343763" elapsed="0.001530"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:16:50.350924" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.350815" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.350795" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:16:50.352176" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:16:50.352069" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.352049" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:16:50.352708" 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-06-06T03:16:50.352390" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.353119" level="INFO">${current_connection_index} = 8</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-06-06T03:16:50.352899" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.383838" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:50.353692" elapsed="0.030243"/>
</kw>
<msg time="2026-06-06T03:16:50.384097" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:16:50.384161" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:16:50.353336" elapsed="0.030862"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.404107" level="INFO">". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "a "r "t "_ "G "o "b "g "p "[K"
[?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-06-06T03:16:50.384734" elapsed="0.019477"/>
</kw>
<msg time="2026-06-06T03:16:50.404379" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:16:50.404424" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "a "r "t "_ "G "o "b "g "p "[K"
[?1l&gt;[?2004l[?1h=[90m~[0...</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-06-06T03:16:50.384370" elapsed="0.020090"/>
</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-06-06T03:16:50.404806" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.404546" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.404522" elapsed="0.000366"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.405343" level="INFO"> ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "a "r "t "_ "G "o "b "g "p "[K"
[?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-06-06T03:16:50.405032" elapsed="0.000370"/>
</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-06-06T03:16:50.405708" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.405469" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.405451" elapsed="0.000337"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:16:50.405823" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:16:50.408445" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:16:50.408670" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:50.407327" elapsed="0.001480"/>
</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="NOT RUN" start="2026-06-06T03:16:50.409086" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.409421" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:16:50.406670" elapsed="0.002936"/>
</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-06-06T03:16:50.406113" elapsed="0.003575"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:16:50.351761" elapsed="0.058027"/>
</kw>
<msg time="2026-06-06T03:16:50.409883" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:50.409928" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "a "r "t "_ "G "o "b "g "p "[K"
[?1l&gt;[?2004l[?1h=[90m~[0...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:50.351146" elapsed="0.058820"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:16:50.410206" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:16:50.410096" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.410076" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.410722" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.411145" elapsed="0.000028"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:16:50.411223" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:16:50.350443" elapsed="0.060891"/>
</kw>
<msg time="2026-06-06T03:16:50.411430" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:16:50.411475" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "a "r "t "_ "G "o "b "g "p "[K"
[?1l&gt;[?2004l[?1h=[90m~[0...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:16:50.345759" elapsed="0.065753"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:16:50.411868" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:16:50.411589" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:16:50.411571" elapsed="0.000377"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:16:50.345597" elapsed="0.066376"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:16:50.345419" elapsed="0.066585"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:16:50.342826" elapsed="0.069233"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:16:50.337846" elapsed="0.074268"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:50.337366" elapsed="0.074792"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:16:50.290942" elapsed="0.121270"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.412737" level="INFO">${cmd} = gobgp.cfg &gt; gobgp.log</msg>
<var>${cmd}</var>
<arg>${GOBGP_CFG} &gt; ${GOBGP_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.412380" elapsed="0.000384"/>
</kw>
<kw name="Start_GoBgp_And_Verify_Connected" owner="GoBgpLib">
<kw name="Start_GoBgp" owner="GoBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.416055" level="INFO">${start_cmd} = /home/jenkins/gobgpd -l debug -f /home/jenkins/gobgp.cfg &gt; gobgp.log</msg>
<var>${start_cmd}</var>
<arg>${GOBGP_EXECUTION_COMMAND} /home/jenkins/${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.415720" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.416486" level="INFO">/home/jenkins/gobgpd -l debug -f /home/jenkins/gobgp.cfg &gt; gobgp.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.416241" elapsed="0.000290"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:16:50.420117" level="INFO">/home/jenkins/gobgpd -l debug -f /home/jenkins/gobgp.cfg &gt; gobgp.log</msg>
<msg time="2026-06-06T03:16:50.420227" level="INFO">${output} =  /home/jenkins/gobgpd -l debug -f /home/jenkins/gobgp.cfg &gt; gobgp.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:16:50.416700" elapsed="0.003557"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.420778" level="INFO"> /home/jenkins/gobgpd -l debug -f /home/jenkins/gobgp.cfg &gt; gobgp.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.420457" elapsed="0.000374"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no gobgp is running. For verified
start use Start_GoBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:16:50.415381" elapsed="0.005518"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_GoBgps_Connection" owner="GoBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.423264" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:16:50.422806" elapsed="0.000497"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.423908" level="INFO">${exp_status_code} = [200, 201, 204]</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:16:50.423499" elapsed="0.000450"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:16:50.431380" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node078yadnmgxpoujdsm6zrbfeku6.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:16:50.431528" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:16:50.431746" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${gobgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:16:50.424153" elapsed="0.007622"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.434429" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:16:50.431963" elapsed="0.002516"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:16:50.437677" level="INFO">Argument types are:
&lt;class 'list'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:16:50.437834" level="FAIL">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:16:50.434662" elapsed="0.003360">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<arg>${session}</arg>
<arg>${gobgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:16:50.422230" elapsed="0.015965">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<kw name="Verify_GoBgps_Connection" owner="GoBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:05.442038" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:05.441037" elapsed="0.001074"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:05.443529" level="INFO">${exp_status_code} = [200, 201, 204]</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:05.442607" elapsed="0.000990"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:17:05.455432" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node078yadnmgxpoujdsm6zrbfeku6.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:05.456328" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1065'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:17:05.456475" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${gobgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:17:05.444045" elapsed="0.012461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:05.464117" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:05.456979" elapsed="0.007376"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:17:05.468628" level="INFO">Argument types are:
&lt;class 'list'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:17:05.468780" level="FAIL">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:17:05.464900" elapsed="0.004056">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<arg>${session}</arg>
<arg>${gobgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:17:05.439487" elapsed="0.029628">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<kw name="Verify_GoBgps_Connection" owner="GoBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.471929" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:20.471261" elapsed="0.000719"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.472838" level="INFO">${exp_status_code} = [200, 201, 204]</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:20.472281" elapsed="0.000598"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:17:20.484064" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node078yadnmgxpoujdsm6zrbfeku6.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:20.484407" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1065'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:17:20.484674" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${gobgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:17:20.473187" elapsed="0.011551"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.489553" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.485144" elapsed="0.004519"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.493340" level="INFO">Argument types are:
&lt;class 'list'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:17:20.493486" level="FAIL">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:17:20.489917" elapsed="0.003803">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<arg>${session}</arg>
<arg>${gobgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:17:20.470225" elapsed="0.023668">ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<msg time="2026-06-06T03:17:20.494032" level="FAIL">Keyword 'Verify_GoBgps_Connection' failed after retrying 3 times. The last error was: ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</msg>
<arg>${connection_retries}x</arg>
<arg>15s</arg>
<arg>Verify_GoBgps_Connection</arg>
<arg>${session}</arg>
<arg>${gobgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:16:50.421562" elapsed="30.072597">Keyword 'Verify_GoBgps_Connection' failed after retrying 3 times. The last error was: ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or a real number, not 'list'</status>
</kw>
<msg time="2026-06-06T03:17:20.494333" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:17:20.494396" level="INFO">${value} = Keyword 'Verify_GoBgps_Connection' failed after retrying 3 times. The last error was: ValueError: '[200, 201, 204]' cannot be converted to a floating point number: float() argument must be a string or...</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>${connection_retries}x</arg>
<arg>15s</arg>
<arg>Verify_GoBgps_Connection</arg>
<arg>${session}</arg>
<arg>${gobgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:16:50.421093" elapsed="30.073337"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_GoBgp" owner="GoBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.495675" level="INFO">[?2004l</msg>
<msg time="2026-06-06T03:17:20.495791" level="INFO">${output} = [?2004l</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:17:20.495479" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.496427" level="INFO">[?2004l</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.496061" elapsed="0.000431"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.497625" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:20.497181" elapsed="0.000627"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:20.498031" elapsed="0.000381"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:17:20.496798" elapsed="0.001716"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.502434" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:17:20.502562" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:20.498751" elapsed="0.003848"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.503220" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.502859" elapsed="0.000426"/>
</kw>
<doc>Stops the GoBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:17:20.495071" elapsed="0.008290"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.494574" elapsed="0.008826"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.494538" elapsed="0.008899"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:17:20.503703" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.503517" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.503494" elapsed="0.000303"/>
</if>
<arg>${cmd}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Starts the GoBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib. [Gobgp at times might take more time, hence the loop]</doc>
<status status="PASS" start="2026-06-06T03:16:50.413047" elapsed="30.090815"/>
</kw>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:16:50.290451" elapsed="30.213576"/>
</test>
<test id="s1-s6-t3" name="Delete_Bgp_Peer_Configuration" line="61">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:20.508546" elapsed="0.000249"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:20.508271" elapsed="0.000584"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.509933" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.509807" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.509784" elapsed="0.000223"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.514977" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.514868" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.514849" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.516078" 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-06-06T03:17:20.515680" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.516569" 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-06-06T03:17:20.516270" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:20.516654" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:17:20.516821" 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-06-06T03:17:20.515283" elapsed="0.001562"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:20.522266" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.522155" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.522135" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:20.523554" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.523443" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.523423" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:20.524125" 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-06-06T03:17:20.523799" elapsed="0.000353"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.524573" level="INFO">${current_connection_index} = 8</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-06-06T03:17:20.524315" elapsed="0.000289"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.553943" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:20.525197" elapsed="0.028874"/>
</kw>
<msg time="2026-06-06T03:17:20.554252" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:20.554299" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:20.524813" elapsed="0.029523"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.580306" level="INFO">". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:17:20.555364" elapsed="0.025052"/>
</kw>
<msg time="2026-06-06T03:17:20.580584" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:20.580630" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</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-06-06T03:17:20.554760" elapsed="0.025929"/>
</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-06-06T03:17:20.581024" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.580777" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.580754" elapsed="0.000353"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.581566" level="INFO"> ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:17:20.581253" elapsed="0.000382"/>
</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-06-06T03:17:20.581945" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.581724" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.581704" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:20.582059" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:20.584725" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:17:20.584937" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:20.583590" elapsed="0.001482"/>
</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="NOT RUN" start="2026-06-06T03:17:20.585346" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.585708" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:20.582953" elapsed="0.002940"/>
</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-06-06T03:17:20.582374" elapsed="0.003585"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:20.523137" elapsed="0.062921"/>
</kw>
<msg time="2026-06-06T03:17:20.586152" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:20.586198" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:20.522489" elapsed="0.063749"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:20.586452" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:17:20.586341" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.586320" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.586967" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.587305" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.587376" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:20.521810" elapsed="0.065675"/>
</kw>
<msg time="2026-06-06T03:17:20.587581" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:20.587626" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:20.517228" elapsed="0.070451"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.588034" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.587757" elapsed="0.000380"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.587738" elapsed="0.000427"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:20.517084" elapsed="0.071108"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:20.516904" elapsed="0.071321"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:20.514468" elapsed="0.073814"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:20.509486" elapsed="0.078854"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:20.509014" elapsed="0.079373"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:20.505312" elapsed="0.083128"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.589550" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.588672" elapsed="0.000908"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.620455" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:20.620067" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:20.621287" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:20.621011" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:20.621460" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:20.620675" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.622367" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:20.621666" elapsed="0.000729"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:20.622724" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ipv6/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:20.622906" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:20.622561" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.623348" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.623093" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.624392" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.624128" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.624894" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.624601" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.625603" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.625304" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.626388" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.626166" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.626466" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:17:20.626623" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.625832" elapsed="0.000833"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.626823" elapsed="0.000300"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:17:20.625167" elapsed="0.001999"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.627736" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.627414" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.628491" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.628278" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.628567" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.628735" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.627954" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.628910" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:17:20.627281" elapsed="0.001892"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.629731" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.629418" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.630490" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.630276" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.630566" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.630734" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.629944" elapsed="0.000815"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.630909" elapsed="0.000220"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:17:20.629285" elapsed="0.001884"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.631723" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.631411" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.632466" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.632255" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.632542" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.632708" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.631933" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.632885" elapsed="0.000221"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:17:20.631281" elapsed="0.001865"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.633881" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.633390" elapsed="0.000518"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.634675" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.634441" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.634753" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.634905" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.634122" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.635086" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:20.633259" elapsed="0.002087"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.635905" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.635589" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.636659" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.636432" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.636736" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.636886" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.636117" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.637063" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:17:20.635457" elapsed="0.001907"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.637925" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.637610" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.638696" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.638468" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.638773" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.638922" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.638153" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.639103" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:20.637477" elapsed="0.001905"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.639943" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:20.639626" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:20.640696" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.640471" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:20.640773" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:20.640922" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:20.640157" elapsed="0.000790"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:20.641101" elapsed="0.000218"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:20.639494" elapsed="0.001865"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:17:20.624973" elapsed="0.016421"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:20.641438" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:17:20.641597" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME'...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:20.623798" elapsed="0.017826"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.623472" elapsed="0.018201"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.641849" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.641699" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.623449" elapsed="0.018475"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.642809" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:20.642081" elapsed="0.000757"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:20.642888" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="PASS" start="2026-06-06T03:17:20.619436" elapsed="0.023575"/>
</kw>
<msg time="2026-06-06T03:17:20.643065" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:20.618536" elapsed="0.024577"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.643612" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.644139" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer.vanadium/gobgp_2.18.0_linux_386.tar.gz,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ipv6/bgp_peer/gobgp_2.18.0_linux_386.tar.gz.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.644703" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.644894" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.645070" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.645626" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.645479" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:20.645463" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.645866" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.646065" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.646237" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:20.645432" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.645145" elapsed="0.001171"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.646460" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.646535" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:17:20.646673" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:20.614201" elapsed="0.032500"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.647810" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.647541" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:17:20.661966" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node078yadnmgxpoujdsm6zrbfeku6.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:20.662041" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:20.662211" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:17:20.650021" elapsed="0.012227"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.647924" elapsed="0.014390"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.662685" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.662355" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.647905" elapsed="0.015011"/>
</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-06-06T03:17:20.667882" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.664447" elapsed="0.003505"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.664134" elapsed="0.003867"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.664107" elapsed="0.003930"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.671763" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.668440" elapsed="0.003389"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.668122" elapsed="0.003755"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.668098" elapsed="0.003813"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.672737" 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-06-06T03:17:20.672153" elapsed="0.000623"/>
</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-06-06T03:17:20.673212" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.672876" elapsed="0.000416"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.674020" 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-06-06T03:17:20.673552" elapsed="0.000505"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.673326" elapsed="0.000781"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.672850" elapsed="0.001287"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.674887" 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-06-06T03:17:20.674355" elapsed="0.000571"/>
</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-06-06T03:17:20.675347" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.675023" elapsed="0.000403"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.676121" 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-06-06T03:17:20.675707" elapsed="0.000450"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:20.675460" elapsed="0.000746"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.674997" elapsed="0.001238"/>
</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-06-06T03:17:20.676447" elapsed="0.000506"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:20.677586" 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-06-06T03:17:20.677184" elapsed="0.000438"/>
</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-06-06T03:17:20.677912" elapsed="0.002417"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:17:20.663506" elapsed="0.016890"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:17:20.680447" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:17:20.682740" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:17:20.646963" elapsed="0.035809"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:20.682837" elapsed="0.000029"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:17:20.589849" elapsed="0.093116"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:17:20.504469" elapsed="0.178621"/>
</test>
<test id="s1-s6-t4" name="Stop_All_Gobgps" line="74">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:20.686656" elapsed="0.000292"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:20.686363" elapsed="0.000654"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.688063" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.687949" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.687928" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.693320" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.693210" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.693191" elapsed="0.000256"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.694491" 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-06-06T03:17:20.694096" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.694998" 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-06-06T03:17:20.694698" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:20.695073" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:17:20.695230" 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-06-06T03:17:20.693712" elapsed="0.001543"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:20.700762" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.700622" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.700600" elapsed="0.000237"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:20.702082" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.701974" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.701954" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:20.702610" 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-06-06T03:17:20.702299" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.703042" level="INFO">${current_connection_index} = 8</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-06-06T03:17:20.702821" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.733713" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:20.703598" elapsed="0.030305"/>
</kw>
<msg time="2026-06-06T03:17:20.734121" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:20.734168" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:20.703258" elapsed="0.030947"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.752576" level="INFO">". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "G "o "b "g "p "s "[K"
[?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-06-06T03:17:20.734883" elapsed="0.017818"/>
</kw>
<msg time="2026-06-06T03:17:20.752868" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:20.752915" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "G "o "b "g "p "s "[K"
[?1l&gt;[?2...</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-06-06T03:17:20.734437" elapsed="0.018516"/>
</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-06-06T03:17:20.753299" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.753047" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.753019" elapsed="0.000377"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.754017" level="INFO"> ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "G "o "b "g "p "s "[K"
[?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-06-06T03:17:20.753565" elapsed="0.000519"/>
</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-06-06T03:17:20.754377" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.754154" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.754135" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:20.754494" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:20.757078" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:17:20.757287" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:20.756041" elapsed="0.001393"/>
</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="NOT RUN" start="2026-06-06T03:17:20.757905" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.758269" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:20.755379" elapsed="0.003076"/>
</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-06-06T03:17:20.754818" elapsed="0.003703"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:20.701605" elapsed="0.057015"/>
</kw>
<msg time="2026-06-06T03:17:20.758737" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:20.758782" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "G "o "b "g "p "s "[K"
[?1l&gt;[?2...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:20.700991" elapsed="0.057830"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:20.759009" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:20.758900" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.758880" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.759495" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.759871" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.759945" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:20.700264" elapsed="0.059789"/>
</kw>
<msg time="2026-06-06T03:17:20.760146" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:20.760190" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "L "l "g "r "[C "B "a "s "i "c ". "S "t "o "p "_ "A "l "l "_ "G "o "b "g "p "s "[K"
[?1l&gt;[?2...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:20.695655" elapsed="0.064574"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:20.760555" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.760305" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.760287" elapsed="0.000344"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:20.695492" elapsed="0.065181"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:20.695314" elapsed="0.065392"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:20.692832" elapsed="0.067930"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:20.687617" elapsed="0.073199"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:20.687177" elapsed="0.073683"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:20.683996" elapsed="0.076916"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.769960" level="INFO">Executing command 'cat gobgp.log'.</msg>
<msg time="2026-06-06T03:17:20.783287" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:20.783543" level="INFO">${output_log} = {"level":"info","msg":"gobgpd started","time":"2026-06-06T03:16:50Z"}
{"Topic":"Config","level":"info","msg":"Finished reading the config file","time":"2026-06-06T03:16:50Z"}
{"level":"info","msg":"Pe...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:20.769815" elapsed="0.013793"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.784755" level="INFO">{"level":"info","msg":"gobgpd started","time":"2026-06-06T03:16:50Z"}
{"Topic":"Config","level":"info","msg":"Finished reading the config file","time":"2026-06-06T03:16:50Z"}
{"level":"info","msg":"Peer 10.30.170.38 is added","time":"2026-06-06T03:16:50Z"}
{"Topic":"Peer","level":"info","msg":"Add a peer configuration for:10.30.170.38","time":"2026-06-06T03:16:50Z"}
{"Duration":0,"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"IdleHoldTimer expired","time":"2026-06-06T03:16:50Z"}
{"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"state changed","new":"BGP_FSM_ACTIVE","old":"BGP_FSM_IDLE","reason":{"Type":7,"BGPNotification":null,"Data":null},"time":"2026-06-06T03:16:50Z"}
{"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"try to connect","time":"2026-06-06T03:16:55Z"}
{"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"state changed","new":"BGP_FSM_OPENSENT","old":"BGP_FSM_ACTIVE","reason":{"Type":11,"BGPNotification":null,"Data":null},"time":"2026-06-06T03:16:55Z"}
{"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"state changed","new":"BGP_FSM_OPENCONFIRM","old":"BGP_FSM_OPENSENT","reason":{"Type":12,"BGPNotification":null,"Data":null},"time":"2026-06-06T03:16:55Z"}
{"Key":"10.30.170.38","State":"BGP_FSM_OPENCONFIRM","Topic":"Peer","level":"info","msg":"Peer Up","time":"2026-06-06T03:16:55Z"}
{"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"state changed","new":"BGP_FSM_ESTABLISHED","old":"BGP_FSM_OPENCONFIRM","reason":{"Type":13,"BGPNotification":null,"Data":null},"time":"2026-06-06T03:16:55Z"}
{"Key":"10.30.170.38","Topic":"Peer","attributes":[],"level":"debug","msg":"received update","nlri":[],"time":"2026-06-06T03:16:55Z","withdrawals":[]}
{"AddressFamily":65537,"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"EOR received","time":"2026-06-06T03:16:55Z"}
{"Key":"10.30.170.38","Topic":"Peer","attributes":[],"level":"debug","msg":"received update","nlri":[],"time":"2026-06-06T03:16:55Z","withdrawals":[]}
{"AddressFamily":65537,"Key":"10.30.170.38","Topic":"Peer","level":"debug","msg":"EOR received","time":"2026-06-06T03:16:55Z"}</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.784075" elapsed="0.000927"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:20.786254" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/gobgp.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/gobgp.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:20.785459" elapsed="0.000931"/>
</kw>
<arg>${GOBGP_LOG}</arg>
<arg>${GOBGP_LOG}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:20.769391" elapsed="0.017150"/>
</kw>
<kw name="Stop_GoBgp" owner="GoBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.788203" level="INFO">${output} =  </msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:17:20.787825" elapsed="0.000441"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.789305" level="INFO"> </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.788633" elapsed="0.000773"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.790937" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:20.790364" elapsed="0.000617"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:20.791213" elapsed="0.000305"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:17:20.789932" elapsed="0.001670"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.822758" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:17:20.822892" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:20.791836" elapsed="0.031088"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.823365" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.823096" elapsed="0.000319"/>
</kw>
<doc>Stops the GoBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:17:20.787128" elapsed="0.036347"/>
</kw>
<doc>Save exabgp logs as exaipv6.log, and stop exabgp with ctrl-c bash signal</doc>
<status status="PASS" start="2026-06-06T03:17:20.683319" elapsed="0.140270"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:17:20.824407" elapsed="0.000620"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:17:20.825270" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:17:20.825190" elapsed="0.000221"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Stop_GoBgp" owner="GoBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.826504" level="INFO">${output} = None</msg>
<msg time="2026-06-06T03:17:20.826570" level="FAIL">No open connection.</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="FAIL" start="2026-06-06T03:17:20.826249" elapsed="0.000672">No open connection.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.827358" level="INFO">None</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.827097" elapsed="0.000306"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.828166" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:20.827848" elapsed="0.000348"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.828900" level="FAIL">No open connection.</msg>
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="FAIL" start="2026-06-06T03:17:20.828350" elapsed="0.001258">No open connection.</status>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="FAIL" start="2026-06-06T03:17:20.827609" elapsed="0.002166">No open connection.</status>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.830106" level="INFO">${output} = None</msg>
<msg time="2026-06-06T03:17:20.830148" level="FAIL">No open connection.</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:17:20.829946" elapsed="0.000409">No open connection.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.830802" level="INFO">None</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.830522" elapsed="0.000325"/>
</kw>
<doc>Stops the GoBgp by sending ctrl+c</doc>
<status status="FAIL" start="2026-06-06T03:17:20.826033" elapsed="0.004931">Several failures occurred:

1) No open connection.

2) No open connection.

3) No open connection.</status>
</kw>
<arg>GoBgpLib.Stop_GoBgp</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:20.825574" elapsed="0.005442"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:17:20.824180" elapsed="0.006890"/>
</kw>
<doc>Functional test for ipv6 connection with bgp.

Copyright (c) 2020 Lumina Networks Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests simple connection between one ibgp peer (goabgp) and Odl.
Peer is configured with ipv6, and gobgp connectes to odl via ipv6.</doc>
<status status="PASS" start="2026-06-06T03:16:46.877571" elapsed="33.953531"/>
</suite>
<suite id="s1-s7" name="Bgp App Peer Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/bgp_app_peer_basic.robot">
<kw name="Setup_Everything" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.925336" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:17:20.920860" elapsed="0.004534"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:17:20.920588" elapsed="0.004879"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.930714" 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-06-06T03:17:20.926678" elapsed="0.004064"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:17:20.930954" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.930829" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.930803" elapsed="0.000224"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.931541" 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-06-06T03:17:20.931184" elapsed="0.000400"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.932126" 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-06-06T03:17:20.931765" elapsed="0.000389"/>
</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-06-06T03:17:20.932725" elapsed="0.000296"/>
</kw>
<msg time="2026-06-06T03:17:20.933120" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:20.933167" 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-06-06T03:17:20.932327" elapsed="0.000863"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.933764" 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-06-06T03:17:20.933362" elapsed="0.000428"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.934835" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:17:20.934544" elapsed="0.000318"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.935280" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:17:20.935016" elapsed="0.000290"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.935776" 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-06-06T03:17:20.935468" elapsed="0.000335"/>
</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-06-06T03:17:20.939170" elapsed="0.000216"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.939905" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:17:20.939551" elapsed="0.000388"/>
</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-06-06T03:17:20.940105" elapsed="0.000267"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.941407" 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-06-06T03:17:20.941091" elapsed="0.000344"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:17:20.941484" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:17:20.941669" 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-06-06T03:17:20.940675" elapsed="0.001021"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:17:20.942296" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5d00390&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-06-06T03:17:20.941859" elapsed="0.000578"/>
</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-06-06T03:17:20.942603" elapsed="0.000212"/>
</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-06-06T03:17:20.938581" elapsed="0.004294"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:20.938382" elapsed="0.004536"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:17:20.935860" elapsed="0.007090"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.943616" 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-06-06T03:17:20.943127" elapsed="0.000555"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.944295" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:17:20.943853" elapsed="0.000489"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.944945" 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-06-06T03:17:20.944532" elapsed="0.000513"/>
</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-06-06T03:17:20.934081" elapsed="0.011024"/>
</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-06-06T03:17:20.926319" elapsed="0.018842"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:20.945353" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:20.945230" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.945210" elapsed="0.000211"/>
</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-06-06T03:17:20.948666" 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-06-06T03:17:20.948211" elapsed="0.000484"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.949160" 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-06-06T03:17:20.948861" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:20.949230" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:20.949386" 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-06-06T03:17:20.947882" elapsed="0.001529"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:20.950518" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:17:20.950154" elapsed="0.000404"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.951492" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:17:20.951593" 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-06-06T03:17:20.951310" elapsed="0.000310"/>
</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-06-06T03:17:20.955654" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:20.954927" elapsed="0.000820"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:20.954896" elapsed="0.000893"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.956460" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:17:20.955996" elapsed="0.000771"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.957741" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:20.957040" elapsed="0.000808"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.959046" 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-06-06T03:17:20.958123" elapsed="0.000976"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:17:20.960943" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:17:20.961122" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:17:20.960552" elapsed="0.000613"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:20.961511" elapsed="0.000516"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:17:20.963302" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:17:21.536864" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:17:21 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:16:47 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:17:20.962974" elapsed="0.574250"/>
</kw>
<msg time="2026-06-06T03:17:21.537331" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:20.962387" elapsed="0.575181"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:17:20.959595" elapsed="0.578197"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.538922" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:17:21.552262" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:17:21.552524" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:17:21.552707" 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-06-06T03:17:21.538273" elapsed="0.014507"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:17:21.553243" elapsed="0.000783"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.555754" 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-06-06T03:17:21.554880" elapsed="0.001045"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:17:21.556999" elapsed="0.000120"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:21.556307" elapsed="0.000982"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.556229" elapsed="0.001146"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:17:21.558178" elapsed="0.000098"/>
</return>
<status status="PASS" start="2026-06-06T03:17:21.557711" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.557609" elapsed="0.000907"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:17:21.558608" elapsed="0.000025"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:21.563974" elapsed="0.000719"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:17:21.565092" elapsed="0.000441"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:17:21.566047" elapsed="0.000310"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:21.559363" elapsed="0.007092"/>
</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-06-06T03:17:20.953855" elapsed="0.612868"/>
</kw>
<msg time="2026-06-06T03:17:21.566810" 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-06-06T03:17:20.952900" elapsed="0.613995"/>
</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-06-06T03:17:20.952378" elapsed="0.614632"/>
</kw>
<msg time="2026-06-06T03:17:21.567067" 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-06-06T03:17:20.951805" elapsed="0.615326"/>
</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-06-06T03:17:21.570927" elapsed="0.000315"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:17:21.571412" elapsed="0.000146"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:17:21.571735" elapsed="0.000099"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:21.567558" elapsed="0.004328"/>
</kw>
<msg time="2026-06-06T03:17:21.571982" 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-06-06T03:17:20.950905" elapsed="0.621103"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.572479" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:21.572227" elapsed="0.000294"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:17:21.572566" elapsed="0.000034"/>
</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-06-06T03:17:20.949796" elapsed="0.622920"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:20.949597" elapsed="0.623222"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:20.949465" elapsed="0.623393"/>
</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-06-06T03:17:20.945666" elapsed="0.627252"/>
</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-06-06T03:17:21.573078" elapsed="0.000214"/>
</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-06-06T03:17:21.587609" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:21.587477" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.587450" elapsed="0.000249"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.588027" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:17:21.588152" 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-06-06T03:17:21.587863" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.588628" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:21.588340" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.589105" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:21.588856" elapsed="0.000294"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:21.589957" 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-06-06T03:17:21.589725" elapsed="0.000345">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:17:21.590180" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:17:21.590226" 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-06-06T03:17:21.589330" elapsed="0.000919"/>
</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-06-06T03:17:21.590555" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:21.590326" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.590306" elapsed="0.000364"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:21.591446" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:17:21.591155" elapsed="0.000324"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:17:21.591542" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:17:21.591726" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:17:21.590877" elapsed="0.000874"/>
</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-06-06T03:17:21.591915" elapsed="0.000413"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.592661" level="INFO">index=4
host=10.30.170.38
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-06-06T03:17:21.592767" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:17:21.592529" elapsed="0.000266"/>
</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-06-06T03:17:21.592952" elapsed="0.002500"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.595951" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:17:21.802236" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:17:21.595672" elapsed="0.206721"/>
</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-06-06T03:17:21.805996" elapsed="0.000377"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:17:21.806563" elapsed="0.000206"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:17:21.806923" elapsed="0.000102"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:21.803603" elapsed="0.003474"/>
</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-06-06T03:17:21.802915" elapsed="0.004209"/>
</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-06-06T03:17:21.587173" elapsed="0.220005"/>
</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-06-06T03:17:21.574181" elapsed="0.233045"/>
</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-06-06T03:17:21.573769" elapsed="0.233512"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:21.573551" elapsed="0.233771"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:17:21.573372" elapsed="0.233989"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:17:20.925870" elapsed="0.881552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:21.810172" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:21.810051" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.810028" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:21.815337" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:21.815228" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.815209" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.816590" 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-06-06T03:17:21.816018" elapsed="0.000599"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.817099" 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-06-06T03:17:21.816800" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:21.817170" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:17:21.817335" 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-06-06T03:17:21.815661" elapsed="0.001699"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:21.823314" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:21.823204" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.823184" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:21.824665" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:21.824511" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.824492" elapsed="0.000246"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:21.825228" 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-06-06T03:17:21.824887" elapsed="0.000368"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.825666" 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-06-06T03:17:21.825420" elapsed="0.000275"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.862400" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:21.826404" elapsed="0.036267"/>
</kw>
<msg time="2026-06-06T03:17:21.862892" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:21.862942" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:17:21.825872" elapsed="0.037108"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.933347" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "b "g "p "_ "a "p "p "[78C_ "[A[78Cp
 "e "e "r "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:17:21.864733" elapsed="0.068881"/>
</kw>
<msg time="2026-06-06T03:17:21.933950" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:21.933999" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:17:21.863984" elapsed="0.070054"/>
</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-06-06T03:17:21.934566" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:21.934168" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.934126" elapsed="0.000649"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:21.935422" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "b "g "p "_ "a "p "p "[78C_ "[A[78Cp
 "e "e "r "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:17:21.934937" elapsed="0.000573"/>
</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-06-06T03:17:21.935874" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:21.935580" elapsed="0.000444"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.935561" elapsed="0.000489"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:21.936093" elapsed="0.000057"/>
</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-06-06T03:17:21.938664" elapsed="0.000462"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:17:21.939480" elapsed="0.000380"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:17:21.940198" elapsed="0.000243"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:21.937837" elapsed="0.002694"/>
</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-06-06T03:17:21.936469" elapsed="0.004322"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:21.824222" elapsed="0.116676"/>
</kw>
<msg time="2026-06-06T03:17:21.940997" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:21.941044" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:21.823542" elapsed="0.117539"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:21.941274" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:21.941165" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.941146" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:21.941803" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:21.942161" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:21.942234" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:21.822904" elapsed="0.119445"/>
</kw>
<msg time="2026-06-06T03:17:21.942449" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:21.942494" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:21.817754" elapsed="0.124781"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:21.942886" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:21.942614" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:21.942596" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:21.817591" elapsed="0.125455"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:21.817415" elapsed="0.125672"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:21.814918" elapsed="0.128230"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:17:21.808052" elapsed="0.135156"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:21.807583" elapsed="0.135671"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:17:20.920228" elapsed="1.023081"/>
</kw>
<kw name="Set Default Configuration" owner="SSHLibrary">
<arg>prompt=${TOOLS_SYSTEM_PROMPT}</arg>
<doc>Update the default `configuration`.</doc>
<status status="PASS" start="2026-06-06T03:17:21.943465" elapsed="0.000250"/>
</kw>
<kw name="Open_BGP_Peer_Console">
<kw name="Open Connection" owner="SSHLibrary">
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>alias=bgp_peer_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:17:21.944079" elapsed="0.000237"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:17:21.946350" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:17:21.946429" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:17:21.946055" elapsed="0.000398"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:21.946619" elapsed="0.000337"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:17:21.947865" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:17:22.270637" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:16:48 UTC 2026

  System load:  0.0                Processes:             108
  Usage of /:   19.6% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:16:49 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:17:21.947494" elapsed="0.323319"/>
</kw>
<msg time="2026-06-06T03:17:22.270899" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:21.947130" elapsed="0.323855"/>
</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-06-06T03:17:21.945366" elapsed="0.325736"/>
</kw>
<msg time="2026-06-06T03:17:22.271158" 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-06-06T03:17:21.944966" elapsed="0.326240"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:17:21.944519" elapsed="0.326769"/>
</kw>
<doc>Create a session for BGP peer.</doc>
<status status="PASS" start="2026-06-06T03:17:21.943859" elapsed="0.327482"/>
</kw>
<kw name="Require_Python" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.272823" level="INFO">Executing command 'python3 --help'.</msg>
<msg time="2026-06-06T03:17:22.285126" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:22.285425" level="INFO">${stdout} = usage: python3 [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_ins...</msg>
<msg time="2026-06-06T03:17:22.285529" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:17:22.285620" 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-06-06T03:17:22.272582" elapsed="0.013129"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.287862" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:17:22.287197" elapsed="0.000771"/>
</kw>
<msg time="2026-06-06T03:17:22.288188" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:17:22.288287" 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-06-06T03:17:22.286231" elapsed="0.002108"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.289772" 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-06-06T03:17:22.288762" elapsed="0.001071"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.290991" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.290022" elapsed="0.001238"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.289971" elapsed="0.001356"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:17:22.291808" elapsed="0.000103"/>
</return>
<status status="PASS" start="2026-06-06T03:17:22.291494" elapsed="0.000512"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.291422" elapsed="0.000641"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.292285" elapsed="0.000041"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:22.292195" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:22.292159" elapsed="0.000306"/>
</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-06-06T03:17:22.292869" elapsed="0.000052"/>
</kw>
<msg time="2026-06-06T03:17:22.293216" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>python3 --help</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-06-06T03:17:22.272178" elapsed="0.021096"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:17:22.293674" elapsed="0.000061"/>
</return>
<status status="PASS" start="2026-06-06T03:17:22.293430" elapsed="0.000372"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.293391" elapsed="0.000468"/>
</if>
<kw name="Fatal Error" owner="BuiltIn">
<arg>Python 3 is not installed!</arg>
<doc>Stops the whole test execution.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.294282" elapsed="0.000065"/>
</kw>
<doc>Verify current SSH connection leads to machine with python working. Fatal fail otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:22.271722" elapsed="0.022783"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.296877" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:17:22.361617" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:22.362102" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:17:22.362231" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:17:22.362337" 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-06-06T03:17:22.296276" elapsed="0.066116"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.364526" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:17:22.363864" elapsed="0.000825"/>
</kw>
<msg time="2026-06-06T03:17:22.364917" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:17:22.365016" 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-06-06T03:17:22.362942" elapsed="0.002124"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.366592" 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-06-06T03:17:22.365457" elapsed="0.001228"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.367742" elapsed="0.000060"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.366884" elapsed="0.001010"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.366833" elapsed="0.001121"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:17:22.368304" elapsed="0.000075"/>
</return>
<status status="PASS" start="2026-06-06T03:17:22.368079" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.368043" elapsed="0.000467"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.368749" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:22.368636" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:22.368601" elapsed="0.000288"/>
</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-06-06T03:17:22.369217" elapsed="0.000047"/>
</kw>
<msg time="2026-06-06T03:17:22.369556" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:17:22.295751" elapsed="0.073861"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:17:22.370124" elapsed="0.000046"/>
</return>
<status status="PASS" start="2026-06-06T03:17:22.369868" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.369814" elapsed="0.000411"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.370382" elapsed="0.000023"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:17:22.295113" elapsed="0.075354"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.406748" level="INFO">[chan 3] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:17:22.421588" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:17:22.370623" elapsed="0.051124"/>
</kw>
<kw name="Open_BGP_Aplication_Peer_Console">
<kw name="Open Connection" owner="SSHLibrary">
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>alias=bgp_app_peer_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.422484" elapsed="0.000400"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:17:22.425445" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:17:22.425604" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:17:22.425042" elapsed="0.000629"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:22.425954" elapsed="0.000401"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.427232" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:17:22.746393" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:16:48 UTC 2026

  System load:  0.0                Processes:             108
  Usage of /:   19.6% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:17:22 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:17:22.426910" elapsed="0.319762"/>
</kw>
<msg time="2026-06-06T03:17:22.746843" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:22.426531" elapsed="0.320484"/>
</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-06-06T03:17:22.424391" elapsed="0.322929"/>
</kw>
<msg time="2026-06-06T03:17:22.747449" 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-06-06T03:17:22.423778" elapsed="0.323816"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:17:22.423268" elapsed="0.324595"/>
</kw>
<doc>Create a session for BGP peer.</doc>
<status status="PASS" start="2026-06-06T03:17:22.422074" elapsed="0.325913"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.756223" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:17:22.764511" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/bgp_app_peer.py' -&gt; '/home/jenkins//bgp_app_peer.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/bgp_app_peer.py</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:17:22.748503" elapsed="0.016219"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.774697" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/ipv4-routes-template.xml.oxygen' -&gt; '/home/jenkins//ipv4-routes-template.xml.oxygen'</msg>
<msg time="2026-06-06T03:17:22.774792" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/ipv4-routes-template.xml' -&gt; '/home/jenkins//ipv4-routes-template.xml'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/ipv4-routes-template.xml*</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:17:22.765186" elapsed="0.009692"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:17:22.775769" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5829110&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:17:22.775226" elapsed="0.000783"/>
</kw>
<doc>Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
put Python tool to mininet machine, setup imported resources.</doc>
<status status="PASS" start="2026-06-06T03:17:20.919869" elapsed="1.856302"/>
</kw>
<test id="s1-s7-t1" name="Reconfigure_ODL_To_Accept_BGP_Peer_Connection" line="101">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:22.781431" elapsed="0.000395"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:22.781010" elapsed="0.000908"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.783531" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:22.783335" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.783298" elapsed="0.000365"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.790802" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:22.790664" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.790626" elapsed="0.000257"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.792128" 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-06-06T03:17:22.791637" elapsed="0.000520"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.792793" 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-06-06T03:17:22.792458" elapsed="0.000361"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:22.792866" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:17:22.793034" 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-06-06T03:17:22.791167" elapsed="0.001891"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:22.799070" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:22.798937" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.798911" elapsed="0.000237"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:22.800470" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:22.800359" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.800339" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:22.801047" 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-06-06T03:17:22.800719" elapsed="0.000356"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.801465" level="INFO">${current_connection_index} = 8</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-06-06T03:17:22.801243" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.832885" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:22.802037" elapsed="0.031194"/>
</kw>
<msg time="2026-06-06T03:17:22.833704" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:22.833816" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:22.801689" elapsed="0.032211"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:22.864980" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "B "G "P "_ "P "e "e "r "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:17:22.835390" elapsed="0.029729"/>
</kw>
<msg time="2026-06-06T03:17:22.865303" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:22.865350" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L...</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-06-06T03:17:22.834391" elapsed="0.030996"/>
</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-06-06T03:17:22.865811" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.865491" elapsed="0.000379"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.865460" elapsed="0.000437"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.866403" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "B "G "P "_ "P "e "e "r "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:17:22.866047" elapsed="0.000436"/>
</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-06-06T03:17:22.866863" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.866552" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.866532" elapsed="0.000414"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:22.866986" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:22.869814" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:17:22.870036" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:22.868623" elapsed="0.001552"/>
</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="NOT RUN" start="2026-06-06T03:17:22.870462" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.870838" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:22.867946" elapsed="0.003145"/>
</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-06-06T03:17:22.867321" elapsed="0.003842"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:22.800045" elapsed="0.071220"/>
</kw>
<msg time="2026-06-06T03:17:22.871363" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:22.871409" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:22.799323" elapsed="0.072124"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:22.871731" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:17:22.871526" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.871506" elapsed="0.000322"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.872247" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.872592" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.872697" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:22.798482" elapsed="0.074330"/>
</kw>
<msg time="2026-06-06T03:17:22.872910" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:22.872955" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:22.793459" elapsed="0.079532"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.873331" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.873069" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.873051" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:22.793307" elapsed="0.080126"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:22.793121" elapsed="0.080347"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:22.790201" elapsed="0.083370"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:22.782876" elapsed="0.090754"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:22.782159" elapsed="0.091546"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:22.777427" elapsed="0.096334"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.874814" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=exam...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.873968" elapsed="0.000876"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.914340" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:22.913821" elapsed="0.000562"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:22.915377" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:22.915048" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:22.915613" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:22.914618" elapsed="0.001046"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.916463" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:22.915980" elapsed="0.000517"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:22.916910" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:22.917139" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:22.916727" elapsed="0.000447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.917722" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:22.917387" elapsed="0.000394"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.919054" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:22.918738" elapsed="0.000367"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.919598" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.919281" elapsed="0.000344"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.920353" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.920046" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.921154" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.920920" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.921241" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:17:22.921409" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.920575" elapsed="0.000860"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.921598" elapsed="0.000289"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:17:22.919902" elapsed="0.002028"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.922492" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.922184" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.923465" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.923226" elapsed="0.000268"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.923545" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:22.923720" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.922728" elapsed="0.001019"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.923906" elapsed="0.000230"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:17:22.922047" elapsed="0.002131"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.924760" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.924430" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.925516" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.925300" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.925594" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:22.925775" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.924976" elapsed="0.000826"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.925959" elapsed="0.000226"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:17:22.924293" elapsed="0.001935"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.926796" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.926475" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.927623" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.927382" elapsed="0.000287"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.927721" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:22.927877" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.927013" elapsed="0.000889"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.928060" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:17:22.926340" elapsed="0.001987"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.928896" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.928574" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.929666" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.929436" elapsed="0.000258"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.929754" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:17:22.929921" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.929113" elapsed="0.000834"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.930106" elapsed="0.000231"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:17:22.928440" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.930955" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.930628" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.931780" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.931539" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.931861" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:22.932015" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.931176" elapsed="0.000865"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.932197" elapsed="0.000227"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:17:22.930492" elapsed="0.001976"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.933046" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.932736" elapsed="0.000335"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.933843" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.933588" elapsed="0.000287"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.933931" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:22.934087" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.933263" elapsed="0.000850"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.934274" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:22.932583" elapsed="0.001957"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.935578" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.934814" elapsed="0.000795"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.936401" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.936190" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.936478" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:22.936630" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.935861" elapsed="0.000809"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.936827" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:17:22.934677" elapsed="0.002414"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.937655" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.937342" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.938457" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.938190" elapsed="0.000294"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.938535" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:22.938701" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.937873" elapsed="0.000853"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.938883" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:22.937208" elapsed="0.001940"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.939783" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:22.939428" elapsed="0.000382"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:22.940524" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.940317" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:22.940600" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:22.940767" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:22.940001" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:22.940947" elapsed="0.000220"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:22.939264" elapsed="0.001944"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:17:22.919705" elapsed="0.021538"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:22.941288" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:17:22.941451" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': ...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:22.918317" elapsed="0.023160"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:22.917883" elapsed="0.023626"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.941718" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.941539" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:22.917851" elapsed="0.023946"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:22.942774" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:22.941948" elapsed="0.000855"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:22.942854" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:22.912973" elapsed="0.030007"/>
</kw>
<msg time="2026-06-06T03:17:22.943038" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:22.897917" elapsed="0.045174"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.956019" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.968823" elapsed="0.000051"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.982022" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.982344" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.982543" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.983009" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:22.982848" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:22.982829" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.983287" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.983465" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.983634" elapsed="0.000037"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:22.982785" elapsed="0.000921"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.982636" elapsed="0.001099"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:22.983890" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:22.983972" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:17:22.984141" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:22.893280" elapsed="0.090895"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.012023" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.011565" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.012905" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.012609" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.013086" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.012245" elapsed="0.000866"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.013691" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.013283" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.014034" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:23.014215" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:23.013886" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.014678" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.014409" elapsed="0.000404"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:23.015332" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.014901" elapsed="0.000498"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.015908" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': ...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.015581" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.015428" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.014874" elapsed="0.001120"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.017037" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.016167" elapsed="0.000901"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.017124" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:23.010771" elapsed="0.006490"/>
</kw>
<msg time="2026-06-06T03:17:23.017322" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:22.997526" elapsed="0.019846"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.030408" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.043408" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.056677" elapsed="0.000056"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.056989" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.057188" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.057681" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.057503" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:23.057484" elapsed="0.000286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.057921" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.058093" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.058261" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:23.057437" elapsed="0.000876"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.057283" elapsed="0.001059"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.058613" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.058715" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:17:23.058929" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:22.994748" elapsed="0.064215"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.060553" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.060245" elapsed="0.000390">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.060750" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.059813" elapsed="0.000963"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.061126" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.060851" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.061710" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.061394" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.061208" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.060830" elapsed="0.000963"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.064345" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.061949" elapsed="0.002422"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:23.064426" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:17:23.064591" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:23.059394" elapsed="0.005221"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.066062" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.065801" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.066512" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.066273" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.067006" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.066740" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.067443" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.067204" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:23.068324" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:17:23.068119" elapsed="0.000231"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:17:23.068699" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:17:23.068505" elapsed="0.000220"/>
</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-06-06T03:17:23.068936" elapsed="0.000223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.069570" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.069321" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:17:23.069674" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:17:23.069871" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:17:23.067711" elapsed="0.002191"/>
</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-06-06T03:17:23.089261" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '1079', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:17:23.089510" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:17:23 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:23.090168" 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-06-06T03:17:23.072428" elapsed="0.017826"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.069978" elapsed="0.020537"/>
</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-06-06T03:17:23.091249" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.090614" elapsed="0.000778"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.069958" elapsed="0.021481"/>
</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-06-06T03:17:23.099403" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.093590" elapsed="0.005963"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.093106" elapsed="0.006619"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.093065" elapsed="0.006738"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.105193" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.100629" elapsed="0.004630"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.099977" elapsed="0.005331"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.099923" elapsed="0.005420"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.106239" 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-06-06T03:17:23.105626" elapsed="0.000652"/>
</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-06-06T03:17:23.106766" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.106381" elapsed="0.000471"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.107725" 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-06-06T03:17:23.107126" elapsed="0.000640"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.106889" elapsed="0.000928"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.106353" elapsed="0.001494"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.108594" 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-06-06T03:17:23.108077" elapsed="0.000555"/>
</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-06-06T03:17:23.109093" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.108756" elapsed="0.000513"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.109991" 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-06-06T03:17:23.109539" elapsed="0.000490"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.109305" elapsed="0.000774"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.108728" elapsed="0.001382"/>
</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-06-06T03:17:23.110338" elapsed="0.000535"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:23.111543" 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-06-06T03:17:23.111118" elapsed="0.000463"/>
</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-06-06T03:17:23.111828" elapsed="0.003328"/>
</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-06-06T03:17:23.092310" elapsed="0.022924"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:17:23.115422" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:17:23.115306" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.115286" elapsed="0.000236"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:17:23.115695" elapsed="0.000025"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.115767" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:17:23.118075" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:17:23.064979" elapsed="0.053123"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.118171" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:23.118331" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:22.881684" elapsed="0.236672"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.118759" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.118456" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.118438" elapsed="0.000417"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.118888" elapsed="0.000025"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:17:22.875130" elapsed="0.243883"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:23.119674" elapsed="0.000250"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:23.119312" elapsed="0.000676"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:22.776272" elapsed="0.343755"/>
</test>
<test id="s1-s7-t2" name="Reconfigure_ODL_To_Accept_BGP_Application_Peer" line="120">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:23.123564" elapsed="0.000225"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:23.123296" elapsed="0.000549"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.124892" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.124781" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.124762" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.130017" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.129910" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.129891" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.131116" 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-06-06T03:17:23.130727" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.131668" 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-06-06T03:17:23.131349" elapsed="0.000347"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:23.131742" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:23.131897" 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-06-06T03:17:23.130320" elapsed="0.001602"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:23.137485" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.137376" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.137356" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:23.138810" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.138696" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.138672" elapsed="0.000211"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:23.139373" 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-06-06T03:17:23.139065" elapsed="0.000336"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.139808" level="INFO">${current_connection_index} = 8</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-06-06T03:17:23.139564" elapsed="0.000270"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.172097" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:23.140348" elapsed="0.031894"/>
</kw>
<msg time="2026-06-06T03:17:23.172430" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:23.172477" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:23.139998" elapsed="0.032518"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.204041" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "[K"
[?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-06-06T03:17:23.173141" elapsed="0.031032"/>
</kw>
<msg time="2026-06-06T03:17:23.204347" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:23.204393" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L...</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-06-06T03:17:23.172747" elapsed="0.031684"/>
</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-06-06T03:17:23.204831" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.204532" elapsed="0.000357"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.204501" elapsed="0.000416"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.205404" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "[K"
[?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-06-06T03:17:23.205077" elapsed="0.000404"/>
</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-06-06T03:17:23.205790" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.205549" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.205531" elapsed="0.000338"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:23.205907" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:23.208664" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:17:23.208878" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.207506" elapsed="0.001507"/>
</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="NOT RUN" start="2026-06-06T03:17:23.209323" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.209748" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:23.206843" elapsed="0.003093"/>
</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-06-06T03:17:23.206234" elapsed="0.003768"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:23.138331" elapsed="0.071770"/>
</kw>
<msg time="2026-06-06T03:17:23.210199" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:23.210243" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:23.137722" elapsed="0.072559"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:23.210497" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:23.210385" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.210365" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.211020" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.211367" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.211438" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:23.137035" elapsed="0.074510"/>
</kw>
<msg time="2026-06-06T03:17:23.211656" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:23.211703" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:23.132317" elapsed="0.079424"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.212071" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.211818" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.211800" elapsed="0.000348"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:23.132169" elapsed="0.080003"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:23.131985" elapsed="0.080222"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:23.129533" elapsed="0.082731"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:23.124457" elapsed="0.087863"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:23.124011" elapsed="0.088354"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:23.120820" elapsed="0.091598"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.213273" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer-app | RIB_INSTANCE_NAME=example-bgp-rib | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=${BGP_PEER_APP_NAME}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>IP=${BGP_APP_PEER_ID}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.212620" elapsed="0.000682"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.248330" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.247940" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.249152" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.248886" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.249325" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.248530" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.249990" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.249518" elapsed="0.000500"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.250342" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:23.250510" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:23.250199" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.250971" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.250714" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.252007" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.251745" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.252486" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.252220" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.253209" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.252908" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:23.253990" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.253765" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:23.254069" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:23.254246" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:23.253428" elapsed="0.000843"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.254429" elapsed="0.000259"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:17:23.252768" elapsed="0.001962"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.255276" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.254981" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:23.256055" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.255845" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:23.256133" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:17:23.256282" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:23.255506" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.256460" elapsed="0.000247"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:17:23.254846" elapsed="0.001903"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.257465" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.256996" elapsed="0.000500"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:23.258314" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.258063" elapsed="0.000280"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:23.258394" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:23.258548" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:23.257722" elapsed="0.000850"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.258770" elapsed="0.000230"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:23.256862" elapsed="0.002181"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.259586" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.259291" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:23.260349" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.260141" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:23.260463" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:23.260616" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:23.259823" elapsed="0.000831"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.260857" elapsed="0.000267"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:17:23.259156" elapsed="0.002012"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.261902" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.261582" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:17:23.262877" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.262609" elapsed="0.000294"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:17:23.262953" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:23.263103" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:17:23.262119" elapsed="0.001008"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.263287" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:17:23.261444" elapsed="0.002105"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:17:23.252568" elapsed="0.011027"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:23.263665" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:23.263829" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:23.251401" elapsed="0.012455"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.251087" elapsed="0.012801"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.264064" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.263913" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.251067" elapsed="0.013074"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.264951" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.264288" elapsed="0.000692"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.265031" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:23.247293" elapsed="0.017861"/>
</kw>
<msg time="2026-06-06T03:17:23.265208" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.233753" elapsed="0.031503"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.277917" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.291111" elapsed="0.000078"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.305782" elapsed="0.000088"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.306385" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.306694" elapsed="0.000032"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.307342" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.307116" elapsed="0.000307"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:23.307089" elapsed="0.000374"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.307689" elapsed="0.000031"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.307934" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.308170" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:23.307029" elapsed="0.001214"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.306824" elapsed="0.001458"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.308494" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.308608" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:17:23.308873" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:23.229450" elapsed="0.079465"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.337263" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.336865" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.338119" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.337821" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.338300" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.337464" elapsed="0.000861"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.338903" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.338495" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.339247" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:23.339425" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:23.339096" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.339883" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.339616" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:23.340368" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.340055" elapsed="0.000372"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.340921" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.340603" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.340453" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.340034" elapsed="0.000973"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.341818" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.341158" elapsed="0.000710"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.341923" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:23.336201" elapsed="0.005860"/>
</kw>
<msg time="2026-06-06T03:17:23.342117" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.323186" elapsed="0.018982"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.354938" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.368332" elapsed="0.000063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.381418" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.381700" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.381905" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.382372" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.382211" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:23.382190" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.382623" elapsed="0.000038"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.382816" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.382987" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:23.382144" elapsed="0.000896"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.382011" elapsed="0.001058"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.383227" elapsed="0.000098"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.383389" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:17:23.383566" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:23.320343" elapsed="0.063256"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.385153" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.384827" elapsed="0.000408">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.385342" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.384367" elapsed="0.001002"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.385797" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.385443" elapsed="0.000417"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.386427" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.386076" elapsed="0.000381"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.385886" elapsed="0.000627"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.385423" elapsed="0.001116"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.389020" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.386751" elapsed="0.002296"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:23.389100" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:17:23.389268" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:23.383988" elapsed="0.005304"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.390813" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.390508" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.391269" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.391024" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.391817" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.391479" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.392345" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.392037" elapsed="0.000356"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:23.393292" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:17:23.393073" elapsed="0.000246"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:17:23.393691" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:17:23.393477" elapsed="0.000242"/>
</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-06-06T03:17:23.393875" elapsed="0.000219"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.394518" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.394261" elapsed="0.000302"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:17:23.394607" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:17:23.394835" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:17:23.392635" elapsed="0.002234"/>
</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-06-06T03:17:23.410408" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:17:23.410496" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:23.410684" 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-06-06T03:17:23.398704" elapsed="0.012020"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.395022" elapsed="0.015769"/>
</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-06-06T03:17:23.411126" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.410831" elapsed="0.000416"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.394998" elapsed="0.016297"/>
</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-06-06T03:17:23.416303" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.412780" elapsed="0.003586"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.412410" elapsed="0.004022"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.412383" elapsed="0.004357"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.423213" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.417773" elapsed="0.005508"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.417013" elapsed="0.006323"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.416938" elapsed="0.006433"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.424244" 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-06-06T03:17:23.423632" elapsed="0.000653"/>
</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-06-06T03:17:23.424844" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.424431" elapsed="0.000502"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.425685" 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-06-06T03:17:23.425208" elapsed="0.000517"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.424968" elapsed="0.000807"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.424398" elapsed="0.001408"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.426570" 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-06-06T03:17:23.426037" elapsed="0.000596"/>
</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-06-06T03:17:23.427247" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.426797" elapsed="0.000553"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.428156" 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-06-06T03:17:23.427695" elapsed="0.000504"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.427386" elapsed="0.000865"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.426763" elapsed="0.001519"/>
</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-06-06T03:17:23.428542" elapsed="0.000536"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:23.429865" 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-06-06T03:17:23.429328" elapsed="0.000577"/>
</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-06-06T03:17:23.430176" elapsed="0.003738"/>
</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-06-06T03:17:23.411888" elapsed="0.022123"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:17:23.434252" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:17:23.434110" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.434083" elapsed="0.000329"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:17:23.434571" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.434657" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:17:23.437105" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:17:23.389677" elapsed="0.047464"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.437228" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:23.437390" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:23.218153" elapsed="0.219263"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.437828" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.437535" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.437516" elapsed="0.000451"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.438010" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_application_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:17:23.213567" elapsed="0.224575"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:23.438815" elapsed="0.000276"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:23.438441" elapsed="0.000719"/>
</kw>
<doc>Configure BGP application peer module.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:23.120270" elapsed="0.318931"/>
</test>
<test id="s1-s7-t3" name="Check_For_Empty_Example-IPv4-Topology" line="134">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:23.442980" elapsed="0.000222"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:23.442703" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.444404" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.444274" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.444251" elapsed="0.000224"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.449757" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.449626" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.449607" elapsed="0.000222"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.450912" 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-06-06T03:17:23.450500" elapsed="0.000440"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.451425" 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-06-06T03:17:23.451106" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:23.451519" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:17:23.451722" 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-06-06T03:17:23.450079" elapsed="0.001678"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:23.457556" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.457437" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.457383" elapsed="0.000243"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:23.458987" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.458843" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.458818" elapsed="0.000262"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:23.459558" 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-06-06T03:17:23.459248" elapsed="0.000385"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.460055" level="INFO">${current_connection_index} = 8</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-06-06T03:17:23.459825" elapsed="0.000257"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.490978" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:23.460604" elapsed="0.030551"/>
</kw>
<msg time="2026-06-06T03:17:23.491373" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:23.491428" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:23.460249" elapsed="0.031219"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.522200" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:17:23.492137" elapsed="0.030251"/>
</kw>
<msg time="2026-06-06T03:17:23.522623" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:23.522723" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y...</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-06-06T03:17:23.491739" elapsed="0.031039"/>
</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-06-06T03:17:23.523262" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.522919" elapsed="0.000405"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.522885" elapsed="0.000465"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.523860" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:17:23.523505" elapsed="0.000433"/>
</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-06-06T03:17:23.524247" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.524009" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.523989" elapsed="0.000359"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:23.524387" elapsed="0.000045"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:23.527284" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:17:23.527496" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.526066" elapsed="0.001562"/>
</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="NOT RUN" start="2026-06-06T03:17:23.527932" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.528270" elapsed="0.000073"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:23.525386" elapsed="0.003068"/>
</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-06-06T03:17:23.524773" elapsed="0.003746"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:23.458433" elapsed="0.070184"/>
</kw>
<msg time="2026-06-06T03:17:23.528730" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:23.528775" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:23.457806" elapsed="0.071010"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:23.529003" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:23.528894" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.528875" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.529559" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.529933" elapsed="0.000095"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.530081" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:23.457051" elapsed="0.073142"/>
</kw>
<msg time="2026-06-06T03:17:23.530288" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:23.530332" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:23.452165" elapsed="0.078204"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.530733" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.530446" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.530428" elapsed="0.000387"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:23.452014" elapsed="0.078826"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:23.451826" elapsed="0.079047"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:23.449233" elapsed="0.081697"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:23.443934" elapsed="0.087054"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:23.443422" elapsed="0.087612"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:23.440176" elapsed="0.090913"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.585395" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.584976" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.586441" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.585983" elapsed="0.000539">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.586619" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.585615" elapsed="0.001069"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.587251" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.586861" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.587591" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:23.587798" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:23.587445" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.588293" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.587992" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.589749" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.589254" elapsed="0.000560"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.590374" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:23.589995" elapsed="0.000407"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.590874" elapsed="0.000048"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.591622" elapsed="0.000079"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.592000" elapsed="0.000047"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:17:23.590628" elapsed="0.001621"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.590460" elapsed="0.001861"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:23.592377" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:17:23.592568" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:23.588818" elapsed="0.003777"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.588428" elapsed="0.004200"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.593000" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.592699" elapsed="0.000392"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.588402" elapsed="0.004724"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.594099" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.593359" elapsed="0.000782"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.594215" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:23.584280" elapsed="0.010285"/>
</kw>
<msg time="2026-06-06T03:17:23.594696" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.571275" elapsed="0.023510"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.609116" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.624810" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.637948" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.638198" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.638397" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.638908" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.638731" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:23.638710" elapsed="0.000316"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.639249" elapsed="0.000032"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.639459" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.639635" elapsed="0.000038"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:23.638661" elapsed="0.001049"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.638512" elapsed="0.001227"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.639894" elapsed="0.000101"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.640061" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:17:23.640220" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:23.566772" elapsed="0.073477"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.641921" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.641561" elapsed="0.000443">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.642103" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.641120" elapsed="0.001008"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.642540" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.642203" elapsed="0.000400"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.643247" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.642857" elapsed="0.000418"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.642628" elapsed="0.000684"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.642182" elapsed="0.001152"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.645746" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.643494" elapsed="0.002279"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:23.645825" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:23.645980" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:23.640606" elapsed="0.005400"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.647232" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.646997" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.647389" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.646657" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:17:23.647621" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:17:23.647485" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.647465" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.647888" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.648062" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.648127" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:17:23.651234" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:23.646314" elapsed="0.004964"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.653493" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.653117" elapsed="0.000445"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.654211" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.653818" elapsed="0.000462"/>
</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-06-06T03:17:23.664426" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:23.664695" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:17:23.664802" 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-06-06T03:17:23.657844" elapsed="0.006986"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.654378" elapsed="0.010497"/>
</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-06-06T03:17:23.665101" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.664903" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.654350" elapsed="0.010859"/>
</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-06-06T03:17:23.668896" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.666341" elapsed="0.002605"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.666088" elapsed="0.002893"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.666069" elapsed="0.002937"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.672864" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.669361" elapsed="0.003570"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.669066" elapsed="0.003915"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.669047" elapsed="0.003968"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.673893" 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-06-06T03:17:23.673303" elapsed="0.000630"/>
</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-06-06T03:17:23.674377" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.674036" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.675174" 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-06-06T03:17:23.674747" elapsed="0.000465"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.674491" elapsed="0.000775"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.674009" elapsed="0.001287"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.676079" 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-06-06T03:17:23.675527" elapsed="0.000590"/>
</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-06-06T03:17:23.676660" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.676218" elapsed="0.000529"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.677426" 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-06-06T03:17:23.677011" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.676780" elapsed="0.000730"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.676191" elapsed="0.001348"/>
</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-06-06T03:17:23.677775" elapsed="0.000491"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:23.678939" 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-06-06T03:17:23.678500" elapsed="0.000478"/>
</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-06-06T03:17:23.679199" elapsed="0.003134"/>
</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-06-06T03:17:23.665621" elapsed="0.016778"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.682580" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.682470" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.682450" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:23.685537" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:17:23.682818" elapsed="0.002748"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:17:23.685617" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:17:23.685799" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:17:23.651800" elapsed="0.034062"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.685930" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:17:23.686086" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:23.543126" elapsed="0.142987"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.720935" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.719708" elapsed="0.001268"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.723271" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:23.722627" elapsed="0.000807">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:23.723582" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:23.721210" elapsed="0.002398"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.724670" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:23.723812" elapsed="0.000888"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:23.725119" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:23.725495" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:23.724881" elapsed="0.000643"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.726195" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.725705" elapsed="0.000562"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:23.727046" elapsed="0.000083"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.726352" elapsed="0.000865"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.728069" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.727423" elapsed="0.000687"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.727245" elapsed="0.000958"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.726327" elapsed="0.001900"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.729321" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.728411" elapsed="0.000940"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.729403" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:23.718564" elapsed="0.010967"/>
</kw>
<msg time="2026-06-06T03:17:23.729599" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.703282" elapsed="0.026382"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.742724" elapsed="0.000073"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.755269" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.767792" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.767991" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.768171" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.768594" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.768446" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:23.768431" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.768835" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.769002" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.769168" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:23.768399" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.768290" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.769397" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.769472" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:23.769589" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:23.700293" elapsed="0.069323"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.769813" elapsed="0.002220"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:23.773147" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.772817" elapsed="0.000359"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:23.773671" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:23.773336" elapsed="0.000366"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:17:23.773861" elapsed="0.000369"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:17:23.772381" elapsed="0.001909"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.772114" elapsed="0.002210"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.774501" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.774349" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.772095" elapsed="0.002482"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:17:23.687281" elapsed="0.087343"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:17:23.686451" elapsed="0.088266"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.686201" elapsed="0.088563"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.686181" elapsed="0.088608"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:23.774823" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:17:23.536497" elapsed="0.238470"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.532196" elapsed="0.242836"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:23.531624" elapsed="0.243456"/>
</kw>
<arg>empty_topology</arg>
<arg>timeout=180s</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:23.531241" elapsed="0.243900"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:23.775745" elapsed="0.000243"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:23.775425" elapsed="0.000626"/>
</kw>
<doc>Sanity check example-ipv4-topology is up but empty.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:23.439572" elapsed="0.336519"/>
</test>
<test id="s1-s7-t4" name="TC1_BGP_Application_Peer_Post_3_Initial_Routes" line="139">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:23.779594" elapsed="0.000232"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:23.779329" elapsed="0.000566"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.780917" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.780807" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.780788" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.786236" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.786128" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.786110" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.787322" 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-06-06T03:17:23.786933" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.787836" 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-06-06T03:17:23.787512" elapsed="0.000349"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:23.787906" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:17:23.788058" 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-06-06T03:17:23.786535" elapsed="0.001547"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:23.793610" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.793501" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.793482" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:23.794850" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:23.794743" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.794724" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:23.795366" 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-06-06T03:17:23.795064" elapsed="0.000391"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.795866" level="INFO">${current_connection_index} = 8</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-06-06T03:17:23.795627" elapsed="0.000266"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.829610" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:23.796415" elapsed="0.033320"/>
</kw>
<msg time="2026-06-06T03:17:23.829912" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:23.829961" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:23.796060" elapsed="0.033938"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.878924" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "P "o "s "t "_ "3 "_ "I "n "i "t "i "a "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:23.830576" elapsed="0.048465"/>
</kw>
<msg time="2026-06-06T03:17:23.879205" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:23.879252" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a...</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-06-06T03:17:23.830182" elapsed="0.049106"/>
</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-06-06T03:17:23.879604" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.879370" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.879348" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.880182" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "P "o "s "t "_ "3 "_ "I "n "i "t "i "a "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:23.879876" elapsed="0.000381"/>
</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-06-06T03:17:23.880549" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.880326" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.880306" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:23.880681" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:23.883237" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:17:23.883445" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:23.882156" elapsed="0.001419"/>
</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="NOT RUN" start="2026-06-06T03:17:23.884039" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.884382" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:23.881515" elapsed="0.003051"/>
</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-06-06T03:17:23.880970" elapsed="0.003662"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:23.794414" elapsed="0.090336"/>
</kw>
<msg time="2026-06-06T03:17:23.884842" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:23.884886" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:23.793848" elapsed="0.091075"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:23.885109" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:23.885000" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.884981" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.885603" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.885969" elapsed="0.000060"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:23.886080" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:23.793160" elapsed="0.093030"/>
</kw>
<msg time="2026-06-06T03:17:23.886284" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:23.886327" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:23.788475" elapsed="0.097889"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:23.886712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:23.886440" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:23.886422" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:23.788331" elapsed="0.098486"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:23.788159" elapsed="0.098687"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:23.785762" elapsed="0.101138"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:23.780500" elapsed="0.106455"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:23.780051" elapsed="0.106949"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:23.777113" elapsed="0.109938"/>
</kw>
<kw name="Switch_To_BGP_Application_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_app_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:23.887454" elapsed="0.000107"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:23.887181" elapsed="0.000435"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.896323" level="INFO">${start_cmd} = python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command post --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-ty...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:23.895993" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.896773" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command post --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.896512" elapsed="0.000309"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:23.902010" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command post --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<msg time="2026-06-06T03:17:23.902104" level="INFO">${output} =  python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command post --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-t...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:23.896977" elapsed="0.005153"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:23.902542" level="INFO"> python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command post --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:23.902293" elapsed="0.000297"/>
</kw>
<arg>${BGP_APP_PEER_POST_COMMAND} ${SCRIPT_URI_OPT}</arg>
<arg>${BGP_APP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:23.895457" elapsed="0.007201"/>
</kw>
<kw name="Wait_Until_Console_Tool_Finish" owner="BGPcliKeywords">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.039972" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:23.907408" elapsed="0.132637"/>
</kw>
<arg>${timeout}</arg>
<arg>1s</arg>
<arg>SSHLibrary.Read Until Prompt</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:23.906918" elapsed="0.133181"/>
</kw>
<arg>${BGP_APP_PEER_TIMEOUT}</arg>
<doc>Wait ${timeout} for the tool exit.</doc>
<status status="PASS" start="2026-06-06T03:17:23.906560" elapsed="0.133599"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.049346" level="INFO">Executing command 'cat bgp_app_peer.log'.</msg>
<msg time="2026-06-06T03:17:24.061819" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:24.062043" level="INFO">${output_log} = 2026-06-06 03:17:24,012 INFO: Post 3 prefix(es) in a single request (starting from 8.0.1.0/28) into 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-fa...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:24.049199" elapsed="0.012905"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.063153" level="INFO">2026-06-06 03:17:24,012 INFO: Post 3 prefix(es) in a single request (starting from 8.0.1.0/28) into 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:24,016 DEBUG: ...streaming chunk 1 (prefix: 8.0.1.0/28)
2026-06-06 03:17:24,016 DEBUG: xml data
&lt;ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.0/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.0/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt;
2026-06-06 03:17:24,016 DEBUG: ...streaming chunk 2 (prefix: 8.0.1.16/28)
2026-06-06 03:17:24,016 DEBUG: xml data
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.16/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.16/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt;
2026-06-06 03:17:24,016 DEBUG: ...streaming chunk 3 (prefix: 8.0.1.32/28)
2026-06-06 03:17:24,016 DEBUG: xml data
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.32/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.32/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt; 
&lt;/ipv4-routes&gt;
2026-06-06 03:17:24,034 DEBUG: &lt;PreparedRequest [POST]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:24,034 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Transfer-Encoding': 'chunked', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:24,034 DEBUG: Response: 
2026-06-06 03:17:24,034 DEBUG: &lt;Response [201]&gt; Created
2026-06-06 03:17:24,034 INFO: Total test execution time: 0.022s
2026-06-06 03:17:24,034 INFO: Total build data time: 0.001s
2026-06-06 03:17:24,035 INFO: Total response time: 0.021s
2026-06-06 03:17:24,035 INFO: Total number of response(s): 1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.062479" elapsed="0.001031"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.064898" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_initial_post_tc1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_initial_post_tc1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:24.064057" elapsed="0.000971"/>
</kw>
<arg>bgp_app_peer.log</arg>
<arg>bgp_app_peer_initial_post_tc1.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:24.048839" elapsed="0.016355"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:24.066698" elapsed="0.000637"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:24.065909" elapsed="0.001574"/>
</kw>
<doc>Start BGP application peer tool and give it 30s</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:23.776510" elapsed="0.291061"/>
</test>
<test id="s1-s7-t5" name="TC1_Check_Example-IPv4-Topology_Is_Filled_With_3_Routes" line="147">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:24.074956" elapsed="0.000399"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:24.074540" elapsed="0.000902"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.077020" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.076835" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.076801" elapsed="0.000323"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.084349" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.084240" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.084221" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.085458" 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-06-06T03:17:24.085055" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.085969" 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-06-06T03:17:24.085666" elapsed="0.000329"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:24.086040" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:17:24.086203" 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-06-06T03:17:24.084666" elapsed="0.001562"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:24.091834" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.091725" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.091706" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:24.093099" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.092993" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.092974" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:24.093621" 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-06-06T03:17:24.093317" elapsed="0.000349"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.094050" level="INFO">${current_connection_index} = 8</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-06-06T03:17:24.093832" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.126086" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:24.094578" elapsed="0.031618"/>
</kw>
<msg time="2026-06-06T03:17:24.126365" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:24.126411" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:24.094239" elapsed="0.032208"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.169540" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "W "i "t "h "_ "3 "_ "R "o "u "t "e "[78Cs "[A[78C"[K
[K
[?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-06-06T03:17:24.127069" elapsed="0.042635"/>
</kw>
<msg time="2026-06-06T03:17:24.169960" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:24.170007" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p...</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-06-06T03:17:24.126677" elapsed="0.043368"/>
</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-06-06T03:17:24.170412" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.170139" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.170112" elapsed="0.000386"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.171024" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "W "i "t "h "_ "3 "_ "R "o "u "t "e "[78Cs "[A[78C"[K
[K
[?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-06-06T03:17:24.170663" elapsed="0.000441"/>
</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-06-06T03:17:24.171397" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.171174" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.171155" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:24.171511" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:24.174204" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:17:24.174420" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:24.173080" elapsed="0.001479"/>
</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="NOT RUN" start="2026-06-06T03:17:24.174901" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.175246" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:24.172412" elapsed="0.003020"/>
</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-06-06T03:17:24.171844" elapsed="0.003652"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:24.092690" elapsed="0.082906"/>
</kw>
<msg time="2026-06-06T03:17:24.175709" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:24.175754" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:24.092057" elapsed="0.083734"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:24.175976" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:24.175868" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.175849" elapsed="0.000210"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.176469" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.176827" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.176899" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:24.091361" elapsed="0.085645"/>
</kw>
<msg time="2026-06-06T03:17:24.177102" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:24.177146" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:24.086610" elapsed="0.090574"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.177512" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.177259" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.177242" elapsed="0.000348"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:24.086464" elapsed="0.091150"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:24.086285" elapsed="0.091377"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:24.083741" elapsed="0.093979"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:24.076383" elapsed="0.101432"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:24.075690" elapsed="0.102172"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:24.069927" elapsed="0.107989"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.236626" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:24.236229" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.237628" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:24.237197" elapsed="0.000537">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:24.237830" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:24.236855" elapsed="0.001000"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.238413" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:24.238026" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.238798" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:24.238965" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:24.238630" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.239400" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.239152" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.240636" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.240192" elapsed="0.000522"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.241239" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:24.240879" elapsed="0.000386"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.241696" elapsed="0.000048"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.242433" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.242825" elapsed="0.000047"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:17:24.241485" elapsed="0.001510"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.241321" elapsed="0.001743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:24.243116" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:17:24.243286" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:24.239842" elapsed="0.003469"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.239521" elapsed="0.003822"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.243517" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.243368" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.239497" elapsed="0.004096"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.244201" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:24.243756" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:24.244278" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:24.235599" elapsed="0.008801"/>
</kw>
<msg time="2026-06-06T03:17:24.244506" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:24.222618" elapsed="0.021938"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.257444" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.270018" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.282616" elapsed="0.000041"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.282829" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.283007" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.283379" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.283230" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:24.283212" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.283600" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.283786" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.283993" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:24.283181" elapsed="0.000886"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.283081" elapsed="0.001017"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.284266" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.284343" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:24.284462" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:24.218296" elapsed="0.066192"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.285819" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:24.285548" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:24.285982" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:24.285196" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.286365" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.286077" elapsed="0.000375"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.286975" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:24.286680" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.286477" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.286058" elapsed="0.000999"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.289401" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:24.287212" elapsed="0.002215"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:24.289478" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:24.289630" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:24.284832" elapsed="0.004845"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.290974" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:24.290724" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:24.291131" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:24.290311" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:17:24.291362" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:24.291225" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.291207" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.291595" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.291794" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.291860" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:17:24.293933" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:24.289985" elapsed="0.003975"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.295363" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.295108" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.295825" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.295565" elapsed="0.000303"/>
</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-06-06T03:17:24.304590" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:24.304761" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:17:24.304874" 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-06-06T03:17:24.298019" elapsed="0.006882"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.295933" elapsed="0.009010"/>
</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-06-06T03:17:24.305126" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.304969" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.295915" elapsed="0.009302"/>
</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-06-06T03:17:24.308771" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.306243" elapsed="0.002582"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.306016" elapsed="0.002894"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.305997" elapsed="0.002943"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.311905" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.309243" elapsed="0.002725"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.309000" elapsed="0.003016"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.308982" elapsed="0.003069"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.312867" 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-06-06T03:17:24.312300" elapsed="0.000605"/>
</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-06-06T03:17:24.313343" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.313005" elapsed="0.000420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.314135" 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-06-06T03:17:24.313710" elapsed="0.000461"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.313458" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.312978" elapsed="0.001273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.315047" 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-06-06T03:17:24.314509" elapsed="0.000574"/>
</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-06-06T03:17:24.315518" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.315181" elapsed="0.000416"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.316297" 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-06-06T03:17:24.315884" elapsed="0.000449"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.315632" elapsed="0.000749"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.315155" elapsed="0.001255"/>
</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-06-06T03:17:24.316627" elapsed="0.000503"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:24.317804" 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-06-06T03:17:24.317365" elapsed="0.000476"/>
</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-06-06T03:17:24.318065" elapsed="0.003338"/>
</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-06-06T03:17:24.305576" elapsed="0.015918"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.321762" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.321592" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.321565" elapsed="0.000293"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:24.325307" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:17:24.322065" elapsed="0.003271"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:17:24.325387" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:17:24.325548" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:17:24.294268" elapsed="0.031306"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:24.325637" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:17:24.325807" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:24.191557" elapsed="0.134276"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.355301" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:24.354493" elapsed="0.000837"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.357382" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:24.356828" elapsed="0.000715">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:24.357694" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:24.355499" elapsed="0.002221"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.358711" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:24.357891" elapsed="0.000848"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:24.359149" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:24.359404" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:24.358908" elapsed="0.000524"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.360044" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.359592" elapsed="0.000518"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:24.360808" elapsed="0.000082"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.360179" elapsed="0.000792"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.361847" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:24.361179" elapsed="0.000710"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.360999" elapsed="0.000992"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.360159" elapsed="0.001857"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.362984" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:24.362202" elapsed="0.000812"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:24.363062" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:24.353768" elapsed="0.009419"/>
</kw>
<msg time="2026-06-06T03:17:24.363242" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:24.340866" elapsed="0.022425"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.376296" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.388922" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.401748" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.401960" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.402166" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.402577" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.402426" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:24.402409" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.402821" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.402993" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.403162" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:24.402373" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.402258" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.403394" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.403470" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:24.403605" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:24.338161" elapsed="0.065472"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:24.403828" elapsed="0.002279"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:24.407376" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:24.406882" elapsed="0.000522"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:24.408016" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:24.407563" elapsed="0.000481"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:17:24.408204" elapsed="0.000332"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:17:24.406438" elapsed="0.002157"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.406189" elapsed="0.002439"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.408827" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.408673" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.406169" elapsed="0.002733"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:17:24.327011" elapsed="0.081939"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:17:24.326163" elapsed="0.082865"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.325915" elapsed="0.083193"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.325898" elapsed="0.083236"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:24.409168" elapsed="0.000031"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:17:24.185262" elapsed="0.224039"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:24.178964" elapsed="0.230400"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:24.178417" elapsed="0.230994"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:24.178064" elapsed="0.231406"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:24.410090" elapsed="0.000243"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:24.409766" elapsed="0.000630"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:24.068261" elapsed="0.342173"/>
</test>
<test id="s1-s7-t6" name="TC1_Connect_BGP_Peer" line="152">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:24.413794" elapsed="0.000241"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:24.413500" elapsed="0.000592"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.415102" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.414991" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.414971" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.420377" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.420271" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.420252" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.421456" 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-06-06T03:17:24.421076" elapsed="0.000406"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.421978" 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-06-06T03:17:24.421661" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:24.422049" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:24.422203" 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-06-06T03:17:24.420695" elapsed="0.001533"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:24.427800" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.427690" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.427670" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:24.429032" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:24.428925" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.428907" elapsed="0.000192"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:24.429545" 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-06-06T03:17:24.429247" elapsed="0.000324"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.429984" level="INFO">${current_connection_index} = 8</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-06-06T03:17:24.429755" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.462334" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:24.430514" elapsed="0.031925"/>
</kw>
<msg time="2026-06-06T03:17:24.462601" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:24.462671" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:24.430174" elapsed="0.032537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.487753" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:24.463284" elapsed="0.024571"/>
</kw>
<msg time="2026-06-06T03:17:24.488012" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:24.488058" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P...</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-06-06T03:17:24.462934" elapsed="0.025161"/>
</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-06-06T03:17:24.488409" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.488174" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.488152" elapsed="0.000336"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.488967" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:24.488636" elapsed="0.000399"/>
</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-06-06T03:17:24.489326" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.489104" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.489085" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:24.489439" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:24.492004" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:17:24.492212" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:24.490927" elapsed="0.001418"/>
</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="NOT RUN" start="2026-06-06T03:17:24.492628" elapsed="0.000101"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.492992" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:24.490294" elapsed="0.002884"/>
</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-06-06T03:17:24.489755" elapsed="0.003488"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:24.428596" elapsed="0.064744"/>
</kw>
<msg time="2026-06-06T03:17:24.493432" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:24.493476" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:24.428021" elapsed="0.065492"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:24.493911" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:17:24.493590" elapsed="0.000385"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.493570" elapsed="0.000431"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.494411" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.494769" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:24.494841" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:24.427336" elapsed="0.067613"/>
</kw>
<msg time="2026-06-06T03:17:24.495042" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:24.495085" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:24.422596" elapsed="0.072526"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:24.495455" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:24.495196" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:24.495178" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:24.422450" elapsed="0.073106"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:24.422279" elapsed="0.073341"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:24.419909" elapsed="0.075782"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:24.414702" elapsed="0.081045"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:24.414252" elapsed="0.081539"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:24.411327" elapsed="0.084515"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:24.496240" elapsed="0.000105"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:24.495969" elapsed="0.000432"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.505078" level="INFO">${start_cmd} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug </msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:24.504746" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.505512" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug </msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.505269" elapsed="0.000289"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:24.508724" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug</msg>
<msg time="2026-06-06T03:17:24.508817" level="INFO">${output} =  python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug 
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:24.505829" elapsed="0.003014"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:24.509254" level="INFO"> python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug 
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:24.509007" elapsed="0.000293"/>
</kw>
<arg>${BGP_PEER_COMMAND}</arg>
<arg>${BGP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:24.504350" elapsed="0.005005"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.512217" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l2026-06-06 03:17:24,592 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:24,594 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:24,603 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:17:24,603 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:24,603 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:24,611 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:17:24,611 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:17:24.510988" elapsed="10.002930">No match found for '&gt;' in 10 seconds
Output:
[?2004l
2026-06-06 03:17:24,592 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:24,594 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
    [ Message content over the limit has been removed. ]
...DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.514285" elapsed="0.000040"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:17:24.510712" elapsed="10.003795">No match found for '&gt;' in 10 seconds
Output:
[?2004l
2026-06-06 03:17:24,592 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:24,594 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
    [ Message content over the limit has been removed. ]
...DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:17:24.510293" elapsed="10.004390"/>
</kw>
<msg time="2026-06-06T03:17:34.514819" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:24.509923" elapsed="10.004924"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:17:34.515052" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:17:34.514951" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.514922" elapsed="0.000224"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.515395" elapsed="0.000035"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.515593" elapsed="0.000022"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:17:24.509592" elapsed="10.006109"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:34.516406" elapsed="0.000371"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:34.516019" elapsed="0.000826"/>
</kw>
<doc>Start BGP peer tool</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:24.410825" elapsed="10.106064"/>
</test>
<test id="s1-s7-t7" name="TC1_BGP_Peer_Check_Incomming_Updates_For_3_Introduced_Prefixes" line="159">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:34.521041" elapsed="0.000257"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:34.520724" elapsed="0.000635"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:34.522440" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.522312" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.522292" elapsed="0.000263"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:34.527794" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.527679" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.527659" elapsed="0.000206"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.528901" 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-06-06T03:17:34.528488" elapsed="0.000441"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.529428" 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-06-06T03:17:34.529095" elapsed="0.000359"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:34.529500" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:34.529680" 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-06-06T03:17:34.528100" elapsed="0.001606"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:34.535478" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.535365" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.535344" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:34.536799" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.536684" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.536623" elapsed="0.000245"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:34.537389" 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-06-06T03:17:34.537021" elapsed="0.000400"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.537843" level="INFO">${current_connection_index} = 7</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-06-06T03:17:34.537602" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.568328" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:34.538381" elapsed="0.030170"/>
</kw>
<msg time="2026-06-06T03:17:34.568823" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:34.568873" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:34.538035" elapsed="0.030875"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.606906" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "I "n "t "r "o "d "u "c "e "d "_ "[78CP "[A[78Cr
 "e "f "i "x "e "s "[K"
[?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-06-06T03:17:34.569778" elapsed="0.037378"/>
</kw>
<msg time="2026-06-06T03:17:34.607404" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:34.607453" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</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-06-06T03:17:34.569232" elapsed="0.038259"/>
</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-06-06T03:17:34.607988" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:34.607619" elapsed="0.000434"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.607579" elapsed="0.000503"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.608638" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "I "n "t "r "o "d "u "c "e "d "_ "[78CP "[A[78Cr
 "e "f "i "x "e "s "[K"
[?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-06-06T03:17:34.608236" elapsed="0.000510"/>
</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-06-06T03:17:34.609087" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:34.608817" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.608797" elapsed="0.000375"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:34.609213" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:34.612118" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:17:34.612338" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:34.610954" elapsed="0.001526"/>
</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="NOT RUN" start="2026-06-06T03:17:34.612796" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.613214" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:34.610251" elapsed="0.003163"/>
</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-06-06T03:17:34.609557" elapsed="0.003927"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:34.536336" elapsed="0.077255"/>
</kw>
<msg time="2026-06-06T03:17:34.613707" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:34.613756" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:34.535722" elapsed="0.078073"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:34.613989" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:34.613876" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.613856" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.614499" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.614868" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:34.614943" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:34.535003" elapsed="0.080055"/>
</kw>
<msg time="2026-06-06T03:17:34.615159" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:34.615204" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:34.530092" elapsed="0.085153"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.615589" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:34.615325" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.615306" elapsed="0.000380"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:34.529943" elapsed="0.085769"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:34.529765" elapsed="0.085981"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:34.527290" elapsed="0.088517"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:34.522006" elapsed="0.093863"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:34.521525" elapsed="0.094393"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:34.518031" elapsed="0.097946"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:34.616402" elapsed="0.000110"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:34.616119" elapsed="0.000452"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.629845" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:34.642977" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:34.643121" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:34.629664" elapsed="0.013492"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.643802" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.643397" elapsed="0.000471"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:34.644092" elapsed="0.000465"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:34.629270" elapsed="0.015404"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:34.616763" elapsed="0.028070"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.662384" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.0/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:34.676736" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:34.676999" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:34.662215" elapsed="0.014851"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.678075" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.677449" elapsed="0.000725"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:34.678524" elapsed="0.000747"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.0/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:34.661839" elapsed="0.017574"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.697728" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.16/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:34.728514" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:34.728767" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:34.697503" elapsed="0.031324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.729897" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.729280" elapsed="0.000716"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:34.730345" elapsed="0.000775"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.16/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:34.696769" elapsed="0.034494"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.748199" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.32/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:34.780396" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:34.780514" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:34.748032" elapsed="0.032509"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.781118" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.780763" elapsed="0.000405"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:34.781331" elapsed="0.000379"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.32/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:34.747669" elapsed="0.034191"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.801556" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:34.828801" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:34.829048" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:34.801371" elapsed="0.027735"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.830140" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.829491" elapsed="0.000752"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:34.830590" elapsed="0.000738"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:34.800942" elapsed="0.030526"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:34.832934" elapsed="0.000549"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:34.832150" elapsed="0.001476"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:34.517374" elapsed="0.316374"/>
</test>
<test id="s1-s7-t8" name="TC1_BGP_Application_Peer_Delete_3_Initial_Routes" line="175">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:34.839351" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:34.839084" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:34.840710" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.840555" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.840529" elapsed="0.000273"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:34.846143" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.846035" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.846017" elapsed="0.000267"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.847316" 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-06-06T03:17:34.846925" elapsed="0.000419"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.847956" 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-06-06T03:17:34.847516" elapsed="0.000474"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:34.848056" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:17:34.848232" 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-06-06T03:17:34.846522" elapsed="0.001736"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:34.854161" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.854032" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.854007" elapsed="0.000232"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:34.855571" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:34.855459" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.855439" elapsed="0.000228"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:34.856152" 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-06-06T03:17:34.855826" elapsed="0.000354"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.856576" level="INFO">${current_connection_index} = 7</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-06-06T03:17:34.856353" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.886541" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:34.857184" elapsed="0.029500"/>
</kw>
<msg time="2026-06-06T03:17:34.886867" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:34.886918" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:34.856832" elapsed="0.030125"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.918226" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "D "e "l "e "t "e "_ "3 "_ "I "n "i "t "i "a "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:34.887561" elapsed="0.030802"/>
</kw>
<msg time="2026-06-06T03:17:34.918541" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:34.918588" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a...</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-06-06T03:17:34.887156" elapsed="0.031469"/>
</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-06-06T03:17:34.919020" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:34.918751" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.918724" elapsed="0.000382"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.919578" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "D "e "l "e "t "e "_ "3 "_ "I "n "i "t "i "a "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:34.919258" elapsed="0.000418"/>
</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-06-06T03:17:34.919975" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:34.919747" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.919728" elapsed="0.000327"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:34.920092" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:34.922804" elapsed="0.000154"/>
</kw>
<msg time="2026-06-06T03:17:34.923022" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:34.921675" elapsed="0.001482"/>
</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="NOT RUN" start="2026-06-06T03:17:34.923725" elapsed="0.000236"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.924233" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:34.921014" elapsed="0.003411"/>
</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-06-06T03:17:34.920417" elapsed="0.004074"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:34.855118" elapsed="0.069474"/>
</kw>
<msg time="2026-06-06T03:17:34.924728" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:34.924776" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:34.854419" elapsed="0.070395"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:34.925022" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:17:34.924895" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.924875" elapsed="0.000235"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.925529" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.925896" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:34.925971" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:34.853606" elapsed="0.072475"/>
</kw>
<msg time="2026-06-06T03:17:34.926177" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:34.926222" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:34.848690" elapsed="0.077570"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:34.926665" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:34.926365" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:34.926335" elapsed="0.000419"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:34.848518" elapsed="0.078273"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:34.848318" elapsed="0.078518"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:34.845668" elapsed="0.081244"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:34.840249" elapsed="0.086743"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:34.839788" elapsed="0.087269"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:34.835878" elapsed="0.091251"/>
</kw>
<kw name="Switch_To_BGP_Application_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_app_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:34.927717" elapsed="0.000150"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:34.927312" elapsed="0.000633"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.939581" level="INFO">${start_cmd} = python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:34.939213" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.940050" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.939798" elapsed="0.000302"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:34.945411" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<msg time="2026-06-06T03:17:34.945513" level="INFO">${output} =  python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:34.940258" elapsed="0.005376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:34.946072" level="INFO"> python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:34.945818" elapsed="0.000303"/>
</kw>
<arg>${BGP_APP_PEER_DELETE_COMMAND} ${SCRIPT_URI_OPT}</arg>
<arg>${BGP_APP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:34.938745" elapsed="0.007432"/>
</kw>
<kw name="Wait_Until_Console_Tool_Finish" owner="BGPcliKeywords">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.094004" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:34.951012" elapsed="0.143172"/>
</kw>
<arg>${timeout}</arg>
<arg>1s</arg>
<arg>SSHLibrary.Read Until Prompt</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:34.950475" elapsed="0.143809"/>
</kw>
<arg>${BGP_APP_PEER_TIMEOUT}</arg>
<doc>Wait ${timeout} for the tool exit.</doc>
<status status="PASS" start="2026-06-06T03:17:34.950120" elapsed="0.144271"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.104676" level="INFO">Executing command 'cat bgp_app_peer.log'.</msg>
<msg time="2026-06-06T03:17:35.116523" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:35.116627" level="INFO">${output_log} = 2026-06-06 03:17:35,059 INFO: Delete 3 prefix(es) (starting from 8.0.1.0/28) from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Au...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:35.104499" elapsed="0.012173"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.117159" level="INFO">2026-06-06 03:17:35,059 INFO: Delete 3 prefix(es) (starting from 8.0.1.0/28) from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:35,059 INFO: Deleting prefix 8.0.1.0/28/,0 from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:35,072 DEBUG: &lt;PreparedRequest [DELETE]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/bgp-inet:ipv4-route=8.0.1.0%2F28,0
2026-06-06 03:17:35,072 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:35,072 DEBUG: Response: 
2026-06-06 03:17:35,072 DEBUG: &lt;Response [204]&gt; No Content
2026-06-06 03:17:35,073 INFO: Deleting prefix 8.0.1.16/28/,0 from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:35,082 DEBUG: &lt;PreparedRequest [DELETE]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/bgp-inet:ipv4-route=8.0.1.16%2F28,0
2026-06-06 03:17:35,082 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:35,082 DEBUG: Response: 
2026-06-06 03:17:35,082 DEBUG: &lt;Response [204]&gt; No Content
2026-06-06 03:17:35,082 INFO: Deleting prefix 8.0.1.32/28/,0 from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:35,091 DEBUG: &lt;PreparedRequest [DELETE]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/bgp-inet:ipv4-route=8.0.1.32%2F28,0
2026-06-06 03:17:35,091 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:35,091 DEBUG: Response: 
2026-06-06 03:17:35,091 DEBUG: &lt;Response [204]&gt; No Content
2026-06-06 03:17:35,091 INFO: Total test execution time: 0.032s
2026-06-06 03:17:35,091 INFO: Total build data time: 0.000s
2026-06-06 03:17:35,091 INFO: Total response time: 0.030s
2026-06-06 03:17:35,091 INFO: Total number of response(s): 3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.116847" elapsed="0.000381"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.118086" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_delete_tc1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_delete_tc1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:35.117445" elapsed="0.000770"/>
</kw>
<arg>bgp_app_peer.log</arg>
<arg>bgp_app_peer_delete_tc1.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:35.104056" elapsed="0.014297"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:35.119763" elapsed="0.000563"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:35.119033" elapsed="0.001502"/>
</kw>
<doc>Start BGP application peer tool and give him 30s</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:34.834452" elapsed="0.286176"/>
</test>
<test id="s1-s7-t9" name="TC1_Check_Example-IPv4-Topology_Is_Empty" line="183">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:35.131003" elapsed="0.000232"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:35.130721" elapsed="0.000574"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.132369" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.132230" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.132205" elapsed="0.000257"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.137690" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.137564" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.137546" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.138819" 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-06-06T03:17:35.138376" elapsed="0.000470"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.139332" 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-06-06T03:17:35.139011" elapsed="0.000347"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:35.139403" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:17:35.139565" 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-06-06T03:17:35.137992" elapsed="0.001598"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:35.145290" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.145182" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.145163" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:35.146556" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.146447" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.146428" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:35.147138" 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-06-06T03:17:35.146798" elapsed="0.000367"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.147549" level="INFO">${current_connection_index} = 8</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-06-06T03:17:35.147331" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.179325" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:35.148101" elapsed="0.031399"/>
</kw>
<msg time="2026-06-06T03:17:35.179776" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:35.179847" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:35.147761" elapsed="0.032142"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.209033" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:17:35.180764" elapsed="0.028390"/>
</kw>
<msg time="2026-06-06T03:17:35.209324" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:35.209372" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p...</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-06-06T03:17:35.180173" elapsed="0.029237"/>
</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-06-06T03:17:35.209776" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.209499" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.209475" elapsed="0.000384"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.210322" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:17:35.210008" elapsed="0.000389"/>
</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-06-06T03:17:35.210707" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.210465" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.210446" elapsed="0.000340"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:35.210822" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:35.213709" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:17:35.213923" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:35.212418" elapsed="0.001690"/>
</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="NOT RUN" start="2026-06-06T03:17:35.214415" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.214935" elapsed="0.000087"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:35.211745" elapsed="0.003392"/>
</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-06-06T03:17:35.211146" elapsed="0.004057"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:35.146142" elapsed="0.069163"/>
</kw>
<msg time="2026-06-06T03:17:35.215402" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:35.215457" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:35.145514" elapsed="0.069984"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:35.215710" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:35.215577" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.215557" elapsed="0.000238"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.216207" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.216565" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.216651" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:35.144841" elapsed="0.071924"/>
</kw>
<msg time="2026-06-06T03:17:35.216859" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:35.216902" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:35.139995" elapsed="0.076945"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.217274" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.217015" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.216998" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:35.139847" elapsed="0.077529"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:35.139663" elapsed="0.077744"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:35.137137" elapsed="0.080327"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:35.131924" elapsed="0.085595"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:35.131451" elapsed="0.086112"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:35.123371" elapsed="0.094245"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.271378" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:35.270956" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.272431" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:35.271975" elapsed="0.000538">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:35.272609" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:35.271592" elapsed="0.001046"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.273303" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:35.272842" elapsed="0.000489"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.273664" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:35.273864" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:35.273500" elapsed="0.000390"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.274306" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.274054" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.275602" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.275137" elapsed="0.000546"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.276265" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:35.275871" elapsed="0.000422"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.276738" elapsed="0.000048"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.277469" elapsed="0.000049"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.277843" elapsed="0.000045"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:17:35.276526" elapsed="0.001482"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.276355" elapsed="0.001720"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:35.278128" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:17:35.278300" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:35.274782" elapsed="0.003543"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.274430" elapsed="0.003927"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.278535" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.278382" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.274405" elapsed="0.004206"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.279231" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:35.278779" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:35.279308" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:35.270208" elapsed="0.009223"/>
</kw>
<msg time="2026-06-06T03:17:35.279487" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:35.257209" elapsed="0.022328"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.292785" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.305558" elapsed="0.000058"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.318727" elapsed="0.000064"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.319056" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.319256" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.319744" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.319567" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:35.319548" elapsed="0.000282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.319981" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.320155" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.320342" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:35.319504" elapsed="0.000891"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.319348" elapsed="0.001075"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.320575" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.320673" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:17:35.320844" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:35.252847" elapsed="0.068026"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.322379" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:35.322069" elapsed="0.000388">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:35.322553" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:35.321628" elapsed="0.000950"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.322946" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.322666" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.323519" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:35.323220" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.323031" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.322631" elapsed="0.000971"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.326103" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:35.323786" elapsed="0.002344"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:35.326185" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:17:35.326350" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:35.321256" elapsed="0.005118"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.327676" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:35.327401" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:35.327922" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:35.327058" elapsed="0.000889"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:17:35.328161" elapsed="0.000045"/>
</return>
<status status="PASS" start="2026-06-06T03:17:35.328021" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.328002" elapsed="0.000264"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.328419" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.328598" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.328684" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:17:35.330842" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:35.326717" elapsed="0.004152"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.332352" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.332063" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.332820" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.332557" elapsed="0.000306"/>
</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-06-06T03:17:35.340582" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:35.340766" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:17:35.340914" 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-06-06T03:17:35.335056" elapsed="0.005887"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.332930" elapsed="0.008067"/>
</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-06-06T03:17:35.341237" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.341033" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.332912" elapsed="0.008415"/>
</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-06-06T03:17:35.345183" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.342524" elapsed="0.002709"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.342277" elapsed="0.002992"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.342255" elapsed="0.003039"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.347968" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.345582" elapsed="0.002432"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.345353" elapsed="0.002695"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.345335" elapsed="0.002738"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.348750" 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-06-06T03:17:35.348312" elapsed="0.000467"/>
</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-06-06T03:17:35.349097" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.348851" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.349684" 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-06-06T03:17:35.349351" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.349181" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.348832" elapsed="0.000938"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.350302" 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-06-06T03:17:35.349934" elapsed="0.000394"/>
</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-06-06T03:17:35.350665" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.350401" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.351299" 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-06-06T03:17:35.351000" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.350828" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.350382" elapsed="0.001000"/>
</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-06-06T03:17:35.351542" elapsed="0.000372"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:35.352409" 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-06-06T03:17:35.352085" elapsed="0.000351"/>
</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-06-06T03:17:35.352600" elapsed="0.002574"/>
</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-06-06T03:17:35.341786" elapsed="0.013459"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.355430" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.355319" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.355299" elapsed="0.000202"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:35.358528" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:17:35.355666" elapsed="0.002892"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:17:35.358610" elapsed="0.000061"/>
</return>
<msg time="2026-06-06T03:17:35.358807" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:17:35.331203" elapsed="0.027631"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:35.358899" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:17:35.359053" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:35.229663" elapsed="0.129416"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.388725" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:35.387951" elapsed="0.000804"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.390861" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:35.390253" elapsed="0.000773">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:35.391160" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:35.388927" elapsed="0.002259"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.392190" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:35.391358" elapsed="0.000860"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:35.392656" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:35.392946" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:35.392388" elapsed="0.000594"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.393796" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.393163" elapsed="0.000731"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:35.394613" elapsed="0.000099"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.393975" elapsed="0.000823"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.395726" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:35.395013" elapsed="0.000759"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.394828" elapsed="0.001026"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.393952" elapsed="0.001926"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.396893" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:35.396053" elapsed="0.000871"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:35.396976" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:35.387212" elapsed="0.009896"/>
</kw>
<msg time="2026-06-06T03:17:35.397163" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:35.374299" elapsed="0.022914"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.409948" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.422666" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.435353" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.435589" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.435800" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.436262" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.436106" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:35.436086" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.436491" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.436677" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.436849" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:35.436016" elapsed="0.000886"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.435891" elapsed="0.001039"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.437147" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.437227" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:17:35.437372" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:35.371562" elapsed="0.065839"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:35.437584" elapsed="0.002322"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:35.441080" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:35.440708" elapsed="0.000401"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:35.441575" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:35.441268" elapsed="0.000335"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:17:35.441793" elapsed="0.000339"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:17:35.440257" elapsed="0.001937"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.439989" elapsed="0.002240"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.442410" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.442255" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.439969" elapsed="0.002519"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:17:35.360312" elapsed="0.082225"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:17:35.359428" elapsed="0.083189"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.359165" elapsed="0.083519"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.359147" elapsed="0.083564"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:35.442747" elapsed="0.000033"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:17:35.222933" elapsed="0.219950"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:35.218631" elapsed="0.224319"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:35.218131" elapsed="0.224869"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:35.217778" elapsed="0.225283"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:35.443662" elapsed="0.000246"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:35.443338" elapsed="0.000635"/>
</kw>
<doc>See new routes are deleted.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:35.121575" elapsed="0.322436"/>
</test>
<test id="s1-s7-t10" name="TC1_Peer_Check_Incomming_Updates_For_3_Withdrawn_Prefixes" line="188">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:35.448144" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:35.447860" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.449477" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.449363" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.449344" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.454806" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.454697" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.454678" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.455892" 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-06-06T03:17:35.455490" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.456421" 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-06-06T03:17:35.456116" elapsed="0.000332"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:35.456494" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:35.456667" 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-06-06T03:17:35.455107" elapsed="0.001586"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:35.462254" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.462144" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.462124" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:35.463637" elapsed="0.000041"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.463529" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.463510" elapsed="0.000224"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:35.464201" 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-06-06T03:17:35.463883" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.464610" level="INFO">${current_connection_index} = 8</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-06-06T03:17:35.464393" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.494068" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:35.465161" elapsed="0.029011"/>
</kw>
<msg time="2026-06-06T03:17:35.494339" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:35.494385" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:35.464822" elapsed="0.029599"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.530992" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "[78Cx "[A[78Ce
 "s "[K"
[?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-06-06T03:17:35.494972" elapsed="0.036197"/>
</kw>
<msg time="2026-06-06T03:17:35.531412" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:35.531483" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "P "e "e "r "_ "C "h "e "c "k "_...</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-06-06T03:17:35.494597" elapsed="0.036942"/>
</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-06-06T03:17:35.532057" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.531688" elapsed="0.000455"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.531626" elapsed="0.000553"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.532875" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "[78Cx "[A[78Ce
 "s "[K"
[?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-06-06T03:17:35.532398" elapsed="0.000597"/>
</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-06-06T03:17:35.533426" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.533097" elapsed="0.000411"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.533069" elapsed="0.000474"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:35.533677" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:35.537532" elapsed="0.000443"/>
</kw>
<msg time="2026-06-06T03:17:35.538070" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:35.535852" elapsed="0.002413"/>
</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="NOT RUN" start="2026-06-06T03:17:35.538891" elapsed="0.000119"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.539425" elapsed="0.000113"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:35.534914" elapsed="0.004815"/>
</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-06-06T03:17:35.534090" elapsed="0.005737"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:35.463227" elapsed="0.076788"/>
</kw>
<msg time="2026-06-06T03:17:35.540155" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:35.540222" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "P "e "e "r "_ "C "h "e "c "k "_...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:35.462478" elapsed="0.077801"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:35.540554" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:17:35.540394" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.540367" elapsed="0.000319"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.541107" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.541452" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.541524" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:35.461802" elapsed="0.079832"/>
</kw>
<msg time="2026-06-06T03:17:35.541746" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:35.541791" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "P "e "e "r "_ "C "h "e "c "k "_...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:35.457063" elapsed="0.084766"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.542173" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.541917" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.541899" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:35.456917" elapsed="0.085358"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:35.456747" elapsed="0.085558"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:35.454316" elapsed="0.088044"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:35.449026" elapsed="0.093390"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:35.448569" elapsed="0.093894"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:35.445288" elapsed="0.097228"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:35.542942" elapsed="0.000106"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.542668" elapsed="0.000437"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.556575" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:35.569505" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:35.569756" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:35.556405" elapsed="0.013410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.570796" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.570187" elapsed="0.000710"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:35.571244" elapsed="0.000782"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:35.556051" elapsed="0.016200"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>3</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:35.543258" elapsed="0.029111"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.589418" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.0/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:35.621123" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:35.621346" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:35.589251" elapsed="0.032151"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.622420" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.621823" elapsed="0.000695"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:35.622911" elapsed="0.000804"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.0/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:35.588897" elapsed="0.035040"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.640382" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.16/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:35.669684" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:35.670068" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:35.640177" elapsed="0.029948"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.671339" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.670602" elapsed="0.000838"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:35.672042" elapsed="0.000792"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.16/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:35.639510" elapsed="0.033535"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.689963" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.32/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:35.721540" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:35.721792" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:35.689794" elapsed="0.032055"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.722832" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.722221" elapsed="0.000709"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:35.723270" elapsed="0.000752"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.32/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:35.689404" elapsed="0.034756"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.740999" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:35.773336" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:35.773555" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:35.740837" elapsed="0.032775"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.774699" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:35.774080" elapsed="0.000720"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:35.775142" elapsed="0.000863"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:35.740480" elapsed="0.035666"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:35.777513" elapsed="0.000754"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:35.776808" elapsed="0.001614"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:35.444463" elapsed="0.334046"/>
</test>
<test id="s1-s7-t11" name="TC1_Stop_BGP_Peer" line="204">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:35.784853" elapsed="0.000294"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:35.784455" elapsed="0.000769"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.786974" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.786739" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.786693" elapsed="0.000389"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.794056" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.793945" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.793926" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.795208" 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-06-06T03:17:35.794776" elapsed="0.000461"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.795743" 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-06-06T03:17:35.795405" elapsed="0.000364"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:35.795815" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:17:35.795981" 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-06-06T03:17:35.794365" elapsed="0.001640"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:35.801851" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.801729" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.801709" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:35.803197" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:35.803087" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.803068" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:35.803789" 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-06-06T03:17:35.803438" elapsed="0.000378"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.804217" level="INFO">${current_connection_index} = 7</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-06-06T03:17:35.803996" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.835381" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:35.804762" elapsed="0.030727"/>
</kw>
<msg time="2026-06-06T03:17:35.835713" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:35.835761" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:35.804407" elapsed="0.031392"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:35.860018" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "S "t "o "p "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:35.836319" elapsed="0.023802"/>
</kw>
<msg time="2026-06-06T03:17:35.860276" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:35.860320" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</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-06-06T03:17:35.835974" elapsed="0.024383"/>
</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-06-06T03:17:35.860685" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.860435" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.860414" elapsed="0.000353"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.861211" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "S "t "o "p "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:35.860913" elapsed="0.000363"/>
</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-06-06T03:17:35.861563" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.861345" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.861325" elapsed="0.000315"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:35.861693" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:35.864348" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:17:35.864553" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:35.863153" elapsed="0.001549"/>
</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="NOT RUN" start="2026-06-06T03:17:35.865024" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.865362" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:35.862516" elapsed="0.003030"/>
</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-06-06T03:17:35.861979" elapsed="0.003632"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:35.802780" elapsed="0.062951"/>
</kw>
<msg time="2026-06-06T03:17:35.865990" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:35.866035" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:35.802108" elapsed="0.063965"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:35.866259" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:35.866152" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.866133" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.866780" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.867124" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:35.867196" elapsed="0.000019"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:35.801363" elapsed="0.065970"/>
</kw>
<msg time="2026-06-06T03:17:35.867433" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:35.867479" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "1 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:35.796398" elapsed="0.071121"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:35.867896" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:35.867617" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:35.867598" elapsed="0.000380"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:35.796250" elapsed="0.071752"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:35.796065" elapsed="0.071970"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:35.793464" elapsed="0.074629"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:35.786229" elapsed="0.081923"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:35.785440" elapsed="0.082761"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:35.780884" elapsed="0.087372"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:35.868686" elapsed="0.000111"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:35.868393" elapsed="0.000462"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:35.870178" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:35.869620" elapsed="0.000586"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:35.870366" elapsed="0.000243"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:17:35.869349" elapsed="0.001346"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:17:37.871484" level="INFO">2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.061s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
^CTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt

[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:17:37.872273" level="INFO">${output} = 2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.061s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (...</msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:17:35.870851" elapsed="2.001492"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:37.873583" level="INFO">2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.061s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
^CTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt

[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:37.872868" elapsed="0.001165"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:17:35.869032" elapsed="2.005203"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:37.889095" level="INFO">Executing command 'cat bgp_peer.log'.</msg>
<msg time="2026-06-06T03:17:37.902346" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:37.902579" level="INFO">${output_log} = 2026-06-06 03:17:24,592 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:24,593 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:37.888894" elapsed="0.013792"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:37.903749" level="INFO">2026-06-06 03:17:24,592 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:24,593 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:24,594 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:24,596 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:17:24,597 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:17:24,598 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:24,598 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:17:24,599 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:24,602 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:24,603 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:24,603 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:17:24,603 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:24,603 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:24,611 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:17:24,611 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,611 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,612 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,613 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,660 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,661 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:24,662 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,663 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,664 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,665 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:24,666 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,667 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:24,668 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:24,669 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:24,670 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.061s
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:17:34,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,076 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,077 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,078 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,079 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,080 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,088 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,089 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,090 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,091 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,092 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:35,093 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:35,094 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:35,095 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:17:35,096 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:35,097 DEBUG BGP-Thread-1 (job): NLRI prefix list: []</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:37.903113" elapsed="0.001320"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:37.905875" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer_tc1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer_tc1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:37.904889" elapsed="0.001081"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>bgp_peer_tc1.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:37.888364" elapsed="0.017707"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:37.906989" elapsed="0.000357"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:37.906511" elapsed="0.000927"/>
</kw>
<doc>Stop BGP peer tool</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:35.779417" elapsed="2.128076"/>
</test>
<test id="s1-s7-t12" name="TC2_Reconnect_BGP_Peer" line="211">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:37.912892" elapsed="0.000329"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:37.912462" elapsed="0.000843"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:37.914844" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:37.914637" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.914604" elapsed="0.000346"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:37.920872" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:37.920764" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.920746" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:37.922028" 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-06-06T03:17:37.921576" elapsed="0.000481"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:37.922525" 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-06-06T03:17:37.922225" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:37.922602" elapsed="0.000058"/>
</return>
<msg time="2026-06-06T03:17:37.922806" 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-06-06T03:17:37.921172" elapsed="0.001661"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:37.930342" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:37.930232" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.930212" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:37.931613" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:37.931505" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.931486" elapsed="0.000221"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:37.932159" 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-06-06T03:17:37.931857" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:37.932566" level="INFO">${current_connection_index} = 7</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-06-06T03:17:37.932350" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:37.962879" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:37.933137" elapsed="0.029911"/>
</kw>
<msg time="2026-06-06T03:17:37.963253" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:37.963300" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:37.932790" elapsed="0.030547"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:37.987229" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "R "e "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:37.964010" elapsed="0.023382"/>
</kw>
<msg time="2026-06-06T03:17:37.987638" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:37.987750" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "R "e "c "o "n "n "e "c "t "_ "B...</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-06-06T03:17:37.963565" elapsed="0.024328"/>
</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-06-06T03:17:37.988402" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:37.988030" elapsed="0.000456"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.987994" elapsed="0.000530"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:37.989379" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "R "e "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:37.988764" elapsed="0.000790"/>
</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-06-06T03:17:37.990088" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:37.989723" elapsed="0.000450"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.989685" elapsed="0.000525"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:37.990265" elapsed="0.000054"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:37.994188" elapsed="0.000220"/>
</kw>
<msg time="2026-06-06T03:17:37.994503" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:37.992558" elapsed="0.002191"/>
</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="NOT RUN" start="2026-06-06T03:17:37.995205" elapsed="0.000115"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:37.995833" elapsed="0.000116"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:37.991580" elapsed="0.004535"/>
</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-06-06T03:17:37.990742" elapsed="0.005468"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:37.931200" elapsed="0.065160"/>
</kw>
<msg time="2026-06-06T03:17:37.996505" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:37.996572" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "R "e "c "o "n "n "e "c "t "_ "B...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:37.930572" elapsed="0.066057"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:37.996931" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:17:37.996770" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.996740" elapsed="0.000318"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:37.997764" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:37.998114" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:37.998187" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:37.929878" elapsed="0.068419"/>
</kw>
<msg time="2026-06-06T03:17:37.998395" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:37.998440" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "R "e "c "o "n "n "e "c "t "_ "B...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:37.923234" elapsed="0.075243"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:37.998829" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:37.998553" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:37.998535" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:37.923085" elapsed="0.075847"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:37.922897" elapsed="0.076068"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:37.920388" elapsed="0.078633"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:37.914209" elapsed="0.084869"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:37.913543" elapsed="0.085635"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:37.908965" elapsed="0.090270"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:37.999662" elapsed="0.000110"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:37.999373" elapsed="0.000455"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:38.008809" level="INFO">${start_cmd} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug </msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:38.008459" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:38.009246" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug </msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:38.008998" elapsed="0.000294"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:38.012168" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug</msg>
<msg time="2026-06-06T03:17:38.012260" level="INFO">${output} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug 
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:38.009488" elapsed="0.002798"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:38.012714" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug 
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:38.012449" elapsed="0.000312"/>
</kw>
<arg>${BGP_PEER_COMMAND}</arg>
<arg>${BGP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:38.008073" elapsed="0.004744"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.015142" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l2026-06-06 03:17:38,103 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:38,105 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:38,107 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:17:38,109 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:17:38,110 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:17:38,111 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:17:38,111 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:17:38,111 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:17:38,112 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:38,113 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:17:38,113 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:38,114 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:38,122 INFO BGP-Thread-1 (job): ... idle for 0.009s
2026-06-06 03:17:38,123 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.009s
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:17:38.014402" elapsed="10.001728">No match found for '&gt;' in 10 seconds
Output:
[?2004l
2026-06-06 03:17:38,103 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:38,105 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:38,107 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
    [ Message content over the limit has been removed. ]
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.016456" elapsed="0.000032"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:17:38.014131" elapsed="10.002536">No match found for '&gt;' in 10 seconds
Output:
[?2004l
2026-06-06 03:17:38,103 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:38,105 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:38,107 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
    [ Message content over the limit has been removed. ]
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:17:38.013722" elapsed="10.003100"/>
</kw>
<msg time="2026-06-06T03:17:48.016944" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:38.013336" elapsed="10.003634"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:17:48.017159" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:17:48.017064" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.017038" elapsed="0.000208"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.017705" elapsed="0.000028"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.017885" elapsed="0.000027"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:17:38.013055" elapsed="10.004918"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.030212" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:48.043922" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:48.044178" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.030011" elapsed="0.014226"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.045389" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.044705" elapsed="0.000787"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:48.045873" elapsed="0.000762"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:48.029587" elapsed="0.017223"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.063807" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:48.104047" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:48.104261" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.063622" elapsed="0.040695"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.105369" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.104789" elapsed="0.000681"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:48.105848" elapsed="0.000780"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:48.063258" elapsed="0.043581"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:48.107799" elapsed="0.000347"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:48.107338" elapsed="0.000895"/>
</kw>
<doc>Start BGP peer tool</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:37.908182" elapsed="10.200104"/>
</test>
<test id="s1-s7-t13" name="TC2_BGP_Application_Peer_Put_3_Routes" line="220">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:48.114337" elapsed="0.000294"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:48.113954" elapsed="0.000780"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.115949" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.115812" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.115789" elapsed="0.000234"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.121108" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.120992" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.120973" elapsed="0.000204"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.122199" 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-06-06T03:17:48.121816" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.122704" 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-06-06T03:17:48.122389" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:48.122776" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:17:48.122938" 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-06-06T03:17:48.121416" elapsed="0.001547"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:48.129094" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.128983" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.128964" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:48.130384" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.130274" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.130255" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:48.130937" 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-06-06T03:17:48.130603" elapsed="0.000362"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.131385" level="INFO">${current_connection_index} = 7</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-06-06T03:17:48.131165" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.161578" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:48.132132" elapsed="0.029647"/>
</kw>
<msg time="2026-06-06T03:17:48.161978" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:48.162026" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:48.131777" elapsed="0.030286"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.189906" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "P "u "t "_ "3 "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:48.162731" elapsed="0.027363"/>
</kw>
<msg time="2026-06-06T03:17:48.190262" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:48.190310" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a...</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-06-06T03:17:48.162295" elapsed="0.028052"/>
</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-06-06T03:17:48.190733" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.190438" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.190413" elapsed="0.000413"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.191283" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "P "u "t "_ "3 "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:48.190974" elapsed="0.000384"/>
</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-06-06T03:17:48.191668" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.191427" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.191407" elapsed="0.000585"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:48.192031" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:48.194805" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:17:48.195016" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:48.193593" elapsed="0.001556"/>
</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="NOT RUN" start="2026-06-06T03:17:48.195433" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.195949" elapsed="0.000111"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:48.192946" elapsed="0.003234"/>
</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-06-06T03:17:48.192361" elapsed="0.003887"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:48.129961" elapsed="0.066394"/>
</kw>
<msg time="2026-06-06T03:17:48.196449" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:48.196495" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:48.129318" elapsed="0.067215"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:48.196739" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:48.196611" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.196592" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.197231" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.197572" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.197647" elapsed="0.000029"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:48.128630" elapsed="0.069141"/>
</kw>
<msg time="2026-06-06T03:17:48.197865" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:48.197910" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:48.123389" elapsed="0.074560"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.198279" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.198024" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.198006" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:48.123242" elapsed="0.075139"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:48.123051" elapsed="0.075361"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:48.120607" elapsed="0.077860"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:48.115492" elapsed="0.083078"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:48.114998" elapsed="0.083620"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:48.109969" elapsed="0.088733"/>
</kw>
<kw name="Switch_To_BGP_Application_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_app_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:48.199117" elapsed="0.000110"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.198842" elapsed="0.000442"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.208089" level="INFO">${start_cmd} = python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-typ...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:48.207754" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.208548" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.208302" elapsed="0.000297"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.213865" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<msg time="2026-06-06T03:17:48.213959" level="INFO">${output} =  python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-ty...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:48.208773" elapsed="0.005212"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.214395" level="INFO"> python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.214149" elapsed="0.000295"/>
</kw>
<arg>${BGP_APP_PEER_PUT_COMMAND} ${SCRIPT_URI_OPT}</arg>
<arg>${BGP_APP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:48.207311" elapsed="0.007189"/>
</kw>
<kw name="Wait_Until_Console_Tool_Finish" owner="BGPcliKeywords">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.368328" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:48.219296" elapsed="0.149166"/>
</kw>
<arg>${timeout}</arg>
<arg>1s</arg>
<arg>SSHLibrary.Read Until Prompt</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:48.218800" elapsed="0.149735"/>
</kw>
<arg>${BGP_APP_PEER_TIMEOUT}</arg>
<doc>Wait ${timeout} for the tool exit.</doc>
<status status="PASS" start="2026-06-06T03:17:48.218441" elapsed="0.150172"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.378016" level="INFO">Executing command 'cat bgp_app_peer.log'.</msg>
<msg time="2026-06-06T03:17:48.390924" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:48.391166" level="INFO">${output_log} = 2026-06-06 03:17:48,346 INFO: Put 3 prefix(es) in a single request (starting from 8.0.1.0/28) into 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-fam...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.377866" elapsed="0.013359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.392271" level="INFO">2026-06-06 03:17:48,346 INFO: Put 3 prefix(es) in a single request (starting from 8.0.1.0/28) into 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
2026-06-06 03:17:48,350 DEBUG: ...streaming chunk 1 (prefix: 8.0.1.0/28)
2026-06-06 03:17:48,350 DEBUG: xml data
&lt;ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.0/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.0/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt;
2026-06-06 03:17:48,350 DEBUG: ...streaming chunk 2 (prefix: 8.0.1.16/28)
2026-06-06 03:17:48,350 DEBUG: xml data
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.16/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.16/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt;
2026-06-06 03:17:48,350 DEBUG: ...streaming chunk 3 (prefix: 8.0.1.32/28)
2026-06-06 03:17:48,350 DEBUG: xml data
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.32/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.32/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt; 
&lt;/ipv4-routes&gt;
2026-06-06 03:17:48,363 DEBUG: &lt;PreparedRequest [PUT]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
2026-06-06 03:17:48,363 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Transfer-Encoding': 'chunked', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:48,363 DEBUG: Response: 
2026-06-06 03:17:48,363 DEBUG: &lt;Response [201]&gt; Created
2026-06-06 03:17:48,363 INFO: Total test execution time: 0.017s
2026-06-06 03:17:48,363 INFO: Total build data time: 0.001s
2026-06-06 03:17:48,363 INFO: Total response time: 0.016s
2026-06-06 03:17:48,363 INFO: Total number of response(s): 1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.391606" elapsed="0.001012"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.393865" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_put_tc2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_put_tc2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:48.393071" elapsed="0.000923"/>
</kw>
<arg>bgp_app_peer.log</arg>
<arg>bgp_app_peer_put_tc2.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:48.377452" elapsed="0.016681"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:48.395509" elapsed="0.000589"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:48.394813" elapsed="0.001435"/>
</kw>
<doc>Start BGP application peer tool and give him 30s</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:48.109109" elapsed="0.287228"/>
</test>
<test id="s1-s7-t14" name="TC2_Check_Example-IPv4-Topology_Is_Filled_With_3_Routes" line="228">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:48.401841" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:48.401550" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.403211" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.403077" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.403053" elapsed="0.000233"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.408340" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.408233" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.408215" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.409447" 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-06-06T03:17:48.409062" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.409952" 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-06-06T03:17:48.409641" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:48.410024" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:17:48.410186" 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-06-06T03:17:48.408636" elapsed="0.001574"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:48.415857" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.415745" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.415725" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:48.417163" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.417048" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.417029" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:48.417717" 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-06-06T03:17:48.417380" elapsed="0.000364"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.418128" level="INFO">${current_connection_index} = 8</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-06-06T03:17:48.417909" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.450863" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:48.418680" elapsed="0.032357"/>
</kw>
<msg time="2026-06-06T03:17:48.451224" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:48.451271" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:48.418319" elapsed="0.032989"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.490582" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "W "i "t "h "_ "3 "_ "R "o "u "t "e "[78Cs "[A[78C"[K
[K
[?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-06-06T03:17:48.452000" elapsed="0.038714"/>
</kw>
<msg time="2026-06-06T03:17:48.490944" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:48.490991" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p...</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-06-06T03:17:48.451553" elapsed="0.039476"/>
</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-06-06T03:17:48.491371" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.491119" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.491094" elapsed="0.000360"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.491942" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "W "i "t "h "_ "3 "_ "R "o "u "t "e "[78Cs "[A[78C"[K
[K
[?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-06-06T03:17:48.491604" elapsed="0.000443"/>
</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-06-06T03:17:48.492343" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.492118" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.492099" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:48.492459" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:48.495105" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:17:48.495317" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:48.494007" elapsed="0.001443"/>
</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="NOT RUN" start="2026-06-06T03:17:48.495762" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.496119" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:48.493331" elapsed="0.002980"/>
</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-06-06T03:17:48.492777" elapsed="0.003598"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:48.416746" elapsed="0.079729"/>
</kw>
<msg time="2026-06-06T03:17:48.496568" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:48.496613" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:48.416118" elapsed="0.080555"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:48.496862" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:48.496754" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.496735" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.497356" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.497720" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.497795" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:48.415392" elapsed="0.082512"/>
</kw>
<msg time="2026-06-06T03:17:48.497999" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:48.498044" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:48.410586" elapsed="0.087496"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.498411" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.498157" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.498139" elapsed="0.000351"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:48.410440" elapsed="0.088074"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:48.410266" elapsed="0.088280"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:48.407874" elapsed="0.090728"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:48.402733" elapsed="0.095983"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:48.402267" elapsed="0.096497"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:48.398617" elapsed="0.100202"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.552075" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:48.551695" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.553023" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:48.552615" elapsed="0.000487">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:48.553198" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:48.552277" elapsed="0.000946"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.553811" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:48.553393" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.554144" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:48.554307" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:48.554005" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.554758" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.554492" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.555986" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.555524" elapsed="0.000523"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.556577" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:48.556220" elapsed="0.000383"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.557065" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.557810" elapsed="0.000049"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.558148" elapsed="0.000044"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:17:48.556838" elapsed="0.001473"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.556672" elapsed="0.001705"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:48.558424" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:48.558587" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:48.555172" elapsed="0.003440"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.554872" elapsed="0.003776"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.558849" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.558695" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.554851" elapsed="0.004074"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.559515" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:48.559071" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:48.559593" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:48.551056" elapsed="0.008681"/>
</kw>
<msg time="2026-06-06T03:17:48.559858" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:48.537926" elapsed="0.021985"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.572839" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.585671" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.598328" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.598537" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.598735" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.599121" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.598971" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:48.598954" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.599350" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.599521" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.599708" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:48.598921" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.598815" elapsed="0.000974"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.599939" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.600015" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:17:48.600147" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:48.533573" elapsed="0.066604"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.601498" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:48.601231" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:48.601701" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:48.600867" elapsed="0.000860"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.602117" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.601801" elapsed="0.000376"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.602708" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:48.602387" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.602203" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.601782" elapsed="0.001012"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.605166" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:48.602952" elapsed="0.002241"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:48.605246" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:48.605404" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:48.600507" elapsed="0.004922"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.606725" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:48.606470" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:48.606884" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:48.606124" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:17:48.607118" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:48.606981" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.606962" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.607355" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.607531" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.607596" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:17:48.609723" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:48.605792" elapsed="0.003958"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.611195" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.610939" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.611648" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.611400" elapsed="0.000306"/>
</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-06-06T03:17:48.621987" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:48.622125" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:17:48.622237" 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-06-06T03:17:48.613903" elapsed="0.008361"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.611773" elapsed="0.010535"/>
</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-06-06T03:17:48.622494" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.622334" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.611755" elapsed="0.010825"/>
</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-06-06T03:17:48.626105" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.623615" elapsed="0.002539"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.623388" elapsed="0.002834"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.623369" elapsed="0.002882"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.628921" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.626539" elapsed="0.002429"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.626310" elapsed="0.002692"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.626292" elapsed="0.002736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.629581" 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-06-06T03:17:48.629196" elapsed="0.000413"/>
</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-06-06T03:17:48.629976" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.629699" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.630538" 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-06-06T03:17:48.630231" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.630062" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.629679" elapsed="0.000944"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.631175" 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-06-06T03:17:48.630808" elapsed="0.000394"/>
</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-06-06T03:17:48.631514" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.631273" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.632082" 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-06-06T03:17:48.631780" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.631596" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.631254" elapsed="0.000911"/>
</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-06-06T03:17:48.632320" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:48.633150" 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-06-06T03:17:48.632858" elapsed="0.000320"/>
</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-06-06T03:17:48.633339" elapsed="0.002421"/>
</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-06-06T03:17:48.622956" elapsed="0.012869"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.636005" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.635897" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.635877" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:48.639077" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:17:48.636224" elapsed="0.002883"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:17:48.639159" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:48.639315" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:17:48.610101" elapsed="0.029241"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:48.639403" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:17:48.639553" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:48.510587" elapsed="0.128992"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.669227" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:48.668394" elapsed="0.000864"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.671332" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:48.670777" elapsed="0.000713">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:48.671623" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:48.669433" elapsed="0.002237"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.672608" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:48.671844" elapsed="0.000793"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:48.673077" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:48.673328" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:48.672838" elapsed="0.000518"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.673971" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.673518" elapsed="0.000519"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:48.674755" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.674111" elapsed="0.000807"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.675755" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:48.675126" elapsed="0.000671"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.674946" elapsed="0.000934"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.674089" elapsed="0.001814"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.676850" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:48.676056" elapsed="0.000824"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:48.676932" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:48.667671" elapsed="0.009390"/>
</kw>
<msg time="2026-06-06T03:17:48.677117" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:48.654599" elapsed="0.022567"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.690076" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.702783" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.715590" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.715806" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.715988" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.716371" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.716222" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:48.716207" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.716594" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.716783" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.716954" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:48.716177" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.716071" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.717183" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.717258" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:48.717380" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:48.651875" elapsed="0.065532"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:48.717586" elapsed="0.002259"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:48.721073" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:48.720590" elapsed="0.000512"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:48.721717" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:48.721260" elapsed="0.000487"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:17:48.721909" elapsed="0.000329"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:17:48.720174" elapsed="0.002124"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.719927" elapsed="0.002404"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.722508" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.722356" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.719907" elapsed="0.002678"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:17:48.640741" elapsed="0.081891"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:17:48.639923" elapsed="0.082808"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.639681" elapsed="0.083131"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.639648" elapsed="0.083190"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:48.722874" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:17:48.504134" elapsed="0.218869"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:48.499840" elapsed="0.223228"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:48.499315" elapsed="0.223802"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:48.498961" elapsed="0.224231"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:48.723794" elapsed="0.000239"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:48.723469" elapsed="0.000627"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:48.397180" elapsed="0.326954"/>
</test>
<test id="s1-s7-t15" name="TC2_BGP_Peer_Check_Incomming_Updates_For_3_Introduced_Prefixes" line="233">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:48.727548" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:48.727280" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.728833" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.728721" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.728701" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.734104" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.733997" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.733979" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.735201" 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-06-06T03:17:48.734812" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.735737" 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-06-06T03:17:48.735420" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:48.735809" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:48.735962" 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-06-06T03:17:48.734401" elapsed="0.001586"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:48.741478" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.741370" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.741351" elapsed="0.000194"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:48.742729" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:48.742592" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.742574" elapsed="0.000225"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:48.743247" 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-06-06T03:17:48.742949" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.743703" level="INFO">${current_connection_index} = 8</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-06-06T03:17:48.743463" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.773745" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:48.744238" elapsed="0.029613"/>
</kw>
<msg time="2026-06-06T03:17:48.774016" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:48.774062" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:48.743896" elapsed="0.030202"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.830590" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "I "n "t "r "o "d "u "c "e "d "_ "[78CP "[A[78Cr
 "e "f "i "x "e "s "[K"
[?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-06-06T03:17:48.774708" elapsed="0.056081"/>
</kw>
<msg time="2026-06-06T03:17:48.830993" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:48.831040" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</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-06-06T03:17:48.774325" elapsed="0.056755"/>
</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-06-06T03:17:48.831485" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.831185" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.831153" elapsed="0.000417"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.832099" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "I "n "t "r "o "d "u "c "e "d "_ "[78CP "[A[78Cr
 "e "f "i "x "e "s "[K"
[?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-06-06T03:17:48.831750" elapsed="0.000436"/>
</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-06-06T03:17:48.832477" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.832255" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.832236" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:48.832593" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:48.835320" elapsed="0.001852"/>
</kw>
<msg time="2026-06-06T03:17:48.837242" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:48.834195" elapsed="0.003184"/>
</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="NOT RUN" start="2026-06-06T03:17:48.837684" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.838029" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:48.833527" elapsed="0.004688"/>
</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-06-06T03:17:48.832961" elapsed="0.005320"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:48.742292" elapsed="0.096089"/>
</kw>
<msg time="2026-06-06T03:17:48.838474" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:48.838520" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:48.741719" elapsed="0.096839"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:48.838765" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:48.838641" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.838618" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.839260" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.839601" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:48.839694" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:48.741034" elapsed="0.098771"/>
</kw>
<msg time="2026-06-06T03:17:48.839898" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:48.839943" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:48.736348" elapsed="0.103632"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:48.840310" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:48.840055" elapsed="0.000358"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:48.840038" elapsed="0.000400"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:48.736204" elapsed="0.104259"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:48.736037" elapsed="0.104458"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:48.733620" elapsed="0.106929"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:48.728415" elapsed="0.112189"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:48.727987" elapsed="0.112679"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:48.725076" elapsed="0.115645"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:48.841160" elapsed="0.000107"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:48.840882" elapsed="0.000442"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.854024" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:48.867395" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:48.867528" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.853854" elapsed="0.013700"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.868095" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.867786" elapsed="0.000355"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:48.868297" elapsed="0.000321"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:48.853491" elapsed="0.015213"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:48.841478" elapsed="0.027283"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.881033" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.0/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:48.921321" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:48.921421" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.880868" elapsed="0.040578"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.921912" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.921615" elapsed="0.000343"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:48.922113" elapsed="0.000315"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.0/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:48.880488" elapsed="0.042001"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.934561" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.16/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:48.973122" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:48.973222" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.934396" elapsed="0.038851"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:48.973698" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:48.973416" elapsed="0.000328"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:48.973899" elapsed="0.000312"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.16/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:48.934012" elapsed="0.040260"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:48.986609" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.32/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:49.025270" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.025374" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:48.986439" elapsed="0.038961"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.025877" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.025575" elapsed="0.000348"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:49.026078" elapsed="0.000323"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.32/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:48.986053" elapsed="0.040416"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.038488" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:49.077465" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.077824" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.038324" elapsed="0.039564"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.079039" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.078343" elapsed="0.000805"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:49.079500" elapsed="0.000815"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:49.037979" elapsed="0.042489"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:49.081904" elapsed="0.000553"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:49.081145" elapsed="0.001462"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:48.724460" elapsed="0.358274"/>
</test>
<test id="s1-s7-t16" name="TC2_BGP_Application_Peer_Delete_All_Routes" line="249">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:49.088172" elapsed="0.000303"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:49.087762" elapsed="0.000794"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.090060" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.089877" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.089844" elapsed="0.000318"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.096362" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.096233" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.096215" elapsed="0.000218"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.097531" 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-06-06T03:17:49.097068" elapsed="0.000494"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.098051" 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-06-06T03:17:49.097749" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:49.098122" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:17:49.098288" 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-06-06T03:17:49.096683" elapsed="0.001629"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:49.104072" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.103963" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.103943" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:49.105351" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.105243" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.105224" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:49.105900" 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-06-06T03:17:49.105568" elapsed="0.000358"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.106307" level="INFO">${current_connection_index} = 7</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-06-06T03:17:49.106092" elapsed="0.000241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.136954" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:49.106856" elapsed="0.030202"/>
</kw>
<msg time="2026-06-06T03:17:49.137224" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:49.137270" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:49.106495" elapsed="0.030813"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.168026" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "D "e "l "e "t "e "_ "A "l "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:49.137864" elapsed="0.030331"/>
</kw>
<msg time="2026-06-06T03:17:49.168382" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:49.168430" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a...</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-06-06T03:17:49.137486" elapsed="0.030981"/>
</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-06-06T03:17:49.168797" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.168546" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.168525" elapsed="0.000353"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.169341" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "D "e "l "e "t "e "_ "A "l "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:49.169041" elapsed="0.000374"/>
</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-06-06T03:17:49.169720" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.169482" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.169464" elapsed="0.000336"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:49.169834" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:49.172367" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:17:49.172574" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:49.171293" elapsed="0.001434"/>
</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="NOT RUN" start="2026-06-06T03:17:49.173035" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.173384" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:49.170668" elapsed="0.002902"/>
</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-06-06T03:17:49.170121" elapsed="0.003515"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:49.104943" elapsed="0.068820"/>
</kw>
<msg time="2026-06-06T03:17:49.173857" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:49.173903" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:49.104315" elapsed="0.069627"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:49.174129" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:17:49.174021" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.174001" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.174628" elapsed="0.000049"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.174998" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.175070" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:49.103609" elapsed="0.071570"/>
</kw>
<msg time="2026-06-06T03:17:49.175274" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:49.175319" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:49.098711" elapsed="0.076645"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.175717" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.175432" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.175415" elapsed="0.000382"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:49.098548" elapsed="0.077273"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:49.098370" elapsed="0.077482"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:49.095841" elapsed="0.080065"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:49.089432" elapsed="0.086574"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:49.088797" elapsed="0.087257"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:49.084602" elapsed="0.091505"/>
</kw>
<kw name="Switch_To_BGP_Application_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_app_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:49.176516" elapsed="0.000106"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.176237" elapsed="0.000462"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.185737" level="INFO">${start_cmd} = python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:49.185390" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.186179" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.185928" elapsed="0.000299"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.191446" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<msg time="2026-06-06T03:17:49.191561" level="INFO">${output} =  python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:49.186381" elapsed="0.005208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.192059" level="INFO"> python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.191789" elapsed="0.000320"/>
</kw>
<arg>${BGP_APP_PEER_DELETE_ALL_COMMAND} ${SCRIPT_URI_OPT}</arg>
<arg>${BGP_APP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:49.184952" elapsed="0.007215"/>
</kw>
<kw name="Wait_Until_Console_Tool_Finish" owner="BGPcliKeywords">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.335599" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:49.197047" elapsed="0.138691"/>
</kw>
<arg>${timeout}</arg>
<arg>1s</arg>
<arg>SSHLibrary.Read Until Prompt</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:49.196527" elapsed="0.139284"/>
</kw>
<arg>${BGP_APP_PEER_TIMEOUT}</arg>
<doc>Wait ${timeout} for the tool exit.</doc>
<status status="PASS" start="2026-06-06T03:17:49.196177" elapsed="0.139708"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.345288" level="INFO">Executing command 'cat bgp_app_peer.log'.</msg>
<msg time="2026-06-06T03:17:49.358275" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.358415" level="INFO">${output_log} = 2026-06-06 03:17:49,310 INFO: Delete all prefixes from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-f...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.345136" elapsed="0.013317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.359114" level="INFO">2026-06-06 03:17:49,310 INFO: Delete all prefixes from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:17:49,325 DEBUG: &lt;PreparedRequest [DELETE]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
2026-06-06 03:17:49,325 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:49,325 DEBUG: Response: 
2026-06-06 03:17:49,325 DEBUG: &lt;Response [204]&gt; No Content
2026-06-06 03:17:49,325 INFO: Total test execution time: 0.016s
2026-06-06 03:17:49,325 INFO: Total build data time: 0.000s
2026-06-06 03:17:49,326 INFO: Total response time: 0.014s
2026-06-06 03:17:49,326 INFO: Total number of response(s): 1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.358715" elapsed="0.000474"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.360008" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_delete_all_tc2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_delete_all_tc2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:49.359492" elapsed="0.000596"/>
</kw>
<arg>bgp_app_peer.log</arg>
<arg>bgp_app_peer_delete_all_tc2.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:49.344735" elapsed="0.015444"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:49.361533" elapsed="0.000608"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:49.360842" elapsed="0.001445"/>
</kw>
<doc>Start BGP application peer tool and give him 30s</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:49.083478" elapsed="0.278894"/>
</test>
<test id="s1-s7-t17" name="TC2_Check_Example-IPv4-Topology_Is_Empty" line="257">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:49.369120" elapsed="0.000218"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:49.368850" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.370463" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.370327" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.370302" elapsed="0.000236"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.376003" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.375894" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.375875" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.377099" 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-06-06T03:17:49.376713" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.377586" 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-06-06T03:17:49.377291" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:49.377674" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:17:49.377839" 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-06-06T03:17:49.376313" elapsed="0.001550"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:49.383404" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.383294" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.383275" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:49.384715" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.384581" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.384562" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:49.385235" 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-06-06T03:17:49.384933" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.385644" level="INFO">${current_connection_index} = 8</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-06-06T03:17:49.385424" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.421387" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:49.386186" elapsed="0.035350"/>
</kw>
<msg time="2026-06-06T03:17:49.421745" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:49.421792" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:49.385848" elapsed="0.035981"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.456628" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:17:49.422425" elapsed="0.034330"/>
</kw>
<msg time="2026-06-06T03:17:49.456913" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:49.456960" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p...</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-06-06T03:17:49.422037" elapsed="0.034959"/>
</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-06-06T03:17:49.457328" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.457085" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.457059" elapsed="0.000349"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.457889" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:17:49.457556" elapsed="0.000411"/>
</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-06-06T03:17:49.458324" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.458097" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.458077" elapsed="0.000326"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:49.458440" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:49.461122" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:17:49.461338" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:49.459984" elapsed="0.001489"/>
</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="NOT RUN" start="2026-06-06T03:17:49.461777" elapsed="0.000084"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.462129" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:49.459321" elapsed="0.003003"/>
</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-06-06T03:17:49.458765" elapsed="0.003640"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:49.384279" elapsed="0.078231"/>
</kw>
<msg time="2026-06-06T03:17:49.462606" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:49.462669" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:49.383682" elapsed="0.079027"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:49.463110" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:49.462996" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.462768" elapsed="0.000429"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.463607" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.463973" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.464046" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:49.382955" elapsed="0.081201"/>
</kw>
<msg time="2026-06-06T03:17:49.464256" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:49.464301" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:49.378242" elapsed="0.086096"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.464729" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.464414" elapsed="0.000371"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.464396" elapsed="0.000413"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:49.378096" elapsed="0.086738"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:49.377921" elapsed="0.086944"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:49.375507" elapsed="0.089414"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:49.370024" elapsed="0.094955"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:49.369552" elapsed="0.095473"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:49.364487" elapsed="0.100593"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.517967" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:49.517555" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.518937" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:49.518563" elapsed="0.000451">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:49.519108" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:49.518216" elapsed="0.000917"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.519715" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:49.519306" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.520049" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:49.520200" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:49.519909" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.520642" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.520388" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.521933" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.521463" elapsed="0.000533"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.522528" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:49.522165" elapsed="0.000390"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.522974" elapsed="0.000047"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.523723" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.524061" elapsed="0.000046"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:17:49.522784" elapsed="0.001443"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.522606" elapsed="0.001689"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:49.524343" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:49.524506" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:49.521075" elapsed="0.003457"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.520774" elapsed="0.003791"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.524761" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.524590" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.520754" elapsed="0.004086"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.525460" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:49.524992" elapsed="0.000496"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:49.525537" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:49.516917" elapsed="0.008762"/>
</kw>
<msg time="2026-06-06T03:17:49.525736" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:49.503752" elapsed="0.022033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.538569" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.551213" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.564185" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.564385" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.564564" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.564961" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.564811" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:49.564797" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.565190" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.565361" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.565529" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:49.564767" elapsed="0.000814"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.564643" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.565788" elapsed="0.000027"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.565872" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:49.565990" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:49.499429" elapsed="0.066587"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.567273" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:49.567034" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:49.567431" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:49.566685" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.567793" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.567525" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.568350" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:49.568051" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.567875" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.567507" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.570829" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:49.568588" elapsed="0.002267"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:49.570906" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:49.571059" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:49.566341" elapsed="0.004779"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.572360" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:49.572125" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:49.572517" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:49.571781" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:17:49.572768" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:17:49.572612" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.572594" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.573006" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.573181" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.573246" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:49.575203" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:49.571433" elapsed="0.003796"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.576644" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.576385" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.577111" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.576863" elapsed="0.000293"/>
</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-06-06T03:17:49.587464" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:49.587673" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:17:49.587832" 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-06-06T03:17:49.579513" elapsed="0.008356"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.577224" elapsed="0.010709"/>
</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-06-06T03:17:49.588194" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.587970" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.577205" elapsed="0.011110"/>
</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-06-06T03:17:49.593271" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.589795" elapsed="0.003543"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.589457" elapsed="0.003931"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.589430" elapsed="0.003994"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.596612" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.593847" elapsed="0.002829"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.593503" elapsed="0.003210"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.593479" elapsed="0.003259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.597302" 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-06-06T03:17:49.596914" elapsed="0.000415"/>
</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-06-06T03:17:49.597648" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.597402" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.598242" 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-06-06T03:17:49.597915" elapsed="0.000354"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.597746" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.597383" elapsed="0.000987"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.598925" 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-06-06T03:17:49.598536" elapsed="0.000417"/>
</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-06-06T03:17:49.599267" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.599026" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.599835" 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-06-06T03:17:49.599517" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.599350" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.599007" elapsed="0.000914"/>
</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-06-06T03:17:49.600078" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:49.600911" 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-06-06T03:17:49.600597" elapsed="0.000341"/>
</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-06-06T03:17:49.601099" elapsed="0.002421"/>
</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-06-06T03:17:49.588842" elapsed="0.014743"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.603783" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.603673" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.603641" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:49.606726" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:17:49.604002" elapsed="0.002753"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:17:49.606809" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:17:49.606969" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:17:49.575544" elapsed="0.031452"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:49.607060" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:17:49.607214" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:49.476563" elapsed="0.130678"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.636787" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:49.636023" elapsed="0.000792"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.638909" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:49.638293" elapsed="0.000780">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:49.639209" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:49.636983" elapsed="0.002251"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.640185" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:49.639404" elapsed="0.000809"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:49.640761" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:49.641013" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:49.640487" elapsed="0.000554"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.641675" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.641212" elapsed="0.000529"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:49.642419" elapsed="0.000082"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.641813" elapsed="0.000770"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.643468" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:49.642852" elapsed="0.000657"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.642647" elapsed="0.000946"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.641792" elapsed="0.001825"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.644560" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:49.643788" elapsed="0.000802"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:49.644644" elapsed="0.000071"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:49.635286" elapsed="0.009530"/>
</kw>
<msg time="2026-06-06T03:17:49.644870" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:49.622436" elapsed="0.022484"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.657647" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.670233" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.682920" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.683149" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.683338" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.683739" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.683575" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:49.683559" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.684002" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.684177" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.684349" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:49.683530" elapsed="0.000872"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.683422" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.684582" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.684673" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:17:49.684793" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:49.619731" elapsed="0.065089"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:49.684999" elapsed="0.002223"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:49.688309" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:49.687976" elapsed="0.000362"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:49.688813" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:49.688493" elapsed="0.000348"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:17:49.688999" elapsed="0.000325"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:17:49.687546" elapsed="0.001838"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.687304" elapsed="0.002113"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.689592" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.689442" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.687285" elapsed="0.002402"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:17:49.608466" elapsed="0.081269"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:17:49.607597" elapsed="0.082213"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.607327" elapsed="0.082530"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.607309" elapsed="0.082572"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:49.689914" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:17:49.470293" elapsed="0.219754"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:49.466082" elapsed="0.224029"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:49.465569" elapsed="0.224590"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:49.465221" elapsed="0.224999"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:49.690823" elapsed="0.000241"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:49.690498" elapsed="0.000666"/>
</kw>
<doc>See new routes are deleted.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:49.363179" elapsed="0.328057"/>
</test>
<test id="s1-s7-t18" name="TC2_BGP_Peer_Check_Incomming_Updates_For_3_Withdrawn_Prefixes" line="262">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:49.694771" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:49.694479" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.696075" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.695964" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.695944" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.701380" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.701272" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.701253" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.702453" 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-06-06T03:17:49.702074" elapsed="0.000406"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.702957" 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-06-06T03:17:49.702648" elapsed="0.000335"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:49.703027" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:49.703180" 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-06-06T03:17:49.701693" elapsed="0.001513"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:49.708775" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.708664" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.708627" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:49.710013" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:49.709907" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.709888" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:49.710528" 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-06-06T03:17:49.710230" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.710955" level="INFO">${current_connection_index} = 8</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-06-06T03:17:49.710738" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.742676" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:49.711505" elapsed="0.031276"/>
</kw>
<msg time="2026-06-06T03:17:49.742946" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:49.742993" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:49.711143" elapsed="0.031887"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.782109" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "W "i "t "h "d "r "a "w "n "_ "P "[78Cr "[A[78Ce
 "f "i "x "e "s "[K"
[?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-06-06T03:17:49.743550" elapsed="0.038684"/>
</kw>
<msg time="2026-06-06T03:17:49.782405" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:49.782451" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</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-06-06T03:17:49.743205" elapsed="0.039284"/>
</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-06-06T03:17:49.782845" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.782572" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.782550" elapsed="0.000377"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.783392" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "W "i "t "h "d "r "a "w "n "_ "P "[78Cr "[A[78Ce
 "f "i "x "e "s "[K"
[?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-06-06T03:17:49.783075" elapsed="0.000451"/>
</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-06-06T03:17:49.783839" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.783596" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.783577" elapsed="0.000342"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:49.783955" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:49.786613" elapsed="0.001844"/>
</kw>
<msg time="2026-06-06T03:17:49.788526" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:49.785480" elapsed="0.003195"/>
</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="NOT RUN" start="2026-06-06T03:17:49.788966" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.789308" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:49.784849" elapsed="0.004647"/>
</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-06-06T03:17:49.784249" elapsed="0.005313"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:49.709580" elapsed="0.080099"/>
</kw>
<msg time="2026-06-06T03:17:49.789775" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:49.789820" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:49.709000" elapsed="0.080858"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:49.790045" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:49.789936" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.789917" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.790574" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.790937" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:49.791009" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:49.708309" elapsed="0.082807"/>
</kw>
<msg time="2026-06-06T03:17:49.791210" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:49.791254" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:49.703590" elapsed="0.087701"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:49.791623" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:49.791368" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:49.791350" elapsed="0.000375"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:49.703441" elapsed="0.088313"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:49.703256" elapsed="0.088535"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:49.700904" elapsed="0.090945"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:49.695671" elapsed="0.096248"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:49.695195" elapsed="0.096770"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:49.692249" elapsed="0.099769"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:49.792457" elapsed="0.000109"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:49.792152" elapsed="0.000470"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.805318" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:49.818757" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.819144" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.805149" elapsed="0.014053"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.820291" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.819628" elapsed="0.000770"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:49.820822" elapsed="0.000724"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:49.804802" elapsed="0.016925"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>3</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:49.792794" elapsed="0.029060"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.838117" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.0/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:49.869010" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.869225" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.837951" elapsed="0.031330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.870296" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.869725" elapsed="0.000671"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:49.870781" elapsed="0.000699"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.0/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:49.837570" elapsed="0.034047"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.887436" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.16/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:49.920539" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.920785" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.887272" elapsed="0.033570"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.921823" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.921215" elapsed="0.000709"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:49.922299" elapsed="0.000742"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.16/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:49.886919" elapsed="0.036259"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.940106" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.32/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:49.972926" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:49.973192" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.939940" elapsed="0.033310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:49.974354" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:49.973722" elapsed="0.000733"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:49.974862" elapsed="0.000717"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.32/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:49.939579" elapsed="0.036187"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:49.992131" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:17:50.024798" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:50.025075" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:49.991963" elapsed="0.033170"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:50.026234" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:50.025567" elapsed="0.000767"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:17:50.026713" elapsed="0.000858"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:17:49.991534" elapsed="0.036237"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:50.029165" elapsed="0.000580"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:50.028414" elapsed="0.001478"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:49.691579" elapsed="0.338398"/>
</test>
<test id="s1-s7-t19" name="TC2_Stop_BGP_Peer" line="278">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:50.037441" elapsed="0.000509"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:50.036837" elapsed="0.001244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:50.040445" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:50.040306" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.040283" elapsed="0.000238"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:50.045581" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:50.045473" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.045455" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:50.046689" 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-06-06T03:17:50.046287" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:50.047177" 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-06-06T03:17:50.046881" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:50.047249" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:17:50.047414" 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-06-06T03:17:50.045904" elapsed="0.001559"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:50.053218" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:50.053109" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.053089" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:50.054479" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:50.054371" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.054352" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:50.055032" 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-06-06T03:17:50.054729" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:50.055442" level="INFO">${current_connection_index} = 7</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-06-06T03:17:50.055224" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:50.090934" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:50.056035" elapsed="0.035001"/>
</kw>
<msg time="2026-06-06T03:17:50.091220" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:50.091267" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:50.055689" elapsed="0.035615"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:50.117813" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "S "t "o "p "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:50.091856" elapsed="0.026059"/>
</kw>
<msg time="2026-06-06T03:17:50.118077" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:50.118124" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</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-06-06T03:17:50.091482" elapsed="0.026679"/>
</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-06-06T03:17:50.118468" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:50.118240" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.118219" elapsed="0.000328"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:50.119018" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "S "t "o "p "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:17:50.118718" elapsed="0.000367"/>
</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-06-06T03:17:50.119377" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:50.119154" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.119135" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:50.119490" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:50.122293" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:17:50.122504" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:50.121112" elapsed="0.001533"/>
</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="NOT RUN" start="2026-06-06T03:17:50.122944" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:50.123293" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:50.120462" elapsed="0.003018"/>
</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-06-06T03:17:50.119839" elapsed="0.003708"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:50.054068" elapsed="0.069601"/>
</kw>
<msg time="2026-06-06T03:17:50.123770" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:50.123815" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:50.053444" elapsed="0.070410"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:50.124040" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:17:50.123932" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.123913" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:50.124552" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:50.124924" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:50.124998" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:50.052769" elapsed="0.072339"/>
</kw>
<msg time="2026-06-06T03:17:50.125204" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:50.125249" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "2 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:50.047867" elapsed="0.077421"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:50.125618" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:50.125365" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:50.125347" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:50.047720" elapsed="0.078018"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:50.047522" elapsed="0.078248"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:50.045112" elapsed="0.080714"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:50.039759" elapsed="0.086125"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:50.038551" elapsed="0.087380"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:50.031836" elapsed="0.094152"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:50.126392" elapsed="0.000107"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:50.126119" elapsed="0.000437"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:50.127914" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:50.127347" elapsed="0.000596"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:50.128101" elapsed="0.000251"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:17:50.127070" elapsed="0.001354"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.130847" level="INFO">2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.017s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:48,370 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
^CTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt

[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:17:52.131960" level="INFO">${output} = 2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.017s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (...</msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:17:50.128581" elapsed="2.003455"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.133269" level="INFO">2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.017s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:48,370 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
^CTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt

[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.132554" elapsed="0.001405"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:17:50.126750" elapsed="2.007350"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.146965" level="INFO">Executing command 'cat bgp_peer.log'.</msg>
<msg time="2026-06-06T03:17:52.160622" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:52.160747" level="INFO">${output_log} = 2026-06-06 03:17:38,103 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:38,104 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:52.146818" elapsed="0.013957"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.161209" level="INFO">2026-06-06 03:17:38,103 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:38,104 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:38,105 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:38,107 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:17:38,108 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:17:38,109 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:17:38,109 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:17:38,110 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:17:38,110 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:17:38,111 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:17:38,111 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:17:38,111 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:17:38,112 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:38,113 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:38,113 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:17:38,113 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:38,114 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:38,122 INFO BGP-Thread-1 (job): ... idle for 0.009s
2026-06-06 03:17:38,123 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.009s
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:38,123 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:38,124 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:38,125 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.017s
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:48,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:48,370 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,371 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,372 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,373 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:48,374 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:48,375 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:48,376 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,331 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,332 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,333 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:17:49,334 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:49,335 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:17:49,336 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:49,337 DEBUG BGP-Thread-1 (job): NLRI prefix list: []</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.160944" elapsed="0.000929"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.163048" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer_tc2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer_tc2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:52.162288" elapsed="0.000889"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>bgp_peer_tc2.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:52.146438" elapsed="0.016878"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:52.164734" elapsed="0.000549"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:52.163973" elapsed="0.001453"/>
</kw>
<doc>Stop BGP peer tool</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:50.030634" elapsed="2.134879"/>
</test>
<test id="s1-s7-t20" name="TC3_BGP_Application_Peer_Put_3_Routes" line="285">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:52.171565" elapsed="0.000233"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:52.171296" elapsed="0.000558"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.172953" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.172811" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.172787" elapsed="0.000243"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.178213" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.178103" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.178084" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.179309" 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-06-06T03:17:52.178919" elapsed="0.000418"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.179823" 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-06-06T03:17:52.179501" elapsed="0.000349"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:52.179895" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:17:52.180058" 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-06-06T03:17:52.178515" elapsed="0.001568"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:52.185927" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.185817" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.185790" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:52.187240" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.187129" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.187110" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:52.187796" 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-06-06T03:17:52.187464" elapsed="0.000360"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.188215" level="INFO">${current_connection_index} = 7</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-06-06T03:17:52.187990" elapsed="0.000252"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.220851" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:52.188809" elapsed="0.032236"/>
</kw>
<msg time="2026-06-06T03:17:52.221274" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:52.221324" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:52.188438" elapsed="0.032925"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.251933" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "P "u "t "_ "3 "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:52.222082" elapsed="0.029965"/>
</kw>
<msg time="2026-06-06T03:17:52.252211" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:52.252336" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a...</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-06-06T03:17:52.221608" elapsed="0.030768"/>
</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-06-06T03:17:52.252770" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.252472" elapsed="0.000358"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.252444" elapsed="0.000415"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.253365" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "P "u "t "_ "3 "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:17:52.253054" elapsed="0.000386"/>
</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-06-06T03:17:52.253754" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.253511" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.253490" elapsed="0.000346"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:52.253874" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:52.256770" elapsed="0.000193"/>
</kw>
<msg time="2026-06-06T03:17:52.257041" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:52.255478" elapsed="0.001730"/>
</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="NOT RUN" start="2026-06-06T03:17:52.257503" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.258004" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:52.254817" elapsed="0.003388"/>
</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-06-06T03:17:52.254204" elapsed="0.004070"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:52.186814" elapsed="0.071564"/>
</kw>
<msg time="2026-06-06T03:17:52.258478" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:52.258526" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:52.186155" elapsed="0.072413"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:52.258795" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:17:52.258671" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.258629" elapsed="0.000256"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.259311" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.259690" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.259767" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:52.185446" elapsed="0.074434"/>
</kw>
<msg time="2026-06-06T03:17:52.259978" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:52.260024" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:52.180484" elapsed="0.079582"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.260405" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.260144" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.260126" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:52.180337" elapsed="0.080175"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:52.180140" elapsed="0.080406"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:52.177736" elapsed="0.082887"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:52.172485" elapsed="0.088223"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:52.172008" elapsed="0.088792"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:52.168386" elapsed="0.092474"/>
</kw>
<kw name="Switch_To_BGP_Application_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_app_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:52.261329" elapsed="0.000110"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.261042" elapsed="0.000456"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.270662" level="INFO">${start_cmd} = python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-typ...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:52.270306" elapsed="0.000387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.271115" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.270858" elapsed="0.000307"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.276098" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<msg time="2026-06-06T03:17:52.276198" level="INFO">${output} =  python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-ty...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:52.271329" elapsed="0.004896"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.276661" level="INFO"> python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command put --count 3 --prefix 8.0.1.0 --prefixlen 28 --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.276392" elapsed="0.000321"/>
</kw>
<arg>${BGP_APP_PEER_PUT_COMMAND} ${SCRIPT_URI_OPT}</arg>
<arg>${BGP_APP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:52.269872" elapsed="0.006900"/>
</kw>
<kw name="Wait_Until_Console_Tool_Finish" owner="BGPcliKeywords">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.441346" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:17:52.281586" elapsed="0.159898"/>
</kw>
<arg>${timeout}</arg>
<arg>1s</arg>
<arg>SSHLibrary.Read Until Prompt</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:52.281075" elapsed="0.160486"/>
</kw>
<arg>${BGP_APP_PEER_TIMEOUT}</arg>
<doc>Wait ${timeout} for the tool exit.</doc>
<status status="PASS" start="2026-06-06T03:17:52.280730" elapsed="0.160916"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.451725" level="INFO">Executing command 'cat bgp_app_peer.log'.</msg>
<msg time="2026-06-06T03:17:52.465166" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:17:52.465270" level="INFO">${output_log} = 2026-06-06 03:17:52,405 INFO: Put 3 prefix(es) in a single request (starting from 8.0.1.0/28) into 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-fam...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:17:52.451549" elapsed="0.013781"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.466364" level="INFO">2026-06-06 03:17:52,405 INFO: Put 3 prefix(es) in a single request (starting from 8.0.1.0/28) into 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
2026-06-06 03:17:52,409 DEBUG: ...streaming chunk 1 (prefix: 8.0.1.0/28)
2026-06-06 03:17:52,409 DEBUG: xml data
&lt;ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.0/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.0/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt;
2026-06-06 03:17:52,409 DEBUG: ...streaming chunk 2 (prefix: 8.0.1.16/28)
2026-06-06 03:17:52,409 DEBUG: xml data
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.16/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.16/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt;
2026-06-06 03:17:52,409 DEBUG: ...streaming chunk 3 (prefix: 8.0.1.32/28)
2026-06-06 03:17:52,410 DEBUG: xml data
&lt;ipv4-route&gt;
  &lt;prefix&gt;8.0.1.32/28&lt;/prefix&gt;
  &lt;path-id&gt;0&lt;/path-id&gt;
  &lt;route-key&gt;8.0.1.32/28&lt;/route-key&gt;
  &lt;attributes&gt;
   &lt;ipv4-next-hop&gt;
    &lt;global&gt;192.0.2.1&lt;/global&gt;
   &lt;/ipv4-next-hop&gt;&lt;as-path/&gt;
   &lt;multi-exit-disc&gt;
    &lt;med&gt;0&lt;/med&gt;
   &lt;/multi-exit-disc&gt;
   &lt;local-pref&gt;
    &lt;pref&gt;100&lt;/pref&gt;
   &lt;/local-pref&gt;
   &lt;originator-id&gt;
    &lt;originator&gt;41.41.41.41&lt;/originator&gt;
   &lt;/originator-id&gt;
   &lt;origin&gt;
    &lt;value&gt;igp&lt;/value&gt;
   &lt;/origin&gt;
   &lt;cluster-id&gt;
    &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
   &lt;/cluster-id&gt;
  &lt;/attributes&gt;
 &lt;/ipv4-route&gt; 
&lt;/ipv4-routes&gt;
2026-06-06 03:17:52,426 DEBUG: &lt;PreparedRequest [PUT]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
2026-06-06 03:17:52,426 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Transfer-Encoding': 'chunked', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:17:52,426 DEBUG: Response: 
2026-06-06 03:17:52,426 DEBUG: &lt;Response [201]&gt; Created
2026-06-06 03:17:52,426 INFO: Total test execution time: 0.021s
2026-06-06 03:17:52,426 INFO: Total build data time: 0.001s
2026-06-06 03:17:52,426 INFO: Total response time: 0.019s
2026-06-06 03:17:52,426 INFO: Total number of response(s): 1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.465750" elapsed="0.000973"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.467847" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_put_tc3.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_put_tc3.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:17:52.467141" elapsed="0.000835"/>
</kw>
<arg>bgp_app_peer.log</arg>
<arg>bgp_app_peer_put_tc3.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:52.451122" elapsed="0.016990"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:52.469454" elapsed="0.000587"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:52.468755" elapsed="0.001431"/>
</kw>
<doc>Start BGP application peer tool and give him 30s</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:52.166529" elapsed="0.303744"/>
</test>
<test id="s1-s7-t21" name="TC3_Check_Example-IPv4-Topology_Is_Filled_With_3_Routes" line="293">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:52.475882" elapsed="0.000303"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:52.475446" elapsed="0.000818"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.477751" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.477549" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.477518" elapsed="0.000335"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.483578" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.483469" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.483450" elapsed="0.000216"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.484687" 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-06-06T03:17:52.484284" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.485183" 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-06-06T03:17:52.484882" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:52.485255" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:17:52.485416" 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-06-06T03:17:52.483900" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:52.491071" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.490961" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.490940" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:52.492335" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.492227" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.492208" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:52.492884" 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-06-06T03:17:52.492553" elapsed="0.000358"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.493295" level="INFO">${current_connection_index} = 8</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-06-06T03:17:52.493076" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.523774" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:52.493845" elapsed="0.030045"/>
</kw>
<msg time="2026-06-06T03:17:52.524052" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:52.524099" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:52.493485" elapsed="0.030651"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.564377" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "W "i "t "h "_ "3 "_ "R "o "u "t "e "[78Cs "[A[78C"[K
[K
[?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-06-06T03:17:52.524678" elapsed="0.039817"/>
</kw>
<msg time="2026-06-06T03:17:52.564723" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:52.564770" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p...</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-06-06T03:17:52.524310" elapsed="0.040499"/>
</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-06-06T03:17:52.565117" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.564887" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.564867" elapsed="0.000330"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.565665" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "F "i "l "l "e "d "_ "W "i "t "h "_ "3 "_ "R "o "u "t "e "[78Cs "[A[78C"[K
[K
[?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-06-06T03:17:52.565347" elapsed="0.000399"/>
</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-06-06T03:17:52.566036" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.565815" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.565796" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:52.566149" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:52.568794" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:17:52.569004" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:52.567642" elapsed="0.001498"/>
</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="NOT RUN" start="2026-06-06T03:17:52.569420" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.569791" elapsed="0.000162"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:52.566978" elapsed="0.003092"/>
</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-06-06T03:17:52.566425" elapsed="0.003710"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:52.491922" elapsed="0.078312"/>
</kw>
<msg time="2026-06-06T03:17:52.570327" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:52.570371" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:52.491300" elapsed="0.079109"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:52.570790" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:17:52.570486" elapsed="0.000368"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.570467" elapsed="0.000412"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.571284" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.571641" elapsed="0.000039"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.571730" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:52.490565" elapsed="0.081275"/>
</kw>
<msg time="2026-06-06T03:17:52.571933" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:52.571977" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:52.485839" elapsed="0.086176"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.572345" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.572090" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.572072" elapsed="0.000351"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:52.485691" elapsed="0.086756"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:52.485497" elapsed="0.086980"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:52.483096" elapsed="0.089433"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:52.477131" elapsed="0.095491"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:52.476487" elapsed="0.096201"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:52.472019" elapsed="0.100723"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.625346" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:52.624965" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.626278" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:52.625900" elapsed="0.000456">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:52.626451" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:52.625542" elapsed="0.000933"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.627053" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:52.626665" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.627385" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:52.627556" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:52.627247" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.628048" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.627781" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.629274" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.628833" elapsed="0.000503"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.629875" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:17:52.629501" elapsed="0.000401"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.630298" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.631057" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.631393" elapsed="0.000045"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:17:52.630108" elapsed="0.001448"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.629951" elapsed="0.001671"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:17:52.631819" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:17:52.632018" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:17:52.628465" elapsed="0.003580"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.628160" elapsed="0.003919"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.632257" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.632104" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.628141" elapsed="0.004217"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.632992" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:52.632512" elapsed="0.000509"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:52.633071" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:52.624321" elapsed="0.008877"/>
</kw>
<msg time="2026-06-06T03:17:52.633300" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:52.611325" elapsed="0.022028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.646075" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.658628" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.671567" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.671782" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.671965" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.672367" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.672190" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:52.672175" elapsed="0.000283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.672606" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.672798" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.672968" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:52.672145" elapsed="0.000876"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.672041" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.673195" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.673271" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:52.673391" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:52.607022" elapsed="0.066395"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.674701" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:52.674433" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:52.674868" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:52.674091" elapsed="0.000802"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.675249" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.674964" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.675829" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:52.675512" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.675334" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.674946" elapsed="0.000967"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.678335" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:52.676070" elapsed="0.002292"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:17:52.678415" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:17:52.678568" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:52.673760" elapsed="0.004833"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.679833" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:52.679582" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:52.679989" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:52.679244" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:17:52.680219" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:17:52.680083" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.680065" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.680482" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.680675" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.680742" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:17:52.682689" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:17:52.678918" elapsed="0.003799"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.684110" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.683861" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.684569" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.684310" elapsed="0.000303"/>
</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-06-06T03:17:52.694534" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:17:52.694699" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:17:52.694817" 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-06-06T03:17:52.686971" elapsed="0.007873"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.684696" elapsed="0.010192"/>
</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-06-06T03:17:52.695072" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.694915" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.684676" elapsed="0.010482"/>
</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-06-06T03:17:52.699307" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.0.1.32/28"},{"prefix":"8.0.1.16/28"},{"prefix":"8.0.1.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.696187" elapsed="0.003187"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.695962" elapsed="0.003505"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.695944" elapsed="0.003561"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.703304" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.699931" elapsed="0.003438"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.699588" elapsed="0.003830"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.699563" elapsed="0.003890"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.704246" 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-06-06T03:17:52.703709" elapsed="0.000576"/>
</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-06-06T03:17:52.704790" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.704386" elapsed="0.000490"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.705562" 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-06-06T03:17:52.705146" elapsed="0.000443"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.704911" elapsed="0.000715"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.704359" elapsed="0.001304"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.706197" 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-06-06T03:17:52.705831" elapsed="0.000393"/>
</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-06-06T03:17:52.706536" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.706296" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.707100" 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-06-06T03:17:52.706801" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.706619" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.706277" elapsed="0.000906"/>
</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-06-06T03:17:52.707344" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:17:52.708166" 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-06-06T03:17:52.707875" elapsed="0.000317"/>
</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-06-06T03:17:52.708351" elapsed="0.002392"/>
</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-06-06T03:17:52.695522" elapsed="0.015285"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.710985" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.710878" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.710858" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:52.714025" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<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="PASS" start="2026-06-06T03:17:52.711200" elapsed="0.002854"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:17:52.714106" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:52.714261" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:17:52.683028" elapsed="0.031260"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:52.714350" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:17:52.714500" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:17:52.584178" elapsed="0.130348"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.743931" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:52.743144" elapsed="0.000816"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.746000" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:17:52.745457" elapsed="0.000693">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:17:52.746283" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:52.744128" elapsed="0.002180"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.747243" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:17:52.746478" elapsed="0.000793"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:17:52.747709" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/filled_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:17:52.747950" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:17:52.747450" elapsed="0.000528"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.748563" level="INFO">{
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "prefix": "8.0.1.16/28"
       },
       {
        "prefix": "8.0.1.32/28"
       }
      ]
     },
     "node-id": "192.0.2.1"
    }
   ],
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.748139" elapsed="0.000490"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:17:52.749332" elapsed="0.000078"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.748718" elapsed="0.000774"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.750317" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:52.749713" elapsed="0.000645"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.749519" elapsed="0.000922"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.748698" elapsed="0.001767"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.751380" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:17:52.750615" elapsed="0.000794"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:17:52.751459" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:17:52.742418" elapsed="0.009164"/>
</kw>
<msg time="2026-06-06T03:17:52.751636" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:52.729541" elapsed="0.022212"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.764563" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.777316" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//filled_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.791257" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.791459" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.791644" elapsed="0.000033"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.792033" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.791885" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:17:52.791869" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.792257" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.792433" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.792603" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:17:52.791840" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.791735" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.792851" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.792928" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:17:52.793050" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:17:52.726849" elapsed="0.066228"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:52.793255" elapsed="0.002258"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:52.796759" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:52.796281" elapsed="0.000507"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:17:52.797394" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "node": [
    {
     "l3-unicast-igp-topology:igp-node-attributes": {
      "prefix": [
       {
        "prefix": "8.0.1.0/28"
       },
       {
        "pre...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:17:52.796947" elapsed="0.000476"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:17:52.797588" elapsed="0.000353"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:17:52.795865" elapsed="0.002137"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.795595" elapsed="0.002441"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.798211" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.798061" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.795575" elapsed="0.002712"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:17:52.715684" elapsed="0.082650"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:17:52.714868" elapsed="0.083546"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.714608" elapsed="0.083899"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.714591" elapsed="0.083943"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:17:52.798568" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:17:52.577993" elapsed="0.220721"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:52.573735" elapsed="0.225041"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:17:52.573223" elapsed="0.225600"/>
</kw>
<arg>filled_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:17:52.572877" elapsed="0.226002"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:17:52.799460" elapsed="0.000260"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:17:52.799150" elapsed="0.000635"/>
</kw>
<doc>See new routes in example-ipv4-topology as a proof that synchronization was correct.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:52.471061" elapsed="0.328762"/>
</test>
<test id="s1-s7-t22" name="TC3_Reconnect_BGP_Peer_And_Check_Incomming_Updates_For_3_Introduced_Prefixes" line="298">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:17:52.803725" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:17:52.803436" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.805012" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.804901" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.804881" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.810413" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.810304" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.810286" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.811496" 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-06-06T03:17:52.811107" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.812005" 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-06-06T03:17:52.811704" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:17:52.812075" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:17:52.812229" 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-06-06T03:17:52.810727" elapsed="0.001528"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:17:52.817824" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.817715" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.817695" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:17:52.819045" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:17:52.818939" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.818920" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:17:52.819556" 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-06-06T03:17:52.819261" elapsed="0.000322"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.819983" level="INFO">${current_connection_index} = 8</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-06-06T03:17:52.819764" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.852732" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:52.820516" elapsed="0.032359"/>
</kw>
<msg time="2026-06-06T03:17:52.853058" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:17:52.853105" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:17:52.820172" elapsed="0.032969"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.899440" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "R "e "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "_ "A "n "d "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "[78C_ "[A[78C3
 "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:17:52.853888" elapsed="0.045852"/>
</kw>
<msg time="2026-06-06T03:17:52.899997" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:17:52.900048" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "R "e "c "o "n "n "e "c "t "_ "B...</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-06-06T03:17:52.853440" elapsed="0.046648"/>
</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-06-06T03:17:52.900597" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.900226" elapsed="0.000467"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.900179" elapsed="0.000547"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.901321" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "R "e "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "_ "A "n "d "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "[78C_ "[A[78C3
 "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:17:52.900902" elapsed="0.000513"/>
</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-06-06T03:17:52.901762" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.901486" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.901466" elapsed="0.000381"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:17:52.901887" 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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:52.904783" elapsed="0.000159"/>
</kw>
<msg time="2026-06-06T03:17:52.905007" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:17:52.903574" elapsed="0.001576"/>
</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="NOT RUN" start="2026-06-06T03:17:52.905440" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.905810" elapsed="0.000086"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:17:52.902902" elapsed="0.003118"/>
</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-06-06T03:17:52.902263" elapsed="0.003825"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:17:52.818611" elapsed="0.087581"/>
</kw>
<msg time="2026-06-06T03:17:52.906343" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:52.906394" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "R "e "c "o "n "n "e "c "t "_ "B...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:52.818044" elapsed="0.088403"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:17:52.906939" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:17:52.906534" elapsed="0.000472"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.906514" elapsed="0.000520"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.907518" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.907894" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:17:52.907967" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:17:52.817335" elapsed="0.090747"/>
</kw>
<msg time="2026-06-06T03:17:52.908180" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:17:52.908224" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "R "e "c "o "n "n "e "c "t "_ "B...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:17:52.812619" elapsed="0.095644"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:17:52.908613" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:17:52.908342" elapsed="0.000424"/>
</branch>
<status status="PASS" start="2026-06-06T03:17:52.908323" elapsed="0.000470"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:17:52.812474" elapsed="0.096345"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:17:52.812305" elapsed="0.096548"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:17:52.809938" elapsed="0.098975"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:17:52.804593" elapsed="0.104382"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:17:52.804151" elapsed="0.104874"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:17:52.800959" elapsed="0.108124"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:17:52.909541" elapsed="0.000146"/>
</kw>
<status status="PASS" start="2026-06-06T03:17:52.909233" elapsed="0.000520"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.919104" level="INFO">${start_cmd} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug </msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:17:52.918688" elapsed="0.000447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.919570" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug </msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.919310" elapsed="0.000308"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:17:52.922885" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug</msg>
<msg time="2026-06-06T03:17:52.922985" level="INFO">${output} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug 
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:17:52.919801" elapsed="0.003211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:17:52.923451" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug 
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:17:52.923181" elapsed="0.000318"/>
</kw>
<arg>${BGP_PEER_COMMAND}</arg>
<arg>${BGP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:17:52.918150" elapsed="0.005408"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:18:02.925937" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l2026-06-06 03:17:53,023 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:53,026 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:17:53,030 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:17:53,030 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:17:53,030 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:17:53,032 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:53,036 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:17:53,036 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:53,036 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:53,044 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:17:53,044 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:53,050 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:53,050 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:17:52.925307" elapsed="10.001746">No match found for '&gt;' in 10 seconds
Output:
[?2004l
2026-06-06 03:17:53,023 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:53,026 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
    [ Message content over the limit has been removed. ]
...DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:02.927340" elapsed="0.000031"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:17:52.925028" elapsed="10.002501">No match found for '&gt;' in 10 seconds
Output:
[?2004l
2026-06-06 03:17:53,023 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:53,026 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
    [ Message content over the limit has been removed. ]
...DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:17:52.924591" elapsed="10.003093"/>
</kw>
<msg time="2026-06-06T03:18:02.927796" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:17:52.924201" elapsed="10.003621"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:18:02.928038" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:18:02.927917" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:02.927891" elapsed="0.000235"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:02.928355" elapsed="0.000026"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:02.928535" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:17:52.923892" elapsed="10.004725"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:02.941800" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:02.956166" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:02.956390" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:02.941604" elapsed="0.014843"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:02.957468" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:02.956871" elapsed="0.000699"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:02.957955" elapsed="0.000758"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:02.941233" elapsed="0.017625"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:02.928800" elapsed="0.030179"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:02.974434" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:03.008947" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.009182" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:02.974269" elapsed="0.034971"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.010281" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.009631" elapsed="0.000754"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:03.010779" elapsed="0.000719"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:02.973920" elapsed="0.037750"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.029097" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.0/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:03.060687" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.060911" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:03.028929" elapsed="0.032039"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.061963" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.061347" elapsed="0.000717"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:03.062416" elapsed="0.000748"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.0/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:03.028074" elapsed="0.035229"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.078492" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.16/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:03.116767" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.116984" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:03.078327" elapsed="0.038712"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.118034" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.117413" elapsed="0.000721"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:03.118476" elapsed="0.000735"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.16/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:03.077978" elapsed="0.041368"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.134396" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.0.1.32/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:03.168798" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.168936" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:03.134231" elapsed="0.034731"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.169470" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.169172" elapsed="0.000343"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:03.169694" elapsed="0.000316"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received: 8.0.1.32/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:03.133879" elapsed="0.036198"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.182236" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:03.221290" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.221436" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:03.182071" elapsed="0.039391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.222012" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.221705" elapsed="0.000353"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:03.222214" elapsed="0.000315"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:03.181709" elapsed="0.040887"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:03.223256" elapsed="0.000254"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:03.222926" elapsed="0.000647"/>
</kw>
<doc>Start BGP peer tool</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:17:52.800285" elapsed="10.423327"/>
</test>
<test id="s1-s7-t23" name="TC3_BGP_Application_Peer_Delete_All_Routes" line="317">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:03.227563" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:03.227223" elapsed="0.000626"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.228962" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.228820" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.228795" elapsed="0.000244"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.234148" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.234036" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.234017" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.235267" 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-06-06T03:18:03.234866" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.235807" 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-06-06T03:18:03.235462" elapsed="0.000377"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:03.235891" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:18:03.236057" 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-06-06T03:18:03.234453" elapsed="0.001628"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:03.241937" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.241821" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.241800" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:03.243230" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.243123" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.243104" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:03.243879" 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-06-06T03:18:03.243531" elapsed="0.000375"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.244299" level="INFO">${current_connection_index} = 7</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-06-06T03:18:03.244078" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.275461" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:03.245019" elapsed="0.030715"/>
</kw>
<msg time="2026-06-06T03:18:03.275979" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:03.276027" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:03.244489" elapsed="0.031576"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.307117" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "D "e "l "e "t "e "_ "A "l "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:18:03.276879" elapsed="0.030552"/>
</kw>
<msg time="2026-06-06T03:18:03.307803" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:03.307877" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a...</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-06-06T03:18:03.276335" elapsed="0.031600"/>
</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-06-06T03:18:03.308567" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.308105" elapsed="0.000585"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.308056" elapsed="0.000677"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.309602" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "D "e "l "e "t "e "_ "A "l "l "_ "R "o "u "t "e "s "[K"
[?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-06-06T03:18:03.308976" elapsed="0.000811"/>
</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-06-06T03:18:03.310287" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.309917" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.309885" elapsed="0.000628"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:03.310570" elapsed="0.000055"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:03.314502" elapsed="0.000177"/>
</kw>
<msg time="2026-06-06T03:18:03.314748" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:03.313059" elapsed="0.001833"/>
</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="NOT RUN" start="2026-06-06T03:18:03.315184" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.315541" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:03.311972" elapsed="0.003784"/>
</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-06-06T03:18:03.311055" elapsed="0.004870"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:03.242819" elapsed="0.073222"/>
</kw>
<msg time="2026-06-06T03:18:03.316145" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:03.316191" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:03.242166" elapsed="0.074064"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:03.316427" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:18:03.316314" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.316292" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.317010" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.317506" elapsed="0.000028"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.317587" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:03.241448" elapsed="0.076269"/>
</kw>
<msg time="2026-06-06T03:18:03.317818" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:03.317863" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "A "p "p "l "i "c "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:03.236472" elapsed="0.081433"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.318244" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.317985" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.317967" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:03.236325" elapsed="0.082022"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:03.236142" elapsed="0.082242"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:03.233666" elapsed="0.084784"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:03.228461" elapsed="0.090056"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:03.228007" elapsed="0.090560"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:03.224602" elapsed="0.094024"/>
</kw>
<kw name="Switch_To_BGP_Application_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_app_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:03.319080" elapsed="0.000109"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.318797" elapsed="0.000449"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.328137" level="INFO">${start_cmd} = python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:03.327793" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.328576" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.328329" elapsed="0.000356"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.333488" level="INFO">python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null</msg>
<msg time="2026-06-06T03:18:03.333583" level="INFO">${output} =  python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:03.328849" elapsed="0.004760"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.334053" level="INFO"> python3 bgp_app_peer.py --host 10.30.170.38 --port 8181 --command delete-all --debug --stream=vanadium --uri data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family &amp;&gt;/dev/null
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.333802" elapsed="0.000301"/>
</kw>
<arg>${BGP_APP_PEER_DELETE_ALL_COMMAND} ${SCRIPT_URI_OPT}</arg>
<arg>${BGP_APP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:18:03.327348" elapsed="0.006812"/>
</kw>
<kw name="Wait_Until_Console_Tool_Finish" owner="BGPcliKeywords">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.509962" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:18:03.339112" elapsed="0.171095"/>
</kw>
<arg>${timeout}</arg>
<arg>1s</arg>
<arg>SSHLibrary.Read Until Prompt</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:03.338459" elapsed="0.171896"/>
</kw>
<arg>${BGP_APP_PEER_TIMEOUT}</arg>
<doc>Wait ${timeout} for the tool exit.</doc>
<status status="PASS" start="2026-06-06T03:18:03.338114" elapsed="0.172405"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.524307" level="INFO">Executing command 'cat bgp_app_peer.log'.</msg>
<msg time="2026-06-06T03:18:03.537746" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.537971" level="INFO">${output_log} = 2026-06-06 03:18:03,470 INFO: Delete all prefixes from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-f...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:03.524148" elapsed="0.013882"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.539079" level="INFO">2026-06-06 03:18:03,470 INFO: Delete all prefixes from 10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family
2026-06-06 03:18:03,484 DEBUG: &lt;PreparedRequest [DELETE]&gt; http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
2026-06-06 03:18:03,485 DEBUG: Request headers: {'Content-Type': 'application/xml', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='}:
2026-06-06 03:18:03,485 DEBUG: Response: 
2026-06-06 03:18:03,485 DEBUG: &lt;Response [204]&gt; No Content
2026-06-06 03:18:03,485 INFO: Total test execution time: 0.015s
2026-06-06 03:18:03,485 INFO: Total build data time: 0.000s
2026-06-06 03:18:03,485 INFO: Total response time: 0.014s
2026-06-06 03:18:03,485 INFO: Total number of response(s): 1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.538406" elapsed="0.000793"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.540348" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_delete_all_tc3.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_app_peer_delete_all_tc3.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:18:03.539604" elapsed="0.000869"/>
</kw>
<arg>bgp_app_peer.log</arg>
<arg>bgp_app_peer_delete_all_tc3.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:03.523697" elapsed="0.016914"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:03.541925" elapsed="0.000355"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:03.541263" elapsed="0.001108"/>
</kw>
<doc>Start BGP application peer tool and give him 30s</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:03.224018" elapsed="0.318408"/>
</test>
<test id="s1-s7-t24" name="TC3_Check_Example-IPv4-Topology_Is_Empty" line="325">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:03.547356" elapsed="0.000334"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:03.546965" elapsed="0.000814"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.549263" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.549077" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.549043" elapsed="0.000322"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.554820" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.554686" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.554656" elapsed="0.000252"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.555988" 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-06-06T03:18:03.555565" elapsed="0.000452"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.556486" 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-06-06T03:18:03.556184" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:03.556637" elapsed="0.000061"/>
</return>
<msg time="2026-06-06T03:18:03.556840" 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-06-06T03:18:03.555173" elapsed="0.001693"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:03.563118" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.563004" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.562983" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:03.564420" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.564309" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.564289" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:03.565003" 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-06-06T03:18:03.564684" elapsed="0.000346"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.565424" level="INFO">${current_connection_index} = 8</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-06-06T03:18:03.565199" elapsed="0.000253"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.597781" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:03.566045" elapsed="0.031858"/>
</kw>
<msg time="2026-06-06T03:18:03.598072" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:03.598119" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:03.565694" elapsed="0.032462"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.627567" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:18:03.598748" elapsed="0.029112"/>
</kw>
<msg time="2026-06-06T03:18:03.628141" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:03.628190" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p...</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-06-06T03:18:03.598337" elapsed="0.029893"/>
</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-06-06T03:18:03.628795" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.628381" elapsed="0.000482"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.628330" elapsed="0.000563"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.629492" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "- "I "P "v "4 "- "T "o "p "o "l "o "g "y "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:18:03.629050" elapsed="0.000525"/>
</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-06-06T03:18:03.629919" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.629691" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.629670" elapsed="0.000329"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:03.630040" elapsed="0.000051"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:03.633016" elapsed="0.000159"/>
</kw>
<msg time="2026-06-06T03:18:03.633238" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:03.631782" elapsed="0.001598"/>
</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="NOT RUN" start="2026-06-06T03:18:03.633700" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.634041" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:03.631069" elapsed="0.003161"/>
</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-06-06T03:18:03.630418" elapsed="0.003880"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:03.564000" elapsed="0.070486"/>
</kw>
<msg time="2026-06-06T03:18:03.634587" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:03.634633" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:03.563353" elapsed="0.071340"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:03.634887" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:18:03.634776" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.634755" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.635398" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.635800" elapsed="0.000031"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.635883" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:03.562637" elapsed="0.073364"/>
</kw>
<msg time="2026-06-06T03:18:03.636105" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:03.636163" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "C "h "e "c "k "_ "E "x "a "m "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:03.557269" elapsed="0.078944"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.636565" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.636304" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.636284" elapsed="0.000389"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:03.557118" elapsed="0.079588"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:03.556928" elapsed="0.079818"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:03.554245" elapsed="0.082568"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:03.548633" elapsed="0.088244"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:03.548001" elapsed="0.088926"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:03.543688" elapsed="0.093299"/>
</kw>
<kw name="Wait_For_Topology_To_Change_To">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Compare_Topology">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.690405" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:03.689990" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.691370" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:03.690982" elapsed="0.000470">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:03.691547" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:03.690616" elapsed="0.000956"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.692172" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:03.691779" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.692509" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:03.692693" level="INFO">${template} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:03.692367" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.693195" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.692940" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.694475" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.694029" elapsed="0.000507"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.695091" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:03.694723" elapsed="0.000395"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.695539" elapsed="0.000047"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.696312" elapsed="0.000050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.696683" elapsed="0.000048"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:18:03.695347" elapsed="0.001504"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.695176" elapsed="0.001742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:03.696969" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:18:03.697140" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:03.693625" elapsed="0.003541"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.693316" elapsed="0.003882"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.697377" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.697224" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.693292" elapsed="0.004162"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.698087" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:03.697602" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:03.698165" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:03.689325" elapsed="0.008963"/>
</kw>
<msg time="2026-06-06T03:18:03.698343" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:03.676376" elapsed="0.022016"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.711497" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.723966" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.736571" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.736790" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.737014" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.737391" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.737240" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:03.737225" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.737616" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.737807" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.737991" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:03.737196" elapsed="0.000849"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.737093" elapsed="0.000977"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.738220" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.738296" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:18:03.738416" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:03.672048" elapsed="0.066394"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.739733" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:03.739472" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:03.739895" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:03.739121" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.740241" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.739990" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.740816" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:03.740504" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.740322" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.739971" elapsed="0.000928"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.743276" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:03.741054" elapsed="0.002248"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:18:03.743353" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:03.743505" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:03.738791" elapsed="0.004738"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.744782" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:03.744523" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:03.744939" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:03.744185" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:18:03.745170" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:18:03.745033" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.745014" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.745406" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.745583" elapsed="0.000079"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.745718" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:18:03.747843" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:03.743856" elapsed="0.004015"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.749287" level="INFO">rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.749038" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.749745" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.749487" elapsed="0.000302"/>
</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-06-06T03:18:03.758708" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:03.758895" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:18:03.759052" 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-06-06T03:18:03.752086" elapsed="0.007003"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.749855" elapsed="0.009295"/>
</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-06-06T03:18:03.759404" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.759187" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.749836" elapsed="0.009686"/>
</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-06-06T03:18:03.764397" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.760973" elapsed="0.003490"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.760633" elapsed="0.003878"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.760607" elapsed="0.003939"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.768245" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.764962" elapsed="0.003346"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.764623" elapsed="0.003733"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.764600" elapsed="0.003790"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.769177" 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-06-06T03:18:03.768621" elapsed="0.000594"/>
</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-06-06T03:18:03.769668" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.769314" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.770496" 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-06-06T03:18:03.770066" elapsed="0.000467"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.769786" elapsed="0.000798"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.769287" elapsed="0.001326"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.771187" 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-06-06T03:18:03.770820" elapsed="0.000394"/>
</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-06-06T03:18:03.771521" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.771284" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.772088" 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-06-06T03:18:03.771791" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.771604" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.771266" elapsed="0.000905"/>
</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-06-06T03:18:03.772324" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:03.773201" 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-06-06T03:18:03.772857" elapsed="0.000371"/>
</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-06-06T03:18:03.773391" elapsed="0.002380"/>
</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-06-06T03:18:03.760046" elapsed="0.015790"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.776013" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.775907" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.775887" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:18:03.778968" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<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="PASS" start="2026-06-06T03:18:03.776230" elapsed="0.002767"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:18:03.779051" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:03.779208" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:18:03.748191" elapsed="0.031043"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:03.779296" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:03.779446" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:18:03.649106" elapsed="0.130366"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.809022" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:03.808245" elapsed="0.000808"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.811136" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:03.810558" elapsed="0.000743">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:03.811437" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:03.809224" elapsed="0.002238"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.812403" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:03.811632" elapsed="0.000800"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:03.812860" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/empty_topology/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:03.813121" level="INFO">${template} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:03.812597" elapsed="0.000552"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.813772" level="INFO">{
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }
  }
 ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.813310" elapsed="0.000525"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:18:03.814532" elapsed="0.000078"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.813909" elapsed="0.000802"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.815533" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:03.814922" elapsed="0.000652"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.814742" elapsed="0.000977"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.813887" elapsed="0.001858"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.816690" level="INFO">${final_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:03.815898" elapsed="0.000823"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:03.816772" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:03.807517" elapsed="0.009385"/>
</kw>
<msg time="2026-06-06T03:18:03.816956" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:03.794520" elapsed="0.022485"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.829984" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.842693" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//empty_topology/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.857245" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.857496" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.857706" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.858177" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.857993" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:03.857973" elapsed="0.000290"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.858410" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.858582" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.858770" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:03.857932" elapsed="0.000893"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.857801" elapsed="0.001054"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.859008" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.859088" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:18:03.859244" level="INFO">${expected_text} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
       "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:03.791719" elapsed="0.067555"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:03.859521" elapsed="0.002385"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:18:03.863180" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:18:03.862730" elapsed="0.000487"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:18:03.863764" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
   }...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:18:03.863387" elapsed="0.000406"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:18:03.863961" elapsed="0.000351"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:18:03.862261" elapsed="0.002113"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.861988" elapsed="0.002420"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.864585" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.864433" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.861968" elapsed="0.002714"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:18:03.780622" elapsed="0.084109"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:18:03.779819" elapsed="0.084989"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.779555" elapsed="0.085299"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.779537" elapsed="0.085340"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:03.864911" elapsed="0.000036"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${folder_name}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:18:03.642853" elapsed="0.222193"/>
</kw>
<arg>${folder_name}</arg>
<doc>Get current example-ipv4-topology as json, and compare it to expected result.</doc>
<status status="PASS" start="2026-06-06T03:18:03.638066" elapsed="0.227043"/>
</kw>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Compare_Topology</arg>
<arg>${folder_name}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:03.637498" elapsed="0.227658"/>
</kw>
<arg>empty_topology</arg>
<doc>Wait until Compare_Topology matches expected result.</doc>
<status status="PASS" start="2026-06-06T03:18:03.637144" elapsed="0.228071"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:03.865826" elapsed="0.000239"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:03.865497" elapsed="0.000632"/>
</kw>
<doc>See new routes are deleted.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:03.542904" elapsed="0.323291"/>
</test>
<test id="s1-s7-t25" name="TC3_BGP_Peer_Check_Incomming_Updates_For_3_Withdrawn_Prefixes" line="330">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:03.869483" elapsed="0.000223"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:03.869220" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.870785" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.870671" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.870636" elapsed="0.000219"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.876101" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.875995" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.875976" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.877183" 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-06-06T03:18:03.876800" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.877783" 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-06-06T03:18:03.877413" elapsed="0.000397"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:03.877856" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:03.878012" 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-06-06T03:18:03.876400" elapsed="0.001637"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:03.883561" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.883452" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.883432" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:03.884824" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:03.884710" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.884690" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:03.885345" 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-06-06T03:18:03.885040" elapsed="0.000331"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.885775" level="INFO">${current_connection_index} = 8</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-06-06T03:18:03.885534" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.916596" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:03.886321" elapsed="0.030536"/>
</kw>
<msg time="2026-06-06T03:18:03.917117" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:03.917185" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:03.885966" elapsed="0.031262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.956751" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "W "i "t "h "d "r "a "w "n "_ "P "[78Cr "[A[78Ce
 "f "i "x "e "s "[K"
[?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-06-06T03:18:03.918061" elapsed="0.038835"/>
</kw>
<msg time="2026-06-06T03:18:03.957060" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:03.957106" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</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-06-06T03:18:03.917525" elapsed="0.039619"/>
</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-06-06T03:18:03.957533" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.957255" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.957220" elapsed="0.000399"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.958129" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "_ "C "h "e "c "k "_ "I "n "c "o "m "m "i "n "g "_ "U "p "d "a "t "e "s "_ "F "o "r "_ "3 "_ "W "i "t "h "d "r "a "w "n "_ "P "[78Cr "[A[78Ce
 "f "i "x "e "s "[K"
[?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-06-06T03:18:03.957810" elapsed="0.000408"/>
</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-06-06T03:18:03.958573" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.958286" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.958267" elapsed="0.000406"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:03.958718" elapsed="0.000051"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:03.961439" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:18:03.961674" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:03.960353" elapsed="0.001466"/>
</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="NOT RUN" start="2026-06-06T03:18:03.962105" elapsed="0.000202"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.962612" elapsed="0.000097"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:03.959687" elapsed="0.003140"/>
</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-06-06T03:18:03.959084" elapsed="0.003811"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:03.884381" elapsed="0.078617"/>
</kw>
<msg time="2026-06-06T03:18:03.963101" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:03.963149" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:03.883802" elapsed="0.079388"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:03.963697" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:18:03.963273" elapsed="0.000488"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.963252" elapsed="0.000535"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.964223" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.964612" elapsed="0.000043"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:03.964708" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:03.883113" elapsed="0.081709"/>
</kw>
<msg time="2026-06-06T03:18:03.964919" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:03.964963" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "_ "C "h...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:03.878420" elapsed="0.086582"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:03.965337" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:03.965079" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:03.965061" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:03.878274" elapsed="0.087167"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:03.878089" elapsed="0.087388"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:03.875614" elapsed="0.089923"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:03.870364" elapsed="0.095235"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:03.869915" elapsed="0.095751"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:03.867008" elapsed="0.098720"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:03.966156" elapsed="0.000108"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:03.965882" elapsed="0.000437"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:03.979196" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:03.992163" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:03.992298" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:03.979026" elapsed="0.013308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:03.992961" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:03.992567" elapsed="0.000456"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:03.993242" elapsed="0.000469"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:03.978677" elapsed="0.015121"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>3</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:03.966509" elapsed="0.027362"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.008507" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.0/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:04.044970" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:04.045257" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:04.008345" elapsed="0.036974"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.046500" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:04.045821" elapsed="0.000886"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:04.047088" elapsed="0.000798"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.0/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:04.007996" elapsed="0.040049"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.065321" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.16/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:04.097592" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:04.098109" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:04.065131" elapsed="0.033059"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.099793" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:04.098888" elapsed="0.001037"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:04.100366" elapsed="0.000911"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.16/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:04.064643" elapsed="0.036809"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.118423" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received: 8.0.1.32/28' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:04.148660" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:04.148807" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:04.118252" elapsed="0.030591"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.149468" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:04.149089" elapsed="0.000445"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:04.149785" elapsed="0.000470"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>withdrawn_prefix_received: 8.0.1.32/28</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:04.117865" elapsed="0.032481"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.165828" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:04.201093" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:04.201307" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:04.165659" elapsed="0.035704"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.202350" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:04.201776" elapsed="0.000672"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:04.202823" elapsed="0.000723"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>nlri_prefix_received:</arg>
<arg>3</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:04.165294" elapsed="0.038417"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:04.205029" elapsed="0.000529"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:04.204318" elapsed="0.001411"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:03.866424" elapsed="0.339393"/>
</test>
<test id="s1-s7-t26" name="TC3_Stop_BGP_Peer" line="346">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:04.211608" elapsed="0.000335"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:04.211212" elapsed="0.000815"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:04.213568" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:04.213380" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.213346" elapsed="0.000352"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:04.219484" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:04.219375" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.219356" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.220579" 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-06-06T03:18:04.220189" elapsed="0.000417"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.221090" 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-06-06T03:18:04.220790" elapsed="0.000395"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:04.221233" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:18:04.221399" 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-06-06T03:18:04.219806" elapsed="0.001618"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:04.227193" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:04.227083" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.227064" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:04.228450" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:04.228342" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.228323" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:04.229149" 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-06-06T03:18:04.228698" elapsed="0.000477"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.229556" level="INFO">${current_connection_index} = 7</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-06-06T03:18:04.229341" elapsed="0.000241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.259725" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:04.230111" elapsed="0.029718"/>
</kw>
<msg time="2026-06-06T03:18:04.259996" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:04.260042" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:04.229766" elapsed="0.030313"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:04.308743" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "S "t "o "p "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:18:04.260607" elapsed="0.048366"/>
</kw>
<msg time="2026-06-06T03:18:04.309226" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:04.309279" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</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-06-06T03:18:04.260257" elapsed="0.049064"/>
</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-06-06T03:18:04.309847" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:04.309450" elapsed="0.000467"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.309410" elapsed="0.000537"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.310529" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "S "t "o "p "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:18:04.310108" elapsed="0.000496"/>
</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-06-06T03:18:04.310959" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:04.310705" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.310683" elapsed="0.000359"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:04.311081" elapsed="0.000075"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:04.314219" elapsed="0.000158"/>
</kw>
<msg time="2026-06-06T03:18:04.314444" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:04.312940" elapsed="0.001645"/>
</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="NOT RUN" start="2026-06-06T03:18:04.314929" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:04.315307" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:04.312210" elapsed="0.003296"/>
</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-06-06T03:18:04.311495" elapsed="0.004102"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:04.228040" elapsed="0.088060"/>
</kw>
<msg time="2026-06-06T03:18:04.316207" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:04.316255" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:04.227419" elapsed="0.088877"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:04.316498" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:18:04.316380" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.316360" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:04.317057" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:04.317422" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:04.317497" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:04.226722" elapsed="0.090891"/>
</kw>
<msg time="2026-06-06T03:18:04.317755" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:04.317803" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "T "C "3 "_ "S "t "o "p "_ "B "G "P "_ "P "e...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:04.221825" elapsed="0.096017"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:04.318193" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:04.317926" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:04.317907" elapsed="0.000379"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:04.221675" elapsed="0.096643"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:04.221482" elapsed="0.096873"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:04.219013" elapsed="0.099406"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:04.212937" elapsed="0.105548"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:04.212262" elapsed="0.106273"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:04.207780" elapsed="0.110814"/>
</kw>
<kw name="Switch_To_BGP_Peer_Console">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:04.319185" elapsed="0.000115"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:04.318860" elapsed="0.000498"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:04.320810" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:04.320176" elapsed="0.000671"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:04.321018" elapsed="0.000245"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:18:04.319896" elapsed="0.001437"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.322314" level="INFO">2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.018s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:03,487 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
^CTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt

[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:18:06.323286" level="INFO">${output} = 2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.018s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (...</msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:18:04.321490" elapsed="2.001874"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.324844" level="INFO">2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.018s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:03,487 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
^CTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt

[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.323932" elapsed="0.001333"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:18:04.319537" elapsed="2.005899"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.341182" level="INFO">Executing command 'cat bgp_peer.log'.</msg>
<msg time="2026-06-06T03:18:06.354907" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:06.355152" level="INFO">${output_log} = 2026-06-06 03:17:53,023 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:53,024 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:06.341000" elapsed="0.014197"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.356104" level="INFO">2026-06-06 03:17:53,023 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:17:53,024 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:17:53,026 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:17:53,028 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:17:53,029 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:17:53,030 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:17:53,030 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:17:53,030 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:17:53,030 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:17:53,031 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0'
2026-06-06 03:17:53,032 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b40a1eabc2100206010400010001020641040000fbf0
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:53,034 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:53,035 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:17:53,036 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:17:53,036 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:17:53,036 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:17:53,044 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:17:53,044 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,044 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,045 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,046 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:53,050 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100
2026-06-06 03:17:53,050 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,055 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000100'
2026-06-06 03:17:53,056 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:53,057 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000100'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,058 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000100'
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.0/28']
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.0/28
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:53,059 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,060 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:53,061 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000120'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:53,062 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000120'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,063 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000120'
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.32/28']
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.32/28
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b020000003440010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:17:53,064 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:17:53,065 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0034' (52)
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800e0e00010104c0000201001c08000110'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08000110'
2026-06-06 03:17:53,066 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08000110'
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.0.1.16/28']
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.0.1.16/28
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:17:53,067 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.018s
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:18:03,074 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:03,487 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,488 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000100'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000100'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,489 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000100'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.0/28']
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.0/28
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,490 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000120'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000120'
2026-06-06 03:18:03,491 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000120'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.32/28']
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.32/28
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:03,492 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'002e' (46)
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'40010100400200800404000000004005040000006480090429292929800a0428282828800f080001011c08000110'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb''
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=4 (MULTI_EXIT_DISC, flags:0xb'80')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000000'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:03,493 DEBUG BGP-Thread-1 (job): Attribute value=0xb'29292929'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute value=0xb'28282828'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08000110'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08000110'
2026-06-06 03:18:03,494 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.0.1.16/28']
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.0.1.16/28
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:03,495 DEBUG BGP-Thread-1 (job): NLRI prefix list: []</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.355505" elapsed="0.001400"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:06.358172" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer_tc3.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer_tc3.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:18:06.357357" elapsed="0.000947"/>
</kw>
<arg>bgp_peer.log</arg>
<arg>bgp_peer_tc3.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:06.340535" elapsed="0.017919"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:06.359995" elapsed="0.000587"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:06.359186" elapsed="0.001637"/>
</kw>
<doc>Stop BGP peer tool</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:04.206280" elapsed="2.154678"/>
</test>
<test id="s1-s7-t27" name="Delete_Bgp_Peer_Configuration" line="353">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:06.367115" elapsed="0.000264"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:06.366766" elapsed="0.000678"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.368611" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.368464" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.368439" elapsed="0.000284"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.374422" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.374303" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.374281" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.375663" 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-06-06T03:18:06.375219" elapsed="0.000480"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.376189" 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-06-06T03:18:06.375874" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:06.376265" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:18:06.376436" 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-06-06T03:18:06.374792" elapsed="0.001670"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:06.382621" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.382487" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.382460" elapsed="0.000258"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:06.384179" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.384055" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.384030" elapsed="0.000236"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:06.384777" 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-06-06T03:18:06.384427" elapsed="0.000378"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.385202" level="INFO">${current_connection_index} = 7</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-06-06T03:18:06.384978" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.418366" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:06.385775" elapsed="0.032802"/>
</kw>
<msg time="2026-06-06T03:18:06.418830" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:06.418879" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:06.385397" elapsed="0.033520"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.447803" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:18:06.419693" elapsed="0.028242"/>
</kw>
<msg time="2026-06-06T03:18:06.448113" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:06.448263" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r...</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-06-06T03:18:06.419196" elapsed="0.029108"/>
</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-06-06T03:18:06.448712" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.448405" elapsed="0.000366"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.448375" elapsed="0.000425"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.449286" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:18:06.448951" elapsed="0.000406"/>
</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-06-06T03:18:06.449674" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.449428" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.449408" elapsed="0.000348"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:06.449794" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:06.452632" elapsed="0.000175"/>
</kw>
<msg time="2026-06-06T03:18:06.452875" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:06.451421" elapsed="0.001596"/>
</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="NOT RUN" start="2026-06-06T03:18:06.453313" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.453699" elapsed="0.000098"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:06.450709" elapsed="0.003211"/>
</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-06-06T03:18:06.450115" elapsed="0.003892"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:06.383718" elapsed="0.070395"/>
</kw>
<msg time="2026-06-06T03:18:06.454211" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:06.454256" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:06.382894" elapsed="0.071403"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:06.454493" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:18:06.454379" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.454358" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.455031" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.455424" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.455500" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:06.382093" elapsed="0.073521"/>
</kw>
<msg time="2026-06-06T03:18:06.455733" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:06.455778" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:06.376887" elapsed="0.078929"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.456155" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.455895" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.455877" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:06.376736" elapsed="0.079524"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:06.376522" elapsed="0.079772"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:06.373855" elapsed="0.082501"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:06.368125" elapsed="0.088291"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:06.367612" elapsed="0.088895"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:06.363878" elapsed="0.092692"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.457386" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.456787" elapsed="0.000629"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.504366" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:06.503971" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:06.505191" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:06.504938" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:06.505363" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:06.504573" elapsed="0.000814"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.505966" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:06.505558" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:06.506301" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:06.506475" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:06.506159" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.506926" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.506677" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.508034" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.507766" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.508508" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.508243" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.509224" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.508927" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.510004" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.509781" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.510083" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:18:06.510239" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.509440" elapsed="0.000824"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.510423" elapsed="0.000257"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:06.508779" elapsed="0.001943"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.511271" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.510976" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.512308" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.511917" elapsed="0.000419"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.512386" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:06.512589" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.511543" elapsed="0.001071"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.512789" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:18:06.510841" elapsed="0.002215"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.513605" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.513305" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.514386" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.514176" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.514461" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:06.514611" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.513854" elapsed="0.000782"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.514856" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:18:06.513169" elapsed="0.001952"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.515776" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.515405" elapsed="0.000397"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.516525" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.516315" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.516599" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:06.516766" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.515995" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.516949" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:06.515232" elapsed="0.001977"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:06.508584" elapsed="0.008659"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:06.517286" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:06.517442" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:06.507378" elapsed="0.010089"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.507044" elapsed="0.010455"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.517693" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.517525" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.507023" elapsed="0.010748"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.518555" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:06.517916" elapsed="0.000669"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:06.518633" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:06.503226" elapsed="0.015550"/>
</kw>
<msg time="2026-06-06T03:18:06.518831" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:06.490099" elapsed="0.028780"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.532463" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.545636" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.559052" elapsed="0.000054"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.559342" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.559607" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.560116" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.559948" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:06.559929" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.560373" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.560547" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.560742" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:06.559884" elapsed="0.000917"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.559743" elapsed="0.001087"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.560999" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.561081" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:18:06.561262" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:06.484505" elapsed="0.076787"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.562631" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.562300" elapsed="0.000415"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:06.582090" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:06.582224" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:06.582508" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:06.565304" elapsed="0.017272"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.562788" elapsed="0.019954"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.583244" elapsed="0.000163"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.582822" elapsed="0.000744"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.562769" elapsed="0.020868"/>
</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-06-06T03:18:06.592111" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.586338" elapsed="0.005819"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.585779" elapsed="0.006414"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.585730" elapsed="0.006488"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.594860" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.592503" elapsed="0.002404"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.592275" elapsed="0.002667"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.592258" elapsed="0.002708"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.595594" 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-06-06T03:18:06.595151" elapsed="0.000475"/>
</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-06-06T03:18:06.595998" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.595732" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.596551" 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-06-06T03:18:06.596247" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.596080" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.595708" elapsed="0.000926"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.597179" 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-06-06T03:18:06.596814" 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-06-06T03:18:06.597515" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.597276" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.598075" 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-06-06T03:18:06.597778" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.597597" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.597258" elapsed="0.000900"/>
</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-06-06T03:18:06.598319" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:06.599160" 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-06-06T03:18:06.598860" elapsed="0.000326"/>
</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-06-06T03:18:06.599346" elapsed="0.002474"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:18:06.584619" elapsed="0.017269"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:06.601939" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:18:06.604311" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:18:06.561593" elapsed="0.042746"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:06.604395" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:18:06.457674" elapsed="0.146851"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:06.605167" elapsed="0.000244"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:06.604854" elapsed="0.000620"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:06.361995" elapsed="0.243519"/>
</test>
<test id="s1-s7-t28" name="Delete_Bgp_Application_Peer_Configuration" line="366">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:06.609135" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:06.608867" elapsed="0.000531"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.610557" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.610441" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.610375" elapsed="0.000254"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.616074" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.615963" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.615944" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.617166" 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-06-06T03:18:06.616778" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.617670" 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-06-06T03:18:06.617358" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:06.617742" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:06.617897" 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-06-06T03:18:06.616378" elapsed="0.001543"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:06.623491" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.623382" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.623363" elapsed="0.000236"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:06.624934" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:06.624826" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.624807" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:06.625452" 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-06-06T03:18:06.625152" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.625881" level="INFO">${current_connection_index} = 7</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-06-06T03:18:06.625658" elapsed="0.000249"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.657394" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:06.626412" elapsed="0.031146"/>
</kw>
<msg time="2026-06-06T03:18:06.657846" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:06.657917" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:06.626070" elapsed="0.031902"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.685994" level="INFO">". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:18:06.658817" elapsed="0.027320"/>
</kw>
<msg time="2026-06-06T03:18:06.686332" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:06.686381" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "A "p "p "l...</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-06-06T03:18:06.658245" elapsed="0.028174"/>
</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-06-06T03:18:06.686789" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.686505" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.686481" elapsed="0.000394"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.687348" level="INFO"> ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "A "p "p "l "i "c "a "t "i "o "n "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:18:06.687025" elapsed="0.000400"/>
</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-06-06T03:18:06.687773" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.687495" elapsed="0.000340"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.687476" elapsed="0.000392"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:06.687914" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:06.691442" elapsed="0.000540"/>
</kw>
<msg time="2026-06-06T03:18:06.692083" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:06.689728" elapsed="0.002547"/>
</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="NOT RUN" start="2026-06-06T03:18:06.692715" elapsed="0.000117"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.693106" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:06.689042" elapsed="0.004257"/>
</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-06-06T03:18:06.688336" elapsed="0.005031"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:06.624497" elapsed="0.068972"/>
</kw>
<msg time="2026-06-06T03:18:06.693563" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:06.693608" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "A "p "p "l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:06.623812" elapsed="0.069852"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:06.693865" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:18:06.693746" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.693726" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.694361" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.694735" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.694813" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:06.623043" elapsed="0.071884"/>
</kw>
<msg time="2026-06-06T03:18:06.695022" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:06.695067" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "A "p "p "[C "P "e "e "r "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "g "p "_ "A "p "p "l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:06.618303" elapsed="0.076801"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.695440" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.695181" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.695163" elapsed="0.000356"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:06.618155" elapsed="0.077388"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:06.617979" elapsed="0.077595"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:06.615538" elapsed="0.080093"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:06.610096" elapsed="0.085639"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:06.609553" elapsed="0.086233"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:06.606552" elapsed="0.089293"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.696611" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer-app | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=${BGP_PEER_APP_NAME}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.696029" elapsed="0.000627"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.740563" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:06.740164" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:06.741450" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:06.741176" elapsed="0.000429">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:06.741749" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:06.740820" elapsed="0.000956"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.742353" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:06.741950" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:06.742734" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_application_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:06.742913" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:06.742552" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.743361" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.743105" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.744433" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.744169" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.744934" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.744660" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.745636" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.745336" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.748488" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.748212" elapsed="0.000304"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.748573" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:18:06.748756" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.745871" elapsed="0.002910"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.748942" elapsed="0.000244"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:06.745196" elapsed="0.004032"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.749842" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.749481" elapsed="0.000390"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.750611" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.750397" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.750706" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:06.750864" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.750071" elapsed="0.000827"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.751064" elapsed="0.000227"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:18:06.749344" elapsed="0.001988"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.751959" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.751598" elapsed="0.000388"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.752749" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.752502" elapsed="0.000281"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.752843" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:18:06.753000" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.752181" elapsed="0.000843"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.753180" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:18:06.751444" elapsed="0.002046"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.754064" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:06.753759" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:06.754838" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.754606" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:06.754916" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:06.755066" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:06.754283" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:06.755246" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:06.753605" elapsed="0.001904"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:06.745016" elapsed="0.010528"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:06.755589" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:06.755804" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:06.743834" elapsed="0.011999"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.743480" elapsed="0.012386"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.756046" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.755892" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.743458" elapsed="0.012679"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.756960" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:06.756287" elapsed="0.000703"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:06.757039" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:06.739460" elapsed="0.017703"/>
</kw>
<msg time="2026-06-06T03:18:06.757218" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:06.726466" elapsed="0.030799"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.817070" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.829866" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_application_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.842486" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.842850" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.843049" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.843477" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.843322" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:06.843303" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.843724" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.843913" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.844085" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:06.843261" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.843139" elapsed="0.001028"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.844319" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:06.844399" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:18:06.844557" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:06.722034" elapsed="0.122551"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.845827" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.845504" elapsed="0.000376"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:06.854813" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ps5yumbq9ti212tbc0xcu7y977.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:06.854865" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:06.854980" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:06.848093" elapsed="0.006914"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.845948" elapsed="0.009101"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.855234" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.855075" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.845929" elapsed="0.009389"/>
</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-06-06T03:18:06.859887" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.856418" elapsed="0.003558"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.856187" elapsed="0.003841"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.856167" elapsed="0.003897"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.863785" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.860461" elapsed="0.003389"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.860143" elapsed="0.003755"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.860119" elapsed="0.003853"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.864807" 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-06-06T03:18:06.864224" elapsed="0.000630"/>
</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-06-06T03:18:06.865241" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.864942" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.865820" 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-06-06T03:18:06.865495" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.865325" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.864919" elapsed="0.000985"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.866439" 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-06-06T03:18:06.866071" elapsed="0.000396"/>
</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-06-06T03:18:06.866795" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:06.866538" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.867343" 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-06-06T03:18:06.867043" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:06.866879" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.866519" elapsed="0.000908"/>
</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-06-06T03:18:06.867584" elapsed="0.000390"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:06.868442" 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-06-06T03:18:06.868146" elapsed="0.000322"/>
</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-06-06T03:18:06.868628" elapsed="0.002383"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:18:06.855710" elapsed="0.015366"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:06.871125" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:18:06.873446" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:18:06.844880" elapsed="0.028593"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:06.873527" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_application_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:18:06.696900" elapsed="0.176776"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:06.874281" elapsed="0.000242"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:06.873973" elapsed="0.000613"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:06.605969" elapsed="0.268655"/>
</test>
<kw name="Teardown_Everything" type="TEARDOWN">
<kw name="Search_And_Kill_Remote_Python" owner="KillPythonTool">
<kw name="Search_For_Remote_Python_Processes" owner="KillPythonTool">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.876267" level="INFO">Executing command 'ps -elf | egrep python | egrep 'play.py' | egrep -v grep'.</msg>
<msg time="2026-06-06T03:18:06.900144" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:18:06.900387" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>ps -elf | egrep python | egrep ${filter} | egrep -v grep</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:06.876122" elapsed="0.024325"/>
</kw>
<return>
<value>${processes}</value>
<status status="PASS" start="2026-06-06T03:18:06.900567" elapsed="0.000120"/>
</return>
<msg time="2026-06-06T03:18:06.901049" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>${filter}</arg>
<doc>Only searches for the list of processes, in case something else than kill has to be done with them.</doc>
<status status="PASS" start="2026-06-06T03:18:06.875827" elapsed="0.025286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.902171" level="INFO"/>
<arg>${processes}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.901515" elapsed="0.000756"/>
</kw>
<kw name="Kill_Remote_Processes" owner="KillPythonTool">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.904305" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:18:06.904488" level="INFO">${arg_length} = 0</msg>
<var>${arg_length}</var>
<arg>${pself_lines}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:18:06.903611" elapsed="0.000934"/>
</kw>
<if>
<branch type="IF" condition="${arg_length} == 0">
<return>
<status status="PASS" start="2026-06-06T03:18:06.905021" elapsed="0.000063"/>
</return>
<status status="PASS" start="2026-06-06T03:18:06.904749" elapsed="0.000405"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.904701" elapsed="0.000513"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${commands}</var>
<arg>echo '${pself_lines}' | awk '{print "kill -${signal}",$4}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.905584" elapsed="0.000051"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${commands}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.906042" elapsed="0.000152"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${stdout}</var>
<var>${stderr}</var>
<arg>echo 'set -exu; ${commands}' | sudo sh</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.906839" elapsed="0.000054"/>
</kw>
<arg>${processes}</arg>
<doc>Kill processes by PIDs from given list (no-op if the list is empty), using specified signal. Log the kill commands used.</doc>
<status status="PASS" start="2026-06-06T03:18:06.902885" elapsed="0.004167"/>
</kw>
<arg>'play\.py'</arg>
<doc>The main keyword. Search for processes, Log the list of them, kill them.</doc>
<status status="PASS" start="2026-06-06T03:18:06.875525" elapsed="0.031649"/>
</kw>
<kw name="Search_And_Kill_Remote_Python" owner="KillPythonTool">
<kw name="Search_For_Remote_Python_Processes" owner="KillPythonTool">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:06.909088" level="INFO">Executing command 'ps -elf | egrep python | egrep 'bgp_app_peer.py' | egrep -v grep'.</msg>
<msg time="2026-06-06T03:18:06.959330" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:18:06.959714" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>ps -elf | egrep python | egrep ${filter} | egrep -v grep</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:06.908951" elapsed="0.050829"/>
</kw>
<return>
<value>${processes}</value>
<status status="PASS" start="2026-06-06T03:18:06.959929" elapsed="0.000106"/>
</return>
<msg time="2026-06-06T03:18:06.960814" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>${filter}</arg>
<doc>Only searches for the list of processes, in case something else than kill has to be done with them.</doc>
<status status="PASS" start="2026-06-06T03:18:06.908442" elapsed="0.052449"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.962154" level="INFO"/>
<arg>${processes}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:06.961386" elapsed="0.000885"/>
</kw>
<kw name="Kill_Remote_Processes" owner="KillPythonTool">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:18:06.964331" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:18:06.964534" level="INFO">${arg_length} = 0</msg>
<var>${arg_length}</var>
<arg>${pself_lines}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:18:06.963625" elapsed="0.000966"/>
</kw>
<if>
<branch type="IF" condition="${arg_length} == 0">
<return>
<status status="PASS" start="2026-06-06T03:18:06.965069" elapsed="0.000060"/>
</return>
<status status="PASS" start="2026-06-06T03:18:06.964798" elapsed="0.000398"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:06.964750" elapsed="0.000502"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${commands}</var>
<arg>echo '${pself_lines}' | awk '{print "kill -${signal}",$4}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.965601" elapsed="0.000078"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${commands}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.966030" elapsed="0.000047"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${stdout}</var>
<var>${stderr}</var>
<arg>echo 'set -exu; ${commands}' | sudo sh</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:06.966415" elapsed="0.000045"/>
</kw>
<arg>${processes}</arg>
<doc>Kill processes by PIDs from given list (no-op if the list is empty), using specified signal. Log the kill commands used.</doc>
<status status="PASS" start="2026-06-06T03:18:06.962894" elapsed="0.003709"/>
</kw>
<arg>'bgp_app_peer\.py'</arg>
<doc>The main keyword. Search for processes, Log the list of them, kill them.</doc>
<status status="PASS" start="2026-06-06T03:18:06.907694" elapsed="0.059057"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:06.967287" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:18:06.967110" elapsed="0.000358"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:18:06.967874" elapsed="0.001120"/>
</kw>
<doc>Make sure Python tool was killed.
Tear down imported Resources.</doc>
<status status="PASS" start="2026-06-06T03:18:06.875249" elapsed="0.093837"/>
</kw>
<doc>Basic tests for BGP application peer.

Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

Test suite performs basic BGP functional test cases for
BGP application peer operations and checks for IP4 topology updates
and updates towards BGP peer as follows:

Test case 1: Initial BGP peer connection with pre-filled topology,
POST and simple DELETE requests used.
BGP_Application_Peer_Post_3_Initial_Routes,
Check_Example-IPv4-Topology_Is_Filled_With_3_Routes,
Connect_BGP_Peer,
BGP_Peer_Check_Incomming_Updates_For_3_Introduced_Prefixes,
BGP_Application_Peer_Delete_3_Initial_Routes,
Check_Example-IPv4-Topology_Is_Empty,
Peer_Check_Incomming_Updates_For_3_Withdrawn_Prefixes,
Stop_BGP_Peer.

Test case 2: PUT and DELETE all routes requests while BGP peer is connected.
Reconnect_BGP_Peer,
BGP_Application_Peer_Put_3_Routes,
Check_Example-IPv4-Topology_Is_Filled_With_3_Routes,
BGP_Peer_Check_Incomming_Updates_For_3_Introduced_Prefixes,
BGP_Application_Peer_Delete_All_Routes,
Check_Example-IPv4-Topology_Is_Empty,
BGP_Peer_Check_Incomming_Updates_For_3_Withdrawn_Prefixes,
Stop_BGP_Peer.

Test case 3: Repeated BGP peer re-connection with pre-filled topology.
BGP_Application_Peer_Put_3_Routes,
Check_Example-IPv4-Topology_Is_Filled_With_3_Routes,
Reconnect_BGP_Peer_And_Check_Incomming_Updates_For_3_Introduced_Prefixes,
BGP_Application_Peer_Delete_All_Routes,
Check_Example-IPv4-Topology_Is_Empty,
BGP_Peer_Check_Incomming_Updates_For_3_Withdrawn_Prefixes,
Stop_BGP_Peer.

Brief description how to configure BGP application peer and
how to use restconf application peer interface:
https://wiki.opendaylight.org/view/BGP_LS_PCEP:User_Guide#BGP_Application_Peer
https://wiki.opendaylight.org/view/BGP_LS_PCEP:Programmer_Guide#BGP</doc>
<status status="PASS" start="2026-06-06T03:17:20.831940" elapsed="46.137193"/>
</suite>
<suite id="s1-s8" name="Ibgp Peers Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/ibgp_peers_basic.robot">
<kw name="Setup_Everything" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.098972" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:18:07.094186" elapsed="0.004845"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:18:07.093910" elapsed="0.005195"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.104522" 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-06-06T03:18:07.100413" elapsed="0.004140"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:18:07.104938" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.104790" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.104748" elapsed="0.000266"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.105567" 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-06-06T03:18:07.105185" elapsed="0.000426"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.106121" 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-06-06T03:18:07.105803" elapsed="0.000345"/>
</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-06-06T03:18:07.106694" elapsed="0.000301"/>
</kw>
<msg time="2026-06-06T03:18:07.107096" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:07.107144" 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-06-06T03:18:07.106321" elapsed="0.000847"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.107736" 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-06-06T03:18:07.107343" elapsed="0.000419"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.108944" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:18:07.108666" elapsed="0.000305"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.109404" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:18:07.109126" elapsed="0.000315"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.109951" 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-06-06T03:18:07.109624" elapsed="0.000354"/>
</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-06-06T03:18:07.114862" elapsed="0.000235"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.115623" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:18:07.115270" elapsed="0.000398"/>
</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-06-06T03:18:07.115829" elapsed="0.000231"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.116930" 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-06-06T03:18:07.116609" elapsed="0.000348"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:18:07.117005" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:18:07.117175" 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-06-06T03:18:07.116269" elapsed="0.000932"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:07.117825" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59a77d0&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-06-06T03:18:07.117363" elapsed="0.000605"/>
</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-06-06T03:18:07.118138" elapsed="0.000192"/>
</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-06-06T03:18:07.114225" elapsed="0.004163"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:07.113978" elapsed="0.004455"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:18:07.110042" elapsed="0.008426"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.119079" 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-06-06T03:18:07.118659" elapsed="0.000465"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.119712" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:18:07.119294" elapsed="0.000462"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.120313" 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-06-06T03:18:07.119925" elapsed="0.000430"/>
</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-06-06T03:18:07.108139" elapsed="0.012336"/>
</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-06-06T03:18:07.100025" elapsed="0.020592"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:07.120857" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.120717" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.120692" elapsed="0.000238"/>
</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-06-06T03:18:07.124325" 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-06-06T03:18:07.123934" elapsed="0.000418"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.124887" 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-06-06T03:18:07.124560" elapsed="0.000354"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:07.124960" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:18:07.125119" 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-06-06T03:18:07.123578" elapsed="0.001566"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:07.126173" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:18:07.125907" elapsed="0.000292"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.126976" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:18:07.127079" 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-06-06T03:18:07.126798" elapsed="0.000307"/>
</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-06-06T03:18:07.130892" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:07.130231" elapsed="0.000749"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.130210" elapsed="0.000810"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.131690" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:18:07.131225" elapsed="0.000750"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.132945" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:07.132245" elapsed="0.000808"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.134244" 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-06-06T03:18:07.133330" elapsed="0.000965"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.136053" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:18:07.136231" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:18:07.135681" elapsed="0.000594"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:07.136823" elapsed="0.000588"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.138580" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:18:07.476098" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:17:21 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:17:21 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:18:07.138247" elapsed="0.338121"/>
</kw>
<msg time="2026-06-06T03:18:07.476454" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:07.137787" elapsed="0.338833"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:18:07.134780" elapsed="0.342022"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.477764" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:18:07.490557" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:18:07.490960" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:18:07.491187" 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-06-06T03:18:07.477240" elapsed="0.014053"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:18:07.492025" elapsed="0.001156"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.495863" 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-06-06T03:18:07.494506" elapsed="0.001603"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:18:07.497095" elapsed="0.000116"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.496484" elapsed="0.000891"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.496425" elapsed="0.001032"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:18:07.498155" elapsed="0.000145"/>
</return>
<status status="PASS" start="2026-06-06T03:18:07.497634" elapsed="0.000840"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.497594" elapsed="0.000967"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:18:07.498722" elapsed="0.000036"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:07.504493" elapsed="0.000570"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:18:07.505361" elapsed="0.000331"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:18:07.505959" elapsed="0.000229"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:07.499992" elapsed="0.006266"/>
</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-06-06T03:18:07.129260" elapsed="0.377178"/>
</kw>
<msg time="2026-06-06T03:18:07.506501" 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-06-06T03:18:07.128296" elapsed="0.378272"/>
</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-06-06T03:18:07.127805" elapsed="0.378866"/>
</kw>
<msg time="2026-06-06T03:18:07.506716" 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-06-06T03:18:07.127267" elapsed="0.379497"/>
</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-06-06T03:18:07.509784" elapsed="0.000327"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:18:07.510285" elapsed="0.000154"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:18:07.510595" elapsed="0.000117"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:07.507079" elapsed="0.003685"/>
</kw>
<msg time="2026-06-06T03:18:07.510861" 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-06-06T03:18:07.126416" elapsed="0.384470"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.511369" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:07.511112" elapsed="0.000301"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:18:07.511462" elapsed="0.000035"/>
</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-06-06T03:18:07.125518" elapsed="0.386077"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:07.125336" elapsed="0.386396"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:07.125201" elapsed="0.386573"/>
</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-06-06T03:18:07.121170" elapsed="0.390667"/>
</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-06-06T03:18:07.512005" elapsed="0.000220"/>
</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-06-06T03:18:07.527256" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.527132" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.527110" elapsed="0.000220"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.527662" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:18:07.527775" 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-06-06T03:18:07.527495" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.528231" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:07.527965" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.528699" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:07.528435" elapsed="0.000310"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:07.529586" 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-06-06T03:18:07.529323" elapsed="0.000388">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:18:07.529822" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:18:07.529869" 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-06-06T03:18:07.528913" elapsed="0.000979"/>
</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-06-06T03:18:07.530202" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:07.529969" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.529950" elapsed="0.000351"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:07.531073" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:18:07.530803" elapsed="0.000296"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:18:07.531146" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:07.531297" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:18:07.530509" elapsed="0.000813"/>
</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-06-06T03:18:07.531483" elapsed="0.000441"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.532207" level="INFO">index=4
host=10.30.170.38
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-06-06T03:18:07.532309" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:18:07.532100" elapsed="0.000236"/>
</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-06-06T03:18:07.532490" elapsed="0.002617"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.535543" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:18:07.738372" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:18:07.535278" elapsed="0.203263"/>
</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-06-06T03:18:07.742355" elapsed="0.000436"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:18:07.742972" elapsed="0.000181"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:18:07.743308" elapsed="0.000105"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:07.739785" elapsed="0.003683"/>
</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-06-06T03:18:07.739071" elapsed="0.004446"/>
</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-06-06T03:18:07.526829" elapsed="0.216743"/>
</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-06-06T03:18:07.513005" elapsed="0.230617"/>
</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-06-06T03:18:07.512588" elapsed="0.231111"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:07.512440" elapsed="0.231303"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:18:07.512285" elapsed="0.231496"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:18:07.099489" elapsed="0.644358"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:07.746737" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.746599" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.746575" elapsed="0.000241"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:07.752041" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.751932" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.751913" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.753112" 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-06-06T03:18:07.752708" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.753712" 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-06-06T03:18:07.753308" elapsed="0.000432"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:07.753787" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:18:07.753954" 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-06-06T03:18:07.752347" elapsed="0.001632"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:07.760142" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.760030" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.760010" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:07.761453" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:07.761310" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.761291" elapsed="0.000232"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:07.762022" 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-06-06T03:18:07.761697" elapsed="0.000352"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.762443" 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-06-06T03:18:07.762213" elapsed="0.000257"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.795160" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:07.763155" elapsed="0.032173"/>
</kw>
<msg time="2026-06-06T03:18:07.795483" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:07.795529" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:18:07.762634" elapsed="0.032931"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.861160" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "i "b "g "p "_ "p "e "[78Ce "[A[78Cr
 "s "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:18:07.796469" elapsed="0.064843"/>
</kw>
<msg time="2026-06-06T03:18:07.861445" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:07.861491" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:18:07.795902" elapsed="0.065657"/>
</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-06-06T03:18:07.861957" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:07.861671" elapsed="0.000436"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.861629" elapsed="0.000508"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:07.862833" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "i "b "g "p "_ "p "e "[78Ce "[A[78Cr
 "s "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:18:07.862291" elapsed="0.000629"/>
</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-06-06T03:18:07.863235" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:07.862989" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.862970" elapsed="0.000439"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:07.863447" elapsed="0.000039"/>
</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-06-06T03:18:07.865470" elapsed="0.000509"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:18:07.866331" elapsed="0.000322"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:18:07.866991" elapsed="0.000238"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:07.864688" elapsed="0.002633"/>
</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-06-06T03:18:07.863781" elapsed="0.003675"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:07.761020" elapsed="0.106540"/>
</kw>
<msg time="2026-06-06T03:18:07.867880" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:07.867928" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:07.760371" elapsed="0.107593"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:07.868154" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:18:07.868045" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.868025" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:07.868673" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:07.869026" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:07.869098" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:07.759730" elapsed="0.109480"/>
</kw>
<msg time="2026-06-06T03:18:07.869308" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:07.869351" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:07.754369" elapsed="0.115018"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:07.869769" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:07.869463" elapsed="0.000363"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:07.869445" elapsed="0.000405"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:07.754217" elapsed="0.115716"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:07.754039" elapsed="0.115930"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:07.751619" elapsed="0.118409"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:18:07.744471" elapsed="0.125614"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:07.744014" elapsed="0.126115"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:18:07.093543" elapsed="0.776640"/>
</kw>
<kw name="Set Default Configuration" owner="SSHLibrary">
<arg>prompt=${ODL_SYSTEM_PROMPT}</arg>
<doc>Update the default `configuration`.</doc>
<status status="PASS" start="2026-06-06T03:18:07.870339" elapsed="0.000182"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${ODL_SYSTEM_IP}</arg>
<arg>alias=bgp_peer1_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:18:07.870698" elapsed="0.000224"/>
</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-06-06T03:18:07.872604" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:18:07.872818" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:18:07.872321" elapsed="0.000522"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:07.873007" elapsed="0.000560"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:18:07.874463" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:18:08.178420" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:17:21 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:18:07 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:18:07.874138" elapsed="0.304442"/>
</kw>
<msg time="2026-06-06T03:18:08.178688" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:07.873766" elapsed="0.305007"/>
</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-06-06T03:18:07.871882" elapsed="0.307008"/>
</kw>
<msg time="2026-06-06T03:18:08.178947" 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-06-06T03:18:07.871468" elapsed="0.307525"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:18:07.871128" elapsed="0.307946"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${ODL_SYSTEM_IP}</arg>
<arg>alias=bgp_peer2_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:18:08.179314" elapsed="0.000324"/>
</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-06-06T03:18:08.181532" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:18:08.181615" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:18:08.181246" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:08.181821" elapsed="0.000375"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.183079" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:18:08.493942" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:17:21 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:18:08 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:18:08.182757" elapsed="0.311340"/>
</kw>
<msg time="2026-06-06T03:18:08.494271" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:08.182371" elapsed="0.311980"/>
</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-06-06T03:18:08.180783" elapsed="0.313709"/>
</kw>
<msg time="2026-06-06T03:18:08.494549" 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-06-06T03:18:08.180301" elapsed="0.314294"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:18:08.179916" elapsed="0.314774"/>
</kw>
<kw name="Require_Python" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.496108" level="INFO">Executing command 'python3 --help'.</msg>
<msg time="2026-06-06T03:18:08.508799" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:08.509078" level="INFO">${stdout} = usage: python3 [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_ins...</msg>
<msg time="2026-06-06T03:18:08.509187" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:18:08.509279" 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-06-06T03:18:08.495893" elapsed="0.013438"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.511474" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:18:08.510803" elapsed="0.000778"/>
</kw>
<msg time="2026-06-06T03:18:08.511840" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:18:08.511940" 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-06-06T03:18:08.509815" elapsed="0.002177"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.513386" 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-06-06T03:18:08.512387" elapsed="0.001058"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.514436" elapsed="0.000075"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.513631" elapsed="0.000970"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.513581" elapsed="0.001108"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:18:08.515043" elapsed="0.000068"/>
</return>
<status status="PASS" start="2026-06-06T03:18:08.514819" elapsed="0.000367"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.514781" elapsed="0.000459"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:18:08.515442" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.515364" elapsed="0.000167"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:08.515329" elapsed="0.000251"/>
</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-06-06T03:18:08.515945" elapsed="0.000049"/>
</kw>
<msg time="2026-06-06T03:18:08.516279" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>python3 --help</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-06-06T03:18:08.495504" elapsed="0.020832"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:18:08.516723" elapsed="0.000057"/>
</return>
<status status="PASS" start="2026-06-06T03:18:08.516490" elapsed="0.000357"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.516451" elapsed="0.000451"/>
</if>
<kw name="Fatal Error" owner="BuiltIn">
<arg>Python 3 is not installed!</arg>
<doc>Stops the whole test execution.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.517230" elapsed="0.000048"/>
</kw>
<doc>Verify current SSH connection leads to machine with python working. Fatal fail otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:08.495052" elapsed="0.022351"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.519557" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:18:08.648090" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:18:08.648496" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:18:08.648603" level="INFO">${stderr} = Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'</msg>
<msg time="2026-06-06T03:18:08.648748" level="INFO">${rc} = 1</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-06-06T03:18:08.519376" elapsed="0.129428"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.651178" level="INFO">Length is 119.</msg>
<msg time="2026-06-06T03:18:08.651378" level="FAIL">'Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:18:08.650320" elapsed="0.001212">'Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'' should be empty.</status>
</kw>
<msg time="2026-06-06T03:18:08.651818" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:18:08.651917" level="INFO">${result} = 'Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'' should be empty.</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-06-06T03:18:08.649336" elapsed="0.002766"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.653616" level="INFO">${success} = False</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-06-06T03:18:08.652509" elapsed="0.001204"/>
</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-06-06T03:18:08.656249" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:08.655679" elapsed="0.000664"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.657842" level="INFO">Traceback (most recent call last):
  File "&lt;string&gt;", line 1, in &lt;module&gt;
ModuleNotFoundError: No module named 'ipaddr'</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:08.656728" elapsed="0.001223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.659044" level="INFO">1</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:08.658314" elapsed="0.000839"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:18:08.654805" elapsed="0.004506"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:08.653914" elapsed="0.005497"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.653859" elapsed="0.005616"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:18:08.659887" elapsed="0.000046"/>
</return>
<status status="PASS" start="2026-06-06T03:18:08.659608" elapsed="0.000363"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.659568" elapsed="0.000428"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:18:08.660087" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.660052" elapsed="0.000075"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:08.660036" elapsed="0.000113"/>
</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-06-06T03:18:08.660298" elapsed="0.000021"/>
</kw>
<msg time="2026-06-06T03:18:08.660446" level="INFO">${passed} = False</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:18:08.519003" elapsed="0.141468"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="NOT RUN" start="2026-06-06T03:18:08.660631" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.660539" elapsed="0.000147"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.660522" elapsed="0.000188"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.697253" level="INFO">[chan 3] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:18:08.711508" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py' -&gt; '/home/jenkins/.//ipaddr.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:18:08.660864" elapsed="0.050835"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:18:08.517981" elapsed="0.193857"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.724394" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:18:08.712184" elapsed="0.012383"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:08.725926" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59d1a10&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:18:08.725041" elapsed="0.001322"/>
</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-06-06T03:18:08.732571" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.732373" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.732334" elapsed="0.000378"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:08.733324" 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-06-06T03:18:08.732975" elapsed="0.000387"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.733871" level="INFO">${current_connection_index} = 8</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-06-06T03:18:08.733598" elapsed="0.000315"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.741927" level="INFO">log:set INFO</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:08.734753" elapsed="0.007234"/>
</kw>
<msg time="2026-06-06T03:18:08.742125" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:08.742187" level="INFO">${message_write} = log:set INFO
</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-06-06T03:18:08.734159" elapsed="0.008059"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.745192" 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-06-06T03:18:08.742775" elapsed="0.002572"/>
</kw>
<msg time="2026-06-06T03:18:08.745451" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:08.745498" 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-06-06T03:18:08.742399" elapsed="0.003127"/>
</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-06-06T03:18:08.745860" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.745605" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.745584" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.746387" 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-06-06T03:18:08.746099" elapsed="0.000340"/>
</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-06-06T03:18:08.746787" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.746508" elapsed="0.000373"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.746489" elapsed="0.000418"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:08.746945" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:08.748883" elapsed="0.000172"/>
</kw>
<msg time="2026-06-06T03:18:08.749101" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:08.748234" elapsed="0.000931"/>
</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="NOT RUN" start="2026-06-06T03:18:08.749332" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.749502" elapsed="0.000020"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:08.747907" elapsed="0.001678"/>
</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-06-06T03:18:08.747351" elapsed="0.002283"/>
</kw>
<arg>log:set ${ODL_LOG_LEVEL}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:08.727430" elapsed="0.022323"/>
</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-06-06T03:18:08.752683" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.752549" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.752528" elapsed="0.000228"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:08.753142" 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-06-06T03:18:08.752914" elapsed="0.000255"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.753503" level="INFO">${current_connection_index} = 8</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-06-06T03:18:08.753334" elapsed="0.000195"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.766625" level="INFO">log:set DEFAULT org.opendaylight.bgpcep</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:08.754059" elapsed="0.012643"/>
</kw>
<msg time="2026-06-06T03:18:08.766807" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:08.766886" level="INFO">${message_write} = log:set DEFAULT org.opendaylight.bgpcep
</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-06-06T03:18:08.753711" elapsed="0.013203"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.805005" 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-06-06T03:18:08.767440" elapsed="0.037631"/>
</kw>
<msg time="2026-06-06T03:18:08.805172" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:08.805218" 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-06-06T03:18:08.767095" elapsed="0.038149"/>
</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-06-06T03:18:08.805556" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.805324" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.805303" elapsed="0.000331"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.806066" 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-06-06T03:18:08.805803" elapsed="0.000311"/>
</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-06-06T03:18:08.806453" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.806230" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.806210" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:08.806567" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:08.808338" elapsed="0.000158"/>
</kw>
<msg time="2026-06-06T03:18:08.808541" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:08.807782" elapsed="0.000820"/>
</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="NOT RUN" start="2026-06-06T03:18:08.808784" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.808959" elapsed="0.000020"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:08.807435" elapsed="0.001608"/>
</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-06-06T03:18:08.806864" elapsed="0.002225"/>
</kw>
<arg>log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.bgpcep</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:08.750261" elapsed="0.058943"/>
</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-06-06T03:18:08.811792" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.811677" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.811656" elapsed="0.000206"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:08.812243" 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-06-06T03:18:08.812019" elapsed="0.000250"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.812603" level="INFO">${current_connection_index} = 8</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-06-06T03:18:08.812433" elapsed="0.000195"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.862398" level="INFO">log:set DEFAULT org.opendaylight.protocol</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:08.813156" elapsed="0.049391"/>
</kw>
<msg time="2026-06-06T03:18:08.862745" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:08.862793" level="INFO">${message_write} = log:set DEFAULT org.opendaylight.protocol
</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-06-06T03:18:08.812812" elapsed="0.050006"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.864990" 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-06-06T03:18:08.863599" elapsed="0.001447"/>
</kw>
<msg time="2026-06-06T03:18:08.865142" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:08.865186" 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-06-06T03:18:08.863125" elapsed="0.002088"/>
</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-06-06T03:18:08.865574" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.865310" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.865280" elapsed="0.000393"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.866092" 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-06-06T03:18:08.865826" elapsed="0.000315"/>
</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-06-06T03:18:08.866427" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.866207" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.866189" elapsed="0.000315"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:08.866542" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:08.868445" elapsed="0.000368"/>
</kw>
<msg time="2026-06-06T03:18:08.868859" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:08.867800" elapsed="0.001124"/>
</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="NOT RUN" start="2026-06-06T03:18:08.869149" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.869321" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:08.867438" elapsed="0.001967"/>
</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-06-06T03:18:08.866878" elapsed="0.002575"/>
</kw>
<arg>log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.protocol</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:08.809554" elapsed="0.059994"/>
</kw>
<doc>Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
prepare directories for responses, put Python tool to mininet machine, setup imported resources.</doc>
<status status="PASS" start="2026-06-06T03:18:07.093162" elapsed="1.776442"/>
</kw>
<test id="s1-s8-t1" name="TC1_Configure_Two_iBGP_Route_Reflector_Client_Peers" line="84">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:08.873871" elapsed="0.000230"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:08.873523" elapsed="0.000635"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:08.875190" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.875077" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.875057" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:08.880666" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.880542" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.880523" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.881745" 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-06-06T03:18:08.881345" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.882243" 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-06-06T03:18:08.881943" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:08.882313" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:08.882466" 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-06-06T03:18:08.880967" elapsed="0.001524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:08.888510" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.888400" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.888379" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:08.889847" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:08.889738" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.889718" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:08.890365" 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-06-06T03:18:08.890063" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.890784" level="INFO">${current_connection_index} = 8</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-06-06T03:18:08.890552" elapsed="0.000258"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.921596" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:08.891330" elapsed="0.030394"/>
</kw>
<msg time="2026-06-06T03:18:08.921891" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:08.921938" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:08.890977" elapsed="0.030998"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:08.987528" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "_ "i "B "G "P "_ "R "o "u "t "e "_ "R "e "f "l "e "c "t "o "r "_ "C "l "i "e "n "t "_ "P "e "e "r "s "[K"
[?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-06-06T03:18:08.922512" elapsed="0.065227"/>
</kw>
<msg time="2026-06-06T03:18:08.987960" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:08.988193" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</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-06-06T03:18:08.922156" elapsed="0.066165"/>
</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-06-06T03:18:08.988837" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.988449" elapsed="0.000471"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.988412" elapsed="0.000553"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:08.989632" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "_ "i "B "G "P "_ "R "o "u "t "e "_ "R "e "f "l "e "c "t "o "r "_ "C "l "i "e "n "t "_ "P "e "e "r "s "[K"
[?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-06-06T03:18:08.989182" elapsed="0.000603"/>
</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-06-06T03:18:08.990204" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.989883" elapsed="0.000397"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.989856" elapsed="0.000458"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:08.990367" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:08.994259" elapsed="0.000193"/>
</kw>
<msg time="2026-06-06T03:18:08.994533" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:08.992622" elapsed="0.002127"/>
</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="NOT RUN" start="2026-06-06T03:18:08.995156" elapsed="0.000124"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.995669" elapsed="0.000098"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:08.991683" elapsed="0.004432"/>
</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-06-06T03:18:08.990835" elapsed="0.005370"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:08.889377" elapsed="0.106966"/>
</kw>
<msg time="2026-06-06T03:18:08.996479" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:08.996543" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:08.888753" elapsed="0.107844"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:08.996886" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:18:08.996735" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.996707" elapsed="0.000304"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.997594" elapsed="0.000035"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.998103" elapsed="0.000033"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:08.998199" elapsed="0.000023"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:08.888055" elapsed="0.110298"/>
</kw>
<msg time="2026-06-06T03:18:08.998485" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:08.998547" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:08.882891" elapsed="0.115712"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:08.999114" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:08.998764" elapsed="0.000478"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:08.998739" elapsed="0.000542"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:08.882743" elapsed="0.116574"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:08.882548" elapsed="0.116814"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:08.880177" elapsed="0.119261"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:08.874762" elapsed="0.124751"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:08.874313" elapsed="0.125322"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:08.870531" elapsed="0.129239"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.001177" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer1 | IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=rr-client | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer1</arg>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=rr-client</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.000020" elapsed="0.001198"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.038768" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.038355" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.039627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.039344" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:09.039818" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:09.038969" elapsed="0.000874"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.040402" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:09.040014" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.040753" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:09.040972" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:09.040596" elapsed="0.000403"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.041410" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.041160" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.042433" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.042170" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.042922" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.042656" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.043667" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.043356" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.044431" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.044207" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.044508" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:09.044678" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.043885" elapsed="0.000819"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.044863" elapsed="0.000241"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:09.043195" elapsed="0.001948"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.045707" level="INFO">${value} = example-bgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.045390" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.047987" level="INFO">${encoded} = example-bgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.047767" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.048066" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.048219" level="INFO">${encoded_value} = example-bgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.045921" elapsed="0.002323"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.048402" elapsed="0.000276"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer1</var>
<status status="PASS" start="2026-06-06T03:18:09.045256" elapsed="0.003467"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.049283" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.048980" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.050058" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.049841" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.050135" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.050287" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.049500" elapsed="0.000812"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.050469" elapsed="0.000240"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:18:09.048840" elapsed="0.001911"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.051330" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.051004" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.052257" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.052006" elapsed="0.000282"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.052350" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:09.052505" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.051597" elapsed="0.000933"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.052703" elapsed="0.000225"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:18:09.050865" elapsed="0.002104"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.053519" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.053220" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.054287" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.054074" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.054362" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.054513" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.053751" elapsed="0.000787"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.054710" elapsed="0.000225"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:18:09.053082" elapsed="0.001894"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.055571" level="INFO">${value} = rr-client</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.055224" elapsed="0.000374"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.056337" level="INFO">${encoded} = rr-client</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.056126" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.056413" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.056562" level="INFO">${encoded_value} = rr-client</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.055804" elapsed="0.000782"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.056757" elapsed="0.000222"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">rr-client</var>
<status status="PASS" start="2026-06-06T03:18:09.055087" elapsed="0.001933"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.057564" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.057267" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.058369" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.058111" elapsed="0.000285"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.058446" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.058597" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.057792" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.058794" elapsed="0.000412"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:18:09.057131" elapsed="0.002119"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.059856" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.059536" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.060726" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.060470" elapsed="0.000284"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.060807" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:09.060961" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.060091" elapsed="0.000896"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.061146" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:09.059396" elapsed="0.002018"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.062032" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.061680" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.062815" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.062573" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.062893" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.063044" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.062252" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.063225" elapsed="0.000258"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:09.061527" elapsed="0.001999"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.064244" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.063933" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.065044" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.064826" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.065123" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:09.065276" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.064473" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.065459" elapsed="0.000244"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:09.063785" elapsed="0.001960"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.066304" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.065999" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.067079" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.066865" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.067158" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.067324" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.066522" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.067507" elapsed="0.000242"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:09.065862" elapsed="0.001929"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.068342" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.068047" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.069177" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.068898" elapsed="0.000306"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.069255" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.069406" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.068558" elapsed="0.000872"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.069601" elapsed="0.000255"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:09.067908" elapsed="0.001992"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:09.043005" elapsed="0.026930"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:09.069982" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:09.070148" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:09.041843" elapsed="0.028331"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.041523" elapsed="0.028685"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.070399" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.070239" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.041504" elapsed="0.028975"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.071475" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:09.070631" elapsed="0.000873"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.071555" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:09.037681" elapsed="0.034018"/>
</kw>
<msg time="2026-06-06T03:18:09.071756" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:09.024173" elapsed="0.047637"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.086541" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.100081" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.113526" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.113754" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.113948" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.114362" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.114207" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:09.114191" elapsed="0.000304"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.114664" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.114846" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.115024" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:09.114158" elapsed="0.000922"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.114047" elapsed="0.001059"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.115259" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.115336" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:18:09.115489" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:09.019621" elapsed="0.095896"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.143881" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.143455" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.144694" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.144422" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:09.144868" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:09.144083" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.145449" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:09.145062" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.145803" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:09.146024" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:09.145662" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.146469" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.146219" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:18:09.146919" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.146596" elapsed="0.000382"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.147468" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.147152" elapsed="0.000376"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.147003" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.146577" elapsed="0.001012"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.148593" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:09.147758" elapsed="0.000866"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.148691" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:09.142804" elapsed="0.006016"/>
</kw>
<msg time="2026-06-06T03:18:09.148880" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:09.129203" elapsed="0.019723"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.162423" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.176389" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.190000" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.190207" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.190389" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.190788" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.190622" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:09.190606" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.191016" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.191186" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.191356" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:09.190577" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.190469" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.191639" elapsed="0.000038"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.191733" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:18:09.191873" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:09.126363" elapsed="0.065585"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.193281" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.193011" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:09.193445" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:09.192633" elapsed="0.000837"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.193812" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.193542" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.194369" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.194078" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.193894" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.193523" elapsed="0.000929"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.196979" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:09.194608" elapsed="0.002398"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:18:09.197058" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.197210" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:09.192295" elapsed="0.004940"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.198739" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.198371" elapsed="0.000418"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.199311" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.198977" elapsed="0.000411"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.200003" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.199699" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.200578" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.200275" elapsed="0.000358"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:09.201575" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:18:09.201358" elapsed="0.000244"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:18:09.201960" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:18:09.201781" elapsed="0.000208"/>
</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-06-06T03:18:09.202185" elapsed="0.000218"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.202839" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.202566" elapsed="0.000319"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:18:09.202931" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:18:09.203091" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:18:09.200916" elapsed="0.002245"/>
</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-06-06T03:18:09.221517" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '1074', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:18:09.221587" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:18:09 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:09.221816" 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-06-06T03:18:09.205730" elapsed="0.016115"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.203237" elapsed="0.018655"/>
</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-06-06T03:18:09.222098" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.221920" elapsed="0.000249"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.203218" elapsed="0.018973"/>
</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-06-06T03:18:09.225785" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.223228" elapsed="0.002602"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.222956" elapsed="0.002910"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.222936" elapsed="0.002954"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.228712" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.226183" elapsed="0.002576"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.225949" elapsed="0.002845"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.225931" elapsed="0.002888"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.229405" 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-06-06T03:18:09.229006" elapsed="0.000427"/>
</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-06-06T03:18:09.229767" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.229504" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.230319" 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-06-06T03:18:09.230019" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.229850" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.229485" elapsed="0.000917"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.230950" 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-06-06T03:18:09.230568" elapsed="0.000408"/>
</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-06-06T03:18:09.231286" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.231047" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.231861" 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-06-06T03:18:09.231547" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.231366" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.231028" elapsed="0.000915"/>
</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-06-06T03:18:09.232143" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:09.232973" 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-06-06T03:18:09.232685" elapsed="0.000315"/>
</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-06-06T03:18:09.233162" elapsed="0.002558"/>
</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-06-06T03:18:09.222570" elapsed="0.013215"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:09.235963" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:18:09.235854" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.235834" elapsed="0.000218"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:18:09.236208" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.236276" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:18:09.238728" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:18:09.197561" elapsed="0.041194"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.238820" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.238975" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:18:09.007976" elapsed="0.231024"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.239343" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.239098" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.239081" elapsed="0.000353"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.239467" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:18:09.001602" elapsed="0.238019"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.240730" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer2 | IP=127.0.0.2 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=rr-client | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer2</arg>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=rr-client</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.239817" elapsed="0.000944"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.277078" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.276662" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.277915" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.277654" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:09.278087" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:09.277290" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.278686" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:09.278283" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.279108" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:09.279268" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:09.278960" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.279756" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.279460" elapsed="0.000344"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.280847" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.280560" elapsed="0.000335"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.281333" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.281063" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.282066" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.281765" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.282846" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.282608" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.282926" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:18:09.283087" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.282282" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.283270" elapsed="0.000237"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:09.281609" elapsed="0.001938"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.284143" level="INFO">${value} = example-bgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.283846" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.284905" level="INFO">${encoded} = example-bgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.284691" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.284980" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.285129" level="INFO">${encoded_value} = example-bgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.284356" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.285308" elapsed="0.000221"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer2</var>
<status status="PASS" start="2026-06-06T03:18:09.283707" elapsed="0.001862"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.286304" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.285833" elapsed="0.000497"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.287066" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.286856" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.287142" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.287291" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.286519" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.287472" elapsed="0.000255"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:18:09.285696" elapsed="0.002073"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.288316" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.288019" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.289083" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.288868" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.289158" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.289344" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.288529" elapsed="0.000841"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.289527" elapsed="0.000239"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:18:09.287882" elapsed="0.001926"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.290385" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.290055" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.291145" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.290936" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.291221" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.291370" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.290599" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.291549" elapsed="0.000268"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:18:09.289919" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.292411" level="INFO">${value} = rr-client</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.292108" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.293181" level="INFO">${encoded} = rr-client</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.292969" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.293257" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.293405" level="INFO">${encoded_value} = rr-client</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.292627" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.293584" elapsed="0.000240"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">rr-client</var>
<status status="PASS" start="2026-06-06T03:18:09.291970" elapsed="0.001896"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.294414" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.294113" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.295176" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.294967" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.295252" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.295399" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.294630" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.295575" elapsed="0.000257"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:18:09.293977" elapsed="0.001897"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.296416" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.296120" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.297355" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.296969" elapsed="0.000413"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.297432" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.297581" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.296629" elapsed="0.000976"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.297777" elapsed="0.000227"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:09.295985" elapsed="0.002061"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.298588" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.298292" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.299351" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.299139" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.299427" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.299576" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.298819" elapsed="0.000867"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.299850" elapsed="0.000225"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:09.298157" elapsed="0.001959"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.300676" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.300363" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.301422" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.301213" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.301497" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.301659" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.300890" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.301840" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:09.300227" elapsed="0.001872"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.302660" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.302350" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.303402" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.303191" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.303478" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.303654" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.302874" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.303836" elapsed="0.000225"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:09.302215" elapsed="0.001886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.304654" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:09.304346" elapsed="0.000335"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:09.305495" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.305287" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:09.305569" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.305739" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:09.304966" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:09.305919" elapsed="0.000218"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:09.304211" elapsed="0.001967"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:09.281414" elapsed="0.024798"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:09.306255" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:18:09.306416" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:09.280231" elapsed="0.026211"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.279883" elapsed="0.026591"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.306668" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.306499" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.279859" elapsed="0.026887"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.307705" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:09.306894" elapsed="0.000841"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.307784" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:09.275953" elapsed="0.031955"/>
</kw>
<msg time="2026-06-06T03:18:09.307999" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:09.262195" elapsed="0.045854"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.321606" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.334824" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.348415" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.348667" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.348863" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.349275" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.349120" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:09.349102" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.349508" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.349698" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.349874" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:09.349066" elapsed="0.000861"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.348950" elapsed="0.001004"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.350109" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.350188" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:18:09.350342" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:09.257605" elapsed="0.092765"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.378431" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.378044" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.379237" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.378988" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:09.379503" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:09.378628" elapsed="0.000901"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.380137" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:09.379740" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.380475" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:09.380634" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:09.380332" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.381094" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.380844" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:18:09.381522" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.381222" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.382075" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.381771" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.381605" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.381203" elapsed="0.000956"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.383162" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:09.382309" elapsed="0.000884"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.383243" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:09.377411" elapsed="0.005960"/>
</kw>
<msg time="2026-06-06T03:18:09.383430" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:09.364054" elapsed="0.019422"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.396876" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.410082" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.423375" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.423576" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.423787" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.424164" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.424015" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:09.424000" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.424391" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.424565" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.424752" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:09.423968" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.423866" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.424982" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.425057" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:18:09.425189" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:09.361213" elapsed="0.064005"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:09.426471" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.426239" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:09.426627" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:09.425894" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.426991" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.426740" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.427548" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.427256" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.427073" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.426721" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.430151" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:09.427832" elapsed="0.002345"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:18:09.430230" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:09.430383" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:09.425548" elapsed="0.004859"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.431823" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.431546" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.432310" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.432067" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.432787" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.432524" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.433227" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.432987" elapsed="0.000283"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:09.434101" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:18:09.433899" elapsed="0.000228"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:18:09.434467" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:18:09.434293" elapsed="0.000200"/>
</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-06-06T03:18:09.434660" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.435280" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.435033" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:18:09.435365" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.435519" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:18:09.433473" elapsed="0.002070"/>
</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-06-06T03:18:09.450373" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1074', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:18:09.450464" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:09.450591" 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-06-06T03:18:09.438023" elapsed="0.012604"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.435612" elapsed="0.015109"/>
</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-06-06T03:18:09.450987" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.450760" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.435595" elapsed="0.015517"/>
</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-06-06T03:18:09.457984" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.452552" elapsed="0.005529"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.452187" elapsed="0.005973"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.452161" elapsed="0.006055"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.462600" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.458878" elapsed="0.003790"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.458342" elapsed="0.004363"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.458304" elapsed="0.004426"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.463287" 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-06-06T03:18:09.462903" elapsed="0.000412"/>
</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-06-06T03:18:09.463631" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.463387" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.464214" 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-06-06T03:18:09.463914" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.463730" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.463368" elapsed="0.000929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.464840" 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-06-06T03:18:09.464461" elapsed="0.000406"/>
</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-06-06T03:18:09.465181" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.464936" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.465739" 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-06-06T03:18:09.465427" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:09.465262" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.464918" elapsed="0.000903"/>
</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-06-06T03:18:09.465975" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:09.466790" 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-06-06T03:18:09.466491" elapsed="0.000325"/>
</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-06-06T03:18:09.466975" elapsed="0.002503"/>
</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-06-06T03:18:09.451619" elapsed="0.017922"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:09.469729" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:18:09.469607" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.469588" elapsed="0.000229"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:18:09.469971" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.470038" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:18:09.472470" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:18:09.430751" elapsed="0.041746"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.472561" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:09.472731" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:18:09.245664" elapsed="0.227092"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.473093" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.472854" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.472837" elapsed="0.000346"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:09.473215" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:18:09.241051" elapsed="0.232327"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:09.473994" elapsed="0.000246"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:09.473681" elapsed="0.000624"/>
</kw>
<doc>Configure two iBGP peers as routing reflector clients.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:08.869688" elapsed="0.604655"/>
</test>
<test id="s1-s8-t2" name="TC1_Connect_BGP_Peer1" line="122">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:09.477784" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:09.477494" elapsed="0.000562"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.479202" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:09.479089" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.479068" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.484662" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:09.484541" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.484523" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.485766" 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-06-06T03:18:09.485357" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.486259" 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-06-06T03:18:09.485961" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:09.486329" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:18:09.486484" 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-06-06T03:18:09.484970" elapsed="0.001538"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:09.492369" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:09.492261" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.492241" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:09.493628" elapsed="0.000039"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:09.493521" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.493502" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:09.494183" 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-06-06T03:18:09.493876" elapsed="0.000335"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:09.494597" level="INFO">${current_connection_index} = 8</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-06-06T03:18:09.494377" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:09.524627" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:09.495153" elapsed="0.029726"/>
</kw>
<msg time="2026-06-06T03:18:09.525243" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:09.525348" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:09.494807" elapsed="0.030623"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:09.544596" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:18:09.526723" elapsed="0.018005"/>
</kw>
<msg time="2026-06-06T03:18:09.544899" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:09.544946" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:18:09.525870" elapsed="0.019113"/>
</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-06-06T03:18:09.545363" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.545119" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.545096" elapsed="0.000349"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.545927" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:18:09.545592" elapsed="0.000402"/>
</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-06-06T03:18:09.546287" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.546062" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.546043" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:09.546399" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:09.549078" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:18:09.549290" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:09.547897" elapsed="0.001525"/>
</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="NOT RUN" start="2026-06-06T03:18:09.549728" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.550073" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:09.547252" elapsed="0.003007"/>
</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-06-06T03:18:09.546705" elapsed="0.003619"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:09.493218" elapsed="0.057204"/>
</kw>
<msg time="2026-06-06T03:18:09.550513" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:09.550557" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:09.492596" elapsed="0.057997"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:09.550804" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:18:09.550695" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.550674" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.551289" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.551621" elapsed="0.000042"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:09.551711" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:09.491922" elapsed="0.059896"/>
</kw>
<msg time="2026-06-06T03:18:09.551911" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:09.551994" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:09.486910" elapsed="0.065122"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:09.552369" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:09.552109" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:09.552091" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:09.486760" elapsed="0.065709"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:09.486565" elapsed="0.065936"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:09.484174" elapsed="0.068381"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:09.478790" elapsed="0.073819"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:09.478215" elapsed="0.074454"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:09.475036" elapsed="0.077687"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:09.552953" elapsed="0.000158"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.563658" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:09.563315" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.564139" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.563848" elapsed="0.000340"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:09.568280" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<msg time="2026-06-06T03:18:09.568374" level="INFO">${output} =  python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:09.564343" elapsed="0.004058"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.568832" level="INFO"> python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.568566" elapsed="0.000315"/>
</kw>
<arg>${BGP_PEER1_COMMAND}</arg>
<arg>${BGP_PEER1_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:18:09.562930" elapsed="0.006006"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:09.577430" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:09.577819" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:18:09.578132" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:09.570164" elapsed="0.008032"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.583907" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.578722" elapsed="0.005274"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.588310" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:09.584247" elapsed="0.004154"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:18:09.592333" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:18:09.588746" elapsed="0.003696">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:18:09.569726" elapsed="0.022883">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:10.603127" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:10.603638" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:18:10.603816" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:10.594862" elapsed="0.008993"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.607840" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:10.604111" elapsed="0.003799"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.611997" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:10.608274" elapsed="0.003809"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:18:10.612370" elapsed="0.003790"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:18:10.593631" elapsed="0.022624"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:09.569106" elapsed="1.047225"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:10.617244" elapsed="0.000421"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:10.616784" elapsed="0.000974"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:09.474568" elapsed="1.143245"/>
</test>
<test id="s1-s8-t3" name="TC1_Connect_BGP_Peer2" line="134">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:10.621244" elapsed="0.000234"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:10.620976" elapsed="0.000557"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:10.622576" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:10.622453" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.622429" elapsed="0.000239"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:10.628166" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:10.628056" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.628038" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.629255" 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-06-06T03:18:10.628867" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.629798" 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-06-06T03:18:10.629481" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:10.629869" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:18:10.630030" 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-06-06T03:18:10.628468" elapsed="0.001588"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:10.635889" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:10.635779" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.635760" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:10.637154" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:10.637048" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.637029" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:10.637732" 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-06-06T03:18:10.637400" elapsed="0.000359"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:10.638141" level="INFO">${current_connection_index} = 7</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-06-06T03:18:10.637925" elapsed="0.000241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:10.668357" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:10.638690" elapsed="0.029793"/>
</kw>
<msg time="2026-06-06T03:18:10.668678" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:10.668728" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:10.638329" elapsed="0.030436"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:10.689687" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:18:10.669304" elapsed="0.020606"/>
</kw>
<msg time="2026-06-06T03:18:10.690094" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:10.690141" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:18:10.668950" elapsed="0.021229"/>
</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-06-06T03:18:10.690563" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:10.690283" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.690249" elapsed="0.000424"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.691160" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:18:10.690827" elapsed="0.000399"/>
</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-06-06T03:18:10.691515" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:10.691294" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.691275" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:10.691631" elapsed="0.000067"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:10.694369" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:18:10.694581" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:10.693212" elapsed="0.001527"/>
</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="NOT RUN" start="2026-06-06T03:18:10.695021" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:10.695362" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:10.692547" elapsed="0.003003"/>
</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-06-06T03:18:10.691984" elapsed="0.003631"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:10.636742" elapsed="0.058997"/>
</kw>
<msg time="2026-06-06T03:18:10.695835" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:10.695880" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:10.636113" elapsed="0.059805"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:10.696324" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:18:10.695997" elapsed="0.000388"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.695978" elapsed="0.000432"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:10.696841" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:10.697188" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:10.697258" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:10.635424" elapsed="0.061943"/>
</kw>
<msg time="2026-06-06T03:18:10.697489" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:10.697532" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:10.630436" elapsed="0.067133"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:10.697917" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:10.697657" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:10.697626" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:10.630289" elapsed="0.067730"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:10.630113" elapsed="0.067938"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:10.627683" elapsed="0.070423"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:10.622155" elapsed="0.076045"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:10.621706" elapsed="0.076542"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:10.618592" elapsed="0.079710"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:10.698470" elapsed="0.000106"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.707832" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:10.707487" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.708267" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:10.708022" elapsed="0.000291"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:10.712448" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<msg time="2026-06-06T03:18:10.712545" level="INFO">${output} =  python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:10.708469" elapsed="0.004104"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.713004" level="INFO"> python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:10.712756" elapsed="0.000298"/>
</kw>
<arg>${BGP_PEER2_COMMAND}</arg>
<arg>${BGP_PEER2_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:18:10.707104" elapsed="0.006004"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:10.720498" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:10.720664" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:18:10.720782" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:10.714383" elapsed="0.006426"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.724221" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:10.720981" elapsed="0.003304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.728365" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:10.724509" elapsed="0.003924"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:18:10.731811" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:18:10.728680" elapsed="0.003210">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:18:10.713949" elapsed="0.018056">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:11.743138" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:11.743785" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '412'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:18:11.743937" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:11.734231" elapsed="0.009744"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.748253" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:11.744224" elapsed="0.004096"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.752220" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:11.748557" elapsed="0.003732"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:18:11.752513" elapsed="0.003428"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:18:11.733019" elapsed="0.022987"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:10.713277" elapsed="1.042781"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:11.756687" elapsed="0.000252"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:11.756353" elapsed="0.000650"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:10.618131" elapsed="1.138911"/>
</test>
<test id="s1-s8-t4" name="TC1_BGP_Peer1_Check_Log_For_Introduced_Prefixes" line="146">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:11.760587" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:11.760318" elapsed="0.000549"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:11.761903" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:11.761781" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.761756" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:11.767324" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:11.767215" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.767197" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.768415" 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-06-06T03:18:11.768032" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.768922" 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-06-06T03:18:11.768606" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:11.768993" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:18:11.769156" 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-06-06T03:18:11.767625" elapsed="0.001555"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:11.775187" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:11.775077" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.775057" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:11.776449" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:11.776341" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.776322" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:11.777002" 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-06-06T03:18:11.776692" elapsed="0.000337"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:11.777514" level="INFO">${current_connection_index} = 8</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-06-06T03:18:11.777195" elapsed="0.000383"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:11.810231" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:11.778115" elapsed="0.032248"/>
</kw>
<msg time="2026-06-06T03:18:11.810561" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:11.810609" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:11.777769" elapsed="0.032897"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:11.837536" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:18:11.811286" elapsed="0.026383"/>
</kw>
<msg time="2026-06-06T03:18:11.837833" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:11.837879" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</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-06-06T03:18:11.810897" elapsed="0.027020"/>
</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-06-06T03:18:11.838246" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:11.838002" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.837978" elapsed="0.000348"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.838825" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:18:11.838477" elapsed="0.000424"/>
</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-06-06T03:18:11.839192" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:11.838969" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.838951" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:11.839306" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:11.842119" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:18:11.842329" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:11.840856" elapsed="0.001606"/>
</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="NOT RUN" start="2026-06-06T03:18:11.842806" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:11.843153" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:11.840195" elapsed="0.003146"/>
</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-06-06T03:18:11.839618" elapsed="0.003788"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:11.776038" elapsed="0.067466"/>
</kw>
<msg time="2026-06-06T03:18:11.843598" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:11.843663" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:11.775413" elapsed="0.068291"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:11.843890" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:18:11.843782" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.843763" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:11.844389" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:11.844753" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:11.844826" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:11.774737" elapsed="0.070246"/>
</kw>
<msg time="2026-06-06T03:18:11.845080" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:11.845124" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:11.769559" elapsed="0.075604"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:11.845498" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:11.845240" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.845222" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:11.769412" elapsed="0.076188"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:11.769237" elapsed="0.076395"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:11.766851" elapsed="0.078857"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:11.761466" elapsed="0.084300"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:11.761025" elapsed="0.084788"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:11.758004" elapsed="0.087863"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:11.846039" elapsed="0.000109"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:11.859989" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:11.873201" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:11.873424" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:11.859821" elapsed="0.013659"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.874486" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:11.873899" elapsed="0.000687"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:11.874998" elapsed="0.000751"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER2_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:11.859392" elapsed="0.016497"/>
</kw>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER2_PREFIX_COUNT}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:11.846313" elapsed="0.029699"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:11.892951" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.2.0.0/28' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:11.924800" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:11.925031" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:11.892785" elapsed="0.032275"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.925775" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:11.925358" elapsed="0.000464"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:11.925982" elapsed="0.000326"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received: ${BGP_PEER2_FIRST_PREFIX_IP}/${BGP_PEER2_PREFIX_LEN}</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:11.892323" elapsed="0.034058"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:11.943055" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:11.977143" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:11.977382" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:11.942808" elapsed="0.034635"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.978517" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:11.977893" elapsed="0.000730"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:18:11.979080" elapsed="0.000793"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:18:11.942285" elapsed="0.037736"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:11.981464" elapsed="0.000621"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:11.980720" elapsed="0.001516"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:11.757405" elapsed="0.225053"/>
</test>
<test id="s1-s8-t5" name="TC1_BGP_Peer2_Check_Log_For_Introduced_Prefixes" line="163">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:11.989302" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:11.989035" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:11.990638" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:11.990498" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.990473" elapsed="0.000259"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:11.996317" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:11.996208" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:11.996189" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.997408" 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-06-06T03:18:11.997019" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:11.997921" 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-06-06T03:18:11.997601" elapsed="0.000347"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:11.997993" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:18:11.998157" 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-06-06T03:18:11.996620" elapsed="0.001562"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:12.004021" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:12.003912" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:12.003892" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:12.005272" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:12.005166" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:12.005147" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:12.005830" 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-06-06T03:18:12.005490" elapsed="0.000367"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:12.006237" level="INFO">${current_connection_index} = 7</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-06-06T03:18:12.006020" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:12.036689" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:12.006787" elapsed="0.030009"/>
</kw>
<msg time="2026-06-06T03:18:12.036960" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:12.037006" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:12.006425" elapsed="0.030618"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:12.063037" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:18:12.037591" elapsed="0.025560"/>
</kw>
<msg time="2026-06-06T03:18:12.063313" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:12.063359" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</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-06-06T03:18:12.037220" elapsed="0.026176"/>
</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-06-06T03:18:12.063740" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:12.063474" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:12.063453" elapsed="0.000371"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:12.064271" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:18:12.063972" elapsed="0.000421"/>
</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-06-06T03:18:12.064703" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:12.064462" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:12.064443" elapsed="0.000340"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:12.064816" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:12.067433" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:18:12.067658" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:12.066298" elapsed="0.001496"/>
</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="NOT RUN" start="2026-06-06T03:18:12.068076" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:12.068412" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:12.065668" elapsed="0.002928"/>
</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-06-06T03:18:12.065108" elapsed="0.003581"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:12.004866" elapsed="0.063924"/>
</kw>
<msg time="2026-06-06T03:18:12.068882" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:12.068926" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:12.004248" elapsed="0.064715"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:12.069329" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:18:12.069039" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:12.069020" elapsed="0.000396"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:12.069837" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:12.070177" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:12.070248" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:12.003560" elapsed="0.066795"/>
</kw>
<msg time="2026-06-06T03:18:12.070448" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:12.070491" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:11.998567" elapsed="0.071960"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:12.070874" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:12.070602" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:12.070585" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:11.998418" elapsed="0.072582"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:11.998240" elapsed="0.072793"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:11.995843" elapsed="0.075257"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:11.990195" elapsed="0.080964"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:11.989741" elapsed="0.081463"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:11.984574" elapsed="0.086683"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:12.071420" elapsed="0.000108"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:12.085052" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:12.098179" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:12.098312" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:12.084886" elapsed="0.013461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:12.099064" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:12.098637" elapsed="0.000493"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:12.099901" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:12.099351" elapsed="0.000656">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:12.084466" elapsed="0.015805">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:13.118338" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:13.132537" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:13.132846" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:13.118138" elapsed="0.014773"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:13.134026" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:13.133344" elapsed="0.000784"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:13.135314" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:13.134480" elapsed="0.000982">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:13.117603" elapsed="0.018126">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:14.155168" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:14.168986" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:14.169213" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:14.154970" elapsed="0.014300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:14.170402" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:14.169705" elapsed="0.000800"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:14.171752" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:14.170910" elapsed="0.000998">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:14.154395" elapsed="0.017751">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:15.191095" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:15.204557" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:15.204822" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:15.190894" elapsed="0.013985"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:15.205974" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:15.205274" elapsed="0.000802"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:15.207350" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:15.206467" elapsed="0.001041">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:15.190338" elapsed="0.017447">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:16.227474" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:16.240973" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:16.241260" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:16.227257" elapsed="0.014066"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:16.242468" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:16.241771" elapsed="0.000810"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:16.243874" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:16.243014" elapsed="0.001015">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:16.226596" elapsed="0.017689">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:17.261770" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:17.275588" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:17.275877" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:17.261517" elapsed="0.014421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:17.277047" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:17.276330" elapsed="0.000818"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:17.278476" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:17.277497" elapsed="0.001129">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:17.260965" elapsed="0.017936">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:18.299496" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:18.312386" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:18.312543" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:18.299294" elapsed="0.013286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:18.313305" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:18.312876" elapsed="0.000497"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:18.314326" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:18.313738" elapsed="0.000738">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:18.298761" elapsed="0.015983">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:19.333934" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:19.346764" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:19.346935" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:19.333738" elapsed="0.013232"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:19.347743" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:19.347231" elapsed="0.000579"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:19.348537" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:19.348031" elapsed="0.000605">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:19.333221" elapsed="0.015610">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:20.368597" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:20.381809" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:20.382061" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:20.368396" elapsed="0.013721"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:20.383380" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:20.382533" elapsed="0.000947"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:20.384724" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:20.383868" elapsed="0.001011">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:20.367744" elapsed="0.017376">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:21.403851" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:21.417480" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:21.417682" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:21.403602" elapsed="0.014124"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:21.418516" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:21.418032" elapsed="0.000548"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:21.419402" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:21.418818" elapsed="0.000746">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:21.402907" elapsed="0.016858">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:22.436229" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:22.449928" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:22.450103" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:22.435969" elapsed="0.014172"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:22.450945" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:22.450434" elapsed="0.000579"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:22.452230" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:22.451324" elapsed="0.001061">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:22.435319" elapsed="0.017308">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:23.473813" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:23.487333" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:23.487595" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:23.473539" elapsed="0.014158"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:23.488876" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:23.488140" elapsed="0.000846"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:23.490368" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:23.489369" elapsed="0.001167">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:23.472934" elapsed="0.017907">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:24.511033" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:24.524787" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:24.525052" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:24.510829" elapsed="0.014288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:24.526362" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:24.525587" elapsed="0.000893"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:24.527936" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:24.526932" elapsed="0.001174">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:24.510253" elapsed="0.018113">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:25.547128" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:25.560379" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:25.560538" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:25.546935" elapsed="0.013640"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:25.561305" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:25.560849" elapsed="0.000520"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:25.562529" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:25.561677" elapsed="0.001033">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:25.546417" elapsed="0.016525">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:26.581259" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:26.595026" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:26.595275" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:26.581060" elapsed="0.014275"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:26.596396" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:26.595763" elapsed="0.000733"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:26.597698" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:26.596877" elapsed="0.000997">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:26.580509" elapsed="0.017597">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:27.615938" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:27.629504" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:27.629704" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:27.615700" elapsed="0.014044"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:27.630506" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:27.630069" elapsed="0.000503"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:27.631883" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:27.630968" elapsed="0.001080">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:27.615040" elapsed="0.017258">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:28.653283" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:28.667071" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:28.667327" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:28.653063" elapsed="0.014333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:28.668901" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:28.668175" elapsed="0.000834"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:28.670333" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:28.669374" elapsed="0.001115">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:28.652375" elapsed="0.018375">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:29.692968" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:29.706437" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:29.706701" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:29.692746" elapsed="0.014018"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:29.707808" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:29.707159" elapsed="0.000749"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:29.709134" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:29.708257" elapsed="0.001024">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:29.692206" elapsed="0.017310">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:30.729078" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:30.742394" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:30.742542" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:30.728884" elapsed="0.013694"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:30.743564" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:30.742932" elapsed="0.000769"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:30.744943" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:30.744106" elapsed="0.000991">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:30.728357" elapsed="0.016979">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:31.763862" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:31.777252" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:31.777481" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:31.763666" elapsed="0.013873"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:31.778613" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:31.777969" elapsed="0.000780"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:31.779923" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:31.779102" elapsed="0.000969">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:31.763149" elapsed="0.017152">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:32.800134" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:32.814322" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:32.814691" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:32.799939" elapsed="0.014817"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.815992" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:32.815251" elapsed="0.000863"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.817480" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:32.816495" elapsed="0.001136">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:32.799359" elapsed="0.018551">0 != 3</status>
</kw>
<msg time="2026-06-06T03:18:32.818109" level="FAIL">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:18:12.071729" elapsed="20.746585">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="NOT RUN" start="2026-06-06T03:18:32.835522" elapsed="0.000055"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="NOT RUN" start="2026-06-06T03:18:32.848331" elapsed="0.000124"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.850116" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:18:32.849783" elapsed="0.000384"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:32.849326" elapsed="0.000897"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:32.848948" elapsed="0.001335"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:18:11.983201" elapsed="20.867124">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</test>
<test id="s1-s8-t6" name="TC1_Disconnect_BGP_Peer1" line="180">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:32.853944" elapsed="0.000230"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:32.853620" elapsed="0.000613"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:32.855325" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:32.855184" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.855159" elapsed="0.000243"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:32.861086" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:32.860968" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.860947" elapsed="0.000210"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.862239" 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-06-06T03:18:32.861835" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.862759" 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-06-06T03:18:32.862435" elapsed="0.000352"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:32.862846" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:18:32.863014" 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-06-06T03:18:32.861396" elapsed="0.001645"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:32.868952" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:32.868837" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.868816" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:32.870266" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:32.870157" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.870138" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:32.870847" 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-06-06T03:18:32.870485" elapsed="0.000391"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:32.871264" level="INFO">${current_connection_index} = 8</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-06-06T03:18:32.871044" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:32.902625" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:32.871821" elapsed="0.031042"/>
</kw>
<msg time="2026-06-06T03:18:32.903081" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:32.903131" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:32.871455" elapsed="0.031714"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:32.926025" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:18:32.903893" elapsed="0.022375"/>
</kw>
<msg time="2026-06-06T03:18:32.926491" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:32.926538" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:18:32.903427" elapsed="0.023284"/>
</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-06-06T03:18:32.927163" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:32.926832" elapsed="0.000389"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.926796" elapsed="0.000451"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.927788" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:18:32.927398" elapsed="0.000461"/>
</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-06-06T03:18:32.928151" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:32.927928" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.927909" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:32.928269" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:32.931273" elapsed="0.000157"/>
</kw>
<msg time="2026-06-06T03:18:32.931496" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:32.929913" elapsed="0.001721"/>
</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="NOT RUN" start="2026-06-06T03:18:32.931946" elapsed="0.000087"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:32.932295" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:32.929234" elapsed="0.003244"/>
</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-06-06T03:18:32.928598" elapsed="0.003947"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:32.869850" elapsed="0.062808"/>
</kw>
<msg time="2026-06-06T03:18:32.932760" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:32.932806" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:32.869189" elapsed="0.063656"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:32.933280" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:18:32.932941" elapsed="0.000406"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.932906" elapsed="0.000467"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:32.933815" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:32.934155" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:32.934226" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:32.868448" elapsed="0.065887"/>
</kw>
<msg time="2026-06-06T03:18:32.934428" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:32.934471" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:32.863427" elapsed="0.071081"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:32.934872" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:32.934583" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:32.934565" elapsed="0.000385"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:32.863277" elapsed="0.071698"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:32.863098" elapsed="0.071910"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:32.860545" elapsed="0.074519"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:32.854872" elapsed="0.080250"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:32.854394" elapsed="0.080776"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:32.851214" elapsed="0.084072"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:32.935457" elapsed="0.000113"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:32.936831" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:32.936485" elapsed="0.000374"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:32.937058" elapsed="0.000313"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:18:32.936214" elapsed="0.001217"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:18:34.938373" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:18:34.938769" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:18:32.937599" elapsed="2.001239"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:34.940015" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:34.939319" elapsed="0.000806"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:18:32.935879" elapsed="2.004381"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:34.955323" level="INFO">Executing command 'cat bgp_peer1.log'.</msg>
<msg time="2026-06-06T03:18:34.968928" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:34.969156" level="INFO">${output_log} = 2026-06-06 03:18:09,652 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:18:09,652 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:18:09,652 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:34.955177" elapsed="0.014040"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:34.970241" level="INFO">2026-06-06 03:18:09,652 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:18:09,652 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:18:09,652 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:18:09,652 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:18:09,652 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:18:09,653 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   Prefix base: 8.1.0.0/28
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706433
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:18:09,655 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:18:09,656 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:18:09,656 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:18:09,656 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:18:09,656 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:18:09,656 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:18:09,656 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:18:09,656 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706433 (0x7f000001)
2026-06-06 03:18:09,657 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:18:09,657 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:18:09,657 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0'
2026-06-06 03:18:09,657 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0
2026-06-06 03:18:09,658 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:18:09,658 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,658 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:09,659 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:18:09,659 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.0')]
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:09,660 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.0')]/28 (0x1c08010000)
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010000
2026-06-06 03:18:09,661 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.16')]
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:09,662 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.16')]/28 (0x1c08010010)
2026-06-06 03:18:09,663 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010010
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.32')]
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:09,664 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:09,665 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:09,665 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,665 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:09,665 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:09,665 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.32')]/28 (0x1c08010020)
2026-06-06 03:18:09,666 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010020
2026-06-06 03:18:09,666 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:18:09,666 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:18:09,666 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:18:09,666 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:18:09,666 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:18:09,666 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.006541728973388672s
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:09,667 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:18:09,668 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:09,669 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:09,670 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:10,834 INFO BGP-Thread-1 (job): ... idle for 1.164s
2026-06-06 03:18:10,834 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.164s
2026-06-06 03:18:10,834 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020000
2026-06-06 03:18:10,834 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0033' (51)
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020000'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:18:10,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020000'
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020000'
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.0/28']
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.0/28
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:10,836 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:10,836 INFO BGP-Thread-1 (job): total_received_update_message_counter: 2
2026-06-06 03:18:10,836 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 1
2026-06-06 03:18:10,836 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:10,852 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020010
2026-06-06 03:18:10,852 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:10,852 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:10,852 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:10,853 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0033' (51)
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020010'
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:18:10,854 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020010'
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020010'
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.16/28']
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.16/28
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:10,855 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020020
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0033' (51)
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020020'
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:18:10,856 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020020'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020020'
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.32/28']
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.32/28
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:10,857 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:20,868 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:18:20,868 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.190s
2026-06-06 03:18:20,868 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:18:20,868 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:18:20,868 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:30,879 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:18:30,879 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.201s
2026-06-06 03:18:30,879 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:18:30,879 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:18:30,879 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:34.969597" elapsed="0.001441"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:34.972346" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc1_bgp_peer1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc1_bgp_peer1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:18:34.971497" elapsed="0.000976"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>tc1_${BGP_PEER1_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:34.954749" elapsed="0.017869"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:34.974098" elapsed="0.000597"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:34.973341" elapsed="0.001502"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:32.850720" elapsed="2.124210"/>
</test>
<test id="s1-s8-t7" name="TC1_BGP_Peer2_Check_Log_For_Withdrawn_Prefixes" line="187">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:34.981421" elapsed="0.000350"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:34.981027" elapsed="0.000826"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:34.983365" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:34.983178" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:34.983145" elapsed="0.000326"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:34.989953" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:34.989837" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:34.989818" elapsed="0.000204"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:34.991059" 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-06-06T03:18:34.990663" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:34.991552" 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-06-06T03:18:34.991254" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:34.991624" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:18:34.991807" 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-06-06T03:18:34.990257" elapsed="0.001576"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:34.997801" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:34.997689" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:34.997668" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:34.999198" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:34.999086" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:34.999065" elapsed="0.000203"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:34.999759" 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-06-06T03:18:34.999422" elapsed="0.000364"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:35.000197" level="INFO">${current_connection_index} = 7</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-06-06T03:18:34.999954" elapsed="0.000273"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:35.029958" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:35.000766" elapsed="0.029301"/>
</kw>
<msg time="2026-06-06T03:18:35.030236" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:35.030283" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:35.000399" elapsed="0.029921"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:35.068910" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:18:35.030884" elapsed="0.038238"/>
</kw>
<msg time="2026-06-06T03:18:35.069410" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:35.069459" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</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-06-06T03:18:35.030501" elapsed="0.038997"/>
</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-06-06T03:18:35.069937" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:35.069606" elapsed="0.000392"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:35.069575" elapsed="0.000450"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:35.070567" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:18:35.070195" elapsed="0.000468"/>
</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-06-06T03:18:35.070964" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:35.070735" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:35.070716" elapsed="0.000328"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:35.071082" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:35.073923" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:18:35.074147" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:35.072705" elapsed="0.001582"/>
</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="NOT RUN" start="2026-06-06T03:18:35.074572" elapsed="0.000105"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:35.074949" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:35.072026" elapsed="0.003117"/>
</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-06-06T03:18:35.071407" elapsed="0.003803"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:34.998698" elapsed="0.076612"/>
</kw>
<msg time="2026-06-06T03:18:35.075408" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:35.075455" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:34.998033" elapsed="0.077462"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:35.075934" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:18:35.075575" elapsed="0.000591"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:35.075555" elapsed="0.000637"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:35.076616" elapsed="0.000042"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:35.076990" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:35.077086" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:34.997330" elapsed="0.079870"/>
</kw>
<msg time="2026-06-06T03:18:35.077296" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:35.077342" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:34.992243" elapsed="0.085136"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:35.077735" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:35.077456" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:35.077438" elapsed="0.000378"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:34.992090" elapsed="0.085751"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:34.991890" elapsed="0.085983"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:34.989449" elapsed="0.088481"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:34.982752" elapsed="0.095282"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:34.982103" elapsed="0.095981"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:34.977339" elapsed="0.100800"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:35.078314" elapsed="0.000139"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:35.092409" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:35.105400" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:35.105545" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:35.092237" elapsed="0.013345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:35.106423" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:35.105854" elapsed="0.000674"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:35.107820" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:35.106922" elapsed="0.001057">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:35.091821" elapsed="0.016396">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:36.128735" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:36.142073" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:36.142307" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:36.128524" elapsed="0.013841"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:36.143493" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:36.142842" elapsed="0.000757"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:36.144942" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:36.143991" elapsed="0.001103">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:36.128007" elapsed="0.017322">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:37.163276" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:37.176389" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:37.176500" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:37.163080" elapsed="0.013446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:37.177076" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:37.176730" elapsed="0.000410"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:37.177885" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:37.177359" elapsed="0.000624">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:37.162557" elapsed="0.015576">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:38.195868" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:38.209296" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:38.209453" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:38.195654" elapsed="0.013835"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:38.210214" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:38.209791" elapsed="0.000488"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:38.211031" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:38.210499" elapsed="0.000630">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:38.195106" elapsed="0.016172">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:39.231884" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:39.245534" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:39.245832" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:39.231639" elapsed="0.014255"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:39.247126" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:39.246344" elapsed="0.000899"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:39.248527" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:39.247628" elapsed="0.001232">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:39.231039" elapsed="0.018088">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:40.267303" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:40.280782" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:40.281013" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:40.267106" elapsed="0.013964"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:40.282144" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:40.281468" elapsed="0.000779"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:40.283443" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:40.282606" elapsed="0.000990">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:40.266544" elapsed="0.017321">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:41.303983" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:41.317090" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:41.317269" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:41.303581" elapsed="0.013725"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:41.318201" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:41.317713" elapsed="0.000594"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:41.319525" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:41.318694" elapsed="0.001021">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:41.302308" elapsed="0.017656">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:42.339737" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:42.353681" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:42.353837" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:42.339525" elapsed="0.014348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:42.354826" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:42.354129" elapsed="0.000800"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:42.356146" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:42.355309" elapsed="0.000987">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:42.338987" elapsed="0.017543">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:43.377307" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:43.390252" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:43.390395" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:43.377105" elapsed="0.013317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:43.391041" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:43.390687" elapsed="0.000402"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:43.392356" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:43.391335" elapsed="0.001182">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:43.376489" elapsed="0.016354">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:44.413126" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:44.426208" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:44.426481" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:44.412926" elapsed="0.013613"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:44.427711" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:44.427028" elapsed="0.000791"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:44.429056" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:44.428178" elapsed="0.001030">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:44.412387" elapsed="0.017081">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:45.448402" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:45.461704" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:45.462012" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:45.448195" elapsed="0.013877"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:45.463396" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:45.462581" elapsed="0.000932"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:45.464804" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:45.463948" elapsed="0.001008">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:45.447658" elapsed="0.017553">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:46.486324" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:46.500253" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:46.500406" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:46.486120" elapsed="0.014321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:46.501137" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:46.500724" elapsed="0.000477"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:46.501977" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:46.501447" elapsed="0.000631">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:46.485568" elapsed="0.016659">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:47.515845" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:47.529356" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:47.529469" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:47.515630" elapsed="0.013866"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:47.530001" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:47.529697" elapsed="0.000351"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:47.530578" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:47.530207" elapsed="0.000461">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:47.515084" elapsed="0.015696">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:48.550295" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:48.563884" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:48.564171" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:48.550096" elapsed="0.014136"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:48.565485" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:48.564706" elapsed="0.000890"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:48.566977" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:48.566016" elapsed="0.001119">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:48.549531" elapsed="0.017895">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:49.588476" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:49.601977" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:49.602218" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:49.588271" elapsed="0.013987"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:49.603399" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:49.602698" elapsed="0.000814"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:49.604814" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:49.603924" elapsed="0.001052">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:49.587687" elapsed="0.017548">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:50.624359" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:50.638341" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:50.638545" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:50.624162" elapsed="0.014452"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:50.639865" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:50.639175" elapsed="0.000795"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:50.641165" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:50.640328" elapsed="0.000986">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:50.623635" elapsed="0.017913">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:51.659780" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:51.674050" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:51.674344" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:51.659566" elapsed="0.014840"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:51.675502" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:51.674853" elapsed="0.000752"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:51.677110" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:51.676103" elapsed="0.001160">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:51.659043" elapsed="0.018525">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:52.696731" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:52.710536" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:52.710821" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:52.696489" elapsed="0.014391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:52.711994" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:52.711294" elapsed="0.000803"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:52.713334" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:52.712451" elapsed="0.001066">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:52.695942" elapsed="0.017892">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:53.734035" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:53.747501" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:53.747808" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:53.733835" elapsed="0.014049"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:53.749082" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:53.748330" elapsed="0.000861"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:53.750439" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:53.749555" elapsed="0.001036">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:53.733290" elapsed="0.017584">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:54.769778" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:54.783404" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:54.783724" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:54.769555" elapsed="0.014232"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:54.784869" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:54.784188" elapsed="0.000783"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:54.786159" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:54.785324" elapsed="0.000987">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:54.769003" elapsed="0.017548">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:55.806826" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:18:55.820427" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:55.820693" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:55.806613" elapsed="0.014142"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.821797" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:55.821143" elapsed="0.000756"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.823273" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:18:55.822307" elapsed="0.001116">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:18:55.806099" elapsed="0.017593">0 != 3</status>
</kw>
<msg time="2026-06-06T03:18:55.823901" level="FAIL">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:18:35.078624" elapsed="20.745479">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="NOT RUN" start="2026-06-06T03:18:55.840065" elapsed="0.000029"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.841479" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:18:55.841161" elapsed="0.000361"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:55.840771" elapsed="0.000803"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:55.840438" elapsed="0.001192"/>
</kw>
<doc>Check incomming updates for withdrawn routes</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:18:34.975700" elapsed="20.865987">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</test>
<test id="s1-s8-t8" name="TC1_Disconnect_BGP_Peer2" line="203">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:55.845986" elapsed="0.000248"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:55.845712" elapsed="0.000579"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:55.847364" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:55.847227" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.847203" elapsed="0.000234"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:55.852805" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:55.852694" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.852675" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.853906" 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-06-06T03:18:55.853497" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.854435" 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-06-06T03:18:55.854133" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:55.854506" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:18:55.854681" 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-06-06T03:18:55.853109" elapsed="0.001599"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:55.860907" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:55.860795" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.860775" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:55.862254" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:55.862143" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.862123" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:55.862856" 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-06-06T03:18:55.862474" elapsed="0.000411"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:55.863290" level="INFO">${current_connection_index} = 8</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-06-06T03:18:55.863056" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:55.894901" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:55.863894" elapsed="0.031124"/>
</kw>
<msg time="2026-06-06T03:18:55.895232" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:55.895281" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:55.863492" elapsed="0.031901"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:55.918225" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:18:55.896021" elapsed="0.022312"/>
</kw>
<msg time="2026-06-06T03:18:55.918500" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:55.918548" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:18:55.895585" elapsed="0.023001"/>
</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-06-06T03:18:55.918977" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:55.918715" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.918685" elapsed="0.000378"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.919537" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:18:55.919215" elapsed="0.000394"/>
</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-06-06T03:18:55.919926" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:55.919697" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.919677" elapsed="0.000328"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:55.920044" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:55.922985" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:18:55.923203" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:55.921622" elapsed="0.001723"/>
</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="NOT RUN" start="2026-06-06T03:18:55.923660" elapsed="0.000083"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:55.924017" elapsed="0.000089"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:55.920958" elapsed="0.003263"/>
</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-06-06T03:18:55.920367" elapsed="0.003922"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:55.861792" elapsed="0.062599"/>
</kw>
<msg time="2026-06-06T03:18:55.924667" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:55.924718" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:55.861135" elapsed="0.063626"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:55.924959" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:18:55.924844" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.924824" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:55.925475" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:55.925850" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:55.925925" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:55.860434" elapsed="0.065606"/>
</kw>
<msg time="2026-06-06T03:18:55.926136" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:55.926219" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:55.855092" elapsed="0.071171"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:55.926668" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:55.926344" elapsed="0.000382"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:55.926325" elapsed="0.000426"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:55.854943" elapsed="0.071833"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:55.854765" elapsed="0.072044"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:55.852307" elapsed="0.074560"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:55.846922" elapsed="0.080002"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:55.846448" elapsed="0.080532"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:55.842871" elapsed="0.084167"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:55.927212" elapsed="0.000111"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:55.928733" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:55.928161" elapsed="0.000601"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:55.928923" elapsed="0.000223"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:18:55.927887" elapsed="0.001319"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:18:57.930208" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:18:57.930697" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:18:55.929373" elapsed="2.001399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:57.931982" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:57.931262" elapsed="0.000837"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:18:55.927534" elapsed="2.004705"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:18:57.945832" level="INFO">Executing command 'cat bgp_peer2.log'.</msg>
<msg time="2026-06-06T03:18:57.959403" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:18:57.959636" level="INFO">${output_log} = 2026-06-06 03:18:10,790 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:18:10,790 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:18:10,790 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:18:57.945678" elapsed="0.014062"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:57.960770" level="INFO">2026-06-06 03:18:10,790 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:18:10,790 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:18:10,790 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:18:10,790 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:18:10,790 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:18:10,791 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:18:10,792 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:18:10,792 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:18:10,792 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:18:10,792 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:18:10,792 INFO BGP-Thread-1 (job):   Prefix base: 8.2.0.0/28
2026-06-06 03:18:10,792 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706434
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:18:10,793 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:18:10,793 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:18:10,793 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:18:10,793 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706434 (0x7f000002)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0'
2026-06-06 03:18:10,794 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0
2026-06-06 03:18:10,795 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:18:10,795 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:10,796 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:18:10,796 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.0')]
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:10,797 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.0')]/28 (0x1c08020000)
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020000
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:18:10,798 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:18:10,799 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:10,799 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:10,799 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:18:10,799 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:10,799 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:10,799 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.16')]
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,803 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.16')]/28 (0x1c08020010)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020010
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:10,804 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:10,805 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.32')]
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:10,806 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.32')]/28 (0x1c08020020)
2026-06-06 03:18:10,807 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020020
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.009980201721191406s
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:10,807 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:10,808 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:18:10,808 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:18:20,818 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:18:20,818 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:18:20,819 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:18:20,819 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:18:20,819 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:30,819 INFO BGP-Thread-1 (job): ... idle for 10.000s
2026-06-06 03:18:30,819 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.010s
2026-06-06 03:18:30,819 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:18:30,819 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:18:30,820 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:40,821 INFO BGP-Thread-1 (job): ... idle for 10.001s
2026-06-06 03:18:40,821 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.011s
2026-06-06 03:18:40,821 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:18:40,821 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:18:40,821 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:18:50,832 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:18:50,832 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.022s
2026-06-06 03:18:50,832 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:18:50,832 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:18:50,832 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:57.960130" elapsed="0.001202"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:57.962812" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc1_bgp_peer2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc1_bgp_peer2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:18:57.961809" elapsed="0.001187"/>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>tc1_${BGP_PEER2_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:57.945217" elapsed="0.017985"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:57.965259" elapsed="0.000728"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:57.964162" elapsed="0.002043"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:55.842240" elapsed="2.124168"/>
</test>
<test id="s1-s8-t9" name="TC_1_Check_for_Empty_IPv4_Topology" line="210">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:57.971488" elapsed="0.000299"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:57.971197" elapsed="0.000653"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:57.973018" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:57.972857" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:57.972832" elapsed="0.000274"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:57.979222" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:57.979097" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:57.979077" elapsed="0.000218"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:57.980382" 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-06-06T03:18:57.979960" elapsed="0.000450"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:57.980906" 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-06-06T03:18:57.980579" elapsed="0.000354"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:57.980978" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:18:57.981142" 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-06-06T03:18:57.979546" elapsed="0.001622"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:57.987525" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:57.987411" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:57.987390" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:57.988850" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:57.988739" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:57.988720" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:57.989379" 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-06-06T03:18:57.989072" elapsed="0.000334"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:57.989810" level="INFO">${current_connection_index} = 8</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-06-06T03:18:57.989574" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.021519" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:57.990374" elapsed="0.031257"/>
</kw>
<msg time="2026-06-06T03:18:58.021828" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:58.021875" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:57.990002" elapsed="0.031910"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.046312" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "1 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:18:58.022517" elapsed="0.023990"/>
</kw>
<msg time="2026-06-06T03:18:58.046812" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:58.046987" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "1 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</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-06-06T03:18:58.022099" elapsed="0.024950"/>
</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-06-06T03:18:58.047562" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.047194" elapsed="0.000476"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.047145" elapsed="0.000566"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.048454" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "1 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:18:58.047937" elapsed="0.000626"/>
</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-06-06T03:18:58.049041" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.048689" elapsed="0.000436"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.048638" elapsed="0.000524"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:58.049213" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:58.052612" elapsed="0.000190"/>
</kw>
<msg time="2026-06-06T03:18:58.052867" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.051275" elapsed="0.001729"/>
</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="NOT RUN" start="2026-06-06T03:18:58.053302" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.053675" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:58.050566" elapsed="0.003301"/>
</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-06-06T03:18:58.049662" elapsed="0.004270"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:57.988405" elapsed="0.065812"/>
</kw>
<msg time="2026-06-06T03:18:58.054336" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:58.054382" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "1 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:57.987779" elapsed="0.066643"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:58.054633" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:18:58.054519" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.054498" elapsed="0.000240"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.055154" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.055515" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.055588" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:57.986876" elapsed="0.068847"/>
</kw>
<msg time="2026-06-06T03:18:58.055821" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:58.055867" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "1 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:57.981552" elapsed="0.074367"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.056258" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.055997" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.055979" elapsed="0.000358"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:57.981404" elapsed="0.074957"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:57.981225" elapsed="0.075168"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:57.978679" elapsed="0.077771"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:57.972517" elapsed="0.083991"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:57.972017" elapsed="0.084587"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:57.967962" elapsed="0.088718"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:58.064909" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:58.065065" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:18:58.065194" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:58.057882" elapsed="0.007340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.068718" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.065395" elapsed="0.003393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.073066" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.069049" elapsed="0.004114"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:18:58.073426" elapsed="0.003189"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Check the example-ipv4-topology does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:18:58.057492" elapsed="0.019205"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:58.056864" elapsed="0.019887"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:58.077374" elapsed="0.000261"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:58.077057" elapsed="0.000661"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:57.967258" elapsed="0.110500"/>
</test>
<test id="s1-s8-t10" name="TC1_Delete_BGP_Peers_Configuration" line="218">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:58.082017" elapsed="0.000217"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:58.081742" elapsed="0.000549"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.083437" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.083314" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.083290" elapsed="0.000218"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.088840" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.088728" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.088708" elapsed="0.000201"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.089953" 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-06-06T03:18:58.089537" elapsed="0.000444"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.090455" 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-06-06T03:18:58.090150" elapsed="0.000332"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:58.090572" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:18:58.090761" 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-06-06T03:18:58.089145" elapsed="0.001643"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:58.096865" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.096748" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.096727" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:58.098154" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.098041" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.098022" elapsed="0.000253"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:58.098820" 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-06-06T03:18:58.098432" elapsed="0.000417"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.099244" level="INFO">${current_connection_index} = 8</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-06-06T03:18:58.099020" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.129387" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:58.099818" elapsed="0.029675"/>
</kw>
<msg time="2026-06-06T03:18:58.129702" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:58.129760" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:58.099439" elapsed="0.030360"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.155332" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:18:58.130346" elapsed="0.025096"/>
</kw>
<msg time="2026-06-06T03:18:58.155609" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:58.155683" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</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-06-06T03:18:58.129984" elapsed="0.025741"/>
</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-06-06T03:18:58.156054" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.155813" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.155789" elapsed="0.000347"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.156596" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:18:58.156287" elapsed="0.000401"/>
</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-06-06T03:18:58.156998" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.156768" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.156748" elapsed="0.000328"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:58.157113" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:58.159774" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:18:58.159990" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.158693" elapsed="0.001446"/>
</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="NOT RUN" start="2026-06-06T03:18:58.160439" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.160816" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:58.158002" elapsed="0.003007"/>
</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-06-06T03:18:58.157413" elapsed="0.003671"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:58.097723" elapsed="0.063465"/>
</kw>
<msg time="2026-06-06T03:18:58.161287" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:58.161409" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:58.097094" elapsed="0.064359"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:58.161671" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:18:58.161538" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.161517" elapsed="0.000244"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.162192" elapsed="0.000031"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.162696" elapsed="0.000032"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.162784" elapsed="0.000019"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:58.096377" elapsed="0.066533"/>
</kw>
<msg time="2026-06-06T03:18:58.163017" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:58.163068" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "1 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:58.091180" elapsed="0.071930"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.163480" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.163196" elapsed="0.000340"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.163176" elapsed="0.000385"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:58.091029" elapsed="0.072556"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:58.090849" elapsed="0.072771"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:58.088342" elapsed="0.075360"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:58.083000" elapsed="0.080765"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:58.082454" elapsed="0.081362"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:58.079219" elapsed="0.084654"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.164623" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer1 | IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer1</arg>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.164069" elapsed="0.000605"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.210919" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.210480" elapsed="0.000471"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.211739" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.211473" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.211919" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.211127" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.212522" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.212118" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.212886" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:58.213049" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:58.212739" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.213502" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.213244" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.214566" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.214293" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.215238" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.214942" elapsed="0.000371"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.216034" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.215720" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.216831" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.216587" elapsed="0.000271"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.216911" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:18:58.217068" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.216256" elapsed="0.000838"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.217257" elapsed="0.000242"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:58.215555" elapsed="0.001986"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.218117" level="INFO">${value} = example-bgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.217812" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.219145" level="INFO">${encoded} = example-bgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.218681" elapsed="0.000492"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.219227" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.219382" level="INFO">${encoded_value} = example-bgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.218335" elapsed="0.001072"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.219566" elapsed="0.000247"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer1</var>
<status status="PASS" start="2026-06-06T03:18:58.217672" elapsed="0.002183"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.220414" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.220109" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.221195" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.220979" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.221273" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.221428" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.220632" elapsed="0.000822"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.221615" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:18:58.219970" elapsed="0.001935"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.222548" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.222158" elapsed="0.000423"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.223393" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.223174" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.223476" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.223629" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.222840" elapsed="0.000834"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.223835" elapsed="0.000229"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.222019" elapsed="0.002086"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.215371" elapsed="0.008769"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.224184" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:58.224345" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:58.213954" elapsed="0.010417"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.213623" elapsed="0.010784"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.224589" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.224433" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.213601" elapsed="0.011084"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.225487" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:58.224852" elapsed="0.000708"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.225616" elapsed="0.000048"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:58.209848" elapsed="0.015918"/>
</kw>
<msg time="2026-06-06T03:18:58.225823" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.196252" elapsed="0.029620"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.239259" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.252508" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.265963" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.266171" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.266368" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.266764" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.266597" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:58.266580" elapsed="0.000297"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.267030" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.267215" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.267389" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:58.266549" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.266447" elapsed="0.001033"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.267633" elapsed="0.000037"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.267741" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:18:58.267880" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:58.191626" elapsed="0.076282"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.269171" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.268885" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:58.282330" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:58.282403" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:58.282556" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:58.271804" elapsed="0.010793"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.269292" elapsed="0.013394"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.283021" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.282737" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.269272" elapsed="0.013890"/>
</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-06-06T03:18:58.288460" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.284724" elapsed="0.003800"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.284370" elapsed="0.004205"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.284340" elapsed="0.004272"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.292571" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.289044" elapsed="0.003593"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.288717" elapsed="0.003989"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.288690" elapsed="0.004051"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.293540" 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-06-06T03:18:58.292992" elapsed="0.000589"/>
</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-06-06T03:18:58.294056" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.293706" elapsed="0.000432"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.294866" 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-06-06T03:18:58.294409" elapsed="0.000522"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.294172" elapsed="0.000816"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.293678" elapsed="0.001340"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.295795" 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-06-06T03:18:58.295254" elapsed="0.000581"/>
</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-06-06T03:18:58.296276" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.295934" elapsed="0.000422"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.297069" 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-06-06T03:18:58.296627" elapsed="0.000479"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.296390" elapsed="0.000767"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.295908" elapsed="0.001278"/>
</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-06-06T03:18:58.297406" elapsed="0.000527"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:58.298576" 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-06-06T03:18:58.298174" elapsed="0.000441"/>
</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-06-06T03:18:58.298867" elapsed="0.002800"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:18:58.283723" elapsed="0.018011"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:58.301831" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:18:58.304278" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:18:58.268251" elapsed="0.036054"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.304361" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:18:58.164916" elapsed="0.139571"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.305217" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer2 | IP=127.0.0.2 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer2</arg>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.304680" elapsed="0.000565"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.351140" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.350736" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.351946" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.351703" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.352116" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.351342" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.352715" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.352310" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.353048" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:58.353206" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:58.352908" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.353657" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.353395" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.354700" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.354423" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.355208" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.354910" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.355922" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.355602" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.356695" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.356461" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.356788" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.356941" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.356137" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.357123" elapsed="0.000229"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:58.355462" elapsed="0.001931"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.357961" level="INFO">${value} = example-bgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.357657" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.358773" level="INFO">${encoded} = example-bgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.358497" elapsed="0.000304"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.358851" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.359019" level="INFO">${encoded_value} = example-bgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.358175" elapsed="0.000870"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.359201" elapsed="0.000225"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer2</var>
<status status="PASS" start="2026-06-06T03:18:58.357506" elapsed="0.001961"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.360184" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.359732" elapsed="0.000479"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.362273" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.362054" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.362353" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.362507" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.361703" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.362718" elapsed="0.000227"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:18:58.359579" elapsed="0.003408"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.363576" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.363273" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.364394" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.364177" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.364474" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.364657" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.363815" elapsed="0.000869"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.364939" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.363134" elapsed="0.002085"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.355287" elapsed="0.009967"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.365297" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.365457" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:58.354080" elapsed="0.011402"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.353781" elapsed="0.011733"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.365712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.365539" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.353761" elapsed="0.012029"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.366566" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:58.365934" elapsed="0.000661"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.366675" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:58.350091" elapsed="0.016717"/>
</kw>
<msg time="2026-06-06T03:18:58.366863" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.336455" elapsed="0.030456"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.381103" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.395731" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.410957" elapsed="0.000041"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.411289" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.411607" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.412023" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.411862" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:58.411846" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.412249" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.412431" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.412602" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:58.411814" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.411705" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.412859" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.412940" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:18:58.413072" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:58.331633" elapsed="0.081467"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.414384" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.414083" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:58.425157" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:58.425210" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:58.425319" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:58.417143" elapsed="0.008203"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.414513" elapsed="0.010877"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.425587" elapsed="0.000097"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.425419" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.414494" elapsed="0.011272"/>
</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-06-06T03:18:58.433396" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.427082" elapsed="0.006426"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.426795" elapsed="0.006796"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.426770" elapsed="0.006910"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.438066" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.434365" elapsed="0.003754"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.433823" elapsed="0.004332"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.433782" elapsed="0.004398"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.438808" 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-06-06T03:18:58.438373" elapsed="0.000463"/>
</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-06-06T03:18:58.439197" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.438912" elapsed="0.000349"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.439822" 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-06-06T03:18:58.439491" elapsed="0.000359"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.439290" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.438890" elapsed="0.001017"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.440465" 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-06-06T03:18:58.440073" elapsed="0.000420"/>
</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-06-06T03:18:58.440824" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.440564" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.441466" 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-06-06T03:18:58.441075" elapsed="0.000421"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.440905" elapsed="0.000628"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.440546" elapsed="0.001008"/>
</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-06-06T03:18:58.441732" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:58.442597" 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-06-06T03:18:58.442283" elapsed="0.000340"/>
</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-06-06T03:18:58.442810" elapsed="0.002630"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:18:58.426150" elapsed="0.019356"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:58.445555" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:18:58.448121" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:18:58.413370" elapsed="0.034779"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.448206" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:18:58.305482" elapsed="0.142861"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:58.449000" elapsed="0.000248"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:58.448668" elapsed="0.000646"/>
</kw>
<doc>Delete all previously configured BGP peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:58.078218" elapsed="0.371149"/>
</test>
<test id="s1-s8-t11" name="TC2_Configure_One_iBGP_Route_Reflector_Client_And_One_iBGP_Non_Client" line="240">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:58.453273" elapsed="0.000227"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:58.452929" elapsed="0.000628"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.454756" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.454553" elapsed="0.000261"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.454532" elapsed="0.000306"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.460898" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.460784" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.460765" elapsed="0.000204"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.462046" 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-06-06T03:18:58.461615" elapsed="0.000458"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.462545" 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-06-06T03:18:58.462242" elapsed="0.000329"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:58.462617" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:18:58.462807" 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-06-06T03:18:58.461208" elapsed="0.001626"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:58.468897" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.468774" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.468754" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:58.470294" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:58.470109" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.470089" elapsed="0.000306"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:58.470890" 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-06-06T03:18:58.470554" elapsed="0.000364"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.471340" level="INFO">${current_connection_index} = 8</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-06-06T03:18:58.471086" elapsed="0.000281"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.502521" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:58.471918" elapsed="0.030805"/>
</kw>
<msg time="2026-06-06T03:18:58.502941" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:58.502991" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:58.471545" elapsed="0.031486"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:58.540570" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "O "n "e "_ "i "B "G "P "_ "R "o "u "t "e "_ "R "e "f "l "e "c "t "o "r "_ "C "l "i "e "n "t "_ "A "n "d "_ "O "n "e "_ "i "B "[78CG "[A[78CP
 "_ "N "o "n "_ "C "l "i "e "n "t "[K"
[?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-06-06T03:18:58.503829" elapsed="0.036886"/>
</kw>
<msg time="2026-06-06T03:18:58.540883" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:58.540943" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "O "n "e "...</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-06-06T03:18:58.503362" elapsed="0.037620"/>
</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-06-06T03:18:58.541332" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.541075" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.541048" elapsed="0.000368"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.541906" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "O "n "e "_ "i "B "G "P "_ "R "o "u "t "e "_ "R "e "f "l "e "c "t "o "r "_ "C "l "i "e "n "t "_ "A "n "d "_ "O "n "e "_ "i "B "[78CG "[A[78CP
 "_ "N "o "n "_ "C "l "i "e "n "t "[K"
[?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-06-06T03:18:58.541570" elapsed="0.000421"/>
</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-06-06T03:18:58.542285" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.542060" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.542041" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:58.542495" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:58.545230" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:18:58.545454" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.544142" elapsed="0.001456"/>
</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="NOT RUN" start="2026-06-06T03:18:58.545910" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.546262" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:58.543442" elapsed="0.003014"/>
</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-06-06T03:18:58.542832" elapsed="0.003695"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:58.469798" elapsed="0.076834"/>
</kw>
<msg time="2026-06-06T03:18:58.546757" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:58.546804" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "O "n "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:58.469125" elapsed="0.077720"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:58.547478" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:18:58.546930" elapsed="0.000616"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.546909" elapsed="0.000662"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.548049" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.548554" elapsed="0.000028"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.548655" elapsed="0.000019"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:58.468416" elapsed="0.080358"/>
</kw>
<msg time="2026-06-06T03:18:58.548872" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:58.548918" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "O "n "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:58.463243" elapsed="0.085715"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.549317" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.549037" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.549018" elapsed="0.000381"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:58.463072" elapsed="0.086366"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:58.462894" elapsed="0.086578"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:58.460349" elapsed="0.089180"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:58.454217" elapsed="0.095372"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:58.453735" elapsed="0.095917"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:58.450285" elapsed="0.099442"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.550784" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer1 | IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=rr-client | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer1</arg>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=rr-client</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.549917" elapsed="0.000898"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.587485" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.587046" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.588396" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.588116" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.588585" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.587768" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.589193" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.588803" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.589529" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:58.589708" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:58.589390" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.590152" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.589900" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.591200" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.590922" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.591718" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.591427" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.592667" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.592138" elapsed="0.000557"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.593464" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.593242" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.593543" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.593730" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.592897" elapsed="0.000859"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.593928" elapsed="0.000255"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:58.591987" elapsed="0.002238"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.594809" level="INFO">${value} = example-bgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.594477" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.595634" level="INFO">${encoded} = example-bgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.595358" elapsed="0.000320"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.595731" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.595885" level="INFO">${encoded_value} = example-bgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.595024" elapsed="0.000886"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.596070" elapsed="0.000237"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer1</var>
<status status="PASS" start="2026-06-06T03:18:58.594338" elapsed="0.002011"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.596927" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.596602" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.597700" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.597471" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.597814" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:18:58.597972" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.597145" elapsed="0.000852"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.598155" elapsed="0.000225"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:18:58.596463" elapsed="0.001959"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.598993" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.598689" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.599814" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.599567" elapsed="0.000273"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.599891" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:18:58.600053" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.599211" elapsed="0.000866"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.600246" elapsed="0.000221"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:18:58.598535" elapsed="0.001974"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.601080" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.600784" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.601862" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.601623" elapsed="0.000265"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.601937" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.602086" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.601293" elapsed="0.000817"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.602263" elapsed="0.000232"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:18:58.600621" elapsed="0.001915"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.603106" level="INFO">${value} = rr-client</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.602799" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.604165" level="INFO">${encoded} = rr-client</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.603758" elapsed="0.000434"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.604246" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.604399" level="INFO">${encoded_value} = rr-client</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.603330" elapsed="0.001093"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.604580" elapsed="0.000242"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">rr-client</var>
<status status="PASS" start="2026-06-06T03:18:58.602662" elapsed="0.002203"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.605417" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.605116" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.606186" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.605974" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.606266" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.606418" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.605633" elapsed="0.000810"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.606599" elapsed="0.000240"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:18:58.604978" elapsed="0.001904"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.607465" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.607138" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.608242" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.608028" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.608322" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.608517" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.607700" elapsed="0.000844"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.608728" elapsed="0.000246"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.606998" elapsed="0.002020"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.609607" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.609289" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.610417" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.610199" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.610495" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:18:58.610664" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.609861" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.610852" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:58.609142" elapsed="0.001976"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.611760" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.611370" elapsed="0.000416"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.612509" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.612301" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.612584" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.612752" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.611978" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.612934" elapsed="0.000218"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.611231" elapsed="0.001962"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.613751" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.613441" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.614491" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.614281" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.614567" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.614733" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.613963" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.614917" elapsed="0.000219"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.613305" elapsed="0.001872"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.615969" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.615441" elapsed="0.000554"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.616742" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.616513" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.616823" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.616975" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.616192" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.617154" elapsed="0.000223"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:58.615289" elapsed="0.002131"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.591797" elapsed="0.025658"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.617503" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:58.617687" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:58.590568" elapsed="0.027147"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.590268" elapsed="0.027481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.617937" elapsed="0.000063"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.617778" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.590248" elapsed="0.027816"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.619040" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:58.618220" elapsed="0.000849"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.619120" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:58.586396" elapsed="0.032852"/>
</kw>
<msg time="2026-06-06T03:18:58.619306" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.572628" elapsed="0.046731"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.632831" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.646422" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.659653" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.659869" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.660066" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.660494" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.660319" elapsed="0.000236"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:58.660299" elapsed="0.000280"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.660745" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.660922" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.661092" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:58.660262" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.660149" elapsed="0.001021"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.661321" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.661400" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:18:58.661532" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:58.568053" elapsed="0.093506"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.690508" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.690120" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.691323" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.691078" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.691497" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.690725" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.692165" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.691770" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.692502" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:58.692689" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:58.692359" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.693295" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.692900" elapsed="0.000454"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:18:58.693744" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.693422" elapsed="0.000383"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.694287" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'rr-client', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.693983" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.693830" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.693403" elapsed="0.000969"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.695361" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:58.694524" elapsed="0.000868"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.695443" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:58.689296" elapsed="0.006298"/>
</kw>
<msg time="2026-06-06T03:18:58.695706" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.675458" elapsed="0.020307"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.709079" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.722452" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.735817" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.736034" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.736228" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.736614" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.736463" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:58.736446" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.736861" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.737035" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.737208" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:58.736415" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.736308" elapsed="0.000980"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.737439" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.737519" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:18:58.737678" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:58.672661" elapsed="0.065048"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.739037" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.738785" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.739199" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.738399" elapsed="0.000825"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.739597" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.739338" elapsed="0.000372"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.740232" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.739928" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.739737" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.739315" elapsed="0.001001"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.743011" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.740474" elapsed="0.002565"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:18:58.743094" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:18:58.743252" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:58.738054" elapsed="0.005224"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.744721" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.744451" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.745183" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.744941" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.745658" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.745398" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.746110" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.745866" elapsed="0.000288"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:58.746994" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:18:58.746793" elapsed="0.000229"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:18:58.747355" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:18:58.747178" elapsed="0.000203"/>
</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-06-06T03:18:58.747534" elapsed="0.000257"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.748206" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.747953" elapsed="0.000298"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:18:58.748293" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.748448" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:18:58.746360" elapsed="0.002113"/>
</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-06-06T03:18:58.766101" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1074', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:18:58.766367" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:58.766593" 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-06-06T03:18:58.750871" elapsed="0.015811"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.748544" elapsed="0.018249"/>
</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-06-06T03:18:58.767241" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.766857" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.748526" elapsed="0.018914"/>
</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-06-06T03:18:58.774806" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.769808" elapsed="0.005062"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.769251" elapsed="0.005669"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.769207" elapsed="0.005750"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.778931" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.775355" elapsed="0.003642"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.775037" elapsed="0.004027"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.775012" elapsed="0.004088"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.779948" 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-06-06T03:18:58.779352" elapsed="0.000634"/>
</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-06-06T03:18:58.780443" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.780102" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.781255" 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-06-06T03:18:58.780836" elapsed="0.000456"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.780574" elapsed="0.000767"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.780075" elapsed="0.001295"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.782123" 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-06-06T03:18:58.781597" elapsed="0.000563"/>
</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-06-06T03:18:58.782610" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.782273" elapsed="0.000437"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.783390" 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-06-06T03:18:58.782977" elapsed="0.000449"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.782744" elapsed="0.000730"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.782232" elapsed="0.001271"/>
</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-06-06T03:18:58.783779" elapsed="0.000488"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:58.784883" 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-06-06T03:18:58.784506" elapsed="0.000403"/>
</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-06-06T03:18:58.785069" elapsed="0.002534"/>
</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-06-06T03:18:58.768379" elapsed="0.019302"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:58.787909" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:18:58.787798" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.787778" elapsed="0.000224"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:18:58.788168" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.788238" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:18:58.790688" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:18:58.743616" elapsed="0.047099"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.790827" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:18:58.790993" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:18:58.556029" elapsed="0.234989"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.791364" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.791119" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.791102" elapsed="0.000356"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.791491" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:18:58.551120" elapsed="0.240496"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.792659" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer2 | IP=127.0.0.2 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=ibgp | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENC...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer2</arg>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=ibgp</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.791843" elapsed="0.000847"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.828915" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.828509" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.829728" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.829472" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.829914" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.829115" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.830506" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.830109" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.830871" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:58.831025" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:58.830714" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.831473" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.831216" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.832519" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.832258" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.833005" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.832744" elapsed="0.000287"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.833731" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.833418" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.834483" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.834267" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.834596" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.834767" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.833947" elapsed="0.000845"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.834948" elapsed="0.000229"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:18:58.833278" elapsed="0.001940"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.835785" level="INFO">${value} = example-bgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.835465" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.836552" level="INFO">${encoded} = example-bgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.836342" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.836628" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:18:58.836813" level="INFO">${encoded_value} = example-bgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.836009" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.836992" elapsed="0.000234"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer2</var>
<status status="PASS" start="2026-06-06T03:18:58.835330" elapsed="0.001936"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.837822" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.837511" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.838587" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.838364" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.838677" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.838827" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.838047" elapsed="0.000816"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.839018" elapsed="0.000410"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:18:58.837377" elapsed="0.002093"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.840064" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.839735" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.840824" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.840597" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.840900" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.841049" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.840278" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.841229" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:18:58.839583" elapsed="0.001908"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.842048" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.841753" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.842817" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.842581" elapsed="0.000263"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.842893" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.843042" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.842262" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.843222" elapsed="0.000220"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:18:58.841602" elapsed="0.001880"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.844056" level="INFO">${value} = ibgp</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.843742" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.844837" level="INFO">${encoded} = ibgp</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.844599" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.844950" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.845103" level="INFO">${encoded_value} = ibgp</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.844281" elapsed="0.000846"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.845283" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">ibgp</var>
<status status="PASS" start="2026-06-06T03:18:58.843592" elapsed="0.001953"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.846119" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.845824" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.846896" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.846679" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.846991" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.847140" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.846331" elapsed="0.000833"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.847318" elapsed="0.000233"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:18:58.845671" elapsed="0.001921"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.848192" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.847880" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.848979" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.848766" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.849054" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.849204" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.848418" elapsed="0.000810"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.849383" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.847719" elapsed="0.001941"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.850246" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.849951" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.852151" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.851936" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.852228" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.852378" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.851574" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.852559" elapsed="0.000246"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:18:58.849789" elapsed="0.003057"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.853398" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.853094" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.854190" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.853967" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.854267" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.854418" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.853615" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.854599" elapsed="0.000249"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.852958" elapsed="0.001931"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.855533" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.855136" elapsed="0.000424"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.856377" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.856159" elapsed="0.000287"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.856501" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:18:58.856683" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.855776" elapsed="0.000934"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.856868" elapsed="0.000226"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:18:58.855000" elapsed="0.002135"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.857736" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:18:58.857400" elapsed="0.000363"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:18:58.858489" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.858277" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:18:58.858565" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:18:58.858732" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:18:58.857954" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:18:58.858913" elapsed="0.000220"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:18:58.857262" elapsed="0.001912"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.833087" elapsed="0.026122"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:18:58.859252" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:18:58.859414" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'P...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:18:58.831931" elapsed="0.027510"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.831585" elapsed="0.027888"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.859667" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.859499" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.831566" elapsed="0.028178"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.860696" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:58.859925" elapsed="0.000800"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.860775" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:58.827869" elapsed="0.033030"/>
</kw>
<msg time="2026-06-06T03:18:58.860953" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.814194" elapsed="0.046807"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.875008" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.888777" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.902329" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.902596" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.902804" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.903188" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.903037" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:58.903021" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.903417" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.903590" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.903786" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:58.902990" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.902885" elapsed="0.000983"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.904044" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.904123" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:18:58.904253" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:58.809522" elapsed="0.094759"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.932969" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.932561" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.933768" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.933505" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.933937" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.933167" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.934537" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.934146" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.934899" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:18:58.935052" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:18:58.934759" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.935503" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.935256" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:18:58.936044" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.935704" elapsed="0.000401"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.936601" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'P...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.936296" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.936130" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.935683" elapsed="0.001032"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.937736" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:18:58.936869" elapsed="0.000905"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:18:58.937840" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:18:58.931914" elapsed="0.006070"/>
</kw>
<msg time="2026-06-06T03:18:58.938044" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:58.918176" elapsed="0.019915"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.951656" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.965238" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.978879" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.979130" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.979326" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.979789" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.979611" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:18:58.979591" elapsed="0.000285"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.980032" elapsed="0.000039"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.980228" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.980400" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:18:58.979548" elapsed="0.000912"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.979416" elapsed="0.001074"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.980739" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:18:58.980823" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:18:58.980995" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:18:58.915265" elapsed="0.065764"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:18:58.982513" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:18:58.982212" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:18:58.982705" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:18:58.981790" elapsed="0.000941"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:58.983297" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:58.982809" elapsed="0.000549"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.983902" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:58.983576" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.983386" elapsed="0.000581"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.982789" elapsed="0.001200"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.987521" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:18:58.984208" elapsed="0.003352"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:18:58.987640" elapsed="0.000067"/>
</return>
<msg time="2026-06-06T03:18:58.987901" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:18:58.981392" elapsed="0.006547"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.990112" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.989726" elapsed="0.000458"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.990803" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.990419" elapsed="0.000476"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.991501" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.991134" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.992255" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.991832" elapsed="0.000492"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:58.993346" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:18:58.993111" elapsed="0.000263"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:18:58.993743" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:18:58.993540" elapsed="0.000229"/>
</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-06-06T03:18:58.994025" elapsed="0.000218"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:58.994683" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:58.994411" elapsed="0.000321"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:18:58.994778" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:18:58.994945" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:18:58.992639" elapsed="0.002332"/>
</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-06-06T03:18:59.011515" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1075', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:18:59.011723" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:59.011981" 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-06-06T03:18:58.997522" elapsed="0.014517"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:58.995046" elapsed="0.017146"/>
</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-06-06T03:18:59.012688" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.012262" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:58.995026" elapsed="0.017865"/>
</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-06-06T03:18:59.019821" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:59.015281" elapsed="0.004609"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:59.014751" elapsed="0.005193"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.014704" elapsed="0.005278"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.024323" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:59.020481" elapsed="0.003911"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:59.020067" elapsed="0.004379"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.020041" elapsed="0.004442"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.025201" 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-06-06T03:18:59.024777" elapsed="0.000452"/>
</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-06-06T03:18:59.025544" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.025300" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.026208" 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-06-06T03:18:59.025861" elapsed="0.000375"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:59.025625" elapsed="0.000648"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.025281" elapsed="0.001014"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.026859" 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-06-06T03:18:59.026466" elapsed="0.000421"/>
</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-06-06T03:18:59.027204" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.026959" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.027858" 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-06-06T03:18:59.027533" elapsed="0.000354"/>
</kw>
<status status="PASS" start="2026-06-06T03:18:59.027356" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.026940" elapsed="0.001006"/>
</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-06-06T03:18:59.028109" elapsed="0.000380"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:18:59.028999" 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-06-06T03:18:59.028680" elapsed="0.000345"/>
</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-06-06T03:18:59.029192" elapsed="0.002584"/>
</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-06-06T03:18:59.013867" elapsed="0.017984"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:18:59.032039" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:18:59.031924" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.031903" elapsed="0.000275"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:18:59.032342" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:18:59.032412" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:18:59.034887" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:18:58.988472" elapsed="0.046443"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:59.034983" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:18:59.035144" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:18:58.797898" elapsed="0.237272"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:59.035537" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.035270" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.035252" elapsed="0.000379"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:18:59.035682" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:18:58.793176" elapsed="0.242635"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:18:59.036504" elapsed="0.000273"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:18:59.036160" elapsed="0.000682"/>
</kw>
<doc>Configure iBGP peers: 1st one as RR client, 2nd one as RR non-client.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:58.449603" elapsed="0.587281"/>
</test>
<test id="s1-s8-t12" name="TC2_Connect_BGP_Peer1" line="278">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:18:59.040663" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:18:59.040326" elapsed="0.000623"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:59.042014" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:59.041895" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.041873" elapsed="0.000212"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:18:59.047465" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:59.047355" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.047336" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.048685" 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-06-06T03:18:59.048238" elapsed="0.000480"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.049274" 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-06-06T03:18:59.048890" elapsed="0.000412"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:18:59.049348" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:18:59.049512" 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-06-06T03:18:59.047796" elapsed="0.001742"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:18:59.055546" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:59.055435" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.055414" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:18:59.056944" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:18:59.056832" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.056811" elapsed="0.000206"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:18:59.057486" 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-06-06T03:18:59.057171" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:18:59.057936" level="INFO">${current_connection_index} = 8</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-06-06T03:18:59.057703" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:59.088325" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:59.058475" elapsed="0.030323"/>
</kw>
<msg time="2026-06-06T03:18:59.089280" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:18:59.089395" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:18:59.058130" elapsed="0.031352"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:18:59.109050" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:18:59.090998" elapsed="0.018159"/>
</kw>
<msg time="2026-06-06T03:18:59.109325" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:18:59.109372" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:18:59.090043" elapsed="0.019366"/>
</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-06-06T03:18:59.109818" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.109504" elapsed="0.000379"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.109476" elapsed="0.000436"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.110406" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:18:59.110086" elapsed="0.000389"/>
</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-06-06T03:18:59.110793" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.110544" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.110525" elapsed="0.000349"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:18:59.110912" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:59.113735" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:18:59.113950" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:18:59.112681" elapsed="0.001404"/>
</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="NOT RUN" start="2026-06-06T03:18:59.114366" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:59.114722" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:18:59.111825" elapsed="0.003084"/>
</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-06-06T03:18:59.111236" elapsed="0.003739"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:18:59.056483" elapsed="0.058649"/>
</kw>
<msg time="2026-06-06T03:18:59.115228" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:59.115274" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:59.055801" elapsed="0.059511"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:18:59.115501" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:18:59.115390" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.115371" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:59.116022" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:59.116427" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:18:59.116502" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:18:59.055080" elapsed="0.061534"/>
</kw>
<msg time="2026-06-06T03:18:59.116740" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:18:59.116802" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:18:59.049956" elapsed="0.066884"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:18:59.117183" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:18:59.116922" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:18:59.116903" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:18:59.049807" elapsed="0.067479"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:18:59.049603" elapsed="0.067715"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:18:59.046979" elapsed="0.070394"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:18:59.041572" elapsed="0.075856"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:18:59.041112" elapsed="0.076361"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:18:59.037592" elapsed="0.079934"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:18:59.117713" elapsed="0.000111"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.127079" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:18:59.126739" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.127515" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:59.127270" elapsed="0.000293"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:18:59.131582" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<msg time="2026-06-06T03:18:59.131695" level="INFO">${output} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:18:59.127734" elapsed="0.003991"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.132187" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:59.131901" elapsed="0.000336"/>
</kw>
<arg>${BGP_PEER1_COMMAND}</arg>
<arg>${BGP_PEER1_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:18:59.126247" elapsed="0.006113"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:18:59.141379" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:18:59.141578" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:18:59.141697" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:18:59.133659" elapsed="0.008066"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.144672" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:59.141902" elapsed="0.002820"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.147459" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:18:59.144892" elapsed="0.002615"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:18:59.150411" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:18:59.147685" elapsed="0.002802">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:18:59.133208" elapsed="0.017389">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:00.161503" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:00.161725" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:19:00.161873" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:00.152699" elapsed="0.009249"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.165827" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:00.162207" elapsed="0.003687"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.169987" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:00.166346" elapsed="0.003710"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:19:00.170282" elapsed="0.003785"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:19:00.151491" elapsed="0.022668"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:18:59.132559" elapsed="1.041673"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:00.175038" elapsed="0.000249"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:00.174661" elapsed="0.000690"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:18:59.037129" elapsed="1.138260"/>
</test>
<test id="s1-s8-t13" name="TC2_Connect_BGP_Peer2" line="290">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:00.178707" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:00.178426" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:00.180005" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:00.179883" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.179858" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:00.185669" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:00.185544" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.185525" elapsed="0.000281"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.186960" 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-06-06T03:19:00.186449" elapsed="0.000539"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.187455" 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-06-06T03:19:00.187155" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:00.187527" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:19:00.187711" 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-06-06T03:19:00.186061" elapsed="0.001676"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:00.193524" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:00.193416" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.193397" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:00.194842" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:00.194729" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.194710" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:00.195363" 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-06-06T03:19:00.195062" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:00.195793" level="INFO">${current_connection_index} = 7</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-06-06T03:19:00.195555" elapsed="0.000268"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:00.226931" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:00.196330" elapsed="0.030704"/>
</kw>
<msg time="2026-06-06T03:19:00.227220" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:00.227267" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:00.195989" elapsed="0.031315"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:00.250689" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:19:00.227876" elapsed="0.022930"/>
</kw>
<msg time="2026-06-06T03:19:00.250976" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:00.251022" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:19:00.227496" elapsed="0.023563"/>
</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-06-06T03:19:00.251378" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:00.251139" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.251118" elapsed="0.000341"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.251945" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:19:00.251608" elapsed="0.000404"/>
</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-06-06T03:19:00.252302" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:00.252079" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.252060" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:00.252413" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:00.254996" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:19:00.255200" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:00.253919" elapsed="0.001425"/>
</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="NOT RUN" start="2026-06-06T03:19:00.256049" elapsed="0.000083"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:00.256407" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:00.253272" elapsed="0.003325"/>
</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-06-06T03:19:00.252721" elapsed="0.003957"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:00.194396" elapsed="0.062383"/>
</kw>
<msg time="2026-06-06T03:19:00.256871" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:00.256916" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:00.193763" elapsed="0.063190"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:00.257138" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:19:00.257030" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.257011" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:00.257625" elapsed="0.000041"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:00.257981" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:00.258071" elapsed="0.000021"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:00.193079" elapsed="0.065112"/>
</kw>
<msg time="2026-06-06T03:19:00.258284" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:00.258328" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:00.188122" elapsed="0.070243"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:00.258709" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:00.258439" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:00.258421" elapsed="0.000365"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:00.187975" elapsed="0.070835"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:00.187796" elapsed="0.071049"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:00.185176" elapsed="0.073723"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:00.179567" elapsed="0.079387"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:00.179125" elapsed="0.079872"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:00.176115" elapsed="0.082934"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:00.259208" elapsed="0.000108"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.268502" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:00.268171" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.269048" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:00.268799" elapsed="0.000295"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:00.272794" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<msg time="2026-06-06T03:19:00.272891" level="INFO">${output} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:00.269250" elapsed="0.003669"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.273332" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:00.273083" elapsed="0.000295"/>
</kw>
<arg>${BGP_PEER2_COMMAND}</arg>
<arg>${BGP_PEER2_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:19:00.267782" elapsed="0.005689"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:00.284253" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:00.284476" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:19:00.284714" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:00.274758" elapsed="0.010009"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.288524" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:00.285018" elapsed="0.003571"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.292489" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:00.288842" elapsed="0.003716"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:19:00.296106" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:19:00.292802" elapsed="0.003379">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:19:00.274307" elapsed="0.021984">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:01.306503" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:01.306759" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '412'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:19:01.306940" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:01.298126" elapsed="0.008856"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.312092" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:01.307295" elapsed="0.004876"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.316370" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:01.312440" elapsed="0.003985"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:19:01.316598" elapsed="0.002723"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:19:01.297124" elapsed="0.022269"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:19:00.273656" elapsed="1.045794"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:01.320289" elapsed="0.000284"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:01.319943" elapsed="0.000714"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:00.175624" elapsed="1.145076"/>
</test>
<test id="s1-s8-t14" name="TC2_BGP_Peer1_Check_Log_For_Introduced_Prefixes" line="302">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:01.324899" elapsed="0.000254"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:01.324598" elapsed="0.000615"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:01.326327" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.326190" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.326164" elapsed="0.000240"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:01.331912" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.331789" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.331768" elapsed="0.000219"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.333114" 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-06-06T03:19:01.332660" elapsed="0.000484"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.333627" 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-06-06T03:19:01.333316" elapsed="0.000354"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:01.333719" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:19:01.333888" 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-06-06T03:19:01.332245" elapsed="0.001667"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:01.340219" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.340092" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.340070" elapsed="0.000258"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:01.341831" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.341716" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.341696" elapsed="0.000207"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:01.342492" 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-06-06T03:19:01.342102" elapsed="0.000421"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.342959" level="INFO">${current_connection_index} = 8</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-06-06T03:19:01.342727" elapsed="0.000259"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.372683" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:01.343719" elapsed="0.029231"/>
</kw>
<msg time="2026-06-06T03:19:01.373238" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:01.373307" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:01.343320" elapsed="0.030040"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.398827" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:19:01.374348" elapsed="0.024631"/>
</kw>
<msg time="2026-06-06T03:19:01.399165" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:01.399212" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</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-06-06T03:19:01.373741" elapsed="0.025508"/>
</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-06-06T03:19:01.399694" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:01.399352" elapsed="0.000488"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.399322" elapsed="0.000551"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.400387" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:19:01.400035" elapsed="0.000428"/>
</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-06-06T03:19:01.400783" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:01.400531" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.400512" elapsed="0.000350"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:01.400900" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:01.403824" elapsed="0.000161"/>
</kw>
<msg time="2026-06-06T03:19:01.404051" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:01.402495" elapsed="0.001696"/>
</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="NOT RUN" start="2026-06-06T03:19:01.404476" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.404842" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:01.401841" elapsed="0.003191"/>
</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-06-06T03:19:01.401238" elapsed="0.003860"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:01.341375" elapsed="0.063821"/>
</kw>
<msg time="2026-06-06T03:19:01.405296" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:01.405341" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:01.340520" elapsed="0.064858"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:01.405573" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:19:01.405459" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.405439" elapsed="0.000238"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.406113" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.406463" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:01.406535" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:01.339717" elapsed="0.066948"/>
</kw>
<msg time="2026-06-06T03:19:01.406766" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:01.406811" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:01.334312" elapsed="0.072539"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.407185" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:01.406927" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.406909" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:01.334162" elapsed="0.073125"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:01.333977" elapsed="0.073344"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:01.331314" elapsed="0.076065"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:01.325872" elapsed="0.081564"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:01.325377" elapsed="0.082114"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:01.322014" elapsed="0.085532"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:01.407749" elapsed="0.000112"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.422105" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:01.446740" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:01.447186" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:01.421913" elapsed="0.025340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.448677" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:01.447894" elapsed="0.000899"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:19:01.449170" elapsed="0.000786"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER2_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:19:01.421368" elapsed="0.028778"/>
</kw>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER2_PREFIX_COUNT}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:19:01.408078" elapsed="0.042246"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.467411" level="INFO">Executing command 'grep -o 'nlri_prefix_received: 8.2.0.0/28' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:01.493708" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:01.493964" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:01.467228" elapsed="0.026794"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.495201" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:01.494439" elapsed="0.000877"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:19:01.495735" elapsed="0.000781"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received: ${BGP_PEER2_FIRST_PREFIX_IP}/${BGP_PEER2_PREFIX_LEN}</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:19:01.466692" elapsed="0.030008"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.514465" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:01.545249" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:01.545495" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:01.514291" elapsed="0.031266"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.546756" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:01.546001" elapsed="0.000862"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:19:01.547233" elapsed="0.000822"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:19:01.513857" elapsed="0.034350"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:01.549669" elapsed="0.000579"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:01.548914" elapsed="0.001565"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:01.321311" elapsed="0.229272"/>
</test>
<test id="s1-s8-t15" name="TC2_BGP_Peer2_Check_Log_For_Introduced_Prefixes" line="319">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:01.557778" elapsed="0.000220"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:01.557488" elapsed="0.000566"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:01.559153" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.559012" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.558987" elapsed="0.000242"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:01.566791" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.566671" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.566635" elapsed="0.000229"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.567999" 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-06-06T03:19:01.567518" elapsed="0.000509"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.568527" 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-06-06T03:19:01.568198" elapsed="0.000369"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:01.568627" elapsed="0.000056"/>
</return>
<msg time="2026-06-06T03:19:01.568825" 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-06-06T03:19:01.567107" elapsed="0.001744"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:01.574960" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.574843" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.574822" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:01.576280" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:01.576170" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.576151" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:01.576833" 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-06-06T03:19:01.576497" elapsed="0.000363"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.577250" level="INFO">${current_connection_index} = 7</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-06-06T03:19:01.577026" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.606617" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:01.577808" elapsed="0.029116"/>
</kw>
<msg time="2026-06-06T03:19:01.607162" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:01.607210" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:01.577441" elapsed="0.029807"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.634730" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:19:01.608043" elapsed="0.026802"/>
</kw>
<msg time="2026-06-06T03:19:01.635008" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:01.635054" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</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-06-06T03:19:01.607512" elapsed="0.027579"/>
</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-06-06T03:19:01.635454" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:01.635189" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.635160" elapsed="0.000378"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.636057" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:19:01.635707" elapsed="0.000447"/>
</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-06-06T03:19:01.636448" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:01.636223" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.636204" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:01.636564" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:01.639320" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:19:01.639535" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:01.638191" elapsed="0.001498"/>
</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="NOT RUN" start="2026-06-06T03:19:01.640018" elapsed="0.000092"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.640407" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:01.637512" elapsed="0.003099"/>
</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-06-06T03:19:01.636909" elapsed="0.003791"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:01.575839" elapsed="0.064962"/>
</kw>
<msg time="2026-06-06T03:19:01.640987" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:01.641033" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:01.575190" elapsed="0.065881"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:01.641479" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:19:01.641149" elapsed="0.000392"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.641130" elapsed="0.000435"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.642019" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.642360" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:01.642432" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:01.574476" elapsed="0.068097"/>
</kw>
<msg time="2026-06-06T03:19:01.642691" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:01.642737" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:01.569368" elapsed="0.073407"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:01.643109" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:01.642851" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:01.642833" elapsed="0.000367"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:01.569192" elapsed="0.074032"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:01.568978" elapsed="0.074278"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:01.566269" elapsed="0.077042"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:01.558695" elapsed="0.084673"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:01.558217" elapsed="0.085198"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:01.552790" elapsed="0.090677"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:01.643657" elapsed="0.000112"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:01.657889" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:01.670992" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:01.671239" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:01.657718" elapsed="0.013577"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.672705" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:01.671741" elapsed="0.001110"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:01.674341" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:01.673318" elapsed="0.001176">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:01.657283" elapsed="0.017500">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:02.694625" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:02.708430" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:02.708704" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:02.694420" elapsed="0.014345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:02.709879" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:02.709161" elapsed="0.000821"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:02.711272" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:02.710401" elapsed="0.001028">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:02.693863" elapsed="0.017835">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:03.734396" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:03.748627" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:03.748942" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:03.733986" elapsed="0.015003"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:03.749953" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:03.749390" elapsed="0.000638"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:03.750921" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:03.750281" elapsed="0.000761">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:03.732697" elapsed="0.018530">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:04.769681" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:04.783788" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:04.784021" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:04.769468" elapsed="0.014612"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:04.785141" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:04.784472" elapsed="0.000769"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:04.786438" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:04.785594" elapsed="0.000998">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:04.768948" elapsed="0.017915">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:05.806123" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:05.820150" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:05.820388" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:05.805923" elapsed="0.014521"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:05.821556" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:05.820918" elapsed="0.000773"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:05.822884" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:05.822047" elapsed="0.000993">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:05.805388" elapsed="0.017908">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:06.842726" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:06.856562" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:06.856733" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:06.842515" elapsed="0.014254"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:06.857629" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:06.857020" elapsed="0.000773"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:06.858963" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:06.858143" elapsed="0.000971">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:06.842003" elapsed="0.017346">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:07.879220" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:07.892500" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:07.892763" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:07.879018" elapsed="0.013804"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:07.893870" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:07.893212" elapsed="0.000759"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:07.895166" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:07.894320" elapsed="0.000944">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:07.878463" elapsed="0.016950">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:08.908925" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:08.922494" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:08.922849" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:08.908728" elapsed="0.014203"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:08.924277" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:08.923581" elapsed="0.000801"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:08.925558" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:08.924764" elapsed="0.000971">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:08.908163" elapsed="0.017811">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:09.943312" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:09.956469" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:09.956623" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:09.943116" elapsed="0.013564"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:09.957366" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:09.956941" elapsed="0.000492"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:09.958210" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:09.957680" elapsed="0.000632">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:09.942600" elapsed="0.015868">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:10.978539" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:10.991736" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:10.991888" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:10.978339" elapsed="0.013585"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:10.992825" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:10.992175" elapsed="0.000755"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:10.994186" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:10.993338" elapsed="0.001004">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:10.977782" elapsed="0.016795">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:12.014492" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:12.028570" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:12.028862" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:12.014294" elapsed="0.014648"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:12.030085" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:12.029352" elapsed="0.000837"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:12.031375" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:12.030539" elapsed="0.000986">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:12.013751" elapsed="0.018041">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:13.051932" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:13.065519" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:13.065691" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:13.051732" elapsed="0.013987"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:13.066309" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:13.065953" elapsed="0.000403"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:13.066982" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:13.066530" elapsed="0.000533">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:13.051166" elapsed="0.016020">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:14.093675" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:14.106776" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:14.106893" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:14.093456" elapsed="0.013463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:14.107697" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:14.107110" elapsed="0.000715"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:14.109060" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:14.108194" elapsed="0.001020">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:14.092827" elapsed="0.016779">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:15.129020" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:15.142291" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:15.142532" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:15.128824" elapsed="0.013765"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:15.143628" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:15.143014" elapsed="0.000744"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:15.145040" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:15.144156" elapsed="0.001036">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:15.128293" elapsed="0.017132">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:16.165653" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:16.178966" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:16.179211" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:16.165440" elapsed="0.013829"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:16.180350" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:16.179709" elapsed="0.000745"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:16.181741" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:16.180876" elapsed="0.001023">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:16.164928" elapsed="0.017209">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:17.200615" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:17.213733" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:17.214064" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:17.200412" elapsed="0.013715"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:17.215344" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:17.214613" elapsed="0.000840"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:17.216843" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:17.215868" elapsed="0.001141">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:17.199878" elapsed="0.017391">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:18.237397" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:18.250803" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:18.251009" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:18.237194" elapsed="0.013842"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:18.251665" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:18.251298" elapsed="0.000417"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:18.252251" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:18.251876" elapsed="0.000448">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:18.236583" elapsed="0.015855">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:19.273362" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:19.286301" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:19.286448" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:19.273161" elapsed="0.013322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:19.287170" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:19.286757" elapsed="0.000475"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:19.288031" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:19.287451" elapsed="0.000685">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:19.272436" elapsed="0.015853">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:20.306527" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:20.320303" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:20.320457" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:20.306331" elapsed="0.014162"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:20.321500" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:20.320822" elapsed="0.000789"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:20.322914" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:20.322021" elapsed="0.001056">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:20.305611" elapsed="0.017721">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:21.341667" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:21.355057" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:21.355295" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:21.341443" elapsed="0.013909"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:21.356468" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:21.355828" elapsed="0.000744"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:21.357818" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:21.356967" elapsed="0.001002">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:21.340877" elapsed="0.017326">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:22.377274" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:22.390874" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:22.391222" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:22.377078" elapsed="0.014217"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.392793" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:22.391921" elapsed="0.001004"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.394570" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:22.393390" elapsed="0.001349">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:22.376494" elapsed="0.018429">0 != 3</status>
</kw>
<msg time="2026-06-06T03:19:22.395077" level="FAIL">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:19:01.643938" elapsed="20.751290">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>nlri_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="NOT RUN" start="2026-06-06T03:19:22.409894" elapsed="0.000030"/>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>0</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="NOT RUN" start="2026-06-06T03:19:22.422209" elapsed="0.000028"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.423614" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:19:22.423298" elapsed="0.000377"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:22.422909" elapsed="0.000819"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:22.422556" elapsed="0.001228"/>
</kw>
<doc>Check incomming updates for new routes</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:19:01.551394" elapsed="20.872430">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</test>
<test id="s1-s8-t16" name="TC2_Disconnect_BGP_Peer1" line="336">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:22.427319" elapsed="0.000212"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:22.427049" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:22.428680" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:22.428518" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.428494" elapsed="0.000262"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:22.434275" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:22.434164" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.434110" elapsed="0.000311"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.435458" 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-06-06T03:19:22.435072" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.435973" 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-06-06T03:19:22.435668" elapsed="0.000331"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:22.436045" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:19:22.436205" 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-06-06T03:19:22.434683" elapsed="0.001547"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:22.442076" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:22.441967" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.441948" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:22.443396" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:22.443285" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.443266" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:22.443948" 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-06-06T03:19:22.443616" elapsed="0.000359"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:22.444361" level="INFO">${current_connection_index} = 8</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-06-06T03:19:22.444142" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:22.475770" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:22.444938" elapsed="0.030971"/>
</kw>
<msg time="2026-06-06T03:19:22.476104" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:22.476151" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:22.444552" elapsed="0.031636"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:22.495999" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:19:22.476835" elapsed="0.019343"/>
</kw>
<msg time="2026-06-06T03:19:22.496373" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:22.496420" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:19:22.476406" elapsed="0.020051"/>
</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-06-06T03:19:22.496875" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:22.496558" elapsed="0.000374"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.496531" elapsed="0.000427"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.497440" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:19:22.497113" elapsed="0.000395"/>
</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-06-06T03:19:22.497828" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:22.497575" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.497557" elapsed="0.000349"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:22.497943" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:22.500885" elapsed="0.000390"/>
</kw>
<msg time="2026-06-06T03:19:22.501342" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:22.499626" elapsed="0.001857"/>
</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="NOT RUN" start="2026-06-06T03:19:22.501800" elapsed="0.000170"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:22.502242" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:22.498943" elapsed="0.003490"/>
</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-06-06T03:19:22.498277" elapsed="0.004243"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:22.442980" elapsed="0.059643"/>
</kw>
<msg time="2026-06-06T03:19:22.502738" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:22.502784" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:22.442336" elapsed="0.060487"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:22.503017" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:19:22.502904" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.502883" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:22.503520" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:22.503901" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:22.503973" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:22.441609" elapsed="0.062472"/>
</kw>
<msg time="2026-06-06T03:19:22.504175" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:22.504219" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:22.436615" elapsed="0.067641"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:22.504586" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:22.504330" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:22.504313" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:22.436466" elapsed="0.068241"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:22.436289" elapsed="0.068450"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:22.433769" elapsed="0.071026"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:22.428215" elapsed="0.076636"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:22.427763" elapsed="0.077135"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:22.424740" elapsed="0.080212"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:22.505128" elapsed="0.000108"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:22.506374" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:22.506060" elapsed="0.000341"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:22.506606" elapsed="0.000308"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:19:22.505788" elapsed="0.001200"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:19:24.507938" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:19:24.508294" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:19:22.507143" elapsed="2.001223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.509686" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:24.508950" elapsed="0.000855"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:19:22.505451" elapsed="2.004486"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:24.526310" level="INFO">Executing command 'cat bgp_peer1.log'.</msg>
<msg time="2026-06-06T03:19:24.539681" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:24.539905" level="INFO">${output_log} = 2026-06-06 03:18:59,209 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:18:59,209 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:18:59,210 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:24.526166" elapsed="0.013928"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.541124" level="INFO">2026-06-06 03:18:59,209 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:18:59,209 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:18:59,210 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:18:59,210 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:18:59,210 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:18:59,210 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:18:59,211 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:18:59,211 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:18:59,211 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Prefix base: 8.1.0.0/28
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706433
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:18:59,212 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706433 (0x7f000001)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0'
2026-06-06 03:18:59,212 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0
2026-06-06 03:18:59,213 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:18:59,213 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:59,214 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:18:59,214 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:59,215 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:18:59,217 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.0')]
2026-06-06 03:18:59,217 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:59,217 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:18:59,217 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:59,218 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:59,218 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:59,218 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:59,218 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:59,219 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,219 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:59,219 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:59,219 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:59,219 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.0')]/28 (0x1c08010000)
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010000
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:18:59,220 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:18:59,221 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:59,222 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:59,223 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:18:59,223 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.16')]
2026-06-06 03:18:59,223 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:59,223 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:18:59,223 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:59,224 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:59,224 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:59,224 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:59,224 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:59,224 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,225 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:59,225 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:59,225 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:59,225 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.16')]/28 (0x1c08010010)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010010
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.32')]
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:18:59,226 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.32')]/28 (0x1c08010020)
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010020
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.011940717697143555s
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job):   
2026-06-06 03:18:59,227 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:18:59,227 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:18:59,228 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:19:00,375 INFO BGP-Thread-1 (job): ... idle for 1.148s
2026-06-06 03:19:00,376 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.148s
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020000
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0033' (51)
2026-06-06 03:19:00,376 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020000'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020000'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020000'
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.0/28']
2026-06-06 03:19:00,377 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.0/28
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:19:00,378 INFO BGP-Thread-1 (job): total_received_update_message_counter: 2
2026-06-06 03:19:00,378 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 1
2026-06-06 03:19:00,378 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020010
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:19:00,378 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0033' (51)
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020010'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020010'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:19:00,379 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020010'
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.16/28']
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.16/28
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:19:00,380 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020020
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:19:00,411 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0033' (51)
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a04c0000202800e0e00010104c0000201001c08020020'
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:19:00,412 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020020'
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020020'
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.32/28']
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.32/28
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:19:00,413 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:19:10,420 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:19:10,421 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.186s
2026-06-06 03:19:10,421 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:19:10,421 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:19:10,421 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:19:20,431 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:19:20,431 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.196s
2026-06-06 03:19:20,431 INFO BGP-Thread-1 (job): total_received_update_message_counter: 4
2026-06-06 03:19:20,432 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:19:20,432 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:24.540478" elapsed="0.001377"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:24.543149" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc2_bgp_peer1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc2_bgp_peer1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:19:24.542291" elapsed="0.000985"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>tc2_${BGP_PEER1_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:24.525739" elapsed="0.017674"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:24.544796" elapsed="0.000659"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:24.544062" elapsed="0.001542"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:22.424210" elapsed="2.121504"/>
</test>
<test id="s1-s8-t17" name="TC2_BGP_Peer2_Check_Log_For_Withdrawn_Prefixes" line="343">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:24.550912" elapsed="0.000297"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:24.550495" elapsed="0.000793"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:24.552760" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:24.552556" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.552524" elapsed="0.000338"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:24.558417" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:24.558310" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.558291" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.559495" 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-06-06T03:19:24.559111" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.560002" 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-06-06T03:19:24.559705" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:24.560072" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:19:24.560232" 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-06-06T03:19:24.558732" elapsed="0.001524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:24.566153" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:24.566044" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.566024" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:24.567413" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:24.567306" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.567287" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:24.567964" 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-06-06T03:19:24.567628" elapsed="0.000363"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:24.568370" level="INFO">${current_connection_index} = 7</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-06-06T03:19:24.568154" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:24.598849" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:24.568924" elapsed="0.030034"/>
</kw>
<msg time="2026-06-06T03:19:24.599127" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:24.599173" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:24.568559" elapsed="0.030650"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:24.623786" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:19:24.599783" elapsed="0.024159"/>
</kw>
<msg time="2026-06-06T03:19:24.624207" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:24.624256" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</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-06-06T03:19:24.599392" elapsed="0.024901"/>
</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-06-06T03:19:24.624709" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:24.624394" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.624364" elapsed="0.000431"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.625323" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:19:24.624946" elapsed="0.000452"/>
</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-06-06T03:19:24.625711" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:24.625468" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.625449" elapsed="0.000343"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:24.625829" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:24.628411" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:19:24.628622" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:24.627370" elapsed="0.001510"/>
</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="NOT RUN" start="2026-06-06T03:19:24.629169" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:24.629547" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:24.626726" elapsed="0.003029"/>
</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-06-06T03:19:24.626140" elapsed="0.003682"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:24.567004" elapsed="0.062918"/>
</kw>
<msg time="2026-06-06T03:19:24.630015" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:24.630060" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:24.566376" elapsed="0.063721"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:24.630285" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:19:24.630175" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.630155" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:24.630802" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:24.631152" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:24.631225" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:24.565703" elapsed="0.065632"/>
</kw>
<msg time="2026-06-06T03:19:24.631430" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:24.631476" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:24.560635" elapsed="0.070879"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:24.631875" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:24.631590" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:24.631572" elapsed="0.000384"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:24.560488" elapsed="0.071492"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:24.560313" elapsed="0.071700"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:24.557950" elapsed="0.074118"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:24.552144" elapsed="0.080017"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:24.551506" elapsed="0.080704"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:24.546883" elapsed="0.085382"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:24.632436" elapsed="0.000108"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:24.646175" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:24.659530" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:24.659783" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:24.646008" elapsed="0.013833"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.660857" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:24.660221" elapsed="0.000747"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:24.662219" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:24.661320" elapsed="0.001051">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:24.645582" elapsed="0.017019">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:25.681088" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:25.694999" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:25.695233" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:25.680891" elapsed="0.014401"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:25.696365" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:25.695731" elapsed="0.000736"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:25.697694" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:25.696864" elapsed="0.001044">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:25.680355" elapsed="0.017794">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:26.715979" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:26.729226" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:26.729378" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:26.715772" elapsed="0.013642"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:26.730249" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:26.729788" elapsed="0.000527"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:26.731258" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:26.730541" elapsed="0.000871">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:26.715210" elapsed="0.016473">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:27.750927" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:27.764276" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:27.764511" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:27.750716" elapsed="0.013852"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:27.765730" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:27.765041" elapsed="0.000796"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:27.767048" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:27.766194" elapsed="0.001005">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:27.750156" elapsed="0.017285">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:28.786480" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:28.799874" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:28.800024" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:28.786281" elapsed="0.013797"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:28.800794" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:28.800331" elapsed="0.000529"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:28.802052" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:28.801205" elapsed="0.001154">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:28.785760" elapsed="0.016841">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:29.821250" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:29.834258" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:29.834406" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:29.821046" elapsed="0.013396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:29.835176" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:29.834720" elapsed="0.000520"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:29.836040" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:29.835458" elapsed="0.000735">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:29.820483" elapsed="0.015942">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:30.855692" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:30.869403" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:30.869681" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:30.855463" elapsed="0.014281"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:30.870819" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:30.870144" elapsed="0.000777"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:30.872094" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:30.871269" elapsed="0.000976">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:30.854785" elapsed="0.017697">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:31.893560" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:31.906735" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:31.906847" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:31.893364" elapsed="0.013509"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:31.907365" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:31.907055" elapsed="0.000374"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:31.907983" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:31.907588" elapsed="0.000471">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:31.892842" elapsed="0.015328">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:32.927222" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:32.940534" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:32.940737" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:32.927029" elapsed="0.013747"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:32.941779" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:32.941092" elapsed="0.000787"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:32.943024" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:32.942225" elapsed="0.000944">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:32.926500" elapsed="0.016898">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:33.963574" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:33.976832" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:33.977075" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:33.963357" elapsed="0.013775"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:33.978212" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:33.977537" elapsed="0.000778"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:33.979532" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:33.978696" elapsed="0.001014">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:33.962832" elapsed="0.017111">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:34.998503" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:35.011705" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:35.011855" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:34.998312" elapsed="0.013579"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:35.012539" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:35.012139" elapsed="0.000462"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:35.013415" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:35.012841" elapsed="0.000671">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:34.997814" elapsed="0.015868">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:36.029731" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:36.043274" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:36.043818" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:36.029520" elapsed="0.014395"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:36.045462" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:36.044578" elapsed="0.000991"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:36.047066" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:36.045975" elapsed="0.001263">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:36.029001" elapsed="0.018511">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:37.068158" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:37.081327" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:37.081480" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:37.067948" elapsed="0.013568"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:37.082244" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:37.081797" elapsed="0.000552"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:37.083538" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:37.082735" elapsed="0.000987">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:37.067274" elapsed="0.016747">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:38.103106" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:38.116429" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:38.116587" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:38.102903" elapsed="0.013721"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:38.117579" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:38.116934" elapsed="0.000791"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:38.119072" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:38.118140" elapsed="0.001087">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:38.102354" elapsed="0.017111">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:39.139881" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:39.153438" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:39.153910" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:39.139676" elapsed="0.014302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:39.155265" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:39.154516" elapsed="0.000857"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:39.156575" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:39.155762" elapsed="0.001023">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:39.139048" elapsed="0.017985">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:40.178624" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:40.192004" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:40.192233" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:40.178349" elapsed="0.013947"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:40.193613" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:40.192946" elapsed="0.000812"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:40.195025" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:40.194140" elapsed="0.001040">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:40.177680" elapsed="0.017945">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:41.214852" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:41.228148" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:41.228404" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:41.214654" elapsed="0.013808"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:41.229507" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:41.228881" elapsed="0.000726"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:41.230799" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:41.229986" elapsed="0.000966">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:41.214141" elapsed="0.017041">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:42.252033" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:42.264934" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:42.265051" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:42.251829" elapsed="0.013248"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:42.265834" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:42.265314" elapsed="0.000566"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:42.266406" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:42.266037" elapsed="0.000445">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:42.251198" elapsed="0.015397">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:43.285831" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:43.299316" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:43.299513" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:43.285611" elapsed="0.013959"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:43.300621" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:43.299999" elapsed="0.000759"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:43.301996" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:43.301105" elapsed="0.001047">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:43.285073" elapsed="0.017358">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:44.321133" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:44.334427" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:44.334706" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:44.320940" elapsed="0.013828"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:44.335897" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:44.335225" elapsed="0.000780"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:44.337214" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:44.336365" elapsed="0.001003">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:44.320417" elapsed="0.017193">0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:45.357320" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:45.370712" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:45.370954" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:45.357109" elapsed="0.013902"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.372171" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:45.371405" elapsed="0.000871"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.373853" level="FAIL">0 != 3</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:45.372629" elapsed="0.001424">0 != 3</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:45.356545" elapsed="0.017779">0 != 3</status>
</kw>
<msg time="2026-06-06T03:19:45.374531" level="FAIL">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${BGP_PEER1_PREFIX_COUNT}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:19:24.632728" elapsed="20.742048">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>withdrawn_prefix_received: ${BGP_PEER1_FIRST_PREFIX_IP}/${BGP_PEER1_PREFIX_LEN}</arg>
<arg>1</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="NOT RUN" start="2026-06-06T03:19:45.390272" elapsed="0.000044"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.391971" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:19:45.391578" elapsed="0.000441"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:45.391116" elapsed="0.000958"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:45.390724" elapsed="0.001409"/>
</kw>
<doc>Check incomming updates for withdrawn routes</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:19:24.546115" elapsed="20.846060">Keyword 'BGPCliKeywords.Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 3</status>
</test>
<test id="s1-s8-t18" name="TC2_Disconnect_BGP_Peer2" line="359">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:45.395950" elapsed="0.000225"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:45.395607" elapsed="0.000626"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:45.397344" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:45.397201" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.397176" elapsed="0.000246"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:45.403154" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:45.403040" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.403021" elapsed="0.000203"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.404381" 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-06-06T03:19:45.403974" elapsed="0.000435"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.404903" 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-06-06T03:19:45.404579" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:45.404975" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:19:45.405141" 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-06-06T03:19:45.403501" elapsed="0.001664"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:45.411134" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:45.411021" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.411001" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:45.412550" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:45.412439" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.412420" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:45.413203" 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-06-06T03:19:45.412889" elapsed="0.000341"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:45.413659" level="INFO">${current_connection_index} = 8</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-06-06T03:19:45.413418" elapsed="0.000269"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:45.448575" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:45.414210" elapsed="0.034557"/>
</kw>
<msg time="2026-06-06T03:19:45.448956" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:45.449004" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:45.413855" elapsed="0.035417"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:45.470373" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:19:45.449896" elapsed="0.020585"/>
</kw>
<msg time="2026-06-06T03:19:45.470665" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:45.470714" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:19:45.449491" elapsed="0.021261"/>
</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-06-06T03:19:45.471077" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:45.470838" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.470815" elapsed="0.000365"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.471688" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:19:45.471354" elapsed="0.000405"/>
</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-06-06T03:19:45.472079" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:45.471828" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.471809" elapsed="0.000350"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:45.472195" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:45.475010" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:19:45.475219" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:45.473886" elapsed="0.001469"/>
</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="NOT RUN" start="2026-06-06T03:19:45.475828" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:45.476222" elapsed="0.000089"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:45.473217" elapsed="0.003221"/>
</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-06-06T03:19:45.472499" elapsed="0.004006"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:45.412127" elapsed="0.064480"/>
</kw>
<msg time="2026-06-06T03:19:45.476726" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:45.476773" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:45.411386" elapsed="0.065426"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:45.477006" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:19:45.476893" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.476872" elapsed="0.000225"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:45.477542" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:45.477900" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:45.477975" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:45.410672" elapsed="0.067415"/>
</kw>
<msg time="2026-06-06T03:19:45.478180" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:45.478224" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:45.405563" elapsed="0.072701"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:45.478655" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:45.478339" elapsed="0.000373"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:45.478321" elapsed="0.000416"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:45.405410" elapsed="0.073352"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:45.405225" elapsed="0.073569"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:45.402663" elapsed="0.076186"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:45.396887" elapsed="0.082020"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:45.396403" elapsed="0.082552"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:45.393278" elapsed="0.085731"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:45.479179" elapsed="0.000110"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:45.480509" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:45.480183" elapsed="0.000354"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:45.480716" elapsed="0.000292"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:19:45.479865" elapsed="0.001218"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.482021" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:19:47.482388" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:19:45.481243" elapsed="2.001211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.483707" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.483000" elapsed="0.000823"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:19:45.479513" elapsed="2.004450"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.497495" level="INFO">Executing command 'cat bgp_peer2.log'.</msg>
<msg time="2026-06-06T03:19:47.511137" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:47.511281" level="INFO">${output_log} = 2026-06-06 03:19:00,351 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:19:00,351 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:19:00,351 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:47.497331" elapsed="0.013988"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.511967" level="INFO">2026-06-06 03:19:00,351 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:19:00,351 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:19:00,351 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:19:00,351 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:19:00,351 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:19:00,351 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Prefix base: 8.2.0.0/28
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706434
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:19:00,353 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:19:00,354 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:19:00,354 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:19:00,354 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706434 (0x7f000002)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0'
2026-06-06 03:19:00,354 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:00,356 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.0')]
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:00,356 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.0')]/28 (0x1c08020000)
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020000
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:19:00,357 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.16')]
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:00,359 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,360 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:00,362 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:00,362 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:00,362 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:00,362 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:00,362 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:00,362 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.16')]/28 (0x1c08020010)
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020010
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:00,363 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:00,364 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:19:00,364 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:00,364 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:00,364 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:19:00,364 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.32')]
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:00,365 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:00,366 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:00,366 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:00,366 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:00,366 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:00,366 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.32')]/28 (0x1c08020020)
2026-06-06 03:19:00,366 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020020
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:19:00,366 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.009767532348632812s
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:00,367 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:19:00,367 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:00,367 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:19:00,368 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:19:00,369 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:19:10,379 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:19:10,380 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:19:10,380 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:19:10,380 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:19:10,380 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:19:20,390 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:19:20,390 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.020s
2026-06-06 03:19:20,390 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:19:20,390 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:19:20,390 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:19:30,395 INFO BGP-Thread-1 (job): ... idle for 10.005s
2026-06-06 03:19:30,395 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.025s
2026-06-06 03:19:30,396 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:19:30,396 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:19:30,396 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:19:40,400 INFO BGP-Thread-1 (job): ... idle for 10.004s
2026-06-06 03:19:40,400 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.028s
2026-06-06 03:19:40,400 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:19:40,400 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:19:40,400 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.511558" elapsed="0.000779"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:47.513196" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc2_bgp_peer2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc2_bgp_peer2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:19:47.512630" elapsed="0.000646"/>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>tc2_${BGP_PEER2_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:47.496895" elapsed="0.016470"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:47.514299" elapsed="0.000378"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:47.513844" elapsed="0.000926"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:45.392746" elapsed="2.122079"/>
</test>
<test id="s1-s8-t19" name="TC_2_Check_for_Empty_IPv4_Topology" line="366">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:47.520012" elapsed="0.000317"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:47.519568" elapsed="0.000842"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.522028" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.521807" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.521771" elapsed="0.000400"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.528996" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.528885" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.528866" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.530150" 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-06-06T03:19:47.529747" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.530673" 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-06-06T03:19:47.530348" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:47.530745" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:19:47.530913" 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-06-06T03:19:47.529302" elapsed="0.001635"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:47.536806" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.536692" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.536670" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:47.538172" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.538057" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.538038" elapsed="0.000206"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:47.538731" 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-06-06T03:19:47.538397" elapsed="0.000362"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.539154" level="INFO">${current_connection_index} = 8</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-06-06T03:19:47.538929" elapsed="0.000252"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.569511" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:47.539718" elapsed="0.029920"/>
</kw>
<msg time="2026-06-06T03:19:47.569853" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:47.569901" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:47.539348" elapsed="0.030590"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.614953" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "2 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:19:47.570486" elapsed="0.044685"/>
</kw>
<msg time="2026-06-06T03:19:47.615389" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:47.615534" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "2 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</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-06-06T03:19:47.570130" elapsed="0.045445"/>
</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-06-06T03:19:47.616025" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.615715" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.615681" elapsed="0.000430"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.616624" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "2 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:19:47.616261" elapsed="0.000454"/>
</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-06-06T03:19:47.617010" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.616785" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.616765" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:47.617127" elapsed="0.000059"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:47.619845" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:19:47.620058" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:47.618796" elapsed="0.001399"/>
</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="NOT RUN" start="2026-06-06T03:19:47.620478" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.620833" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:47.618118" elapsed="0.002904"/>
</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-06-06T03:19:47.617476" elapsed="0.003612"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:47.537740" elapsed="0.083449"/>
</kw>
<msg time="2026-06-06T03:19:47.621284" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:47.621330" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "2 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:47.537035" elapsed="0.084333"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:47.621571" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:19:47.621446" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.621427" elapsed="0.000250"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.622090" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.622437" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.622510" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:47.536330" elapsed="0.086290"/>
</kw>
<msg time="2026-06-06T03:19:47.622732" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:47.622775" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "2 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:47.531330" elapsed="0.091483"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.623144" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.622889" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.622871" elapsed="0.000351"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:47.531179" elapsed="0.092067"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:47.530996" elapsed="0.092282"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:47.528498" elapsed="0.094836"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:47.521309" elapsed="0.102084"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:47.520638" elapsed="0.102843"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:47.515890" elapsed="0.107650"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:47.631566" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:47.631717" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:19:47.631831" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:47.624741" elapsed="0.007116"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.636304" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.632027" elapsed="0.004345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.640268" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.636605" elapsed="0.003730"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:19:47.640558" elapsed="0.003290"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Check the example-ipv4-topology does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:19:47.624364" elapsed="0.019550"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:19:47.623742" elapsed="0.020222"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:47.644559" elapsed="0.000262"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:47.644249" elapsed="0.000635"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.515254" elapsed="0.129669"/>
</test>
<test id="s1-s8-t20" name="TC2_Delete_BGP_Peers_Configuration" line="374">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:47.648379" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:47.648112" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.649715" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.649580" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.649556" elapsed="0.000230"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.655258" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.655150" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.655131" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.656549" 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-06-06T03:19:47.656137" elapsed="0.000441"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.657076" 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-06-06T03:19:47.656769" elapsed="0.000334"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:47.657151" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:19:47.657316" 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-06-06T03:19:47.655556" elapsed="0.001786"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:47.663432" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.663321" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.663300" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:47.664743" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:47.664610" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.664591" elapsed="0.000287"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:47.665342" 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-06-06T03:19:47.665034" elapsed="0.000335"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.665805" level="INFO">${current_connection_index} = 8</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-06-06T03:19:47.665536" elapsed="0.000296"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.694584" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:47.666351" elapsed="0.028352"/>
</kw>
<msg time="2026-06-06T03:19:47.694869" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:47.694915" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:47.666002" elapsed="0.028950"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:47.717211" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:19:47.695482" elapsed="0.021837"/>
</kw>
<msg time="2026-06-06T03:19:47.717482" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:47.717528" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</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-06-06T03:19:47.695130" elapsed="0.022434"/>
</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-06-06T03:19:47.717939" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.717702" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.717677" elapsed="0.000343"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.718471" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:19:47.718170" elapsed="0.000375"/>
</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-06-06T03:19:47.718855" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.718615" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.718596" elapsed="0.000337"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:47.718968" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:47.721483" elapsed="0.000186"/>
</kw>
<msg time="2026-06-06T03:19:47.721733" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:47.720444" elapsed="0.001423"/>
</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="NOT RUN" start="2026-06-06T03:19:47.722148" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.722491" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:47.719816" elapsed="0.002879"/>
</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-06-06T03:19:47.719259" elapsed="0.003503"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:47.664301" elapsed="0.058560"/>
</kw>
<msg time="2026-06-06T03:19:47.722956" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:47.723001" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:47.663676" elapsed="0.059362"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:47.723226" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:19:47.723115" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.723096" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.723729" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.724133" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.724204" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:47.662972" elapsed="0.061341"/>
</kw>
<msg time="2026-06-06T03:19:47.724407" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:47.724452" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "2 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:47.657764" elapsed="0.066724"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.724834" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.724564" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.724546" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:47.657598" elapsed="0.067338"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:47.657402" elapsed="0.067565"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:47.654687" elapsed="0.070336"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:47.649256" elapsed="0.075823"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:47.648820" elapsed="0.076304"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:47.645825" elapsed="0.079353"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.725953" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer1 | IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer1</arg>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.725357" elapsed="0.000625"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.772192" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:47.771810" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:47.773022" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:47.772750" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:47.773198" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:47.772390" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.773838" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:47.773391" elapsed="0.000474"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:47.774173" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:19:47.774362" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:19:47.774034" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.774819" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.774552" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.775842" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.775556" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.776317" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.776051" elapsed="0.000342"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.777092" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.776789" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.777895" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.777666" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.777974" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:19:47.778137" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.777310" elapsed="0.000852"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.778329" elapsed="0.000242"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:19:47.776630" elapsed="0.001983"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.779212" level="INFO">${value} = example-bgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.778894" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.780009" level="INFO">${encoded} = example-bgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.779794" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.780086" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:47.780238" level="INFO">${encoded_value} = example-bgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.779441" elapsed="0.000822"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.780418" elapsed="0.000442"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer1</var>
<status status="PASS" start="2026-06-06T03:19:47.778753" elapsed="0.002149"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.781452" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.781151" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.782267" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.782044" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.782344" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:47.782495" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.781719" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.782691" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:19:47.781014" elapsed="0.001942"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.783505" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.783205" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.784271" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.784059" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.784347" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:47.784497" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.783737" elapsed="0.000784"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.784692" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:47.783069" elapsed="0.001889"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:19:47.776449" elapsed="0.008543"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:19:47.785036" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:19:47.785195" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:19:47.775231" elapsed="0.009989"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.774931" elapsed="0.010321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.785435" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.785279" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.774912" elapsed="0.010599"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.786338" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:47.785691" elapsed="0.000770"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:19:47.786515" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:47.771171" elapsed="0.015492"/>
</kw>
<msg time="2026-06-06T03:19:47.786723" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:47.757388" elapsed="0.029387"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.800132" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.813498" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.826797" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.827008" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.827194" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.827586" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.827433" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:19:47.827416" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.827832" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.828003" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.828172" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:19:47.827383" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.827276" elapsed="0.000975"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.828403" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.828478" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:19:47.828609" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:19:47.752621" elapsed="0.076016"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.829895" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.829572" elapsed="0.000371"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:47.843201" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:47.843268" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:47.843395" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:47.832404" elapsed="0.011028"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.830010" elapsed="0.013479"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.843778" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.843526" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.829992" elapsed="0.013907"/>
</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-06-06T03:19:47.848928" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.845330" elapsed="0.003659"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.845012" elapsed="0.004026"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.844986" elapsed="0.004087"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.853011" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.849466" elapsed="0.003611"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.849151" elapsed="0.003975"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.849128" elapsed="0.004032"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.854008" 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-06-06T03:19:47.853412" elapsed="0.000634"/>
</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-06-06T03:19:47.854486" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.854146" elapsed="0.000426"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.855282" 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-06-06T03:19:47.854861" elapsed="0.000457"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.854606" elapsed="0.000762"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.854120" elapsed="0.001277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.856156" 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-06-06T03:19:47.855631" elapsed="0.000563"/>
</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-06-06T03:19:47.856630" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.856292" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.857417" 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-06-06T03:19:47.857001" elapsed="0.000454"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.856766" elapsed="0.000738"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.856266" elapsed="0.001268"/>
</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-06-06T03:19:47.857805" elapsed="0.000491"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:19:47.859022" 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-06-06T03:19:47.858534" elapsed="0.000515"/>
</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-06-06T03:19:47.859210" elapsed="0.002533"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:19:47.844409" elapsed="0.017399"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:19:47.861899" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:19:47.864543" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:19:47.828963" elapsed="0.035609"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:19:47.864630" elapsed="0.000203"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:19:47.726217" elapsed="0.138719"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.865712" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer2 | IP=127.0.0.2 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer2</arg>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.865125" elapsed="0.000618"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.911975" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:47.911566" elapsed="0.000441"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:47.912805" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:47.912528" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:47.913005" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:47.912184" elapsed="0.000845"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.913585" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:47.913201" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:47.913968" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:19:47.914169" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:19:47.913823" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.914613" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.914360" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.915658" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.915383" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.916145" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.915873" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.916860" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.916541" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.917621" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.917401" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.917740" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:19:47.917913" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.917076" elapsed="0.000862"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.918098" elapsed="0.000236"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:19:47.916401" elapsed="0.001974"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.918935" level="INFO">${value} = example-bgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.918621" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.919770" level="INFO">${encoded} = example-bgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.919470" elapsed="0.000327"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.919848" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:47.920000" level="INFO">${encoded_value} = example-bgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.919149" elapsed="0.000875"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.920181" elapsed="0.000221"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer2</var>
<status status="PASS" start="2026-06-06T03:19:47.918486" elapsed="0.001957"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.921007" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.920708" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.921943" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.921716" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.922021" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:47.922172" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.921220" elapsed="0.000976"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.922352" elapsed="0.000221"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:19:47.920556" elapsed="0.002058"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.923177" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:47.922878" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:47.923934" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.923725" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:47.924010" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:47.924156" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:47.923390" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:47.924335" elapsed="0.000219"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:47.922741" elapsed="0.001854"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:19:47.916225" elapsed="0.008404"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:19:47.924688" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:19:47.924845" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:19:47.915056" elapsed="0.009814"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.914752" elapsed="0.010150"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.925078" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.924927" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.914729" elapsed="0.010426"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.925958" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:47.925300" elapsed="0.000688"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:19:47.926036" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:47.910935" elapsed="0.015224"/>
</kw>
<msg time="2026-06-06T03:19:47.926215" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:47.897179" elapsed="0.029083"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.939593" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.952859" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.966038" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.966240" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.966420" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.966818" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.966664" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:19:47.966634" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.967040" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.967210" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.967379" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:19:47.966604" elapsed="0.000827"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.966497" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.967610" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:19:47.967701" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:19:47.967975" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:19:47.892289" elapsed="0.075712"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.969105" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.968855" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:47.980794" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:47.980842" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:47.980934" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:47.971588" elapsed="0.009372"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.969219" elapsed="0.011782"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:47.981184" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.981027" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.969201" elapsed="0.012101"/>
</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-06-06T03:19:47.986715" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.982930" elapsed="0.003857"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.982552" elapsed="0.004287"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.982521" elapsed="0.004352"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.990772" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:47.987268" elapsed="0.003556"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.986950" elapsed="0.003911"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.986927" elapsed="0.003959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.991502" 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-06-06T03:19:47.991093" elapsed="0.000436"/>
</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-06-06T03:19:47.991866" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.991601" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.992421" 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-06-06T03:19:47.992118" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.991949" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.991583" elapsed="0.000921"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.993056" 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-06-06T03:19:47.992689" elapsed="0.000395"/>
</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-06-06T03:19:47.993395" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:47.993155" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:47.993976" 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-06-06T03:19:47.993657" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:47.993477" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:47.993136" elapsed="0.000923"/>
</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-06-06T03:19:47.994217" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:19:47.995092" 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-06-06T03:19:47.994797" elapsed="0.000321"/>
</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-06-06T03:19:47.995275" elapsed="0.002565"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:19:47.981726" elapsed="0.016186"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:19:47.997964" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:19:48.000491" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:19:47.968267" elapsed="0.032253"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.000575" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:19:47.865989" elapsed="0.134727"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:48.001333" elapsed="0.000244"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:48.001016" elapsed="0.000649"/>
</kw>
<doc>Delete all previously configured BGP peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:47.645227" elapsed="0.356478"/>
</test>
<test id="s1-s8-t21" name="TC3_Configure_Two_iBGP_Non_Client_Peers" line="396">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:48.005386" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:48.005116" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.006825" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.006611" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.006587" elapsed="0.000312"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.012182" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.012076" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.012058" elapsed="0.000192"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.013260" 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-06-06T03:19:48.012879" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.013764" 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-06-06T03:19:48.013451" elapsed="0.000374"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:48.013878" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:48.014102" 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-06-06T03:19:48.012481" elapsed="0.001672"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:48.020051" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.019943" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.019923" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:48.021327" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.021218" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.021199" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:48.021901" 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-06-06T03:19:48.021545" elapsed="0.000383"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.022322" level="INFO">${current_connection_index} = 8</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-06-06T03:19:48.022100" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.054494" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:48.022876" elapsed="0.031719"/>
</kw>
<msg time="2026-06-06T03:19:48.054778" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:48.054824" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:48.022513" elapsed="0.032348"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.079259" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "_ "i "B "G "P "_ "N "o "n "_ "C "l "i "e "n "t "_ "P "e "e "r "s "[K"
[?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-06-06T03:19:48.055380" elapsed="0.023999"/>
</kw>
<msg time="2026-06-06T03:19:48.079548" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:48.079597" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</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-06-06T03:19:48.055035" elapsed="0.024601"/>
</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-06-06T03:19:48.079998" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.079750" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.079725" elapsed="0.000353"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.080533" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "_ "i "B "G "P "_ "N "o "n "_ "C "l "i "e "n "t "_ "P "e "e "r "s "[K"
[?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-06-06T03:19:48.080224" elapsed="0.000380"/>
</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-06-06T03:19:48.080910" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.080688" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.080668" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:48.081023" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:48.083908" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:19:48.084120" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:48.082603" elapsed="0.001652"/>
</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="NOT RUN" start="2026-06-06T03:19:48.084533" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.084892" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:48.081900" elapsed="0.003181"/>
</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-06-06T03:19:48.081311" elapsed="0.003837"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:48.020914" elapsed="0.064333"/>
</kw>
<msg time="2026-06-06T03:19:48.085342" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:48.085386" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:48.020275" elapsed="0.065149"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:48.085608" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:19:48.085500" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.085481" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.086154" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.086497" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.086569" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:48.019588" elapsed="0.067104"/>
</kw>
<msg time="2026-06-06T03:19:48.086789" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:48.086833" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:48.014548" elapsed="0.072322"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.087199" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.086945" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.086927" elapsed="0.000348"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:48.014390" elapsed="0.072909"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:48.014213" elapsed="0.073117"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:48.011715" elapsed="0.075670"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:48.006299" elapsed="0.081141"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:48.005856" elapsed="0.081629"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:48.002608" elapsed="0.084931"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.088533" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer1 | IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=ibgp | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENC...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer1</arg>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=ibgp</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.087736" elapsed="0.000826"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.125712" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.125308" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.126592" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.126348" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:48.126781" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:48.125995" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.127368" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:48.126977" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.127717" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:19:48.127878" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:19:48.127563" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.128312" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.128066" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.129334" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.129072" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.129836" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.129544" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.130561" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.130264" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.131340" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.131120" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.131417" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.131566" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.130799" elapsed="0.000792"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.131763" elapsed="0.000240"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:19:48.130123" elapsed="0.001921"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.132590" level="INFO">${value} = example-bgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.132292" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.133355" level="INFO">${encoded} = example-bgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.133144" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.133432" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.133582" level="INFO">${encoded_value} = example-bgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.132822" elapsed="0.000785"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.133780" elapsed="0.000253"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer1</var>
<status status="PASS" start="2026-06-06T03:19:48.132156" elapsed="0.001919"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.134819" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.134324" elapsed="0.000521"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.135573" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.135362" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.135664" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:48.135853" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.135038" elapsed="0.000840"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.136035" elapsed="0.000223"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:19:48.134188" elapsed="0.002112"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.136874" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.136557" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.137623" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.137408" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.137721" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.137885" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.137088" elapsed="0.000822"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.138069" elapsed="0.000225"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:19:48.136421" elapsed="0.001915"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.138908" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.138588" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.139675" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.139447" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.139752" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:48.139903" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.139123" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.140082" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:19:48.138451" elapsed="0.001893"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.140907" level="INFO">${value} = ibgp</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.140592" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.141667" level="INFO">${encoded} = ibgp</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.141443" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.141745" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.141932" level="INFO">${encoded_value} = ibgp</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.141122" elapsed="0.000840"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.142120" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">ibgp</var>
<status status="PASS" start="2026-06-06T03:19:48.140457" elapsed="0.001927"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.142945" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.142630" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.143703" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.143477" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.143780" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.143929" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.143157" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.144109" elapsed="0.000219"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:19:48.142495" elapsed="0.001874"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.144929" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.144616" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.147070" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.146845" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.147149" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.147300" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.145142" elapsed="0.002216"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.147520" elapsed="0.000243"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:48.144480" elapsed="0.003324"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.148356" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.148054" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.149125" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.148912" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.149203" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.149353" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.148572" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.149533" elapsed="0.000239"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:19:48.147917" elapsed="0.001896"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.150428" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.150088" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.151208" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.150996" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.151285" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.151434" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.150665" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.151613" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:48.149951" elapsed="0.001941"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.152437" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.152140" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.153199" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.152988" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.153277" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.153428" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.152666" elapsed="0.000787"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.153608" elapsed="0.000237"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:48.152004" elapsed="0.001893"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.154448" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.154149" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.155211" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.155001" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.155288" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.155438" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.154679" elapsed="0.000784"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.155617" elapsed="0.000241"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:19:48.154014" elapsed="0.001886"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:19:48.129926" elapsed="0.026009"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:19:48.155979" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:19:48.156142" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'P...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:19:48.128744" elapsed="0.027425"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.128424" elapsed="0.027777"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.156380" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.156226" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.128406" elapsed="0.028087"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.157407" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:48.156656" elapsed="0.000781"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.157487" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:48.124680" elapsed="0.032931"/>
</kw>
<msg time="2026-06-06T03:19:48.157683" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:48.111058" elapsed="0.046674"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.213460" elapsed="0.000061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.227149" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.240514" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.240745" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.240937" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.241346" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.241193" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:19:48.241175" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.241576" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.241763" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.241936" elapsed="0.000034"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:19:48.241136" elapsed="0.000868"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.241023" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.242184" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.242263" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:19:48.242417" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:19:48.106442" elapsed="0.136003"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.270883" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.270479" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.271682" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.271418" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:48.271853" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:48.271080" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.272436" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:48.272045" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.272786" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:19:48.272955" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:19:48.272628" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.273399" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.273144" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:19:48.273846" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.273527" elapsed="0.000378"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.274393" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'P...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.274094" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.273931" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.273508" elapsed="0.000969"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.275601" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:48.274626" elapsed="0.001007"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.275702" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:48.269810" elapsed="0.006024"/>
</kw>
<msg time="2026-06-06T03:19:48.275894" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:48.256341" elapsed="0.019601"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.290093" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.303622" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.316902" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.317119" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.317306" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.317739" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.317567" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:19:48.317548" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.317972" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.318178" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.318349" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:19:48.317510" elapsed="0.000892"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.317393" elapsed="0.001037"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.318583" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.318677" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:19:48.318840" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:19:48.253388" elapsed="0.065482"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.320253" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.319984" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:48.320422" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:48.319569" elapsed="0.000878"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.320799" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.320519" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.321361" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.321064" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.320881" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.320500" elapsed="0.000982"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.324016" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:48.321660" elapsed="0.002384"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:19:48.324097" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:19:48.324255" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:19:48.319211" elapsed="0.005069"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.325723" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.325454" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.326193" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.325931" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.326675" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.326409" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.327118" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.326877" elapsed="0.000285"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:48.327988" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:19:48.327792" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:19:48.328348" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:19:48.328172" elapsed="0.000202"/>
</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-06-06T03:19:48.328528" elapsed="0.000223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.329159" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.328911" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:19:48.329247" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.329402" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:19:48.327364" elapsed="0.002064"/>
</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-06-06T03:19:48.345027" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1075', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:19:48.345143" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:48.345252" 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-06-06T03:19:48.332001" elapsed="0.013278"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.329696" elapsed="0.015629"/>
</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-06-06T03:19:48.345510" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.345352" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.329481" elapsed="0.016119"/>
</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-06-06T03:19:48.353681" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.347850" elapsed="0.005933"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.347315" elapsed="0.006547"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.347273" elapsed="0.006648"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.357096" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.354591" elapsed="0.002550"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.354092" elapsed="0.003085"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.354007" elapsed="0.003194"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.357775" 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-06-06T03:19:48.357369" elapsed="0.000435"/>
</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-06-06T03:19:48.358143" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.357876" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.358726" 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-06-06T03:19:48.358397" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.358228" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.357858" elapsed="0.000954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.359346" 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-06-06T03:19:48.358978" elapsed="0.000395"/>
</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-06-06T03:19:48.359702" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.359445" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.360249" 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-06-06T03:19:48.359952" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.359786" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.359426" elapsed="0.000906"/>
</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-06-06T03:19:48.360487" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:19:48.361301" 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-06-06T03:19:48.361021" elapsed="0.000306"/>
</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-06-06T03:19:48.361487" elapsed="0.002525"/>
</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-06-06T03:19:48.346487" elapsed="0.017589"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:19:48.364251" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:19:48.364144" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.364125" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:19:48.364491" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.364560" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:19:48.367059" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:19:48.324611" elapsed="0.042476"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.367185" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:48.367347" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:19:48.093657" elapsed="0.273715"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.367731" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.367474" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.367456" elapsed="0.000369"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.367859" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:19:48.088862" elapsed="0.279121"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.368965" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer2 | IP=127.0.0.2 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=ibgp | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENC...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer2</arg>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=ibgp</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.368160" elapsed="0.000843"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.405588" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.405177" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.406504" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.406215" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:48.406701" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:48.405828" elapsed="0.000898"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.407286" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:48.406900" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.407619" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:19:48.407890" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:19:48.407478" elapsed="0.000439"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.408331" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.408083" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.409419" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.409152" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.409924" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.409636" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.410672" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.410357" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.411435" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.411215" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.411592" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:19:48.411771" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.410889" elapsed="0.000907"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.411956" elapsed="0.000240"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:19:48.410216" elapsed="0.002021"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.412966" level="INFO">${value} = example-bgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.412487" elapsed="0.000506"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.413736" level="INFO">${encoded} = example-bgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.413508" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.413814" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.413964" level="INFO">${encoded_value} = example-bgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.413183" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.414193" elapsed="0.000226"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer2</var>
<status status="PASS" start="2026-06-06T03:19:48.412350" elapsed="0.002111"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.415045" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.414743" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.415812" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.415584" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.415889" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.416038" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.415259" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.416227" elapsed="0.000221"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:19:48.414573" elapsed="0.001917"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.417051" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.416751" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.417814" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.417587" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.417890" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.418039" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.417264" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.418236" elapsed="0.000221"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:19:48.416600" elapsed="0.001898"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.419060" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.418761" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.419830" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.419598" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.419908" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:48.420058" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.419275" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.420239" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:19:48.418609" elapsed="0.001892"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.421064" level="INFO">${value} = ibgp</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.420762" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.421830" level="INFO">${encoded} = ibgp</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.421601" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.421977" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:19:48.422161" level="INFO">${encoded_value} = ibgp</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.421278" elapsed="0.000911"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.422351" elapsed="0.000226"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">ibgp</var>
<status status="PASS" start="2026-06-06T03:19:48.420612" elapsed="0.002006"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.423184" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.422885" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.424133" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.423915" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.424212" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.424362" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.423402" elapsed="0.000985"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.424544" elapsed="0.000241"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:19:48.422748" elapsed="0.002078"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.425372" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.425074" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.426163" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.425937" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.426238" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.426387" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.425586" elapsed="0.000826"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.426566" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:48.424938" elapsed="0.001907"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.427382" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.427089" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.428138" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.427929" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.428212" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.428359" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.427594" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.428538" elapsed="0.000237"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:19:48.426955" elapsed="0.001861"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.429352" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.429059" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.430192" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.429897" elapsed="0.000322"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.430269" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.430419" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.429564" elapsed="0.000879"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.430599" elapsed="0.000237"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:48.428926" elapsed="0.001952"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.431418" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.431123" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.432177" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.431967" elapsed="0.000300"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.432323" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:19:48.432476" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.431631" elapsed="0.000870"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.432672" elapsed="0.000223"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:19:48.430988" elapsed="0.001949"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.433477" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:19:48.433181" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:19:48.434249" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.434026" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:19:48.434325" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.434475" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:19:48.433708" elapsed="0.000792"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:19:48.434670" elapsed="0.000222"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:19:48.433047" elapsed="0.001887"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:19:48.410007" elapsed="0.024962"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:19:48.435011" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:19:48.435173" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'P...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:19:48.408820" elapsed="0.026379"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.408458" elapsed="0.026774"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.435409" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.435257" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.408433" elapsed="0.027054"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.436607" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:48.435635" elapsed="0.001002"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.436704" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:48.404464" elapsed="0.032367"/>
</kw>
<msg time="2026-06-06T03:19:48.436886" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:48.390395" elapsed="0.046538"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.450290" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.463609" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.476859" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.477096" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.477278" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.477659" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.477498" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:19:48.477483" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.477888" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.478061" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.478281" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:19:48.477455" elapsed="0.000882"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.477355" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.478514" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.478590" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:19:48.478733" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:19:48.385782" elapsed="0.092979"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.507398" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.507020" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.508200" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.507953" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:48.508367" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:48.507597" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.509133" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:48.508560" elapsed="0.000600"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.509465" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:19:48.509690" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:19:48.509326" elapsed="0.000395"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.510160" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.509885" elapsed="0.000393"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:19:48.510675" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.510352" elapsed="0.000385"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.511219" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'P...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.510915" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.510763" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.510331" elapsed="0.000974"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.512309" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:19:48.511459" elapsed="0.000881"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.512394" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:19:48.506383" elapsed="0.006141"/>
</kw>
<msg time="2026-06-06T03:19:48.512583" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:48.492592" elapsed="0.020038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.526199" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.539508" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.552882" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.553084" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.553265" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.553635" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.553487" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:19:48.553472" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.553876" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.554047" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.554229" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:19:48.553443" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.553342" elapsed="0.000967"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.554506" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.554584" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:19:48.554734" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:19:48.489762" elapsed="0.065001"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:19:48.556031" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.555797" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:19:48.556189" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:19:48.555428" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.556535" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.556285" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.557112" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.556819" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.556622" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.556266" elapsed="0.000929"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.559720" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:19:48.557351" elapsed="0.002396"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:19:48.559799" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.559953" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:19:48.555095" elapsed="0.004882"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.561372" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.561122" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.561835" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.561577" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.562313" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.562050" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.562769" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.562511" elapsed="0.000301"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:48.563621" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:19:48.563424" elapsed="0.000241"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:19:48.564002" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:19:48.563825" elapsed="0.000202"/>
</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-06-06T03:19:48.564228" elapsed="0.000208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.564868" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.564602" elapsed="0.000311"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:19:48.564956" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.565111" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:19:48.563014" elapsed="0.002122"/>
</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-06-06T03:19:48.581312" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1075', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:19:48.581407" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:48.581534" 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-06-06T03:19:48.567604" elapsed="0.013965"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.565206" elapsed="0.016427"/>
</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-06-06T03:19:48.581925" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.581698" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.565187" elapsed="0.016861"/>
</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-06-06T03:19:48.589614" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.583929" elapsed="0.005815"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.583397" elapsed="0.006426"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.583356" elapsed="0.006522"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.593078" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.590587" elapsed="0.002536"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.590004" elapsed="0.003154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.589966" elapsed="0.003216"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.593744" 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-06-06T03:19:48.593350" elapsed="0.000423"/>
</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-06-06T03:19:48.594091" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.593845" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.594675" 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-06-06T03:19:48.594357" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.594173" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.593827" elapsed="0.000933"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.595289" 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-06-06T03:19:48.594925" elapsed="0.000391"/>
</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-06-06T03:19:48.595634" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.595387" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.596240" 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-06-06T03:19:48.595938" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:19:48.595763" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.595369" elapsed="0.000956"/>
</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-06-06T03:19:48.596480" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:19:48.597299" 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-06-06T03:19:48.597018" elapsed="0.000308"/>
</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-06-06T03:19:48.597487" elapsed="0.002515"/>
</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-06-06T03:19:48.582586" elapsed="0.017481"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:19:48.600243" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:19:48.600136" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.600117" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:19:48.600483" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.600552" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:19:48.603023" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:19:48.560306" elapsed="0.042745"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.603117" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:19:48.603272" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:19:48.374071" elapsed="0.229227"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.603634" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.603397" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.603379" elapsed="0.000365"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:19:48.603777" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:19:48.369287" elapsed="0.234613"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:48.604495" elapsed="0.000260"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:48.604185" elapsed="0.000635"/>
</kw>
<doc>Configure iBGP peers: 1st one as RR client, 2nd one as RR non-client.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:48.002046" elapsed="0.602813"/>
</test>
<test id="s1-s8-t22" name="TC3_Connect_BGP_Peer1" line="434">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:48.608466" elapsed="0.000398"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:48.608195" elapsed="0.000727"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.609925" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.609815" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.609796" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.615507" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.615400" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.615382" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.616593" 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-06-06T03:19:48.616213" elapsed="0.000406"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.617150" 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-06-06T03:19:48.616809" elapsed="0.000368"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:48.617223" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:19:48.617379" 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-06-06T03:19:48.615832" elapsed="0.001573"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:48.623305" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.623197" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.623177" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:48.624629" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:48.624508" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.624488" elapsed="0.000236"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:48.625202" 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-06-06T03:19:48.624885" elapsed="0.000343"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.625612" level="INFO">${current_connection_index} = 8</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-06-06T03:19:48.625393" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.655866" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:48.626167" elapsed="0.029807"/>
</kw>
<msg time="2026-06-06T03:19:48.656141" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:48.656187" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:48.625822" elapsed="0.030402"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.676456" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:19:48.656916" elapsed="0.019814"/>
</kw>
<msg time="2026-06-06T03:19:48.677105" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:48.677211" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:19:48.656403" elapsed="0.020893"/>
</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-06-06T03:19:48.678030" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.677472" elapsed="0.000683"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.677427" elapsed="0.000782"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.679295" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:19:48.678582" elapsed="0.000862"/>
</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-06-06T03:19:48.680130" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.679596" elapsed="0.000659"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.679554" elapsed="0.000754"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:48.680384" elapsed="0.000063"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:48.684275" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:19:48.684482" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:48.683140" elapsed="0.001472"/>
</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="NOT RUN" start="2026-06-06T03:19:48.684915" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.685259" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:48.682224" elapsed="0.003219"/>
</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-06-06T03:19:48.681006" elapsed="0.004501"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:48.624155" elapsed="0.061511"/>
</kw>
<msg time="2026-06-06T03:19:48.685761" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:48.685806" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:48.623529" elapsed="0.062314"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:48.686028" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:19:48.685920" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.685900" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.686529" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.686893" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:48.686965" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:48.622856" elapsed="0.064217"/>
</kw>
<msg time="2026-06-06T03:19:48.687167" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:48.687210" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:48.617796" elapsed="0.069450"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:48.687574" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:48.687321" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:48.687304" elapsed="0.000364"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:48.617632" elapsed="0.070061"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:48.617459" elapsed="0.070263"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:48.615024" elapsed="0.072750"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:48.609511" elapsed="0.078319"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:48.609079" elapsed="0.078795"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:48.605701" elapsed="0.082225"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:48.688086" elapsed="0.000108"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.697794" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:48.697398" elapsed="0.000428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.698241" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.697992" elapsed="0.000333"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:48.702097" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<msg time="2026-06-06T03:19:48.702188" level="INFO">${output} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:48.698485" elapsed="0.003730"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.702664" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.702394" elapsed="0.000320"/>
</kw>
<arg>${BGP_PEER1_COMMAND}</arg>
<arg>${BGP_PEER1_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:19:48.696980" elapsed="0.005790"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:48.711551" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:48.711838" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:19:48.711980" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:48.704004" elapsed="0.008014"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.716580" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.712267" elapsed="0.004418"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.720884" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:48.716934" elapsed="0.004020"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:19:48.724378" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:19:48.721190" elapsed="0.003261">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:19:48.703553" elapsed="0.021010">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:49.735986" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:49.736186" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:19:49.736338" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:49.726744" elapsed="0.009633"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.740356" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:49.736667" elapsed="0.003756"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.744337" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:49.740671" elapsed="0.003737"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:19:49.744688" elapsed="0.006478"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:19:49.725492" elapsed="0.025823"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:19:48.702938" elapsed="1.048493"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:49.752842" elapsed="0.000549"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:49.752102" elapsed="0.001443"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:48.605173" elapsed="1.148497"/>
</test>
<test id="s1-s8-t23" name="TC3_Connect_BGP_Peer2" line="446">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:49.758145" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:49.757878" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:49.759491" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:49.759358" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.759334" elapsed="0.000235"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:49.766617" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:49.766506" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.766487" elapsed="0.000287"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.767845" 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-06-06T03:19:49.767436" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.768335" 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-06-06T03:19:49.768037" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:49.768405" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:19:49.768567" 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-06-06T03:19:49.767049" elapsed="0.001543"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:49.774500" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:49.774391" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.774372" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:49.775844" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:49.775737" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.775717" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:49.776380" 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-06-06T03:19:49.776075" elapsed="0.000332"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:49.776808" level="INFO">${current_connection_index} = 7</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-06-06T03:19:49.776569" elapsed="0.000266"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:49.806563" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:49.777351" elapsed="0.029339"/>
</kw>
<msg time="2026-06-06T03:19:49.806875" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:49.806923" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:49.776998" elapsed="0.029962"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:49.828520" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:19:49.807519" elapsed="0.021107"/>
</kw>
<msg time="2026-06-06T03:19:49.828811" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:49.828857" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:19:49.807153" elapsed="0.021740"/>
</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-06-06T03:19:49.829198" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:49.828970" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.828949" elapsed="0.000327"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.829747" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:19:49.829420" elapsed="0.000393"/>
</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-06-06T03:19:49.830099" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:49.829879" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.829861" elapsed="0.000315"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:49.830209" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:49.832817" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:19:49.833023" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:49.831714" elapsed="0.001441"/>
</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="NOT RUN" start="2026-06-06T03:19:49.833478" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:49.833852" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:49.831068" elapsed="0.002973"/>
</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-06-06T03:19:49.830495" elapsed="0.003609"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:49.775404" elapsed="0.058797"/>
</kw>
<msg time="2026-06-06T03:19:49.834293" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:49.834338" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:49.774741" elapsed="0.059635"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:49.834746" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:19:49.834453" elapsed="0.000355"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.834433" elapsed="0.000402"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:49.835269" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:49.835609" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:49.835699" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:49.774053" elapsed="0.061755"/>
</kw>
<msg time="2026-06-06T03:19:49.835900" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:49.835944" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:49.768997" elapsed="0.066984"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:49.836308" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:49.836055" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:49.836037" elapsed="0.000347"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:49.768849" elapsed="0.067559"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:49.768669" elapsed="0.067769"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:49.766134" elapsed="0.070358"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:49.759048" elapsed="0.077499"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:49.758563" elapsed="0.078029"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:49.755518" elapsed="0.081142"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:49.836825" elapsed="0.000107"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.846035" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:49.845704" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.846467" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:49.846224" elapsed="0.000290"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:49.850329" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log</msg>
<msg time="2026-06-06T03:19:49.850423" level="INFO">${output} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:49.846685" elapsed="0.003766"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.850877" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log &amp;&gt;bgp_peer2.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:49.850614" elapsed="0.000310"/>
</kw>
<arg>${BGP_PEER2_COMMAND}</arg>
<arg>${BGP_PEER2_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:19:49.845303" elapsed="0.005746"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:49.860010" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:49.860186" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:19:49.860334" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:49.852275" elapsed="0.008096"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.864153" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:49.860603" elapsed="0.003615"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.867970" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:49.864443" elapsed="0.003576"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:19:49.870883" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:19:49.868179" elapsed="0.002782">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:19:49.851844" elapsed="0.019243">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:19:50.880942" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:19:50.881152" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '412'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:19:50.881310" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:19:50.873195" elapsed="0.008153"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:50.885949" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:50.881621" elapsed="0.004399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:50.889685" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:50.886268" elapsed="0.003468"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:19:50.889898" elapsed="0.002803"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:19:50.872052" elapsed="0.020723"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:19:49.851218" elapsed="1.041612"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:19:50.893579" elapsed="0.000285"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:19:50.893241" elapsed="0.000687"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:49.754354" elapsed="1.139613"/>
</test>
<test id="s1-s8-t24" name="TC3_BGP_Peer1_Check_Log_For_No_Updates" line="458">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:19:50.897661" elapsed="0.000245"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:19:50.897361" elapsed="0.000610"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:50.899072" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:50.898934" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.898909" elapsed="0.000237"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:19:50.904874" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:50.904739" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.904716" elapsed="0.000240"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:19:50.906113" 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-06-06T03:19:50.905665" elapsed="0.000478"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:19:50.906625" 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-06-06T03:19:50.906315" elapsed="0.000354"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:19:50.906718" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:19:50.906887" 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-06-06T03:19:50.905242" elapsed="0.001670"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:19:50.913381" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:50.913247" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.913223" elapsed="0.000242"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:19:50.914852" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:19:50.914740" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.914721" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:19:50.915400" 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-06-06T03:19:50.915077" elapsed="0.000353"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:19:50.915906" level="INFO">${current_connection_index} = 8</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-06-06T03:19:50.915676" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:19:50.945078" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:19:50.916451" elapsed="0.028861"/>
</kw>
<msg time="2026-06-06T03:19:50.945550" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:19:50.945600" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:19:50.916099" elapsed="0.029540"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:19:50.970108" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "N "o "_ "U "p "d "a "t "e "s "[K"
[?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-06-06T03:19:50.946421" elapsed="0.023944"/>
</kw>
<msg time="2026-06-06T03:19:50.970832" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:19:50.970938" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</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-06-06T03:19:50.945941" elapsed="0.025082"/>
</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-06-06T03:19:50.971945" elapsed="0.000075"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:50.971225" elapsed="0.001033"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.971169" elapsed="0.001174"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:50.973484" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "N "o "_ "U "p "d "a "t "e "s "[K"
[?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-06-06T03:19:50.972756" elapsed="0.000930"/>
</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-06-06T03:19:50.974404" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:50.973847" elapsed="0.000688"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.973803" elapsed="0.000787"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:19:50.974710" elapsed="0.000079"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:50.980838" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:19:50.981072" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:19:50.978321" elapsed="0.002893"/>
</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="NOT RUN" start="2026-06-06T03:19:50.981532" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:50.981960" elapsed="0.000092"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:19:50.976792" elapsed="0.005400"/>
</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-06-06T03:19:50.975387" elapsed="0.006886"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:19:50.914402" elapsed="0.067997"/>
</kw>
<msg time="2026-06-06T03:19:50.982517" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:50.982573" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:50.913678" elapsed="0.068944"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:19:50.982871" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:19:50.982744" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.982721" elapsed="0.000254"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:50.983507" elapsed="0.000035"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:50.984035" elapsed="0.000035"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:19:50.984134" elapsed="0.000022"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:19:50.912806" elapsed="0.071475"/>
</kw>
<msg time="2026-06-06T03:19:50.984407" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:19:50.984466" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:19:50.907313" elapsed="0.077209"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:19:50.984996" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:19:50.984626" elapsed="0.000446"/>
</branch>
<status status="PASS" start="2026-06-06T03:19:50.984602" elapsed="0.000503"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:19:50.907162" elapsed="0.077976"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:19:50.906975" elapsed="0.078209"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:19:50.904189" elapsed="0.081073"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:19:50.898600" elapsed="0.086737"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:19:50.898132" elapsed="0.087270"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:19:50.894919" elapsed="0.090557"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:19:50.985836" elapsed="0.000160"/>
</kw>
<kw name="Comment" owner="BuiltIn">
<arg>From neon onwards there is extra BGP End-Of-RIB message</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="PASS" start="2026-06-06T03:19:50.986326" elapsed="0.000301"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:19:50.987226" level="INFO">${update_messages} = 1</msg>
<var>${update_messages}</var>
<arg>1</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:19:50.986875" elapsed="0.000385"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:51.006225" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:51.019576" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:51.019916" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:51.005987" elapsed="0.013986"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:51.021100" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:51.020415" elapsed="0.000785"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:51.022361" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:51.021545" elapsed="0.000965">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:51.005288" elapsed="0.017494">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:52.041686" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:52.057189" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:52.057415" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:52.041478" elapsed="0.015995"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:52.058529" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:52.057904" elapsed="0.000728"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:52.059848" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:52.059016" elapsed="0.000981">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:52.040966" elapsed="0.019311">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:53.079297" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:53.092984" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:53.093322" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:53.079095" elapsed="0.014288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:53.094634" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:53.093918" elapsed="0.000857"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:53.096011" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:53.095148" elapsed="0.001037">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:53.078543" elapsed="0.017890">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:54.116891" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:54.130539" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:54.130817" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:54.116694" elapsed="0.014182"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:54.131956" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:54.131273" elapsed="0.000785"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:54.133247" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:54.132410" elapsed="0.001143">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:54.116142" elapsed="0.017682">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:55.154668" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:55.168317" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:55.168577" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:55.154456" elapsed="0.014220"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:55.169790" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:55.169112" elapsed="0.000861"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:55.171157" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:55.170328" elapsed="0.000979">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:55.153871" elapsed="0.017837">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:56.191449" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:56.205259" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:56.205485" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:56.191255" elapsed="0.014287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:56.206683" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:56.205972" elapsed="0.000819"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:56.207978" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:56.207149" elapsed="0.000976">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:56.190742" elapsed="0.017615">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:57.228430" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:57.241760" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:57.242079" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:57.228229" elapsed="0.013912"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:57.243441" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:57.242678" elapsed="0.000866"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:57.244768" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:57.243933" elapsed="0.000990">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:57.227616" elapsed="0.017548">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:58.266568" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:58.280133" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:58.280370" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:58.266375" elapsed="0.014053"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:58.281513" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:58.280867" elapsed="0.000747"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:58.282857" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:58.282004" elapsed="0.001023">0 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:58.265858" elapsed="0.017426">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:19:59.303819" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:19:59.318117" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:19:59.318378" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:19:59.303603" elapsed="0.014837"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:19:59.319612" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:19:59.318914" elapsed="0.000848"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:19:59.321127" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:19:59.320210" elapsed="0.001073">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:19:59.303084" elapsed="0.018437">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:00.341750" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:00.355759" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:00.355871" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:00.341535" elapsed="0.014361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:00.356403" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:00.356088" elapsed="0.000361"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:00.357026" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:00.356627" elapsed="0.000475">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:00.340981" elapsed="0.016233">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:01.377901" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:01.391981" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:01.392253" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:01.377586" elapsed="0.014726"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:01.393485" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:01.392786" elapsed="0.000802"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:01.394806" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:01.393971" elapsed="0.000991">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:01.376972" elapsed="0.018233">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:02.415193" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:02.429388" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:02.429779" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:02.414993" elapsed="0.014855"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:02.430947" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:02.430272" elapsed="0.000779"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:02.432255" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:02.431400" elapsed="0.001041">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:02.414373" elapsed="0.018342">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:03.452077" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:03.466100" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:03.466351" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:03.451888" elapsed="0.014520"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:03.467457" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:03.466830" elapsed="0.000727"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:03.468752" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:03.467934" elapsed="0.000965">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:03.451369" elapsed="0.017766">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:04.487747" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:04.501960" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:04.502350" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:04.487562" elapsed="0.014859"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:04.504170" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:04.503074" elapsed="0.001207"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:04.505618" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:04.504718" elapsed="0.001125">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:04.487132" elapsed="0.018990">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:05.527535" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:05.540755" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:05.540990" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:05.527327" elapsed="0.013719"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:05.542122" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:05.541442" elapsed="0.000781"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:05.543446" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:05.542570" elapsed="0.001026">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:05.526750" elapsed="0.017123">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:06.562004" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:06.575541" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:06.575710" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:06.561809" elapsed="0.013938"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:06.576730" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:06.576114" elapsed="0.000721"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:06.578010" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:06.577186" elapsed="0.000971">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:06.561282" elapsed="0.017106">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:07.598283" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:07.611775" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:07.612049" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:07.597991" elapsed="0.014102"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:07.613042" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:07.612503" elapsed="0.000610"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:07.613903" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:07.613350" elapsed="0.000669">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:07.597098" elapsed="0.017090">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:08.635727" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:08.649350" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:08.649600" level="INFO">${output_log} = 1</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:08.635475" elapsed="0.014164"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:08.650510" level="INFO">1</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:08.650024" elapsed="0.000553"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:08.651385" level="FAIL">1 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:08.650835" elapsed="0.000656">1 != 2</status>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:08.634697" elapsed="0.016984">1 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:09.671118" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:09.684365" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:09.684582" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:09.670926" elapsed="0.013745"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:09.685723" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:09.685057" elapsed="0.000769"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:20:09.686174" elapsed="0.000732"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:20:09.670404" elapsed="0.016639"/>
</kw>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>2</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:19:50.987475" elapsed="18.699690"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:09.688513" elapsed="0.000564"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:09.687821" elapsed="0.001398"/>
</kw>
<doc>Check for no updates received by iBGP peer No. 1</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:19:50.894319" elapsed="18.794985"/>
</test>
<test id="s1-s8-t25" name="TC3_Disconnect_BGP_Peer1" line="472">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:09.694855" elapsed="0.000314"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:09.694416" elapsed="0.000834"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:09.696830" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:09.696620" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.696588" elapsed="0.000349"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:09.704275" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:09.704152" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.704133" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:09.705607" 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-06-06T03:20:09.705178" elapsed="0.000457"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:09.706126" 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-06-06T03:20:09.705823" elapsed="0.000330"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:09.706199" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:20:09.706362" 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-06-06T03:20:09.704779" elapsed="0.001617"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:09.712451" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:09.712341" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.712322" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:09.713807" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:09.713689" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.713668" elapsed="0.000208"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:09.714333" 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-06-06T03:20:09.714028" elapsed="0.000335"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:09.714762" level="INFO">${current_connection_index} = 7</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-06-06T03:20:09.714529" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:09.746711" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:09.715297" elapsed="0.031533"/>
</kw>
<msg time="2026-06-06T03:20:09.746996" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:09.747043" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:09.714953" elapsed="0.032127"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:09.770740" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:20:09.747602" elapsed="0.023242"/>
</kw>
<msg time="2026-06-06T03:20:09.771005" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:09.771051" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:20:09.747257" elapsed="0.023830"/>
</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-06-06T03:20:09.771396" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:09.771166" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.771145" elapsed="0.000331"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:09.771951" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:20:09.771622" elapsed="0.000398"/>
</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-06-06T03:20:09.772308" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:09.772087" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.772068" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:09.772420" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:09.774999" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:20:09.775205" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:09.773942" elapsed="0.001396"/>
</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="NOT RUN" start="2026-06-06T03:20:09.775796" elapsed="0.000095"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:09.776253" elapsed="0.000086"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:09.773262" elapsed="0.003200"/>
</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-06-06T03:20:09.772723" elapsed="0.003813"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:09.713314" elapsed="0.063357"/>
</kw>
<msg time="2026-06-06T03:20:09.776773" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:09.776819" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:09.712695" elapsed="0.064162"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:09.777044" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:09.776935" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.776915" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:09.777553" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:09.777909" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:09.777981" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:09.711995" elapsed="0.066094"/>
</kw>
<msg time="2026-06-06T03:20:09.778183" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:09.778228" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:09.706804" elapsed="0.071461"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:09.778597" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:09.778342" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:09.778322" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:09.706653" elapsed="0.072062"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:09.706458" elapsed="0.072288"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:09.703754" elapsed="0.075046"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:09.696179" elapsed="0.082678"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:09.695486" elapsed="0.083416"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:09.690721" elapsed="0.088234"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:09.779120" elapsed="0.000107"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:09.780364" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:09.780047" elapsed="0.000345"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:09.780548" elapsed="0.001273"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:20:09.779777" elapsed="0.002106"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:20:11.782798" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:20:11.783140" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:20:09.782050" elapsed="2.001154"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.784384" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:11.783728" elapsed="0.000765"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:20:09.779443" elapsed="2.005183"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:11.800729" level="INFO">Executing command 'cat bgp_peer1.log'.</msg>
<msg time="2026-06-06T03:20:11.814261" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:11.814424" level="INFO">${output_log} = 2026-06-06 03:19:48,785 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:19:48,785 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:19:48,785 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:11.800556" elapsed="0.014148"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.815736" level="INFO">2026-06-06 03:19:48,785 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:19:48,785 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:19:48,785 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:19:48,785 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:19:48,786 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:19:48,786 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Prefix base: 8.1.0.0/28
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706433
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:19:48,788 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:19:48,789 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:19:48,789 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:19:48,789 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:19:48,789 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706433 (0x7f000001)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:19:48,789 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:19:48,790 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0'
2026-06-06 03:19:48,790 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0
2026-06-06 03:19:48,791 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:19:48,791 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,791 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:19:48,791 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:19:48,791 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:48,792 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:19:48,792 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,792 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:19:48,792 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:19:48,792 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:48,792 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:48,793 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:19:48,793 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:19:48,793 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:19:48,793 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:48,794 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:48,794 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:19:48,794 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:48,794 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:48,794 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:19:48,795 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.0')]
2026-06-06 03:19:48,796 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:48,796 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:19:48,796 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:48,796 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:48,797 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:48,797 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:48,797 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:48,797 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.0')]/28 (0x1c08010000)
2026-06-06 03:19:48,798 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010000
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:19:48,799 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:19:48,800 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:19:48,800 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:19:48,800 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.16')]
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:48,801 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.16')]/28 (0x1c08010010)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010010
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.32')]
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.32')]/28 (0x1c08010020)
2026-06-06 03:19:48,802 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08010020
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.009006023406982422s
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:48,803 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:19:48,803 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:19:48,804 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:19:58,814 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:19:58,815 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:19:58,815 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:19:58,815 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:19:58,815 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:08,820 INFO BGP-Thread-1 (job): ... idle for 10.005s
2026-06-06 03:20:08,821 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.016s
2026-06-06 03:20:08,821 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:20:08,821 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:08,821 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:11.815101" elapsed="0.001118"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:11.817470" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc3_bgp_peer1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc3_bgp_peer1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:20:11.816682" elapsed="0.000914"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>tc3_${BGP_PEER1_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:11.800074" elapsed="0.017695"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:11.819157" elapsed="0.000572"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:11.818405" elapsed="0.001467"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:09.689863" elapsed="2.130093"/>
</test>
<test id="s1-s8-t26" name="TC3_BGP_Peer2_Check_Log_For_No_Updates" line="479">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:11.825333" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:11.825061" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:11.826888" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:11.826538" elapsed="0.000400"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.826515" elapsed="0.000447"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:11.832258" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:11.832148" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.832129" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.833358" 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-06-06T03:20:11.832963" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.833873" 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-06-06T03:20:11.833554" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:11.833944" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:20:11.834106" 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-06-06T03:20:11.832562" elapsed="0.001569"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:11.840535" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:11.840424" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.840405" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:11.841853" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:11.841740" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.841721" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:11.842376" 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-06-06T03:20:11.842073" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:11.842840" level="INFO">${current_connection_index} = 7</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-06-06T03:20:11.842597" elapsed="0.000269"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:11.876623" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:11.843375" elapsed="0.033734"/>
</kw>
<msg time="2026-06-06T03:20:11.877595" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:11.877806" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:11.843032" elapsed="0.034870"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:11.901475" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "N "o "_ "U "p "d "a "t "e "s "[K"
[?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-06-06T03:20:11.879484" elapsed="0.022268"/>
</kw>
<msg time="2026-06-06T03:20:11.901996" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:11.902145" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</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-06-06T03:20:11.878425" elapsed="0.023761"/>
</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-06-06T03:20:11.902725" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:11.902316" elapsed="0.000473"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.902274" elapsed="0.000543"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.903385" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "N "o "_ "U "p "d "a "t "e "s "[K"
[?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-06-06T03:20:11.902972" elapsed="0.000487"/>
</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-06-06T03:20:11.903772" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:11.903528" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.903509" elapsed="0.000343"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:11.903892" 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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:11.906783" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:20:11.907000" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:11.905527" elapsed="0.001609"/>
</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="NOT RUN" start="2026-06-06T03:20:11.907603" elapsed="0.000094"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:11.907964" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:11.904862" elapsed="0.003291"/>
</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-06-06T03:20:11.904239" elapsed="0.003981"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:11.841411" elapsed="0.066910"/>
</kw>
<msg time="2026-06-06T03:20:11.908420" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:11.908466" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:11.840779" elapsed="0.067728"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:11.908714" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:20:11.908587" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.908567" elapsed="0.000234"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:11.909224" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:11.909583" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:11.909672" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:11.840079" elapsed="0.069707"/>
</kw>
<msg time="2026-06-06T03:20:11.909882" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:11.909926" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:11.834510" elapsed="0.075458"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:11.910302" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:11.910044" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:11.910026" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:11.834363" elapsed="0.076042"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:11.834187" elapsed="0.076252"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:11.831782" elapsed="0.078715"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:11.826229" elapsed="0.084325"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:11.825778" elapsed="0.084931"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:11.821922" elapsed="0.088845"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:11.910943" elapsed="0.000108"/>
</kw>
<kw name="Convert Time" owner="DateTime">
<msg time="2026-06-06T03:20:11.911530" level="INFO">${log_check_timeout} = 20.0</msg>
<var>${log_check_timeout}</var>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>result_format=number</arg>
<doc>Converts between supported `time formats`.</doc>
<status status="PASS" start="2026-06-06T03:20:11.911210" elapsed="0.000346"/>
</kw>
<kw name="Comment" owner="BuiltIn">
<arg>From neon onwards there is extra BGP End-Of-RIB message</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="PASS" start="2026-06-06T03:20:11.911756" elapsed="0.000217"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.912393" level="INFO">${update_messages} = 1</msg>
<var>${update_messages}</var>
<arg>1</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:11.912139" elapsed="0.000280"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:11.928856" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:11.941963" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:11.942174" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:11.928680" elapsed="0.013549"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.943293" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:11.942700" elapsed="0.000692"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:11.944544" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:11.943766" elapsed="0.000957">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:11.928228" elapsed="0.016728">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:12.964132" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:12.977949" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:12.978191" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:12.963937" elapsed="0.014312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:12.979343" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:12.978685" elapsed="0.000762"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:12.980628" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:12.979837" elapsed="0.000972">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:12.963407" elapsed="0.017634">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:14.004210" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:14.018259" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:14.018626" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:14.003341" elapsed="0.015396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:14.019980" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:14.019218" elapsed="0.000863"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:14.021262" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:14.020434" elapsed="0.000975">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:14.002150" elapsed="0.019522">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:15.040818" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:15.054588" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:15.054865" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:15.040518" elapsed="0.014387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:15.055702" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:15.055239" elapsed="0.000528"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:15.056546" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:15.055987" elapsed="0.000680">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:15.039707" elapsed="0.017114">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:16.074039" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:16.087518" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:16.087790" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:16.073842" elapsed="0.014007"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:16.088985" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:16.088244" elapsed="0.000865"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:16.090306" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:16.089469" elapsed="0.000989">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:16.073154" elapsed="0.017571">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:17.112399" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:17.125637" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:17.125904" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:17.112206" elapsed="0.013757"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:17.127071" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:17.126394" elapsed="0.000779"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:17.128371" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:17.127523" elapsed="0.001020">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:17.111699" elapsed="0.017126">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:18.149509" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:18.163277" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:18.163505" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:18.149314" elapsed="0.014250"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:18.164612" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:18.163996" elapsed="0.000754"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:18.165963" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:18.165106" elapsed="0.001008">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:18.148796" elapsed="0.017550">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:19.186476" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:19.200134" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:19.200355" level="INFO">${output_log} = 2</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:19.186259" elapsed="0.014151"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:19.201435" level="INFO">2</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:19.200829" elapsed="0.000706"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:19.202745" level="FAIL">2 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:19.201913" elapsed="0.000979">2 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:19.185736" elapsed="0.017387">2 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:20.223943" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:20.237785" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:20.238035" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:20.223681" elapsed="0.014412"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:20.239280" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:20.238511" elapsed="0.000871"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:20.240603" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:20.239786" elapsed="0.001008">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:20.223054" elapsed="0.017996">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:21.257581" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:21.270855" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:21.270967" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:21.257390" elapsed="0.013602"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:21.271615" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:21.271273" elapsed="0.000408"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:21.272226" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:21.271860" elapsed="0.000439">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:21.256836" elapsed="0.015571">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:22.292678" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:22.305977" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:22.306203" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:22.292468" elapsed="0.013793"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:22.307388" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:22.306685" elapsed="0.000808"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:22.308830" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:22.307950" elapsed="0.001034">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:22.291947" elapsed="0.017272">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:23.329056" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:23.342148" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:23.342303" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:23.328861" elapsed="0.013478"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:23.343217" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:23.342595" elapsed="0.000744"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:23.344549" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:23.343737" elapsed="0.001002">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:23.328284" elapsed="0.016701">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:24.365281" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:24.378393" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:24.378618" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:24.365087" elapsed="0.013628"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:24.379770" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:24.379111" elapsed="0.000761"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:24.381105" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:24.380281" elapsed="0.000972">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:24.364551" elapsed="0.016934">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:25.400578" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:25.414291" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:25.414518" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:25.400386" elapsed="0.014188"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:25.415788" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:25.415004" elapsed="0.000891"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:25.417080" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:25.416251" elapsed="0.000980">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:25.399881" elapsed="0.017583">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:26.435470" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:26.448667" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:26.448903" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:26.435279" elapsed="0.013683"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:26.450033" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:26.449372" elapsed="0.000764"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:26.451454" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:26.450609" elapsed="0.000993">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:26.434769" elapsed="0.017103">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:27.471217" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:27.484555" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:27.484876" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:27.471022" elapsed="0.013912"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:27.486110" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:27.485384" elapsed="0.000827"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:27.487383" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:27.486565" elapsed="0.000962">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:27.470421" elapsed="0.017386">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:28.507405" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:28.520684" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:28.520988" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:28.507192" elapsed="0.013857"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:28.522258" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:28.521567" elapsed="0.000794"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:28.523553" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:28.522755" elapsed="0.000984">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:28.506569" elapsed="0.017409">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:29.542572" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:29.555953" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:29.556150" level="INFO">${output_log} = 3</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:29.542378" elapsed="0.013800"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:29.556765" level="INFO">3</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:29.556405" elapsed="0.000407"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:20:29.557741" level="FAIL">3 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:20:29.556972" elapsed="0.000933">3 != 4</status>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:20:29.541842" elapsed="0.016318">3 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:30.576452" level="INFO">Executing command 'grep -o 'total_received_update_message_counter: 1' bgp_peer2.log | wc -l'.</msg>
<msg time="2026-06-06T03:20:30.589350" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:30.589610" level="INFO">${output_log} = 4</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:30.576256" elapsed="0.013461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:30.590904" level="INFO">4</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:30.590182" elapsed="0.000831"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:20:30.591373" elapsed="0.000750"/>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="PASS" start="2026-06-06T03:20:30.575706" elapsed="0.016562"/>
</kw>
<arg>${log_check_timeout*2}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>BGPCliKeywords.Check_File_For_Word_Count</arg>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>total_received_update_message_counter: ${update_messages}</arg>
<arg>4</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:11.912586" elapsed="18.679804"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:30.593843" elapsed="0.000574"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:30.593106" elapsed="0.001457"/>
</kw>
<doc>Consequent check for no updates received by iBGP peer No. 2</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:11.820596" elapsed="18.774082"/>
</test>
<test id="s1-s8-t27" name="TC3_Disconnect_BGP_Peer2" line="494">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:30.601168" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:30.600815" elapsed="0.000626"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:30.602551" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:30.602410" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.602385" elapsed="0.000243"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:30.608091" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:30.607976" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.607956" elapsed="0.000206"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:30.609216" 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-06-06T03:20:30.608808" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:30.609740" 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-06-06T03:20:30.609412" elapsed="0.000355"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:30.609814" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:20:30.609982" 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-06-06T03:20:30.608400" elapsed="0.001607"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:30.616364" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:30.616246" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.616222" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:30.617742" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:30.617587" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.617568" elapsed="0.000263"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:30.618799" 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-06-06T03:20:30.618056" elapsed="0.000782"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:30.619257" level="INFO">${current_connection_index} = 8</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-06-06T03:20:30.619016" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:30.648002" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:30.619852" elapsed="0.028284"/>
</kw>
<msg time="2026-06-06T03:20:30.648323" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:30.648374" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:30.619450" elapsed="0.028962"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:30.669140" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:20:30.649042" elapsed="0.020210"/>
</kw>
<msg time="2026-06-06T03:20:30.669418" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:30.669466" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:20:30.648614" elapsed="0.020891"/>
</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-06-06T03:20:30.669881" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:30.669594" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.669569" elapsed="0.000396"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:30.670482" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:20:30.670118" elapsed="0.000440"/>
</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-06-06T03:20:30.670901" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:30.670631" elapsed="0.000404"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.670610" elapsed="0.000454"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:30.671103" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:30.673988" elapsed="0.000154"/>
</kw>
<msg time="2026-06-06T03:20:30.674208" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:30.672749" elapsed="0.001601"/>
</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="NOT RUN" start="2026-06-06T03:20:30.674683" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:30.675036" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:30.672052" elapsed="0.003176"/>
</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-06-06T03:20:30.671419" elapsed="0.003878"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:30.617277" elapsed="0.058123"/>
</kw>
<msg time="2026-06-06T03:20:30.675497" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:30.675543" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:30.616595" elapsed="0.058988"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:30.675795" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:20:30.675681" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.675659" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:30.676305" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:30.676670" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:30.676745" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:30.615811" elapsed="0.061046"/>
</kw>
<msg time="2026-06-06T03:20:30.676954" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:30.676999" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:30.610467" elapsed="0.066571"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:30.677378" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:30.677117" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:30.677098" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:30.610313" elapsed="0.067170"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:30.610087" elapsed="0.067429"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:30.607535" elapsed="0.070039"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:30.602099" elapsed="0.075535"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:30.601598" elapsed="0.076104"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:30.596937" elapsed="0.080823"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:30.677932" elapsed="0.000111"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:30.679266" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:30.678941" elapsed="0.000353"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:30.679454" elapsed="0.000259"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:20:30.678632" elapsed="0.001151"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.680959" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:20:32.681548" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:20:30.679941" elapsed="2.001683"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.682985" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:32.682237" elapsed="0.000859"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:20:30.678259" elapsed="2.004979"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.698222" level="INFO">Executing command 'cat bgp_peer2.log'.</msg>
<msg time="2026-06-06T03:20:32.711420" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:32.711690" level="INFO">${output_log} = 2026-06-06 03:19:49,927 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:19:49,928 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:19:49,928 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:32.698070" elapsed="0.013713"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.712852" level="INFO">2026-06-06 03:19:49,927 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:19:49,928 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:19:49,928 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:19:49,928 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:19:49,928 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:19:49,928 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job):   Prefix base: 8.2.0.0/28
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:19:49,930 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706434
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:19:49,931 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:19:49,931 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:19:49,931 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:19:49,931 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,931 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:19:49,931 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706434 (0x7f000002)
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0'
2026-06-06 03:19:49,932 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0
2026-06-06 03:19:49,933 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:19:49,933 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,933 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:19:49,933 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:19:49,934 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:19:49,934 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.0')]
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:49,935 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:19:49,936 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:49,936 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:49,936 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:49,936 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:49,937 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:49,940 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:49,940 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:49,940 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.0')]/28 (0x1c08020000)
2026-06-06 03:19:49,940 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020000
2026-06-06 03:19:49,940 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:19:49,941 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.16')]
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:49,942 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.16')]/28 (0x1c08020010)
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020010
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.32')]
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:19:49,943 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.32')]/28 (0x1c08020020)
2026-06-06 03:19:49,944 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf040050400000064400304c00002011c08020020
2026-06-06 03:19:49,944 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.009926080703735352s
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job):   
2026-06-06 03:19:49,945 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:19:49,945 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:19:49,946 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:19:59,956 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:19:59,957 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:19:59,957 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:19:59,957 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:19:59,957 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:09,961 INFO BGP-Thread-1 (job): ... idle for 10.004s
2026-06-06 03:20:09,961 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.014s
2026-06-06 03:20:09,961 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:20:09,961 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:09,962 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:19,971 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:20:19,971 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.023s
2026-06-06 03:20:19,971 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:20:19,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:19,971 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:29,974 INFO BGP-Thread-1 (job): ... idle for 10.003s
2026-06-06 03:20:29,975 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.026s
2026-06-06 03:20:29,975 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:20:29,975 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:29,975 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:32.712217" elapsed="0.001148"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:32.714607" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc3_bgp_peer2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc3_bgp_peer2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:20:32.713846" elapsed="0.000923"/>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>tc3_${BGP_PEER2_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:32.697623" elapsed="0.017290"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:32.716346" elapsed="0.000596"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:32.715540" elapsed="0.001550"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:30.595555" elapsed="2.121612"/>
</test>
<test id="s1-s8-t28" name="TC_3_Check_for_Empty_IPv4_Topology" line="501">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:32.722342" elapsed="0.000338"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:32.721896" elapsed="0.000870"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:32.724315" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.724126" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.724087" elapsed="0.000331"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:32.731944" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.731790" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.731763" elapsed="0.000279"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.733525" 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-06-06T03:20:32.732982" elapsed="0.000581"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.734250" 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-06-06T03:20:32.733827" elapsed="0.000459"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:32.734351" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:20:32.734575" 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-06-06T03:20:32.732413" elapsed="0.002197"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:32.742564" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.742453" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.742433" elapsed="0.000229"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:32.743913" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.743804" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.743784" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:32.744457" 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-06-06T03:20:32.744134" elapsed="0.000350"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.744887" level="INFO">${current_connection_index} = 8</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-06-06T03:20:32.744666" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.774290" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:32.745425" elapsed="0.028970"/>
</kw>
<msg time="2026-06-06T03:20:32.774560" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:32.774607" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:32.745079" elapsed="0.029586"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.797829" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "3 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:20:32.775194" elapsed="0.022744"/>
</kw>
<msg time="2026-06-06T03:20:32.798099" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:32.798188" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "3 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</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-06-06T03:20:32.774846" elapsed="0.023382"/>
</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-06-06T03:20:32.798542" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.798308" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.798287" elapsed="0.000384"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.799129" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "3 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:20:32.798825" elapsed="0.000380"/>
</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-06-06T03:20:32.799496" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.799274" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.799255" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:32.799607" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:32.802217" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:20:32.802424" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:32.801133" elapsed="0.001425"/>
</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="NOT RUN" start="2026-06-06T03:20:32.802863" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.803208" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:32.800481" elapsed="0.002913"/>
</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-06-06T03:20:32.799906" elapsed="0.003553"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:32.743465" elapsed="0.060105"/>
</kw>
<msg time="2026-06-06T03:20:32.803689" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:32.803742" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "3 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:32.742831" elapsed="0.060952"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:32.803977" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:20:32.803863" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.803843" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.804544" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.804924" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:32.804997" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:32.742108" elapsed="0.062998"/>
</kw>
<msg time="2026-06-06T03:20:32.805199" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:32.805243" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "3 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:32.735162" elapsed="0.070119"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.805615" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.805356" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.805339" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:32.734955" elapsed="0.070783"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:32.734712" elapsed="0.071056"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:32.731243" elapsed="0.074579"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:32.723628" elapsed="0.082250"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:32.722992" elapsed="0.082970"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:32.718342" elapsed="0.087676"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:32.814165" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:32.814340" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:20:32.814492" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:32.807213" elapsed="0.007317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.818387" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:32.814803" elapsed="0.003650"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.822026" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:32.818704" elapsed="0.003372"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:20:32.822239" elapsed="0.002716"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Check the example-ipv4-topology does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:20:32.806858" elapsed="0.018162"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:32.806224" elapsed="0.018847"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:32.825683" elapsed="0.000245"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:32.825354" elapsed="0.000638"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:32.717730" elapsed="0.108302"/>
</test>
<test id="s1-s8-t29" name="TC3_Delete_BGP_Peers_Configuration" line="509">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:32.829452" elapsed="0.000231"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:32.829183" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:32.830747" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.830616" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.830596" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:32.836197" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.836089" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.836070" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.837364" 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-06-06T03:20:32.836957" elapsed="0.000434"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.837881" 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-06-06T03:20:32.837559" elapsed="0.000349"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:32.837953" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:20:32.838110" 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-06-06T03:20:32.836492" elapsed="0.001643"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:32.844121" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.844011" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.843991" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:32.845385" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:32.845277" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.845258" elapsed="0.000255"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:32.845993" 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-06-06T03:20:32.845690" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.846397" level="INFO">${current_connection_index} = 8</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-06-06T03:20:32.846184" elapsed="0.000240"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.874542" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:32.846952" elapsed="0.027720"/>
</kw>
<msg time="2026-06-06T03:20:32.874841" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:32.874888" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:32.846589" elapsed="0.028337"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:32.898773" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:20:32.875466" elapsed="0.023421"/>
</kw>
<msg time="2026-06-06T03:20:32.899051" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:32.899097" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</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-06-06T03:20:32.875107" elapsed="0.024027"/>
</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-06-06T03:20:32.899462" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.899220" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.899196" elapsed="0.000348"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.900058" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:20:32.899745" elapsed="0.000386"/>
</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-06-06T03:20:32.900426" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.900201" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.900182" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:32.900541" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:32.903195" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:20:32.903416" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:32.902097" elapsed="0.001454"/>
</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="NOT RUN" start="2026-06-06T03:20:32.903852" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.904196" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:32.901448" elapsed="0.002938"/>
</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-06-06T03:20:32.900895" elapsed="0.003569"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:32.844973" elapsed="0.059593"/>
</kw>
<msg time="2026-06-06T03:20:32.904694" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:32.904742" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:32.844347" elapsed="0.060436"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:32.905075" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:20:32.904926" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.904896" elapsed="0.000283"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.905595" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.906012" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:32.906086" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:32.843668" elapsed="0.062529"/>
</kw>
<msg time="2026-06-06T03:20:32.906294" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:32.906338" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "3 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:32.838515" elapsed="0.067862"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.906730" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.906454" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.906436" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:32.838367" elapsed="0.068468"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:32.838195" elapsed="0.068671"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:32.835721" elapsed="0.071203"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:32.830326" elapsed="0.076658"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:32.829895" elapsed="0.077136"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:32.826869" elapsed="0.080217"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.907849" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer1 | IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer1</arg>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.907269" elapsed="0.000610"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.956827" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:32.956413" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:32.957716" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:32.957411" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:32.957896" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:32.957035" elapsed="0.000885"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.958476" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:32.958091" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:32.958827" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:32.959004" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:32.958685" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.959450" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:32.959197" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.960489" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:32.960226" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.960988" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.960717" elapsed="0.000374"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.961799" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:32.961475" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:32.962570" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.962346" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:32.962667" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:20:32.962829" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:32.962019" elapsed="0.000835"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.963015" elapsed="0.000271"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:20:32.961332" elapsed="0.002002"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.964017" level="INFO">${value} = example-bgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:32.963674" elapsed="0.000369"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:32.964802" level="INFO">${encoded} = example-bgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.964567" elapsed="0.000262"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:32.964880" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:32.965033" level="INFO">${encoded_value} = example-bgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:32.964242" elapsed="0.000816"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.965291" elapsed="0.000433"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer1</var>
<status status="PASS" start="2026-06-06T03:20:32.963475" elapsed="0.002293"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.966322" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:32.966019" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:32.967096" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.966883" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:32.967177" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:20:32.967329" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:32.966540" elapsed="0.000814"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.967509" elapsed="0.000243"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:20:32.965881" elapsed="0.001914"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.968340" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:32.968042" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:32.969116" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.968890" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:32.969194" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:32.969343" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:32.968552" elapsed="0.000816"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:32.969524" elapsed="0.000239"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:32.967906" elapsed="0.001898"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:32.961151" elapsed="0.008687"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:32.969880" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:32.970038" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:32.959899" elapsed="0.010164"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:32.959570" elapsed="0.010525"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.970306" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:32.970123" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:32.959548" elapsed="0.010840"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:32.971212" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:32.970545" elapsed="0.000733"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:32.971331" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:32.955781" elapsed="0.015675"/>
</kw>
<msg time="2026-06-06T03:20:32.971512" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:32.942045" elapsed="0.029513"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.984901" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:32.998221" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.011597" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.011818" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.012001" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.012385" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.012234" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:33.012219" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.012613" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.012805" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.012975" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:33.012189" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.012081" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.013203" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.013307" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:20:33.013437" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:32.937221" elapsed="0.076243"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.014662" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.014388" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:33.026962" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.027031" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.027160" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:33.017253" elapsed="0.009944"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.014781" elapsed="0.012473"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.027515" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.027291" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.014762" elapsed="0.012870"/>
</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-06-06T03:20:33.032703" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.029099" elapsed="0.003666"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.028782" elapsed="0.004032"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.028755" elapsed="0.004095"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.036810" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.033249" elapsed="0.003626"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.032929" elapsed="0.003996"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.032905" elapsed="0.004054"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.038877" 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-06-06T03:20:33.037209" elapsed="0.001696"/>
</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-06-06T03:20:33.039226" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.038978" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.039796" 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-06-06T03:20:33.039475" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.039308" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.038959" elapsed="0.000919"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.040410" 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-06-06T03:20:33.040042" elapsed="0.000395"/>
</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-06-06T03:20:33.040764" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.040506" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.041306" 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-06-06T03:20:33.041010" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.040846" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.040488" elapsed="0.000932"/>
</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-06-06T03:20:33.041579" elapsed="0.000367"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:33.042410" 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-06-06T03:20:33.042117" elapsed="0.000320"/>
</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-06-06T03:20:33.042597" elapsed="0.002540"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:20:33.028164" elapsed="0.017037"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:33.045292" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:20:33.047776" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:20:33.013792" elapsed="0.034011"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.047858" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:20:32.908121" elapsed="0.139863"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.048713" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-bgp-peer2 | IP=127.0.0.2 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-bgp-peer2</arg>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.048162" elapsed="0.000580"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.095170" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.094769" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.096008" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.095743" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.096186" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.095383" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.096792" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.096385" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.097129" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:33.097297" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:33.096987" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.097816" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.097487" elapsed="0.000375"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.098871" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.098587" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.099378" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.099080" elapsed="0.000325"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.100174" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.099817" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.100962" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.100736" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.101042" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:20:33.101200" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.100395" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.101382" elapsed="0.000259"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:20:33.099671" elapsed="0.002032"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.102255" level="INFO">${value} = example-bgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.101957" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.103093" level="INFO">${encoded} = example-bgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.102808" elapsed="0.000312"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.103170" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.103321" level="INFO">${encoded_value} = example-bgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.102468" elapsed="0.000878"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.103502" elapsed="0.000243"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-bgp-peer2</var>
<status status="PASS" start="2026-06-06T03:20:33.101819" elapsed="0.001968"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.104334" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.104036" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.105397" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.105179" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.105474" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.105678" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.104547" elapsed="0.001159"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.105864" elapsed="0.000225"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:20:33.103900" elapsed="0.002230"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.106692" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.106377" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.107433" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.107224" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.107508" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:33.107672" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.106905" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.107854" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:33.106241" elapsed="0.001875"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:33.099465" elapsed="0.008686"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:33.108194" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:33.108351" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-bgp-peer2', 'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:33.098256" elapsed="0.010121"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.097940" elapsed="0.010468"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.108587" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.108434" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.097915" elapsed="0.010766"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.109448" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:33.108832" elapsed="0.000644"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.109525" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:33.094122" elapsed="0.015574"/>
</kw>
<msg time="2026-06-06T03:20:33.109755" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.080227" elapsed="0.029576"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.123093" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.136476" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.149709" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.149931" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.150147" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.150530" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.150379" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:33.150364" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.150772" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.150946" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.151116" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:33.150334" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.150230" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.151344" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.151418" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:20:33.151542" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:33.075313" elapsed="0.076256"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.152744" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.152468" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:33.163196" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.163262" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.163388" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:33.155321" elapsed="0.008103"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.152860" elapsed="0.010621"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.163768" elapsed="0.000128"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.163518" elapsed="0.000448"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.152842" elapsed="0.011155"/>
</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-06-06T03:20:33.169012" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.165435" elapsed="0.003636"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.165122" elapsed="0.003999"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.165095" elapsed="0.004060"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.172273" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.169553" elapsed="0.002766"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.169239" elapsed="0.003115"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.169216" elapsed="0.003162"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.172959" 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-06-06T03:20:33.172557" elapsed="0.000429"/>
</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-06-06T03:20:33.173299" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.173057" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.173869" 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-06-06T03:20:33.173546" elapsed="0.000391"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.173380" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.173038" elapsed="0.000961"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.174530" 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-06-06T03:20:33.174165" elapsed="0.000391"/>
</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-06-06T03:20:33.174883" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.174625" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.175427" 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-06-06T03:20:33.175132" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.174966" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.174607" elapsed="0.000902"/>
</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-06-06T03:20:33.175678" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:33.176471" 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-06-06T03:20:33.176193" elapsed="0.000304"/>
</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-06-06T03:20:33.176671" elapsed="0.002528"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:20:33.164520" elapsed="0.014743"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:33.179308" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:33.181773" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:20:33.151856" elapsed="0.029944"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.181855" elapsed="0.000033"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:20:33.048983" elapsed="0.133026"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:33.182621" elapsed="0.000261"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:33.182309" elapsed="0.000637"/>
</kw>
<doc>Delete all previously configured BGP peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:32.826309" elapsed="0.356676"/>
</test>
<test id="s1-s8-t30" name="TC4_Configure_Two_iBGP_RR_Clients_With_Cluster_Id" line="531">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:33.186975" elapsed="0.000212"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:33.186699" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.188299" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.188149" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.188128" elapsed="0.000244"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.193860" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.193740" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.193718" elapsed="0.000219"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.195137" 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-06-06T03:20:33.194696" elapsed="0.000471"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.195675" 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-06-06T03:20:33.195343" elapsed="0.000360"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:33.195751" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:20:33.195917" 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-06-06T03:20:33.194275" elapsed="0.001668"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:33.202345" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.202185" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.202156" elapsed="0.000281"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:33.203763" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.203621" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.203602" elapsed="0.000234"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:33.204323" 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-06-06T03:20:33.203990" elapsed="0.000363"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.204773" level="INFO">${current_connection_index} = 8</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-06-06T03:20:33.204525" elapsed="0.000276"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.231240" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:33.205313" elapsed="0.026034"/>
</kw>
<msg time="2026-06-06T03:20:33.231512" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:33.231558" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:33.204968" elapsed="0.026627"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.255045" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "_ "i "B "G "P "_ "R "R "_ "C "l "i "e "n "t "s "_ "W "i "t "h "_ "C "l "u "s "t "e "r "_ "I "d "[K"
[?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-06-06T03:20:33.232144" elapsed="0.023018"/>
</kw>
<msg time="2026-06-06T03:20:33.255331" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:33.255379" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</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-06-06T03:20:33.231799" elapsed="0.023619"/>
</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-06-06T03:20:33.255785" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.255499" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.255478" elapsed="0.000392"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.256327" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "_ "i "B "G "P "_ "R "R "_ "C "l "i "e "n "t "s "_ "W "i "t "h "_ "C "l "u "s "t "e "r "_ "I "d "[K"
[?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-06-06T03:20:33.256020" elapsed="0.000385"/>
</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-06-06T03:20:33.256717" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.256473" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.256454" elapsed="0.000344"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:33.256832" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:33.259603" elapsed="0.000180"/>
</kw>
<msg time="2026-06-06T03:20:33.259850" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.258452" elapsed="0.001533"/>
</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="NOT RUN" start="2026-06-06T03:20:33.260274" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.260622" elapsed="0.000100"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:33.257761" elapsed="0.003074"/>
</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-06-06T03:20:33.257130" elapsed="0.003774"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:33.203314" elapsed="0.057693"/>
</kw>
<msg time="2026-06-06T03:20:33.261103" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:33.261149" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:33.202620" elapsed="0.058573"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:33.261383" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:20:33.261271" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.261251" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.261899" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.262281" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.262356" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:33.201663" elapsed="0.060806"/>
</kw>
<msg time="2026-06-06T03:20:33.262566" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:33.262612" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "f "i "g "u "r "e "_ "T "w "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:33.196359" elapsed="0.066308"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.263022" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.262747" elapsed="0.000354"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.262728" elapsed="0.000403"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:33.196204" elapsed="0.066957"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:33.196009" elapsed="0.067194"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:33.193302" elapsed="0.069971"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:33.187857" elapsed="0.075477"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:33.187402" elapsed="0.075980"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:33.183984" elapsed="0.079455"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.264265" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RR_CLIENT=true }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RR_CLIENT=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.263626" elapsed="0.000670"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.300813" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.300414" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.301679" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.301349" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.301854" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.301010" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.302463" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.302050" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.302810" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:33.302973" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:33.302670" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.303411" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.303159" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.304422" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.304164" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.304910" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.304629" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.305598" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.305301" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.306373" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.306151" elapsed="0.000298"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.306504" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:33.306673" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.305830" elapsed="0.000869"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.306858" elapsed="0.000239"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:20:33.305162" elapsed="0.001976"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.307699" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.307383" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.308443" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.308232" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.308517" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.308682" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.307912" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.308863" elapsed="0.000221"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:20:33.307248" elapsed="0.001876"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.309849" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.309369" elapsed="0.000505"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.310633" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.310383" elapsed="0.000293"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.310729" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.310881" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.310060" elapsed="0.000846"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.311187" elapsed="0.000233"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:20:33.309233" elapsed="0.002264"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.312069" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.311770" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.312828" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.312599" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.312904" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:33.313052" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.312282" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.313231" elapsed="0.000221"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:33.311610" elapsed="0.001883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.314052" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.313756" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.314842" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.314616" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.314917" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.315066" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.314262" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.315245" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:33.313604" elapsed="0.001905"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.316073" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.315774" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.316842" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.316612" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.316918" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.317068" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.316289" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.317247" elapsed="0.000224"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:33.315621" elapsed="0.001892"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:33.304986" elapsed="0.012562"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:33.317590" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:33.317767" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:33.303837" elapsed="0.013957"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.303524" elapsed="0.014302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.318005" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.317851" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.303506" elapsed="0.014576"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.318925" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:33.318229" elapsed="0.000726"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.319004" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:33.299778" elapsed="0.019350"/>
</kw>
<msg time="2026-06-06T03:20:33.319182" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.285840" elapsed="0.033390"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.334098" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.347459" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.360985" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.361192" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.361373" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.361758" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.361593" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:33.361577" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.361982" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.362154" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.362324" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:33.361549" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.361449" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.362550" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.362688" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:20:33.362815" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:33.281277" elapsed="0.081565"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.393184" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.392810" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.393952" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.393740" elapsed="0.000278">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.394149" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.393387" elapsed="0.000787"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.394894" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.394463" elapsed="0.000459"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.395226" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:33.395364" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:33.395090" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.395819" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
            &lt;route-reflector-cluster-id&gt;$IP&lt;/route-reflector-cluster-id&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.395554" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:33.396244" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.395951" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.396789" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.396478" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.396328" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.395932" elapsed="0.000941"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.397761" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:33.397024" elapsed="0.000768"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.397842" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:33.392177" elapsed="0.005790"/>
</kw>
<msg time="2026-06-06T03:20:33.398026" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.378744" elapsed="0.019328"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.411500" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.424808" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.438117" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.438317" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.438499" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.438883" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.438734" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:33.438719" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.439125" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.439296" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.439466" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:33.438689" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.438573" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.439712" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.439789" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:33.439922" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:33.375937" elapsed="0.064014"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.441211" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.440973" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.441366" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.440611" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.441726" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.441461" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.442275" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.441983" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.441808" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.441442" elapsed="0.000914"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.444864" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.442510" elapsed="0.002381"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:33.444943" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:33.445095" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:33.440281" elapsed="0.004839"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.446506" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.446256" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.447029" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
            &lt;route-reflector-cluster-id&gt;127.0.0.1&lt;/route-reflector-cluster-id&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.446768" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.447560" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.447254" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.448019" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.447778" elapsed="0.000285"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:33.448884" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:20:33.448691" elapsed="0.000218"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:20:33.449241" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:20:33.449067" elapsed="0.000199"/>
</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-06-06T03:20:33.449418" elapsed="0.000198"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.450042" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.449795" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:20:33.450128" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:33.450284" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:20:33.448265" elapsed="0.002044"/>
</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-06-06T03:20:33.468256" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1153', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
            &lt;route-reflector-cluster-id&gt;127.0.0.1&lt;/route-reflector-cluster-id&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:20:33.468402" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.468618" 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-06-06T03:20:33.452820" elapsed="0.015890"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.450379" elapsed="0.018434"/>
</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-06-06T03:20:33.469235" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.468872" elapsed="0.000511"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.450361" elapsed="0.019069"/>
</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-06-06T03:20:33.476763" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.471754" elapsed="0.005053"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.471217" elapsed="0.005625"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.471174" elapsed="0.005693"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.479641" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.477149" elapsed="0.002554"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.476924" elapsed="0.002814"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.476907" elapsed="0.002855"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.480310" 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-06-06T03:20:33.479931" elapsed="0.000406"/>
</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-06-06T03:20:33.480667" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.480408" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.481218" 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-06-06T03:20:33.480919" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.480751" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.480389" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.481852" 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-06-06T03:20:33.481466" elapsed="0.000412"/>
</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-06-06T03:20:33.482187" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.481948" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.482746" 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-06-06T03:20:33.482432" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.482267" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.481930" elapsed="0.000898"/>
</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-06-06T03:20:33.482981" elapsed="0.000436"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:33.483883" 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-06-06T03:20:33.483590" elapsed="0.000319"/>
</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-06-06T03:20:33.484067" elapsed="0.002495"/>
</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-06-06T03:20:33.470340" elapsed="0.016285"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:33.486821" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:20:33.486714" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.486694" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:20:33.487056" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.487148" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:20:33.489582" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:20:33.445444" elapsed="0.044165"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.489689" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.489843" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:33.269344" elapsed="0.220524"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.490202" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.489965" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.489948" elapsed="0.000383"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.490368" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}cluster_id/ibgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:20:33.264573" elapsed="0.225919"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.491298" level="INFO">&amp;{mapping} = { IP=127.0.0.2 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RR_CLIENT=true }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RR_CLIENT=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.490678" elapsed="0.000649"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.527332" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.526942" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.528094" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.527887" elapsed="0.000271">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.528252" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.527530" elapsed="0.000746"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.528846" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.528444" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.529173" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:33.529305" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:33.529037" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.529754" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.529492" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.530764" level="INFO">mapping: {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.530487" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.531234" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.530973" elapsed="0.000414"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.533035" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.532305" elapsed="0.000789"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.534828" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.534326" elapsed="0.000561"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.535000" elapsed="0.000065"/>
</return>
<msg time="2026-06-06T03:20:33.535392" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.533522" elapsed="0.001927"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.535829" elapsed="0.000499"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:20:33.531985" elapsed="0.004433"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.537700" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.537005" elapsed="0.000756"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.539509" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.539005" elapsed="0.000563"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.539709" elapsed="0.000065"/>
</return>
<msg time="2026-06-06T03:20:33.540121" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.538178" elapsed="0.002000"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.540529" elapsed="0.000530"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:20:33.536697" elapsed="0.004454"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.542394" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.541733" elapsed="0.000717"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.544336" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.544065" elapsed="0.000298"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.544414" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.544564" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.543263" elapsed="0.001326"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.544762" elapsed="0.000224"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:20:33.541401" elapsed="0.003627"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.545577" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.545277" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.546341" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.546129" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.546417" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.546568" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.545808" elapsed="0.000785"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.546764" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:33.545140" elapsed="0.001890"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.547757" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.547442" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.548509" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.548298" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.548585" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:33.548753" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.547970" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.548934" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:33.547142" elapsed="0.002056"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.549764" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:33.549446" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:33.550508" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.550297" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:33.550584" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.550752" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:33.549977" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:33.550933" elapsed="0.000224"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:33.549310" elapsed="0.001893"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:33.531530" elapsed="0.019708"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:33.551280" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:33.551467" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:33.530160" elapsed="0.021334"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.529867" elapsed="0.021660"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.551722" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.551552" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.529847" elapsed="0.021991"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.552623" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:33.551989" elapsed="0.000682"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.552723" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:33.526302" elapsed="0.026547"/>
</kw>
<msg time="2026-06-06T03:20:33.552903" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.512683" elapsed="0.040269"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.566559" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.579927" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.593215" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.593414" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.593597" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.593984" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.593834" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:33.593819" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.594209" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.594383" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.594555" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:33.593790" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.593687" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.594804" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.594882" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:33.595003" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:33.508111" elapsed="0.086921"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.623272" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.622896" elapsed="0.000404"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.624074" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.623857" elapsed="0.000281">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.624237" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.623468" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.624842" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.624431" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.625173" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:33.625363" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:33.625037" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.625827" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.625556" elapsed="0.000331"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:33.626250" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.625955" elapsed="0.000353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.626796" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RR_CLIENT': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.626484" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.626334" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.625936" elapsed="0.000944"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.627772" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:33.627030" elapsed="0.000773"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.627853" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:33.622258" elapsed="0.005720"/>
</kw>
<msg time="2026-06-06T03:20:33.628035" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.608785" elapsed="0.019297"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.641506" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.655112" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.668384" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.668584" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.668779" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.669147" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.668999" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:33.668984" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.669371" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.669543" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.669729" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:33.668955" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.668855" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.669958" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.670032" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:33.670165" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:33.605961" elapsed="0.064233"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:33.671549" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.671311" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:33.671731" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:33.670946" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.672128" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.671872" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.672691" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.672379" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.672210" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.671848" elapsed="0.000975"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.675408" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:33.673002" elapsed="0.002433"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:33.675488" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.675659" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:33.670583" elapsed="0.005103"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.677115" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.676853" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.677561" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.677321" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.678046" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.677802" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.678485" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.678246" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:33.679367" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:20:33.679153" elapsed="0.000243"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:20:33.679775" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:20:33.679576" elapsed="0.000225"/>
</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-06-06T03:20:33.680009" elapsed="0.000206"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.680633" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.680382" elapsed="0.000317"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:20:33.680743" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.680900" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:20:33.678746" elapsed="0.002180"/>
</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-06-06T03:20:33.729795" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '1074', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:20:33.729945" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.730241" 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-06-06T03:20:33.683416" elapsed="0.046885"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.680996" elapsed="0.049412"/>
</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-06-06T03:20:33.730870" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.730468" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.680978" elapsed="0.050095"/>
</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-06-06T03:20:33.738455" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.733364" elapsed="0.005155"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.732813" elapsed="0.005755"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.732768" elapsed="0.005836"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.742556" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.739030" elapsed="0.003591"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.738708" elapsed="0.003984"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.738682" elapsed="0.004046"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.743516" 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-06-06T03:20:33.742977" elapsed="0.000577"/>
</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-06-06T03:20:33.744020" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.743676" elapsed="0.000457"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.744846" 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-06-06T03:20:33.744405" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.744168" elapsed="0.000764"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.743627" elapsed="0.001334"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.745577" 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-06-06T03:20:33.745194" elapsed="0.000409"/>
</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-06-06T03:20:33.745933" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.745691" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.746486" 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-06-06T03:20:33.746184" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:33.746014" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.745672" elapsed="0.000896"/>
</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-06-06T03:20:33.746784" elapsed="0.000353"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:33.747596" 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-06-06T03:20:33.747314" elapsed="0.000308"/>
</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-06-06T03:20:33.747801" elapsed="0.002575"/>
</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-06-06T03:20:33.731933" elapsed="0.018507"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:33.750615" elapsed="0.000046"/>
</return>
<status status="PASS" start="2026-06-06T03:20:33.750506" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.750488" elapsed="0.000235"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:20:33.750879" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.750948" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:33.753399" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:20:33.676025" elapsed="0.077401"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.753492" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.753707" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:33.496214" elapsed="0.257519"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.754076" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.753833" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.753816" elapsed="0.000353"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:33.754208" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:20:33.491597" elapsed="0.262734"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:33.754941" elapsed="0.000240"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:33.754614" elapsed="0.000631"/>
</kw>
<doc>Configure two iBGP peers as routing reflector clients with cluster-id argument.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:33.183323" elapsed="0.571961"/>
</test>
<test id="s1-s8-t31" name="TC4_Connect_BGP_Peers" line="557">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:33.758928" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:33.758632" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.760250" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.760107" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.760088" elapsed="0.000231"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.765631" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.765523" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.765504" elapsed="0.000213"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.766736" 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-06-06T03:20:33.766331" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.767225" 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-06-06T03:20:33.766928" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:33.767297" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:33.767452" 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-06-06T03:20:33.765947" elapsed="0.001530"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:33.773328" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.773219" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.773199" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:33.774578" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:33.774472" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.774453" elapsed="0.000219"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:33.775126" 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-06-06T03:20:33.774825" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.775533" level="INFO">${current_connection_index} = 8</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-06-06T03:20:33.775316" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.805987" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:33.776232" elapsed="0.029861"/>
</kw>
<msg time="2026-06-06T03:20:33.806257" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:33.806303" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:33.775853" elapsed="0.030531"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.830417" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "s "[K"
[?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-06-06T03:20:33.806944" elapsed="0.023576"/>
</kw>
<msg time="2026-06-06T03:20:33.830702" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:33.830750" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:20:33.806566" elapsed="0.024221"/>
</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-06-06T03:20:33.831094" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.830864" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.830844" elapsed="0.000330"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.831617" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "s "[K"
[?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-06-06T03:20:33.831320" elapsed="0.000386"/>
</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-06-06T03:20:33.831997" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.831774" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.831755" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:33.832110" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:33.834666" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:20:33.834874" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:33.833579" elapsed="0.001424"/>
</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="NOT RUN" start="2026-06-06T03:20:33.835282" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.835623" elapsed="0.000098"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:33.832959" elapsed="0.002874"/>
</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-06-06T03:20:33.832382" elapsed="0.003516"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:33.774169" elapsed="0.061826"/>
</kw>
<msg time="2026-06-06T03:20:33.836086" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:33.836129" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:33.773554" elapsed="0.062613"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:33.836351" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:33.836244" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.836225" elapsed="0.000241"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.836883" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.837216" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:33.837286" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:33.772877" elapsed="0.064515"/>
</kw>
<msg time="2026-06-06T03:20:33.837485" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:33.837529" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:33.767870" elapsed="0.069697"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:33.837914" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:33.837658" elapsed="0.000374"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:33.837624" elapsed="0.000434"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:33.767724" elapsed="0.070359"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:33.767531" elapsed="0.070582"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:33.765158" elapsed="0.073008"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:33.759816" elapsed="0.078406"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:33.759361" elapsed="0.078906"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:33.756177" elapsed="0.082143"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:33.838480" elapsed="0.000105"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.843571" level="INFO">${peer1_cluster_id} = 127.0.0.4</msg>
<arg>${peer1_cluster_id}</arg>
<arg>127.0.0.4</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:20:33.838780" elapsed="0.004838"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.848720" level="INFO">${default_cluster_id} = 192.0.2.2</msg>
<arg>${default_cluster_id}</arg>
<arg>192.0.2.2</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:20:33.843807" elapsed="0.004960"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.857904" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log --cluster=127.0.0.4 &amp;&gt;bgp_peer1.lo...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:33.857556" elapsed="0.000377"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.858338" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log --cluster=127.0.0.4 &amp;&gt;bgp_peer1.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.858095" elapsed="0.000290"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:33.862769" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log --cluster=127.0.0.4 &amp;&gt;bgp_peer1.log</msg>
<msg time="2026-06-06T03:20:33.862867" level="INFO">${output} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log --cluster=127.0.0.4 &amp;&gt;bgp_peer1.lo...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:33.858539" elapsed="0.004356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.863311" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log --cluster=127.0.0.4 &amp;&gt;bgp_peer1.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.863063" elapsed="0.000296"/>
</kw>
<arg>${BGP_PEER1_COMMAND} --cluster=${peer1_cluster_id}</arg>
<arg>${BGP_PEER1_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:20:33.857076" elapsed="0.006339"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:33.871164" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:33.871335" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:20:33.871465" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:33.864677" elapsed="0.006825"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.875618" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.871770" elapsed="0.003936"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.879582" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:33.875932" elapsed="0.003736"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:20:33.883732" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:20:33.879894" elapsed="0.003935">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:20:33.864206" elapsed="0.019821">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '{"prefix":"8.1.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:34.894543" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:34.894780" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:20:34.895018" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:34.886105" elapsed="0.008955"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.899296" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:34.895335" elapsed="0.004032"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.903629" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:34.899614" elapsed="0.004112"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:20:34.903973" elapsed="0.003159"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:20:34.884965" elapsed="0.022242"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:33.863584" elapsed="1.043683"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:34.907448" elapsed="0.000117"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.916925" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log --cluster=127.0.0.2 &amp;&gt;bgp_peer2.lo...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:34.916544" elapsed="0.000412"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.917371" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log --cluster=127.0.0.2 &amp;&gt;bgp_peer2.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:34.917123" elapsed="0.000295"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:34.921326" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log --cluster=127.0.0.2 &amp;&gt;bgp_peer2.log</msg>
<msg time="2026-06-06T03:20:34.921446" level="INFO">${output} = python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log --cluster=127.0.0.2 &amp;&gt;bgp_peer2.lo...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:34.917576" elapsed="0.003897"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.921971" level="INFO">python3 play.py --firstprefix 8.2.0.0 --prefixlen 28 --amount 3 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer2.log --cluster=127.0.0.2 &amp;&gt;bgp_peer2.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:34.921686" elapsed="0.000333"/>
</kw>
<arg>${BGP_PEER2_COMMAND} --cluster=${BGP_PEER2_IP}</arg>
<arg>${BGP_PEER2_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:20:34.915959" elapsed="0.006122"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:34.929474" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:34.929630" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '338'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:20:34.929775" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:34.923409" elapsed="0.006469"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.934482" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:34.930093" elapsed="0.004463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.938944" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:34.934833" elapsed="0.004187"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:20:34.943475" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:20:34.939278" elapsed="0.004308">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:20:34.922943" elapsed="0.020844">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.1.0.0/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"}]}}]}]}' does not contain '{"prefix":"8.2.0.0/28"}'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:35.954266" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:35.954474" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '412'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]} 
 </msg>
<msg time="2026-06-06T03:20:35.954632" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:35.945876" elapsed="0.008827"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:35.959455" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:35.954977" elapsed="0.004585"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:35.964035" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}},"node":[{"node-id":"192.0.2.1","l3-unicast-igp-topology:igp-node-attributes":{"prefix":[{"prefix":"8.2.0.16/28"},{"prefix":"8.1.0.16/28"},{"prefix":"8.1.0.32/28"},{"prefix":"8.2.0.32/28"},{"prefix":"8.2.0.0/28"},{"prefix":"8.1.0.0/28"}]}}]}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:35.959959" elapsed="0.004151"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:20:35.964352" elapsed="0.004030"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="PASS" start="2026-06-06T03:20:35.944725" elapsed="0.023730"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>{"prefix":"${BGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:34.922265" elapsed="1.046246"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:35.969187" elapsed="0.000261"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:35.968850" elapsed="0.000661"/>
</kw>
<doc>Connect BGP peers, each set to send 3 prefixes.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:33.755616" elapsed="2.213934"/>
</test>
<test id="s1-s8-t32" name="TC4_BGP_Peer1_Check_Rib_Out_For_Introduced_Prefixes" line="579">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:35.973411" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:35.973137" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:35.974753" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:35.974609" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:35.974583" elapsed="0.000247"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:35.982109" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:35.981997" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:35.981978" elapsed="0.000201"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:35.983219" 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-06-06T03:20:35.982817" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:35.983777" 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-06-06T03:20:35.983415" elapsed="0.000388"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:35.983848" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:20:35.984014" 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-06-06T03:20:35.982415" elapsed="0.001624"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:35.989885" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:35.989776" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:35.989756" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:35.991163" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:35.991055" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:35.991036" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:35.991745" 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-06-06T03:20:35.991381" elapsed="0.000392"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:35.992157" level="INFO">${current_connection_index} = 8</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-06-06T03:20:35.991938" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.024429" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:35.992713" elapsed="0.031907"/>
</kw>
<msg time="2026-06-06T03:20:36.024856" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:36.024905" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:35.992350" elapsed="0.032593"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.074148" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "R "i "b "_ "O "u "t "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:20:36.025626" elapsed="0.048749"/>
</kw>
<msg time="2026-06-06T03:20:36.074619" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:36.074701" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</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-06-06T03:20:36.025179" elapsed="0.049562"/>
</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-06-06T03:20:36.075210" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.074865" elapsed="0.000406"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.074826" elapsed="0.000471"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.075899" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "c "k "_ "R "i "b "_ "O "u "t "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:20:36.075451" elapsed="0.000528"/>
</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-06-06T03:20:36.076271" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.076047" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.076029" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:36.076386" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:36.079135" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:20:36.079408" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.077988" elapsed="0.001556"/>
</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="NOT RUN" start="2026-06-06T03:20:36.079898" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.080239" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:36.077311" elapsed="0.003116"/>
</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-06-06T03:20:36.076734" elapsed="0.003759"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:35.990751" elapsed="0.089841"/>
</kw>
<msg time="2026-06-06T03:20:36.080705" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:36.080751" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:35.990111" elapsed="0.090679"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:36.081196" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:20:36.080867" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.080848" elapsed="0.000437"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.081720" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.082070" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.082142" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:35.989419" elapsed="0.092833"/>
</kw>
<msg time="2026-06-06T03:20:36.082347" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:36.082391" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "1 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:35.984429" elapsed="0.098000"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.082787" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.082503" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.082486" elapsed="0.000380"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:35.984279" elapsed="0.098611"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:35.984098" elapsed="0.098824"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:35.981608" elapsed="0.101367"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:35.974306" elapsed="0.108725"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:35.973849" elapsed="0.109228"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:35.970791" elapsed="0.112340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.084036" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib | PEER_NUMBER=2 | CLUSTER_ID=127.0.0.2 | DEFAULT_ID=192.0.2.2 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>PEER_NUMBER=2</arg>
<arg>CLUSTER_ID=${BGP_PEER2_IP}</arg>
<arg>DEFAULT_ID=${default_cluster_id}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.083312" elapsed="0.000755"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.138025" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.137597" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.138884" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.138594" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.139135" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.138241" elapsed="0.000920"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.139745" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:36.139334" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.140141" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:36.140311" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:36.139993" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.140769" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.140501" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.141853" level="INFO">mapping: {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_NUMBER': '2', 'CLUSTER_ID': '127.0.0.2', 'DEFAULT_ID': '192.0.2.2'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.141568" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.142342" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.142067" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.143353" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.142764" elapsed="0.000615"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.144343" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.143992" elapsed="0.000379"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.144425" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:20:36.144585" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.143574" elapsed="0.001036"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.144787" elapsed="0.000292"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:20:36.142606" elapsed="0.002516"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.145715" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.145374" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.146621" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.146279" elapsed="0.000385"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.146717" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:36.146869" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.145931" elapsed="0.000963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.147053" elapsed="0.000274"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:36.145239" elapsed="0.002131"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.148007" level="INFO">${value} = 2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.147623" elapsed="0.000411"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.148930" level="INFO">${encoded} = 2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.148572" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.149007" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.149160" level="INFO">${encoded_value} = 2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.148224" elapsed="0.000961"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.149341" elapsed="0.000273"/>
</kw>
<var name="${key}">PEER_NUMBER</var>
<var name="${value}">2</var>
<status status="PASS" start="2026-06-06T03:20:36.147486" elapsed="0.002187"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.150294" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.149970" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.151216" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.150875" elapsed="0.000368"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.151295" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.151447" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.150511" elapsed="0.000961"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.151629" elapsed="0.000319"/>
</kw>
<var name="${key}">CLUSTER_ID</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:20:36.149831" elapsed="0.002161"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.152565" level="INFO">${value} = 192.0.2.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.152243" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.153503" level="INFO">${encoded} = 192.0.2.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.153166" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.153581" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.153750" level="INFO">${encoded_value} = 192.0.2.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.152820" elapsed="0.000956"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.153932" elapsed="0.000272"/>
</kw>
<var name="${key}">DEFAULT_ID</var>
<var name="${value}">192.0.2.2</var>
<status status="PASS" start="2026-06-06T03:20:36.152107" elapsed="0.002139"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:36.142424" elapsed="0.011857"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:36.154325" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:36.154487" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_NUMBER': '2', 'CLUSTER_ID': '127.0.0.2', 'DEFAULT_ID': '192.0.2.2'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:36.141238" elapsed="0.013275"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.140897" elapsed="0.013649"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.154747" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.154573" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.140873" elapsed="0.013954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.155678" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:36.154978" elapsed="0.000731"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.155760" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:36.136944" elapsed="0.018947"/>
</kw>
<msg time="2026-06-06T03:20:36.155999" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.123177" elapsed="0.032876"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.169815" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.183410" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.197020" elapsed="0.000036"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.197267" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.197588" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.198045" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.197888" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:36.197868" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.198282" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.198455" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.198627" elapsed="0.000038"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:36.197826" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.197699" elapsed="0.001029"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.198881" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.198962" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:20:36.199124" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:36.118471" elapsed="0.080682"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.200729" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.200394" elapsed="0.000413">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.200906" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.199882" elapsed="0.001050"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.201279" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.201005" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.201865" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.201546" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.201359" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.200986" elapsed="0.000963"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.204511" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:36.202108" elapsed="0.002429"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:36.204591" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:20:36.204765" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:36.199500" elapsed="0.005290"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.206231" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.205981" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.206460" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.205440" elapsed="0.001045"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:20:36.206713" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:36.206556" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.206537" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.206949" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.207128" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.207193" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:36.209787" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:36.205104" elapsed="0.004735"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.212142" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.211711" elapsed="0.000505"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.212854" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.212455" elapsed="0.000465"/>
</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-06-06T03:20:36.240794" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:36.242383" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '972'} 
 body={"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.2.0.16/28","prefix":"8.2.0.16/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["192.0.2.2","127.0.0.2"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.2.0.32/28","prefix":"8.2.0.32/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["192.0.2.2","127.0.0.2"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.2.0.0/28","prefix":"8.2.0.0/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["192.0.2.2","127.0.0.2"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}} 
 </msg>
<msg time="2026-06-06T03:20:36.242718" 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-06-06T03:20:36.216499" elapsed="0.026284"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.213025" elapsed="0.029874"/>
</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-06-06T03:20:36.243382" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.242967" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.212993" elapsed="0.030585"/>
</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-06-06T03:20:36.250639" level="INFO">{"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.2.0.16/28","prefix":"8.2.0.16/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["192.0.2.2","127.0.0.2"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.2.0.32/28","prefix":"8.2.0.32/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["192.0.2.2","127.0.0.2"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.2.0.0/28","prefix":"8.2.0.0/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["192.0.2.2","127.0.0.2"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.246092" elapsed="0.004623"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.245543" elapsed="0.005208"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.245499" elapsed="0.005279"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.253616" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.251064" elapsed="0.002616"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.250835" elapsed="0.002956"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.250818" elapsed="0.003001"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.254471" 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-06-06T03:20:36.254018" elapsed="0.000481"/>
</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-06-06T03:20:36.254841" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.254573" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.255406" 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-06-06T03:20:36.255099" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.254926" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.254554" elapsed="0.000939"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.256049" 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-06-06T03:20:36.255675" elapsed="0.000402"/>
</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-06-06T03:20:36.256442" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.256151" elapsed="0.000350"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.257011" 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-06-06T03:20:36.256710" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.256525" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.256132" elapsed="0.000963"/>
</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-06-06T03:20:36.257258" elapsed="0.000358"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:36.258114" 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-06-06T03:20:36.257809" elapsed="0.000331"/>
</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-06-06T03:20:36.258302" elapsed="0.002760"/>
</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-06-06T03:20:36.244514" elapsed="0.016621"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.261320" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.261207" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.261188" elapsed="0.000204"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:20:36.266541" level="INFO">${text_normalized} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<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="PASS" start="2026-06-06T03:20:36.261545" elapsed="0.005088"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:20:36.266829" elapsed="0.000096"/>
</return>
<msg time="2026-06-06T03:20:36.267268" level="INFO">${response_text} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:20:36.210338" elapsed="0.056992"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.267505" elapsed="0.000091"/>
</return>
<msg time="2026-06-06T03:20:36.267969" level="INFO">${response_text} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:36.093965" elapsed="0.174067"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.305390" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.304927" elapsed="0.000498"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.306796" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.306347" elapsed="0.000549">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.307007" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.305808" elapsed="0.001227"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.307736" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:36.307247" elapsed="0.000526"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.308145" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:36.308384" level="INFO">${template} = {
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.0/28",
        "route-key": "8.$PEER_NUMBER.0.0/28",
        "attributes": {
       ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:36.307974" elapsed="0.000448"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.308950" level="INFO">{
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.0/28",
        "route-key": "8.$PEER_NUMBER.0.0/28",
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "originator-id": {
            "originator": "192.0.2.2"
          },
          "local-pref": {
            "pref": 100
          },
          "as-path": {
            "segments": [
              {
                "as-sequence": [
                  64496
                ]
              }
            ]
          },
          "cluster-id": {
            "cluster": [
              "$CLUSTER_ID",
              "$DEFAULT_ID"
            ]
          },
          "ipv4-next-hop": {
            "global": "192.0.2.1"
          }
        }
      },
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.16/28",
        "route-key": "8.$PEER_NUMBER.0.16/28",
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "originator-id": {
            "originator": "192.0.2.2"
          },
          "local-pref": {
            "pref": 100
          },
          "as-path": {
            "segments": [
              {
                "as-sequence": [
                  64496
                ]
              }
            ]
          },
          "cluster-id": {
            "cluster": [
              "$CLUSTER_ID",
              "$DEFAULT_ID"
            ]
          },
          "ipv4-next-hop": {
            "global": "192.0.2.1"
          }
        }
      },
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.32/28",
        "route-key": "8.$PEER_NUMBER.0.32/28",
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "originator-id": {
            "originator": "192.0.2.2"
          },
          "local-pref": {
            "pref": 100
          },
          "as-path": {
            "segments": [
              {
                "as-sequence": [
                  64496
                ]
              }
            ]
          },
          "cluster-id": {
            "cluster": [
              "$CLUSTER_ID",
              "$DEFAULT_ID"
            ]
          },
          "ipv4-next-hop": {
            "global": "192.0.2.1"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.308631" elapsed="0.000390"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:36.309488" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.309116" elapsed="0.000435"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.310059" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_NUMBER': '2', 'CLUSTER_ID': '127.0.0.2', 'DEFAULT_ID': '192.0.2.2'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.309749" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.309580" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.309085" elapsed="0.001059"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.311231" level="INFO">${final_text} = {
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.2.0.0/28",
        "route-key": "8.2.0.0/28",
        "attributes": {
          "origin": {
       ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:36.310304" elapsed="0.000957"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.311314" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:36.304134" elapsed="0.007317"/>
</kw>
<msg time="2026-06-06T03:20:36.311516" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.290010" elapsed="0.021556"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.325536" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.339189" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.352858" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.353098" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.353296" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.353751" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.353575" elapsed="0.000236"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:36.353557" elapsed="0.000281"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.353990" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.354165" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.354338" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:36.353513" elapsed="0.000880"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.353389" elapsed="0.001033"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.354576" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.354672" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:20:36.354844" level="INFO">${expected_text} = {
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.2.0.0/28",
        "route-key": "8.2.0.0/28",
        "attributes": {
          "origin": {
       ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:36.287046" elapsed="0.067827"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.355060" elapsed="0.002521"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:20:36.359540" level="INFO">${expected_normalized} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.358402" elapsed="0.001168"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:20:36.360840" level="INFO">${actual_normalized} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.359760" elapsed="0.001111"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:20:36.361092" elapsed="0.000352"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:20:36.357947" elapsed="0.003561"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.357685" elapsed="0.003858"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.361749" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.361569" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.357663" elapsed="0.004166"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:20:36.271021" elapsed="0.090858"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:20:36.269052" elapsed="0.092907"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.268331" elapsed="0.093676"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.268277" elapsed="0.093755"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.362068" elapsed="0.000035"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}cluster_id/peer_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:20:36.088992" elapsed="0.273214"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VARIABLES_FOLDER}${/}cluster_id/peer_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:36.084251" elapsed="0.278018"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:36.362906" elapsed="0.000250"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:36.362573" elapsed="0.000648"/>
</kw>
<doc>Check incomming updates for new routes and respective cluster-ids
on first peer which should contain default-cluster id from global config reflected
from the second peer equal to router-id.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:35.969937" elapsed="0.393324"/>
</test>
<test id="s1-s8-t33" name="TC4_BGP_Peer2_Check_Rib_Out_For_Introduced_Prefixes" line="599">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:36.367009" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:36.366741" elapsed="0.000531"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.368287" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.368172" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.368151" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.374100" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.373983" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.373963" elapsed="0.000209"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.375234" 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-06-06T03:20:36.374824" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.375745" 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-06-06T03:20:36.375427" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:36.375817" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:20:36.375978" 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-06-06T03:20:36.374417" elapsed="0.001586"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:36.381931" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.381820" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.381800" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:36.383190" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.383081" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.383062" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:36.383803" 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-06-06T03:20:36.383409" elapsed="0.000422"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.384224" level="INFO">${current_connection_index} = 8</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-06-06T03:20:36.384001" elapsed="0.000249"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.418767" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:36.384806" elapsed="0.034072"/>
</kw>
<msg time="2026-06-06T03:20:36.419067" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:36.419117" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:36.384417" elapsed="0.034739"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.454883" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "R "i "b "_ "O "u "t "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:20:36.419737" elapsed="0.035265"/>
</kw>
<msg time="2026-06-06T03:20:36.455170" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:36.455218" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</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-06-06T03:20:36.419343" elapsed="0.035914"/>
</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-06-06T03:20:36.455580" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.455338" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.455316" elapsed="0.000377"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.456166" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "c "k "_ "R "i "b "_ "O "u "t "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:20:36.455849" elapsed="0.000398"/>
</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-06-06T03:20:36.456548" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.456317" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.456297" elapsed="0.000331"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:36.456682" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:36.459395" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:20:36.459607" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.458273" elapsed="0.001490"/>
</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="NOT RUN" start="2026-06-06T03:20:36.460048" elapsed="0.000241"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.460567" elapsed="0.000094"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:36.457573" elapsed="0.003220"/>
</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-06-06T03:20:36.457010" elapsed="0.003851"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:36.382775" elapsed="0.078187"/>
</kw>
<msg time="2026-06-06T03:20:36.461056" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:36.461100" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:36.382158" elapsed="0.078980"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:36.461333" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:20:36.461217" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.461197" elapsed="0.000222"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.461852" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.462239" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.462312" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:36.381463" elapsed="0.080960"/>
</kw>
<msg time="2026-06-06T03:20:36.462517" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:36.462563" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "B "G "P "_ "P "e "e "r "2 "_ "C "h "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:36.376390" elapsed="0.086211"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.462958" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.462696" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.462677" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:36.376241" elapsed="0.086820"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:36.376061" elapsed="0.087031"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:36.373565" elapsed="0.089582"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:36.367878" elapsed="0.095325"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:36.367428" elapsed="0.095821"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:36.364359" elapsed="0.098943"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.464095" level="INFO">&amp;{mapping} = { IP=127.0.0.2 | BGP_RIB_OPENCONFIG=example-bgp-rib | PEER_NUMBER=1 | CLUSTER_ID=127.0.0.1 | DEFAULT_ID=127.0.0.4 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>PEER_NUMBER=1</arg>
<arg>CLUSTER_ID=${BGP_PEER1_IP}</arg>
<arg>DEFAULT_ID=${peer1_cluster_id}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.463482" elapsed="0.000642"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.517780" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.517339" elapsed="0.000477"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.518613" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.518348" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.518811" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.518002" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.519397" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:36.519009" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.519756" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:36.519930" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:36.519593" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.520374" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.520123" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.521703" level="INFO">mapping: {'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_NUMBER': '1', 'CLUSTER_ID': '127.0.0.1', 'DEFAULT_ID': '127.0.0.4'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.521186" elapsed="0.000564"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.522268" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.521983" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.523063" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.522704" elapsed="0.000386"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.524017" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.523637" elapsed="0.000407"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.524098" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:20:36.524260" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.523286" elapsed="0.000999"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.524449" elapsed="0.000311"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:20:36.522540" elapsed="0.002263"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.525398" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.525071" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.526325" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.525984" elapsed="0.000369"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.526404" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.526556" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.525616" elapsed="0.000966"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.526756" elapsed="0.000275"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:36.524931" elapsed="0.002142"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.527743" level="INFO">${value} = 1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.527385" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.528664" level="INFO">${encoded} = 1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.528307" elapsed="0.000386"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.528744" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.528896" level="INFO">${encoded_value} = 1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.527961" elapsed="0.001007"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.529154" elapsed="0.000282"/>
</kw>
<var name="${key}">PEER_NUMBER</var>
<var name="${value}">1</var>
<status status="PASS" start="2026-06-06T03:20:36.527229" elapsed="0.002249"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.530077" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.529749" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.531001" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.530662" elapsed="0.000366"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.531078" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:36.531230" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.530297" elapsed="0.000958"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.531411" elapsed="0.000288"/>
</kw>
<var name="${key}">CLUSTER_ID</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:20:36.529592" elapsed="0.002149"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.532312" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.531992" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:36.533256" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.532905" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:36.533334" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.533485" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:36.532529" elapsed="0.000981"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:36.533682" elapsed="0.000273"/>
</kw>
<var name="${key}">DEFAULT_ID</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:20:36.531856" elapsed="0.002177"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:36.522350" elapsed="0.011721"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:36.534115" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:36.534279" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_NUMBER': '1', 'CLUSTER_ID': '127.0.0.1', 'DEFAULT_ID': '127.0.0.4'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:36.520828" elapsed="0.013477"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.520500" elapsed="0.013838"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.534519" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.534364" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.520474" elapsed="0.014124"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.535694" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:36.534766" elapsed="0.000959"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.535777" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:36.516668" elapsed="0.019237"/>
</kw>
<msg time="2026-06-06T03:20:36.535961" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.502982" elapsed="0.033026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.549445" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.563103" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.576557" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.576809" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.577002" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.577469" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.577311" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:36.577289" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.577722" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.577896" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.578064" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:36.577245" elapsed="0.000947"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.577118" elapsed="0.001103"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.578377" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.578458" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:20:36.578629" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:36.498248" elapsed="0.080428"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.580140" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.579839" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.580318" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.579400" elapsed="0.000943"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.580702" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.580414" elapsed="0.000346"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.581293" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.580972" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.580786" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.580395" elapsed="0.000981"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.583891" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:36.581533" elapsed="0.002384"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:36.583969" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:20:36.584124" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:36.579026" elapsed="0.005123"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.585414" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.585178" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.585571" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.584808" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:20:36.585820" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:36.585681" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.585661" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.586054" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.586230" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.586294" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:36.588554" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:36.584463" elapsed="0.004118"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.590034" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.589774" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.590529" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.590276" elapsed="0.000298"/>
</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-06-06T03:20:36.607022" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:36.607727" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '972'} 
 body={"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.1.0.0/28","prefix":"8.1.0.0/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["127.0.0.1","127.0.0.4"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.1.0.16/28","prefix":"8.1.0.16/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["127.0.0.1","127.0.0.4"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.1.0.32/28","prefix":"8.1.0.32/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["127.0.0.1","127.0.0.4"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}} 
 </msg>
<msg time="2026-06-06T03:20:36.607832" 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-06-06T03:20:36.592884" elapsed="0.014974"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.590657" elapsed="0.017245"/>
</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-06-06T03:20:36.608090" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.607929" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.590622" elapsed="0.017555"/>
</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-06-06T03:20:36.612040" level="INFO">{"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.1.0.0/28","prefix":"8.1.0.0/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["127.0.0.1","127.0.0.4"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.1.0.16/28","prefix":"8.1.0.16/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["127.0.0.1","127.0.0.4"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}},{"path-id":0,"route-key":"8.1.0.32/28","prefix":"8.1.0.32/28","attributes":{"origin":{"value":"igp"},"originator-id":{"originator":"192.0.2.2"},"cluster-id":{"cluster":["127.0.0.1","127.0.0.4"]},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.609402" elapsed="0.002691"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.609168" elapsed="0.002960"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.609129" elapsed="0.003024"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.614977" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.612440" elapsed="0.002583"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.612208" elapsed="0.002849"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.612192" elapsed="0.002889"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.615662" 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-06-06T03:20:36.615251" elapsed="0.000440"/>
</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-06-06T03:20:36.616007" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.615763" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.616552" 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-06-06T03:20:36.616254" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.616089" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.615744" elapsed="0.000893"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.617210" 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-06-06T03:20:36.616818" elapsed="0.000420"/>
</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-06-06T03:20:36.617548" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.617308" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.618108" 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-06-06T03:20:36.617812" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.617629" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.617290" elapsed="0.000934"/>
</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-06-06T03:20:36.618380" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:36.619217" 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-06-06T03:20:36.618921" elapsed="0.000322"/>
</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-06-06T03:20:36.619404" elapsed="0.004211"/>
</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-06-06T03:20:36.608720" elapsed="0.014978"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.623878" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.623770" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.623751" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:20:36.627564" level="INFO">${text_normalized} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<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="PASS" start="2026-06-06T03:20:36.624096" elapsed="0.003499"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:20:36.627665" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:20:36.627827" level="INFO">${response_text} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:20:36.588914" elapsed="0.038940"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.627916" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:20:36.628064" level="INFO">${response_text} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:36.473842" elapsed="0.154248"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.658354" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.657975" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.659201" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:36.658907" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:36.659364" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:36.658548" elapsed="0.000840"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.659981" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:36.659557" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:36.660311" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/peer_rib_out/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:36.660481" level="INFO">${template} = {
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.0/28",
        "route-key": "8.$PEER_NUMBER.0.0/28",
        "attributes": {
       ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:36.660174" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.660940" level="INFO">{
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.0/28",
        "route-key": "8.$PEER_NUMBER.0.0/28",
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "originator-id": {
            "originator": "192.0.2.2"
          },
          "local-pref": {
            "pref": 100
          },
          "as-path": {
            "segments": [
              {
                "as-sequence": [
                  64496
                ]
              }
            ]
          },
          "cluster-id": {
            "cluster": [
              "$CLUSTER_ID",
              "$DEFAULT_ID"
            ]
          },
          "ipv4-next-hop": {
            "global": "192.0.2.1"
          }
        }
      },
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.16/28",
        "route-key": "8.$PEER_NUMBER.0.16/28",
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "originator-id": {
            "originator": "192.0.2.2"
          },
          "local-pref": {
            "pref": 100
          },
          "as-path": {
            "segments": [
              {
                "as-sequence": [
                  64496
                ]
              }
            ]
          },
          "cluster-id": {
            "cluster": [
              "$CLUSTER_ID",
              "$DEFAULT_ID"
            ]
          },
          "ipv4-next-hop": {
            "global": "192.0.2.1"
          }
        }
      },
      {
        "path-id": 0,
        "prefix": "8.$PEER_NUMBER.0.32/28",
        "route-key": "8.$PEER_NUMBER.0.32/28",
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "originator-id": {
            "originator": "192.0.2.2"
          },
          "local-pref": {
            "pref": 100
          },
          "as-path": {
            "segments": [
              {
                "as-sequence": [
                  64496
                ]
              }
            ]
          },
          "cluster-id": {
            "cluster": [
              "$CLUSTER_ID",
              "$DEFAULT_ID"
            ]
          },
          "ipv4-next-hop": {
            "global": "192.0.2.1"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:36.660689" elapsed="0.000360"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:36.661442" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.661119" elapsed="0.000383"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.662001" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PEER_NUMBER': '1', 'CLUSTER_ID': '127.0.0.1', 'DEFAULT_ID': '127.0.0.4'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:36.661698" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.661528" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.661099" elapsed="0.000987"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.663098" level="INFO">${final_text} = {
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.1.0.0/28",
        "route-key": "8.1.0.0/28",
        "attributes": {
          "origin": {
       ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:36.662238" elapsed="0.000889"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.663177" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:36.657334" elapsed="0.005973"/>
</kw>
<msg time="2026-06-06T03:20:36.663373" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.643641" elapsed="0.019780"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.677256" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.690734" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/peer_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.704213" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.704431" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.704616" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.705049" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.704889" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:36.704872" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.705282" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.705491" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.705684" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:36.704837" elapsed="0.000902"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.704719" elapsed="0.001048"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.705991" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.706072" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:20:36.706236" level="INFO">${expected_text} = {
  "bgp-inet:ipv4-routes": {
    "ipv4-route": [
      {
        "path-id": 0,
        "prefix": "8.1.0.0/28",
        "route-key": "8.1.0.0/28",
        "attributes": {
          "origin": {
       ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:36.640813" elapsed="0.065452"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.706456" elapsed="0.002573"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:20:36.711159" level="INFO">${expected_normalized} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.709858" elapsed="0.001331"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:20:36.712396" level="INFO">${actual_normalized} = {
 "bgp-inet:ipv4-routes": {
  "ipv4-route": [
   {
    "attributes": {
     "as-path": {
      "segments": [
       {
        "as-sequence": [
         64496
        ]
       }
      ]
     },
     "...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:20:36.711355" elapsed="0.001071"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:20:36.712593" elapsed="0.000364"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:20:36.709374" elapsed="0.003646"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.709114" elapsed="0.003942"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.713240" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.713082" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.709094" elapsed="0.004228"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:20:36.629266" elapsed="0.084106"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:20:36.628423" elapsed="0.085059"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:36.628172" elapsed="0.085359"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.628155" elapsed="0.085401"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:36.713592" elapsed="0.000034"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}cluster_id/peer_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:20:36.468992" elapsed="0.244752"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VARIABLES_FOLDER}${/}cluster_id/peer_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:36.464314" elapsed="0.249492"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:36.714415" elapsed="0.000259"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:36.714104" elapsed="0.000636"/>
</kw>
<doc>Check incomming updates for new routes and respective cluster-ids
in second peer which has local route-reflector-cluster-id</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:36.363612" elapsed="0.351167"/>
</test>
<test id="s1-s8-t34" name="TC4_Disconnect_BGP_Peers" line="618">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:36.718253" elapsed="0.000207"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:36.717987" elapsed="0.000528"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.719526" elapsed="0.000059"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.719414" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.719394" elapsed="0.000276"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.725254" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.725146" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.725128" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.726369" 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-06-06T03:20:36.725983" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.726885" 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-06-06T03:20:36.726563" elapsed="0.000349"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:36.726957" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:36.727114" 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-06-06T03:20:36.725583" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:36.733006" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.732898" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.732878" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:36.734269" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:36.734161" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.734142" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:36.734819" 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-06-06T03:20:36.734490" elapsed="0.000356"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.735233" level="INFO">${current_connection_index} = 8</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-06-06T03:20:36.735013" elapsed="0.000252"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.767274" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:36.735798" elapsed="0.031641"/>
</kw>
<msg time="2026-06-06T03:20:36.767639" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:36.767713" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:36.735435" elapsed="0.032316"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:36.789523" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "s "[K"
[?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-06-06T03:20:36.768390" elapsed="0.021279"/>
</kw>
<msg time="2026-06-06T03:20:36.789848" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:36.789895" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</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-06-06T03:20:36.767989" elapsed="0.021944"/>
</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-06-06T03:20:36.790318" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.790029" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.790001" elapsed="0.000398"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.790912" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "s "[K"
[?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-06-06T03:20:36.790551" elapsed="0.000430"/>
</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-06-06T03:20:36.791272" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.791048" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.791029" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:36.791388" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:36.794295" elapsed="0.000154"/>
</kw>
<msg time="2026-06-06T03:20:36.794513" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:36.793035" elapsed="0.001646"/>
</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="NOT RUN" start="2026-06-06T03:20:36.794970" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.795307" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:36.792338" elapsed="0.003155"/>
</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-06-06T03:20:36.791750" elapsed="0.003810"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:36.733855" elapsed="0.061830"/>
</kw>
<msg time="2026-06-06T03:20:36.795784" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:36.795830" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:36.733230" elapsed="0.062638"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:36.796284" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:20:36.795947" elapsed="0.000399"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.795927" elapsed="0.000445"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.796820" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.797180" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:36.797254" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:36.732545" elapsed="0.064818"/>
</kw>
<msg time="2026-06-06T03:20:36.797458" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:36.797503" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:36.727520" elapsed="0.070021"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:36.797916" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:36.797619" elapsed="0.000351"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:36.797600" elapsed="0.000394"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:36.727372" elapsed="0.070646"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:36.727194" elapsed="0.070856"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:36.724782" elapsed="0.073325"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:36.719124" elapsed="0.079042"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:36.718687" elapsed="0.079527"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:36.715667" elapsed="0.082602"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:36.798445" elapsed="0.000108"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:36.799790" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:36.799394" elapsed="0.000424"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:36.799974" elapsed="0.000290"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:20:36.799125" elapsed="0.001199"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:20:38.801169" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:20:38.801514" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:20:36.800491" elapsed="2.001090"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:38.802854" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:38.802125" elapsed="0.000986"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:20:36.798804" elapsed="2.004451"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:38.817791" level="INFO">Executing command 'cat bgp_peer1.log'.</msg>
<msg time="2026-06-06T03:20:38.831952" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:38.832178" level="INFO">${output_log} = 2026-06-06 03:20:33,941 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:33,942 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:20:33,942 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:38.817629" elapsed="0.014611"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:38.833280" level="INFO">2026-06-06 03:20:33,941 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:33,942 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:20:33,942 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:20:33,942 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:20:33,942 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:20:33,942 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job):   Prefix base: 8.1.0.0/28
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:20:33,944 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706433
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Cluster list: 127.0.0.4
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:20:33,945 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:20:33,945 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:20:33,946 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:20:33,946 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706433 (0x7f000001)
2026-06-06 03:20:33,946 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:20:33,947 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:20:33,947 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0'
2026-06-06 03:20:33,947 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0
2026-06-06 03:20:33,948 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:33,949 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:33,950 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:20:33,952 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:20:33,952 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:20:33,952 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:33,952 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:33,952 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:20:33,953 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:33,954 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:33,954 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:20:33,954 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.0')]
2026-06-06 03:20:33,954 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:33,954 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:20:33,955 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:33,955 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:33,955 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:33,955 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   Length=62 (0x003e)
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=34 (0x0022)
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201800a047f000004)
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:33,956 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.4
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.0')]/28 (0x1c08010000)
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003e02000000224001010040020602010000fbf040050400000064400304c0000201800a047f0000041c08010000
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:33,957 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:33,958 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.16')]
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:33,959 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Length=62 (0x003e)
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=34 (0x0022)
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201800a047f000004)
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:33,960 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.4
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.16')]/28 (0x1c08010010)
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003e02000000224001010040020602010000fbf040050400000064400304c0000201800a047f0000041c08010010
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.1.0.32')]
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:33,961 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Length=62 (0x003e)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=34 (0x0022)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201800a047f000004)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.4
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.1.0.32')]/28 (0x1c08010020)
2026-06-06 03:20:33,962 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003e02000000224001010040020602010000fbf040050400000064400304c0000201800a047f0000041c08010020
2026-06-06 03:20:33,962 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:20:33,962 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:20:33,962 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:20:33,962 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:20:33,962 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:20:33,962 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.010246515274047852s
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:33,963 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:20:33,963 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:33,963 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:33,963 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:20:33,963 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.4
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:20:33,964 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:20:35,027 INFO BGP-Thread-1 (job): ... idle for 1.063s
2026-06-06 03:20:35,028 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.063s
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004e02000000374001010040020602010000fbf040050400000064800904c0000202800a08c00002027f000002800e0e00010104c0000201001c08020000
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004e' (78)
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0037' (55)
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a08c00002027f000002800e0e00010104c0000201001c08020000'
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:35,028 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c00002027f000002'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020000'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020000'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.0/28']
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.0/28
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:35,029 INFO BGP-Thread-1 (job): total_received_update_message_counter: 2
2026-06-06 03:20:35,029 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 1
2026-06-06 03:20:35,029 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004e02000000374001010040020602010000fbf040050400000064800904c0000202800a08c00002027f000002800e0e00010104c0000201001c08020020
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004e' (78)
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0037' (55)
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a08c00002027f000002800e0e00010104c0000201001c08020020'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c00002027f000002'
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:20:35,031 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020020'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020020'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.32/28']
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.32/28
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004e02000000374001010040020602010000fbf040050400000064800904c0000202800a08c00002027f000002800e0e00010104c0000201001c08020010
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004e' (78)
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0037' (55)
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a08c00002027f000002800e0e00010104c0000201001c08020010'
2026-06-06 03:20:35,032 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c00002027f000002'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08020010'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08020010'
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.2.0.16/28']
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.2.0.16/28
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,033 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:38.832617" elapsed="0.001401"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:38.835299" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc4_bgp_peer1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc4_bgp_peer1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:20:38.834459" elapsed="0.000967"/>
</kw>
<arg>${BGP_PEER1_LOG_FILE}</arg>
<arg>tc4_${BGP_PEER1_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:38.817202" elapsed="0.018366"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>bgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:38.835966" elapsed="0.000246"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:38.838921" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:38.838086" elapsed="0.000900"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:38.839343" elapsed="0.000228"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:20:38.837443" elapsed="0.002190"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:20:40.840593" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:20:40.840893" level="INFO">${output} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:20:38.839814" elapsed="2.001124"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.841964" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:40.841307" elapsed="0.000769"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:20:38.836719" elapsed="2.005497"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:40.857491" level="INFO">Executing command 'cat bgp_peer2.log'.</msg>
<msg time="2026-06-06T03:20:40.870690" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:40.870792" level="INFO">${output_log} = 2026-06-06 03:20:35,003 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:35,004 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:20:35,004 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:40.857346" elapsed="0.013473"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.871263" level="INFO">2026-06-06 03:20:35,003 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:35,004 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:20:35,004 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:20:35,004 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:20:35,004 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:20:35,004 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 3
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job):   Prefix base: 8.2.0.0/28
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706434
2026-06-06 03:20:35,006 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Cluster list: 127.0.0.2
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 3
2026-06-06 03:20:35,007 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 2]
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:20:35,007 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:20:35,007 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:20:35,007 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,007 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:20:35,007 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:20:35,007 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706434 (0x7f000002)
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0'
2026-06-06 03:20:35,008 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000002100206010400010001020641040000fbf0
2026-06-06 03:20:35,009 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:35,009 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,009 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:35,009 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:35,009 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:35,010 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 3
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): Remaining prefixes: 3
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:35,010 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.0')]
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Length=62 (0x003e)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=34 (0x0022)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201800a047f000002)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.2
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.0')]/28 (0x1c08020000)
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003e02000000224001010040020602010000fbf040050400000064400304c0000201800a047f0000021c08020000
2026-06-06 03:20:35,011 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.16')]
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Length=62 (0x003e)
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=34 (0x0022)
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201800a047f000002)
2026-06-06 03:20:35,012 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.2
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.16')]/28 (0x1c08020010)
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003e02000000224001010040020602010000fbf040050400000064400304c0000201800a047f0000021c08020010
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): ########## Iteration: 2 ##########
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix indexes: [2]
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.2.0.32')]
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix slot index: 2
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:35,013 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   Length=62 (0x003e)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=34 (0x0022)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064400304c0000201800a047f000002)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.2
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.2.0.32')]/28 (0x1c08020020)
2026-06-06 03:20:35,014 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003e02000000224001010040020602010000fbf040050400000064400304c0000201800a047f0000021c08020020
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): Number of iterations: 3
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 3
2026-06-06 03:20:35,014 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0038106441497802734s
2026-06-06 03:20:35,015 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:20:35,015 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:20:35,015 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:35,015 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:35,016 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:20:35,016 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:35,016 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:35,016 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):     Cluster list=127.0.0.2
2026-06-06 03:20:35,016 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:20:35,017 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:20:35,017 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:20:35,017 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:35,017 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:35,018 INFO BGP-Thread-1 (job): ... idle for 0.001s
2026-06-06 03:20:35,018 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.001s
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,018 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,019 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,019 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:20:35,019 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:20:35,019 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,019 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,019 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:35,023 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004e02000000374001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800e0e00010104c0000201001c08010000
2026-06-06 03:20:35,023 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,023 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,023 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004e' (78)
2026-06-06 03:20:35,023 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,023 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0037' (55)
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800e0e00010104c0000201001c08010000'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute value=0xb'7f0000017f000004'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08010000'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:35,024 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08010000'
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.1.0.0/28']
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.1.0.0/28
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004e02000000374001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800e0e00010104c0000201001c08010010
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004e' (78)
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0037' (55)
2026-06-06 03:20:35,025 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800e0e00010104c0000201001c08010010'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute value=0xb'7f0000017f000004'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08010010'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08010010'
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.1.0.16/28']
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.1.0.16/28
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004e02000000374001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800e0e00010104c0000201001c08010020
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:35,026 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004e' (78)
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:35,029 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0037' (55)
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800e0e00010104c0000201001c08010020'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute value=0xb'7f0000017f000004'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute type=14 (MP_REACH_NLRI, flags:0xb'80')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00010104c0000201001c08010020'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   Length of Next Hop Network Address=4 (0xb'04')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   Network Address of Next Hop=192.0.2.1 (0xb'c0000201')
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   Reserved=0xb'00'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=0xb'1c08010020'
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   NLRI prefix list: ['8.1.0.32/28']
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job):   nlri_prefix_received: 8.1.0.32/28
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:35,030 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:36,832 INFO BGP-Thread-1 (job): ... idle for 1.801s
2026-06-06 03:20:36,832 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.806s
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004802000000314001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800f080001011c08010000
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0048' (72)
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:36,832 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0031' (49)
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800f080001011c08010000'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute value=0xb'7f0000017f000004'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08010000'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08010000'
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.1.0.0/28']
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.1.0.0/28
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:36,833 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004802000000314001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800f080001011c08010010
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0048' (72)
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0031' (49)
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800f080001011c08010010'
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:36,834 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'7f0000017f000004'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08010010'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08010010'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.1.0.16/28']
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.1.0.16/28
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004802000000314001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800f080001011c08010020
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0048' (72)
2026-06-06 03:20:36,835 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0031' (49)
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'4001010040020602010000fbf040050400000064800904c0000202800a087f0000017f000004800f080001011c08010020'
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute type=1 (ORIGIN, flags:0xb'40')
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00'
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute type=2 (AS_PATH, flags:0xb'40')
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute value=0xb'02010000fbf0'
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute type=5 (LOCAL_PREF, flags:0xb'40')
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute value=0xb'00000064'
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute type=9 (ORIGINATOR_ID, flags:0xb'80')
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute value=0xb'c0000202'
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute type=10 (CLUSTER_LIST, flags:0xb'80')
2026-06-06 03:20:36,836 DEBUG BGP-Thread-1 (job): Attribute value=0xb'7f0000017f000004'
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job): Attribute value=0xb'0001011c08010020'
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'0001'
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'01'
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb'1c08010020'
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: ['8.1.0.32/28']
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job):   withdrawn_prefix_received: 8.1.0.32/28
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:36,837 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:36,837 INFO BGP-Thread-1 (job): total_received_update_message_counter: 7
2026-06-06 03:20:36,837 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 3
2026-06-06 03:20:36,837 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 3
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:40.870989" elapsed="0.001076"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:40.873313" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc4_bgp_peer2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc4_bgp_peer2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:20:40.872510" elapsed="0.000931"/>
</kw>
<arg>${BGP_PEER2_LOG_FILE}</arg>
<arg>tc4_${BGP_PEER2_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:40.856910" elapsed="0.016673"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:40.875063" elapsed="0.000564"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:40.874260" elapsed="0.001550"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:36.715131" elapsed="4.160770"/>
</test>
<test id="s1-s8-t35" name="TC4_Check_for_Empty_IPv4_Topology" line="628">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:40.881275" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:40.881009" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:40.882619" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.882468" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.882443" elapsed="0.000268"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:40.888086" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.887978" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.887959" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.889178" 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-06-06T03:20:40.888789" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.889686" 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-06-06T03:20:40.889371" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:40.889758" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:20:40.889922" 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-06-06T03:20:40.888385" elapsed="0.001562"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:40.896255" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.896140" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.896117" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:40.897553" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.897443" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.897423" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:40.898113" 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-06-06T03:20:40.897802" elapsed="0.000339"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:40.898553" level="INFO">${current_connection_index} = 8</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-06-06T03:20:40.898311" elapsed="0.000271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:40.928453" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:40.899138" elapsed="0.029550"/>
</kw>
<msg time="2026-06-06T03:20:40.928909" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:40.928956" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:40.898785" elapsed="0.030209"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:40.950764" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:20:40.929696" elapsed="0.021184"/>
</kw>
<msg time="2026-06-06T03:20:40.951042" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:40.951172" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "...</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-06-06T03:20:40.929242" elapsed="0.021970"/>
</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-06-06T03:20:40.951574" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:40.951309" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.951281" elapsed="0.000406"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.952153" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:20:40.951842" elapsed="0.000383"/>
</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-06-06T03:20:40.952523" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:40.952294" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.952274" elapsed="0.000329"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:40.952657" 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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:40.955403" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:20:40.955619" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:40.954239" elapsed="0.001537"/>
</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="NOT RUN" start="2026-06-06T03:20:40.956061" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:40.956405" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:40.953571" elapsed="0.003021"/>
</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-06-06T03:20:40.952993" elapsed="0.003684"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:40.897129" elapsed="0.059652"/>
</kw>
<msg time="2026-06-06T03:20:40.956876" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:40.956922" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:40.896493" elapsed="0.060472"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:40.957152" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:20:40.957043" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.957023" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:40.957677" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:40.958031" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:40.958104" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:40.895768" elapsed="0.062446"/>
</kw>
<msg time="2026-06-06T03:20:40.958309" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:40.958355" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "C "h "e "c "k "_ "f "o "r "_ "E "m "p "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:40.890328" elapsed="0.068067"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:40.958771" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:40.958472" elapsed="0.000356"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.958454" elapsed="0.000399"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:40.890181" elapsed="0.068697"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:40.890003" elapsed="0.068908"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:40.887604" elapsed="0.071364"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:40.882168" elapsed="0.076859"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:40.881719" elapsed="0.077394"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:40.877749" elapsed="0.081420"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:40.966342" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:40.966484" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:20:40.966598" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:40.960342" elapsed="0.006283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.970353" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:40.966843" elapsed="0.003577"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.974404" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:40.970700" elapsed="0.003770"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:20:40.974746" elapsed="0.002908"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Check the example-ipv4-topology does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:20:40.959987" elapsed="0.017733"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:20:40.959350" elapsed="0.018420"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:40.978360" elapsed="0.000243"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:40.978050" elapsed="0.000646"/>
</kw>
<doc>Checks for empty topology after</doc>
<status status="PASS" start="2026-06-06T03:20:40.876569" elapsed="0.102167"/>
</test>
<test id="s1-s8-t36" name="TC4_Delete_BGP_Peers_Configuration" line="637">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:40.982181" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:40.981915" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:40.983476" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.983361" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.983341" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:40.988957" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.988850" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.988832" elapsed="0.000205"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.990054" 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-06-06T03:20:40.989670" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:40.990543" 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-06-06T03:20:40.990246" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:40.990614" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:20:40.990816" 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-06-06T03:20:40.989269" elapsed="0.001571"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:40.996873" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.996765" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.996745" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:40.998146" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:40.998000" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:40.997982" elapsed="0.000236"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:40.998722" 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-06-06T03:20:40.998370" elapsed="0.000381"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:40.999133" level="INFO">${current_connection_index} = 8</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-06-06T03:20:40.998917" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.028014" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:40.999687" elapsed="0.028438"/>
</kw>
<msg time="2026-06-06T03:20:41.028301" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:41.028350" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:40.999326" elapsed="0.029062"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.050214" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:20:41.028972" elapsed="0.021351"/>
</kw>
<msg time="2026-06-06T03:20:41.050487" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:41.050533" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</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-06-06T03:20:41.028576" elapsed="0.021994"/>
</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-06-06T03:20:41.050945" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.050677" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.050629" elapsed="0.000398"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.051480" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:20:41.051175" elapsed="0.000377"/>
</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-06-06T03:20:41.051863" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.051620" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.051601" elapsed="0.000341"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:41.051976" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:41.054542" elapsed="0.000168"/>
</kw>
<msg time="2026-06-06T03:20:41.054773" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:41.053454" elapsed="0.001479"/>
</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="NOT RUN" start="2026-06-06T03:20:41.055215" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.055555" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:41.052822" elapsed="0.002939"/>
</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-06-06T03:20:41.052259" elapsed="0.003566"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:40.997694" elapsed="0.058229"/>
</kw>
<msg time="2026-06-06T03:20:41.056016" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:41.056060" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:40.997099" elapsed="0.059000"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:41.056286" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:20:41.056177" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.056157" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.056797" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.057190" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:41.057262" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:40.996410" elapsed="0.060961"/>
</kw>
<msg time="2026-06-06T03:20:41.057465" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:41.057509" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "4 "_ "D "e "l "e "t "e "_ "B "G "P "_ "P "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:40.991218" elapsed="0.066328"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.057897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.057622" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.057604" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:40.991071" elapsed="0.066929"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:40.990896" elapsed="0.067134"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:40.988472" elapsed="0.069612"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:40.983072" elapsed="0.075067"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:40.982600" elapsed="0.075584"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:40.979588" elapsed="0.078650"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.058927" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${BGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.058409" elapsed="0.000546"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.105422" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:41.105039" elapsed="0.000414"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:41.106228" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:41.105986" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:41.106400" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:41.105625" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.107030" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:41.106596" elapsed="0.000462"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:41.107366" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/cluster_id/ibgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:41.107520" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:41.107227" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.107974" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.107725" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.108995" level="INFO">mapping: {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.108733" elapsed="0.000307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.109471" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.109205" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.110228" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:41.109925" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:41.111195" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.110968" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:41.111272" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:41.111422" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:41.110451" elapsed="0.000996"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.111610" elapsed="0.000253"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:20:41.109782" elapsed="0.002124"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.112455" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:41.112154" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:41.113381" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.113012" elapsed="0.000395"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:41.113459" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:41.113613" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:41.112686" elapsed="0.000967"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.113816" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:41.112018" elapsed="0.002063"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:41.109585" elapsed="0.004532"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:41.114159" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:41.114315" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:41.108389" elapsed="0.005951"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.108087" elapsed="0.006285"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.114555" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.114396" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.108068" elapsed="0.006565"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.115437" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:41.114800" elapsed="0.000666"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:41.115517" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:41.104388" elapsed="0.011270"/>
</kw>
<msg time="2026-06-06T03:20:41.115716" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:41.090581" elapsed="0.025183"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.129092" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.142458" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//cluster_id/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.155850" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.156051" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.156235" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.156604" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.156454" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:41.156438" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.156845" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.157017" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.157186" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:41.156410" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:41.156310" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.157415" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:41.157490" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:41.157612" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:41.085929" elapsed="0.071724"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.158776" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.158505" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:41.204096" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:41.204222" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:41.204448" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:41.161096" elapsed="0.043411"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.158890" elapsed="0.045718"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.205093" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.204705" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.158872" elapsed="0.046406"/>
</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-06-06T03:20:41.213959" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.207699" elapsed="0.006358"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.207145" elapsed="0.006991"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.207101" elapsed="0.007174"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.217765" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.214952" elapsed="0.002860"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.214412" elapsed="0.003436"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.214373" elapsed="0.003500"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.218459" 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-06-06T03:20:41.218057" elapsed="0.000432"/>
</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-06-06T03:20:41.218825" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.218561" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.219396" 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-06-06T03:20:41.219089" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.218910" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.218543" elapsed="0.000938"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.220032" 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-06-06T03:20:41.219662" elapsed="0.000397"/>
</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-06-06T03:20:41.220374" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.220131" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.220944" 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-06-06T03:20:41.220625" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.220458" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.220112" elapsed="0.000917"/>
</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-06-06T03:20:41.221188" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:41.222020" 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-06-06T03:20:41.221729" elapsed="0.000318"/>
</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-06-06T03:20:41.222210" elapsed="0.002561"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:20:41.206123" elapsed="0.018714"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:41.224887" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:20:41.227350" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:20:41.157921" elapsed="0.069456"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:41.227433" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}cluster_id/ibgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:20:41.059186" elapsed="0.168372"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.228216" level="INFO">&amp;{mapping} = { IP=127.0.0.2 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${BGP_PEER2_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.227752" elapsed="0.000493"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.274005" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:41.273612" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:41.274802" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:41.274542" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:41.274970" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:41.274202" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.275566" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:41.275177" elapsed="0.000457"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:41.275963" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:41.276118" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:41.275823" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.276557" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.276306" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.277583" level="INFO">mapping: {'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.277321" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.278245" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.277814" elapsed="0.000458"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.278979" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:41.278676" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:41.279803" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.279558" elapsed="0.000271"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:41.279880" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:41.280031" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:41.279222" elapsed="0.000834"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.280213" elapsed="0.000227"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:20:41.278520" elapsed="0.001960"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.281047" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:41.280747" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:41.281810" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.281582" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:41.281886" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:41.282035" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:41.281261" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:41.282215" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:41.280593" elapsed="0.001883"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:41.278342" elapsed="0.004169"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:41.282553" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:41.282727" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:41.276988" elapsed="0.005765"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.276688" elapsed="0.006097"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.282964" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.282810" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.276668" elapsed="0.006372"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.283797" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:41.283203" elapsed="0.000679"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:41.283933" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:41.272989" elapsed="0.011069"/>
</kw>
<msg time="2026-06-06T03:20:41.284147" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:41.259403" elapsed="0.024793"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.297538" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.310968" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.324405" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.324604" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.324803" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.325171" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.325023" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:41.325007" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.325394" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.325563" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.325747" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:41.324979" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:41.324879" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.325976" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:41.326051" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:41.326172" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:41.254801" elapsed="0.071398"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.327343" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.327059" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:41.338824" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node017dck29lrz7z27pkh087y5fql16.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:41.338906" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:41.339007" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:41.331363" elapsed="0.007670"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.327460" elapsed="0.011614"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.339272" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.339100" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.327441" elapsed="0.011916"/>
</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-06-06T03:20:41.344411" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.340783" elapsed="0.003693"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.340420" elapsed="0.004112"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.340394" elapsed="0.004177"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.348601" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.345013" elapsed="0.003650"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.344675" elapsed="0.004024"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.344629" elapsed="0.004096"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.349358" 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-06-06T03:20:41.348900" elapsed="0.000486"/>
</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-06-06T03:20:41.349729" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.349461" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.350276" 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-06-06T03:20:41.349978" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.349812" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.349439" elapsed="0.000920"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.350905" 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-06-06T03:20:41.350524" elapsed="0.000408"/>
</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-06-06T03:20:41.351242" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.351002" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.351824" 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-06-06T03:20:41.351513" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:41.351340" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.350984" elapsed="0.000924"/>
</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-06-06T03:20:41.352063" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:41.352866" 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-06-06T03:20:41.352574" elapsed="0.000318"/>
</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-06-06T03:20:41.353050" elapsed="0.002536"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:20:41.339847" elapsed="0.015816"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:41.355712" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:41.358162" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:20:41.326466" elapsed="0.031723"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:41.358243" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:20:41.228476" elapsed="0.129891"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:41.358977" elapsed="0.000241"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:41.358665" elapsed="0.000619"/>
</kw>
<doc>Delete all previously configured BGP peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:40.979031" elapsed="0.380347"/>
</test>
<kw name="Teardown_Everything" owner="BgpOperations" type="TEARDOWN">
<kw name="Search_And_Kill_Remote_Python" owner="KillPythonTool">
<kw name="Search_For_Remote_Python_Processes" owner="KillPythonTool">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.361126" level="INFO">Executing command 'ps -elf | egrep python | egrep 'play.py' | egrep -v grep'.</msg>
<msg time="2026-06-06T03:20:41.384417" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:20:41.384629" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>ps -elf | egrep python | egrep ${filter} | egrep -v grep</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:20:41.360986" elapsed="0.023734"/>
</kw>
<return>
<value>${processes}</value>
<status status="PASS" start="2026-06-06T03:20:41.384829" elapsed="0.000068"/>
</return>
<msg time="2026-06-06T03:20:41.385171" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>${filter}</arg>
<doc>Only searches for the list of processes, in case something else than kill has to be done with them.</doc>
<status status="PASS" start="2026-06-06T03:20:41.360710" elapsed="0.024517"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.386172" level="INFO"/>
<arg>${processes}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.385585" elapsed="0.000681"/>
</kw>
<kw name="Kill_Remote_Processes" owner="KillPythonTool">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.388173" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:20:41.388343" level="INFO">${arg_length} = 0</msg>
<var>${arg_length}</var>
<arg>${pself_lines}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:20:41.387548" elapsed="0.000849"/>
</kw>
<if>
<branch type="IF" condition="${arg_length} == 0">
<return>
<status status="PASS" start="2026-06-06T03:20:41.388831" elapsed="0.000059"/>
</return>
<status status="PASS" start="2026-06-06T03:20:41.388556" elapsed="0.000398"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.388515" elapsed="0.000493"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${commands}</var>
<arg>echo '${pself_lines}' | awk '{print "kill -${signal}",$4}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.389350" elapsed="0.000046"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${commands}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.389780" elapsed="0.000047"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${stdout}</var>
<var>${stderr}</var>
<arg>echo 'set -exu; ${commands}' | sudo sh</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:41.390169" elapsed="0.000044"/>
</kw>
<arg>${processes}</arg>
<doc>Kill processes by PIDs from given list (no-op if the list is empty), using specified signal. Log the kill commands used.</doc>
<status status="PASS" start="2026-06-06T03:20:41.386837" elapsed="0.003517"/>
</kw>
<arg>'play\.py'</arg>
<doc>The main keyword. Search for processes, Log the list of them, kill them.</doc>
<status status="PASS" start="2026-06-06T03:20:41.360393" elapsed="0.030073"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:41.390988" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:20:41.390824" elapsed="0.000322"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:20:41.391503" elapsed="0.000942"/>
</kw>
<doc>Create and Log the diff between expected and actual responses, make sure Python tool was killed.
Tear down imported Resources.</doc>
<status status="PASS" start="2026-06-06T03:20:41.360120" elapsed="0.032624"/>
</kw>
<doc>Basic tests for iBGP peers.

Copyright (c) 2015-2018 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

Test suite performs basic iBGP functional test cases for
BGP peers in different roles (iBGP, iBGP RR-client):

Test Case 1: Two iBGP RR-client peers introduce prefixes
Expected result: controller forwards updates towards both peers

Test Case 2: Two iBGP peers: one RR client and one non-client introduces prefixes
Expected result: controller forwards updates towards both peers

Test Case 3: Two iBGP RR non-client peers introduce prefixes
Expected result: controller does not forward any update towards peers

Test Case 4: Two iBGP(play.py) RR-client peers configured, first of them configured
with route-reflector-cluster-id, second inherits it's cluster-id from global config.
Each of them introduces 3 prefixes.
Expected result: controller forwards updates towards both peers and each of their
adj-rib-in contains routes. First peer should contain default cluster-id and
second cluster-id from first peers configuration.

For polices see: https://wiki.opendaylight.org/view/BGP_LS_PCEP:BGP</doc>
<status status="FAIL" start="2026-06-06T03:18:06.970893" elapsed="154.421937"/>
</suite>
<suite id="s1-s9" name="Ebgp Peers Basic" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/ebgp_peers_basic.robot">
<kw name="Setup_Everything" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.494442" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:20:41.489527" elapsed="0.004964"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:20:41.489300" elapsed="0.005257"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.499927" 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-06-06T03:20:41.495679" elapsed="0.004276"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:20:41.500142" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:41.500035" elapsed="0.000149"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.500014" elapsed="0.000192"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.500738" 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-06-06T03:20:41.500366" elapsed="0.000417"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.501262" 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-06-06T03:20:41.500951" elapsed="0.000338"/>
</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-06-06T03:20:41.501872" elapsed="0.000285"/>
</kw>
<msg time="2026-06-06T03:20:41.502256" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:41.502304" 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-06-06T03:20:41.501458" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.502897" 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-06-06T03:20:41.502506" elapsed="0.000419"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.503948" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:20:41.503676" elapsed="0.000299"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.504393" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:20:41.504131" elapsed="0.000288"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.504892" 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-06-06T03:20:41.504582" elapsed="0.000337"/>
</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-06-06T03:20:41.508509" elapsed="0.000225"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.509233" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:20:41.508902" elapsed="0.000357"/>
</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-06-06T03:20:41.509418" elapsed="0.000248"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.510464" 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-06-06T03:20:41.510168" elapsed="0.000323"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:20:41.510536" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:20:41.510706" 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-06-06T03:20:41.509868" elapsed="0.000864"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:41.511314" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e765b3d0&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-06-06T03:20:41.510893" elapsed="0.000548"/>
</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-06-06T03:20:41.511627" elapsed="0.000208"/>
</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-06-06T03:20:41.507937" elapsed="0.003956"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:41.507743" elapsed="0.004195"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:20:41.504974" elapsed="0.006994"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.512544" 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-06-06T03:20:41.512138" elapsed="0.000449"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.513168" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:20:41.512770" elapsed="0.000441"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.513785" 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-06-06T03:20:41.513380" elapsed="0.000449"/>
</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-06-06T03:20:41.503174" elapsed="0.010711"/>
</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-06-06T03:20:41.495305" elapsed="0.018634"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:41.514118" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:41.514005" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.513986" elapsed="0.000198"/>
</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-06-06T03:20:41.517556" 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-06-06T03:20:41.517177" elapsed="0.000406"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.518105" 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-06-06T03:20:41.517804" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:41.518177" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:41.518333" 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-06-06T03:20:41.516843" elapsed="0.001515"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:41.519368" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:20:41.519104" elapsed="0.000290"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.520170" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:20:41.520270" 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-06-06T03:20:41.520018" elapsed="0.000279"/>
</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-06-06T03:20:41.523902" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:41.523281" elapsed="0.000708"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:41.523261" elapsed="0.000767"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.524691" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:20:41.524236" elapsed="0.000743"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.525941" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:41.525254" elapsed="0.000792"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.527390" 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-06-06T03:20:41.526324" elapsed="0.001117"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:20:41.529199" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:20:41.529379" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:20:41.528845" elapsed="0.000577"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:41.529785" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:20:41.531405" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:20:42.117712" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:20:41 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:18:08 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:20:41.531078" elapsed="0.586777"/>
</kw>
<msg time="2026-06-06T03:20:42.117936" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:41.530606" elapsed="0.587491"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:20:41.527931" elapsed="0.590310"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.119125" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:20:42.132167" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:20:42.132524" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:20:42.132845" 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-06-06T03:20:42.118614" elapsed="0.014341"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:20:42.133873" elapsed="0.001124"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.137686" 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-06-06T03:20:42.136392" elapsed="0.001451"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:20:42.138459" elapsed="0.000082"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:42.138088" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.138050" elapsed="0.000675"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:20:42.139194" elapsed="0.000089"/>
</return>
<status status="PASS" start="2026-06-06T03:20:42.138844" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.138819" elapsed="0.000631"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:20:42.139540" elapsed="0.000023"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:42.145102" elapsed="0.000691"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.146079" elapsed="0.000291"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:20:42.146656" elapsed="0.000226"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:42.140237" elapsed="0.006715"/>
</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-06-06T03:20:41.522322" elapsed="0.624806"/>
</kw>
<msg time="2026-06-06T03:20:42.147193" 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-06-06T03:20:41.521492" elapsed="0.625769"/>
</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-06-06T03:20:41.520996" elapsed="0.626353"/>
</kw>
<msg time="2026-06-06T03:20:42.147391" 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-06-06T03:20:41.520458" elapsed="0.626984"/>
</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-06-06T03:20:42.150683" elapsed="0.000376"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.151278" elapsed="0.000184"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:20:42.151831" 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-06-06T03:20:42.147843" elapsed="0.004153"/>
</kw>
<msg time="2026-06-06T03:20:42.152116" 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-06-06T03:20:41.519632" elapsed="0.632512"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.152637" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:42.152342" elapsed="0.000358"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:20:42.152745" elapsed="0.000031"/>
</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-06-06T03:20:41.518739" elapsed="0.634135"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:41.518541" elapsed="0.634370"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:41.518409" elapsed="0.634537"/>
</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-06-06T03:20:41.514407" elapsed="0.638597"/>
</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-06-06T03:20:42.153168" elapsed="0.000216"/>
</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-06-06T03:20:42.168943" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:42.168783" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.168762" elapsed="0.000256"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.169321" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:20:42.169441" 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-06-06T03:20:42.169180" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.169932" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:42.169662" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.170392" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:42.170141" elapsed="0.000297"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:42.171280" 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-06-06T03:20:42.171045" elapsed="0.000340">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:20:42.171499" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:20:42.171546" 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-06-06T03:20:42.170606" elapsed="0.000966"/>
</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-06-06T03:20:42.171902" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:42.171667" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.171631" elapsed="0.000374"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:42.172823" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:20:42.172503" elapsed="0.000349"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:20:42.172904" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:42.173064" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:20:42.172216" 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-06-06T03:20:42.173252" elapsed="0.000429"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.173971" level="INFO">index=4
host=10.30.170.38
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-06-06T03:20:42.174073" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:20:42.173863" elapsed="0.000237"/>
</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-06-06T03:20:42.174256" elapsed="0.002743"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.177433" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:20:42.369191" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.177171" elapsed="0.192167"/>
</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-06-06T03:20:42.373051" elapsed="0.000375"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.373607" elapsed="0.000198"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:20:42.373961" elapsed="0.000102"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:42.370455" elapsed="0.003663"/>
</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-06-06T03:20:42.369772" elapsed="0.004465"/>
</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-06-06T03:20:42.168423" elapsed="0.205869"/>
</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-06-06T03:20:42.154151" elapsed="0.220190"/>
</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-06-06T03:20:42.153771" elapsed="0.220624"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:42.153590" elapsed="0.220848"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:20:42.153441" elapsed="0.221033"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:20:41.494866" elapsed="0.879670"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:42.377491" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:42.377368" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.377345" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:42.383180" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:42.383072" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.383054" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.384236" 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-06-06T03:20:42.383839" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.384750" 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-06-06T03:20:42.384431" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:42.384823" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:20:42.385021" 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-06-06T03:20:42.383479" elapsed="0.001568"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:42.390938" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:42.390828" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.390809" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:42.392220" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:42.392094" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.392075" elapsed="0.000215"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:42.392783" 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-06-06T03:20:42.392440" elapsed="0.000370"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.393236" 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-06-06T03:20:42.393007" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.428536" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:42.393943" elapsed="0.034744"/>
</kw>
<msg time="2026-06-06T03:20:42.428821" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:42.428867" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:20:42.393426" elapsed="0.035478"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.499076" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "e "b "g "p "_ "p "e "[78Ce "[A[78Cr
 "s "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:20:42.429613" elapsed="0.069616"/>
</kw>
<msg time="2026-06-06T03:20:42.499362" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:42.499464" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:20:42.429101" elapsed="0.070406"/>
</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-06-06T03:20:42.499882" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:42.499595" elapsed="0.000440"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.499572" elapsed="0.000490"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:42.500580" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "e "b "g "p "_ "p "e "[78Ce "[A[78Cr
 "s "_ "b "a "s "i "c ". "r "o "b "o "t "[K"
[?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-06-06T03:20:42.500213" elapsed="0.000470"/>
</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-06-06T03:20:42.500998" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:42.500752" elapsed="0.000443"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.500733" elapsed="0.000498"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:42.501271" elapsed="0.000043"/>
</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-06-06T03:20:42.503321" elapsed="0.000475"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.504155" elapsed="0.000306"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:20:42.504821" elapsed="0.000439"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:42.502505" elapsed="0.002851"/>
</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-06-06T03:20:42.501585" elapsed="0.003907"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:42.391803" elapsed="0.113794"/>
</kw>
<msg time="2026-06-06T03:20:42.505735" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:42.505780" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:42.391163" elapsed="0.114655"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:42.506006" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:42.505897" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.505877" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:42.506496" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:42.506885" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:42.506957" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:42.390521" elapsed="0.116545"/>
</kw>
<msg time="2026-06-06T03:20:42.507159" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:42.507204" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:42.385421" elapsed="0.121819"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:42.507572" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:42.507316" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:42.507299" elapsed="0.000479"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:42.385275" elapsed="0.122529"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:42.385101" elapsed="0.122732"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:42.382777" elapsed="0.125111"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:20:42.375167" elapsed="0.132776"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:42.374719" elapsed="0.133267"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:20:41.488979" elapsed="1.019096"/>
</kw>
<kw name="Set Default Configuration" owner="SSHLibrary">
<arg>prompt=${ODL_SYSTEM_PROMPT}</arg>
<doc>Update the default `configuration`.</doc>
<status status="PASS" start="2026-06-06T03:20:42.508232" elapsed="0.000181"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${ODL_SYSTEM_IP}</arg>
<arg>alias=ibgp_peer1_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.508572" elapsed="0.000239"/>
</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-06-06T03:20:42.510599" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:20:42.510695" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:20:42.510319" elapsed="0.000401"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:42.510884" elapsed="0.000317"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.512070" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:20:42.842236" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:20:41 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:20:42 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:20:42.511751" elapsed="0.330661"/>
</kw>
<msg time="2026-06-06T03:20:42.842503" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:42.511374" elapsed="0.331207"/>
</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-06-06T03:20:42.509874" elapsed="0.332840"/>
</kw>
<msg time="2026-06-06T03:20:42.842769" 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-06-06T03:20:42.509396" elapsed="0.333419"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:20:42.509019" elapsed="0.333873"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${ODL_SYSTEM_IP}</arg>
<arg>alias=ebgp_peer1_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:42.843131" elapsed="0.000339"/>
</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-06-06T03:20:42.845612" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:20:42.845742" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:20:42.845325" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:42.845934" elapsed="0.000345"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:20:42.847164" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:20:43.159359" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:20:41 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:20:42 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:20:42.846839" elapsed="0.312660"/>
</kw>
<msg time="2026-06-06T03:20:43.159583" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:42.846456" elapsed="0.313214"/>
</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-06-06T03:20:42.844869" elapsed="0.314912"/>
</kw>
<msg time="2026-06-06T03:20:43.159834" 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-06-06T03:20:42.844106" elapsed="0.315773"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:20:42.843725" elapsed="0.316304"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${ODL_SYSTEM_IP}</arg>
<arg>alias=ebgp_peer2_console</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.160254" elapsed="0.000313"/>
</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-06-06T03:20:43.162416" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:20:43.162498" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:20:43.162128" elapsed="0.000395"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.162704" elapsed="0.000341"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.163924" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:20:43.522057" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:20:41 UTC 2026

  System load:  0.0                Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:20:43 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:20:43.163583" elapsed="0.358642"/>
</kw>
<msg time="2026-06-06T03:20:43.522315" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.163221" elapsed="0.359175"/>
</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-06-06T03:20:43.161631" elapsed="0.360882"/>
</kw>
<msg time="2026-06-06T03:20:43.522572" 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-06-06T03:20:43.161185" elapsed="0.361454"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:20:43.160813" elapsed="0.361921"/>
</kw>
<kw name="Require_Python" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.524237" level="INFO">Executing command 'python3 --help'.</msg>
<msg time="2026-06-06T03:20:43.536547" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:43.536845" level="INFO">${stdout} = usage: python3 [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_ins...</msg>
<msg time="2026-06-06T03:20:43.536949" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:20:43.537039" 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-06-06T03:20:43.524015" elapsed="0.013074"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.539131" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:20:43.538370" elapsed="0.000865"/>
</kw>
<msg time="2026-06-06T03:20:43.539449" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:20:43.539548" 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-06-06T03:20:43.537506" elapsed="0.002095"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.541021" 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-06-06T03:20:43.540032" elapsed="0.001048"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.542058" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.541261" elapsed="0.000938"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.541213" elapsed="0.001046"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:20:43.542606" elapsed="0.000149"/>
</return>
<status status="PASS" start="2026-06-06T03:20:43.542383" elapsed="0.000452"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.542348" elapsed="0.000544"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:20:43.543097" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.543018" elapsed="0.000169"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:43.542982" elapsed="0.000253"/>
</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-06-06T03:20:43.543567" elapsed="0.000044"/>
</kw>
<msg time="2026-06-06T03:20:43.544030" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>python3 --help</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-06-06T03:20:43.523620" elapsed="0.020446"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:20:43.544292" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:20:43.544163" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.544139" elapsed="0.000264"/>
</if>
<kw name="Fatal Error" owner="BuiltIn">
<arg>Python 3 is not installed!</arg>
<doc>Stops the whole test execution.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.544610" elapsed="0.000048"/>
</kw>
<doc>Verify current SSH connection leads to machine with python working. Fatal fail otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:43.523146" elapsed="0.021596"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.546476" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:20:43.604897" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:20:43.605177" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:20:43.605279" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:20:43.605369" 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-06-06T03:20:43.546221" elapsed="0.059199"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.607416" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:20:43.606809" elapsed="0.000707"/>
</kw>
<msg time="2026-06-06T03:20:43.607759" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:20:43.607860" 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-06-06T03:20:43.605903" elapsed="0.002007"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.609324" 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-06-06T03:20:43.608297" elapsed="0.001089"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.610541" elapsed="0.000078"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.609577" elapsed="0.001231"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.609523" elapsed="0.001353"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:20:43.611286" elapsed="0.000066"/>
</return>
<status status="PASS" start="2026-06-06T03:20:43.611046" elapsed="0.000382"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.610990" elapsed="0.000493"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:20:43.611725" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.611608" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:43.611572" elapsed="0.000295"/>
</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-06-06T03:20:43.612199" elapsed="0.000048"/>
</kw>
<msg time="2026-06-06T03:20:43.612529" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:20:43.545691" elapsed="0.066898"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:20:43.612982" elapsed="0.000055"/>
</return>
<status status="PASS" start="2026-06-06T03:20:43.612778" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.612738" elapsed="0.000417"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.613493" elapsed="0.000048"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:20:43.545084" elapsed="0.068618"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.649936" level="INFO">[chan 3] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:20:43.664825" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:20:43.614046" elapsed="0.050863"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:43.665563" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5c39b10&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:20:43.665160" elapsed="0.000664"/>
</kw>
<kw name="Create_Default_Session" owner="TemplatedRequests">
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:43.671139" level="INFO">Creating Session using : alias=default, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5de8210&gt;, timeout=5, proxies=None, verify=False,                     debug=0 </msg>
<arg>default</arg>
<arg>url=${url}</arg>
<arg>auth=${auth}</arg>
<arg>timeout=${timeout}</arg>
<arg>max_retries=${max_retries}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:20:43.670715" elapsed="0.000531"/>
</kw>
<doc>Create "default" session to ${url} with authentication and connection parameters.
This Keyword is in this Resource only so that user do not need to call RequestsLibrary directly.</doc>
<status status="PASS" start="2026-06-06T03:20:43.670245" elapsed="0.001134"/>
</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-06-06T03:20:43.673852" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.673738" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.673719" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:43.674302" 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-06-06T03:20:43.674076" elapsed="0.000252"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.674680" level="INFO">${current_connection_index} = 9</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-06-06T03:20:43.674491" elapsed="0.000217"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.681822" level="INFO">log:set INFO</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:43.675284" elapsed="0.006596"/>
</kw>
<msg time="2026-06-06T03:20:43.681980" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:43.682024" level="INFO">${message_write} = log:set INFO
</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-06-06T03:20:43.674924" elapsed="0.007124"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.691919" 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-06-06T03:20:43.682564" elapsed="0.009415"/>
</kw>
<msg time="2026-06-06T03:20:43.692076" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:43.692121" 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-06-06T03:20:43.682221" elapsed="0.009927"/>
</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-06-06T03:20:43.692449" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.692225" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.692205" elapsed="0.000322"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.692955" 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-06-06T03:20:43.692699" elapsed="0.000306"/>
</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-06-06T03:20:43.693290" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.693071" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.693053" elapsed="0.000314"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:43.693400" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:43.695181" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:20:43.695368" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.694531" elapsed="0.000900"/>
</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="NOT RUN" start="2026-06-06T03:20:43.695602" elapsed="0.000021"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.695788" elapsed="0.000021"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:43.694209" elapsed="0.001661"/>
</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-06-06T03:20:43.693696" elapsed="0.002221"/>
</kw>
<arg>log:set ${ODL_LOG_LEVEL}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:43.671759" elapsed="0.024254"/>
</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-06-06T03:20:43.698625" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.698514" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.698495" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:43.699109" 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-06-06T03:20:43.698885" elapsed="0.000250"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.699467" level="INFO">${current_connection_index} = 9</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-06-06T03:20:43.699298" elapsed="0.000194"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.749985" level="INFO">log:set DEFAULT org.opendaylight.bgpcep</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:43.700018" elapsed="0.050069"/>
</kw>
<msg time="2026-06-06T03:20:43.750188" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:43.750232" level="INFO">${message_write} = log:set DEFAULT org.opendaylight.bgpcep
</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-06-06T03:20:43.699671" elapsed="0.050585"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.752305" 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-06-06T03:20:43.750794" elapsed="0.001567"/>
</kw>
<msg time="2026-06-06T03:20:43.752457" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:43.752500" 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-06-06T03:20:43.750430" elapsed="0.002098"/>
</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-06-06T03:20:43.752844" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.752607" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.752588" elapsed="0.000334"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.753318" 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-06-06T03:20:43.753067" elapsed="0.000300"/>
</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-06-06T03:20:43.753665" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.753433" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.753415" elapsed="0.000331"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:43.753780" elapsed="0.000027"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:43.755411" elapsed="0.000140"/>
</kw>
<msg time="2026-06-06T03:20:43.755593" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.754892" elapsed="0.000775"/>
</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="NOT RUN" start="2026-06-06T03:20:43.755830" elapsed="0.000021"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.755995" elapsed="0.000021"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:43.754555" elapsed="0.001520"/>
</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-06-06T03:20:43.754050" elapsed="0.002070"/>
</kw>
<arg>log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.bgpcep</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:43.696359" elapsed="0.059855"/>
</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-06-06T03:20:43.758653" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.758527" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.758509" elapsed="0.000216"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:43.759111" 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-06-06T03:20:43.758876" elapsed="0.000261"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.759467" level="INFO">${current_connection_index} = 9</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-06-06T03:20:43.759300" elapsed="0.000193"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.811253" level="INFO">log:set DEFAULT org.opendaylight.protocol</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:43.760010" elapsed="0.051462"/>
</kw>
<msg time="2026-06-06T03:20:43.811816" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:43.811920" level="INFO">${message_write} = log:set DEFAULT org.opendaylight.protocol
</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-06-06T03:20:43.759669" elapsed="0.052306"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.816925" 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-06-06T03:20:43.813474" elapsed="0.003585"/>
</kw>
<msg time="2026-06-06T03:20:43.817277" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:43.817376" 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-06-06T03:20:43.812467" elapsed="0.004969"/>
</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-06-06T03:20:43.818331" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.817787" elapsed="0.000667"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.817733" elapsed="0.000778"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.819510" 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-06-06T03:20:43.818873" elapsed="0.000734"/>
</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-06-06T03:20:43.819920" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.819696" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.819676" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:43.820039" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:43.821950" elapsed="0.000161"/>
</kw>
<msg time="2026-06-06T03:20:43.822156" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.821332" elapsed="0.000889"/>
</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="NOT RUN" start="2026-06-06T03:20:43.822627" elapsed="0.000040"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.822825" elapsed="0.000020"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:43.820969" elapsed="0.001942"/>
</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-06-06T03:20:43.820389" elapsed="0.002570"/>
</kw>
<arg>log:set ${ODL_BGP_LOG_LEVEL} org.opendaylight.protocol</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:43.756554" elapsed="0.066520"/>
</kw>
<doc>Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
prepare directories for responses, put Python tool to mininet machine, setup imported resources.</doc>
<status status="PASS" start="2026-06-06T03:20:41.488670" elapsed="2.334466"/>
</kw>
<test id="s1-s9-t1" name="Configure_BGP_Peers" line="96">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:43.826681" elapsed="0.000218"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:43.826333" elapsed="0.000624"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:43.828048" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.827934" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.827915" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:43.833945" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.833836" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.833817" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.835113" 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-06-06T03:20:43.834659" elapsed="0.000488"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.835625" 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-06-06T03:20:43.835322" elapsed="0.000348"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:43.835716" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:43.835872" 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-06-06T03:20:43.834252" elapsed="0.001645"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:43.842019" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.841910" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.841890" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:43.843292" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:43.843183" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.843164" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:43.843836" 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-06-06T03:20:43.843506" elapsed="0.000357"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.844280" level="INFO">${current_connection_index} = 9</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-06-06T03:20:43.844064" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.876656" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:43.844836" elapsed="0.031927"/>
</kw>
<msg time="2026-06-06T03:20:43.876933" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:43.876981" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:43.844474" elapsed="0.032543"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:43.932014" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "B "G "P "_ "P "e "e "r "s "[K"
[?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-06-06T03:20:43.877565" elapsed="0.054575"/>
</kw>
<msg time="2026-06-06T03:20:43.932314" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:43.932361" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "B "G "P "_ "P "e "e "...</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-06-06T03:20:43.877208" elapsed="0.055189"/>
</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-06-06T03:20:43.932761" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.932486" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.932464" elapsed="0.000380"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.933304" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "B "G "P "_ "P "e "e "r "s "[K"
[?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-06-06T03:20:43.932989" elapsed="0.000381"/>
</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-06-06T03:20:43.933678" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.933438" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.933419" elapsed="0.000339"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:43.933793" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:43.936435" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:20:43.936657" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.935345" elapsed="0.001444"/>
</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="NOT RUN" start="2026-06-06T03:20:43.937073" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.937419" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:43.934638" elapsed="0.002965"/>
</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-06-06T03:20:43.934070" elapsed="0.003620"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:43.842867" elapsed="0.094923"/>
</kw>
<msg time="2026-06-06T03:20:43.937882" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:43.937927" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "B "G "P "_ "P "e "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:43.842243" elapsed="0.095721"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:43.938150" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:43.938041" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.938022" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.938657" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.939005" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:43.939130" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:43.841548" elapsed="0.097724"/>
</kw>
<msg time="2026-06-06T03:20:43.939374" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:43.939419" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "f "i "g "u "r "e "_ "B "G "P "_ "P "e "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:43.836289" elapsed="0.103168"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:43.939808" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:43.939533" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.939515" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:43.836140" elapsed="0.103771"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:43.835957" elapsed="0.103985"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:43.833441" elapsed="0.106557"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:43.827613" elapsed="0.112442"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:43.827152" elapsed="0.112948"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:43.823806" elapsed="0.116348"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.941150" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-ibgp-peer1 | IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=ibgp | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPEN...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-ibgp-peer1</arg>
<arg>IP=${iBGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=ibgp</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=false</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.940329" elapsed="0.000850"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.979101" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:43.978719" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:43.979949" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:43.979689" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:43.980126" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:43.979333" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.980718" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:43.980318" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:43.981048" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:43.981216" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:43.980912" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.981665" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:43.981406" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.982682" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ibgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'false'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:43.982403" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.983198" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.982933" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.983974" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.983670" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.984764" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.984522" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.984842" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:43.984994" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.984192" elapsed="0.000827"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.985178" elapsed="0.000241"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:20:43.983513" elapsed="0.001947"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.986020" level="INFO">${value} = example-ibgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.985722" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.986929" level="INFO">${encoded} = example-ibgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.986716" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.987006" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:43.987155" level="INFO">${encoded_value} = example-ibgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.986234" elapsed="0.000946"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.987361" elapsed="0.000224"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-ibgp-peer1</var>
<status status="PASS" start="2026-06-06T03:20:43.985570" elapsed="0.002056"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.988187" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.987891" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.988950" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.988738" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.989025" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:43.989172" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.988403" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.989351" elapsed="0.000219"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:20:43.987754" elapsed="0.001856"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.990171" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.989874" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.990933" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.990722" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.991009" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:43.991157" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.990385" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.991359" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:20:43.989738" elapsed="0.001883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.992195" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.991885" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.992969" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.992754" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.993046" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:43.993196" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.992416" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.993413" elapsed="0.000240"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:20:43.991748" elapsed="0.001949"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.994243" level="INFO">${value} = ibgp</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.993947" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.995009" level="INFO">${encoded} = ibgp</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.994798" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.995086" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:43.995234" level="INFO">${encoded_value} = ibgp</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.994457" elapsed="0.000821"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.995437" elapsed="0.000240"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">ibgp</var>
<status status="PASS" start="2026-06-06T03:20:43.993810" elapsed="0.001909"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.996264" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.995968" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.997233" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.996820" elapsed="0.000440"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.997313" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:20:43.997467" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.996477" elapsed="0.001015"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.997670" elapsed="0.000227"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:20:43.995831" elapsed="0.002107"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:43.998505" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:43.998191" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:43.999310" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.999061" elapsed="0.000281"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:43.999393" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:43.999543" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:43.998740" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:43.999741" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:43.998053" elapsed="0.001952"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.000561" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.000253" elapsed="0.000333"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.001336" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.001125" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.001411" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.001559" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.000803" elapsed="0.000780"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.001756" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:44.000116" elapsed="0.001903"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.002561" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.002264" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.003354" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.003110" elapsed="0.000290"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.003451" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.003601" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.002790" elapsed="0.000835"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.003798" elapsed="0.000269"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.002128" elapsed="0.001981"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.004677" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.004365" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.005422" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.005211" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.005498" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.005664" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.004893" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.005847" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.004226" elapsed="0.001885"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.006683" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.006365" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.007441" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.007217" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.007517" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.007680" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.006898" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.007863" elapsed="0.000221"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:20:44.006222" elapsed="0.001903"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:43.983313" elapsed="0.024846"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:44.008210" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:44.008374" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ibgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:43.982076" elapsed="0.026325"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:43.981779" elapsed="0.026654"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.008620" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.008461" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:43.981760" elapsed="0.026954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.009892" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:44.008869" elapsed="0.001053"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.009972" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:43.978078" elapsed="0.032019"/>
</kw>
<msg time="2026-06-06T03:20:44.010153" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:43.963704" elapsed="0.046498"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.024160" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.038242" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.052282" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.052495" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.052696" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.053096" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.052941" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:44.052924" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.053331" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.053503" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.053688" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:44.052889" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.052781" elapsed="0.000988"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.053920" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.053997" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:20:44.054136" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:43.958930" elapsed="0.095233"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.089547" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.089136" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.090395" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.090133" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.090568" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.089784" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.091171" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.090781" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.091546" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:44.091741" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:44.091365" elapsed="0.000478"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.092267" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;$RR_CLIENT&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.092012" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:44.092757" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.092411" elapsed="0.000409"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.093309" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ibgp-peer1', 'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ibgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.093000" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.092848" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.092385" elapsed="0.001010"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.094434" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:44.093549" elapsed="0.000916"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.094521" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:44.088488" elapsed="0.006186"/>
</kw>
<msg time="2026-06-06T03:20:44.094736" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:44.071078" elapsed="0.023706"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.108898" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.122696" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.136548" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.136764" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.136946" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.137385" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.137232" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:44.137217" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.137612" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.137804" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.137977" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:44.137186" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.137072" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.138210" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.138286" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:44.138419" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:44.066024" elapsed="0.072424"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.140182" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.139639" elapsed="0.000671">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.140498" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.139133" elapsed="0.001411"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.140892" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.140617" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.141462" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.141163" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.140975" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.140598" elapsed="0.000947"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.144157" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.141720" elapsed="0.002464"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:44.144236" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.144389" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:44.138801" elapsed="0.005612"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.145896" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.145624" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.146337" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.146101" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.146857" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.146594" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.147294" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.147055" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:44.148195" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:20:44.147995" elapsed="0.000225"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:20:44.148551" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:20:44.148377" elapsed="0.000200"/>
</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-06-06T03:20:44.148746" elapsed="0.000217"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.149368" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.149122" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:20:44.149456" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.149614" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:20:44.147566" elapsed="0.002086"/>
</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-06-06T03:20:44.169106" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '1075', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:20:44.169175" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:20:44 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:44.169266" 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-06-06T03:20:44.152271" elapsed="0.017020"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.149726" elapsed="0.019611"/>
</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-06-06T03:20:44.169524" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.169364" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.149708" elapsed="0.019905"/>
</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-06-06T03:20:44.173227" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.170574" elapsed="0.002697"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.170349" elapsed="0.002956"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.170331" elapsed="0.002999"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.176374" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.173610" elapsed="0.002810"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.173386" elapsed="0.003068"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.173369" elapsed="0.003110"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.177042" 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-06-06T03:20:44.176661" elapsed="0.000408"/>
</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-06-06T03:20:44.177385" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.177140" elapsed="0.000343"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.178001" 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-06-06T03:20:44.177698" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.177508" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.177121" elapsed="0.000964"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.178618" 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-06-06T03:20:44.178251" elapsed="0.000409"/>
</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-06-06T03:20:44.178974" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.178733" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.179552" 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-06-06T03:20:44.179222" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.179056" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.178714" elapsed="0.000939"/>
</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-06-06T03:20:44.179811" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:44.180614" 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-06-06T03:20:44.180332" elapsed="0.000324"/>
</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-06-06T03:20:44.180819" elapsed="0.002734"/>
</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-06-06T03:20:44.169996" elapsed="0.013627"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:44.183822" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:44.183714" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.183693" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:20:44.184060" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.184127" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:44.186668" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:20:44.144764" elapsed="0.041932"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.186759" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.186915" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:43.946726" elapsed="0.240213"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.187276" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.187037" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.187020" elapsed="0.000347"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.187400" elapsed="0.000025"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:20:43.941471" elapsed="0.246078"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.188781" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-ebgp-peer1 | IP=127.0.0.3 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=ebgp | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPEN...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-ebgp-peer1</arg>
<arg>IP=${eBGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=ebgp</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=false</arg>
<arg>AS_NUMBER=${eBGP_PEER1_AS}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.187739" elapsed="0.001072"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.225806" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.225415" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.226591" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.226336" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.226767" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.226000" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.227342" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.226960" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.227726" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:44.227866" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:44.227532" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.228300" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.228056" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.229314" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer1', 'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ebgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'false', 'AS_NUMBER': '32768'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.229052" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.229804" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.229522" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.230497" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.230203" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.231269" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.231051" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.231345" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.231493" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.230728" elapsed="0.000790"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.231707" elapsed="0.000226"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:20:44.230065" elapsed="0.001909"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.232515" level="INFO">${value} = example-ebgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.232221" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.234512" level="INFO">${encoded} = example-ebgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.234299" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.234590" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.234758" level="INFO">${encoded_value} = example-ebgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.233968" elapsed="0.000815"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.234940" elapsed="0.000225"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-ebgp-peer1</var>
<status status="PASS" start="2026-06-06T03:20:44.232085" elapsed="0.003121"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.235796" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.235453" elapsed="0.000369"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.236583" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.236367" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.236681" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.236831" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.236045" elapsed="0.000811"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.237012" elapsed="0.000222"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:20:44.235317" elapsed="0.001958"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.237836" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.237520" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.238582" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.238372" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.238673" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.238824" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.238050" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.239004" elapsed="0.000220"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:20:44.237385" elapsed="0.001879"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.239841" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.239510" elapsed="0.000357"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.240584" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.240374" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.240676" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:44.240827" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.240054" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.241007" elapsed="0.000222"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:20:44.239375" elapsed="0.001894"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.241832" level="INFO">${value} = ebgp</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.241518" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.242579" level="INFO">${encoded} = ebgp</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.242366" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.242671" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:44.242824" level="INFO">${encoded_value} = ebgp</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.242046" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.243002" elapsed="0.000222"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">ebgp</var>
<status status="PASS" start="2026-06-06T03:20:44.241382" elapsed="0.001883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.243858" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.243511" elapsed="0.000373"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.244602" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.244391" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.244693" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:44.244843" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.244072" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.245021" elapsed="0.000412"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:20:44.243375" elapsed="0.002100"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.246048" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.245747" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.246861" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.246633" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.246937" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.247087" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.246310" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.247267" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.245588" elapsed="0.001941"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.248111" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.247815" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.248870" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.248658" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.248946" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.249094" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.248322" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.249273" elapsed="0.000219"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:44.247671" elapsed="0.001861"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.250098" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.249801" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.250852" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.250628" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.250927" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.251076" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.250310" elapsed="0.000790"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.251254" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.249659" elapsed="0.002026"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.252235" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.251937" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.252997" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.252784" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.253072" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.253221" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.252448" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.253399" elapsed="0.000226"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.251799" elapsed="0.001881"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.254226" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.253930" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.254983" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.254772" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.255058" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.255206" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.254437" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.255383" elapsed="0.000235"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:20:44.253795" elapsed="0.001878"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.256221" level="INFO">${value} = 32768</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.255923" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.257222" level="INFO">${encoded} = 32768</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.256998" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.257298" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.257448" level="INFO">${encoded_value} = 32768</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.256473" elapsed="0.001000"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.257629" elapsed="0.000240"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">32768</var>
<status status="PASS" start="2026-06-06T03:20:44.255787" elapsed="0.002123"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:44.229877" elapsed="0.028068"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:44.257987" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:44.258148" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer1', 'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ebgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:44.228723" elapsed="0.029451"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.228412" elapsed="0.029794"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.258384" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.258231" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.228392" elapsed="0.030069"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.259370" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:44.258606" elapsed="0.000793"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.259449" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:44.224795" elapsed="0.034779"/>
</kw>
<msg time="2026-06-06T03:20:44.259672" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:44.210754" elapsed="0.048972"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.273585" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.287544" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.301797" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.301997" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.302175" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.302541" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.302393" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:44.302378" elapsed="0.000298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.302829" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.303003" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.303174" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:44.302350" elapsed="0.000877"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.302249" elapsed="0.001004"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.303404" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.303480" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:20:44.303605" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:44.206063" elapsed="0.097569"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.333428" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.333031" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.334259" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.334002" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.334432" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.333658" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.335036" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.334630" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.335374" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:44.335556" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:44.335231" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.336027" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;$AS_NUMBER&lt;/peer-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.335779" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:44.336486" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.336167" elapsed="0.000378"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.337053" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer1', 'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ebgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.336742" elapsed="0.000400"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.336575" elapsed="0.000606"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.336141" elapsed="0.001062"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.338530" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:44.337359" elapsed="0.001202"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.338616" elapsed="0.000052"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:44.332387" elapsed="0.006387"/>
</kw>
<msg time="2026-06-06T03:20:44.338834" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:44.318122" elapsed="0.020760"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.352819" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.366819" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.380966" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.381185" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.381369" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.381789" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.381622" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:44.381606" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.382016" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.382188" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.382367" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:44.381573" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.381459" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.382600" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.382692" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:20:44.382830" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:44.314998" elapsed="0.067915"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.384278" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.383997" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.384447" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.383607" elapsed="0.000864"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.384813" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.384543" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.385378" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.385085" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.384895" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.384524" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.388056" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.385616" elapsed="0.002466"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:44.388135" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.388288" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:44.383264" elapsed="0.005049"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.389728" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.389463" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.390173" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;32768&lt;/peer-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.389935" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.390627" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.390385" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.391082" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.390843" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:44.391971" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:20:44.391755" elapsed="0.000243"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:20:44.392329" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:20:44.392156" elapsed="0.000199"/>
</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-06-06T03:20:44.392508" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.393287" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.393041" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:20:44.393374" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.393694" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:20:44.391329" elapsed="0.002392"/>
</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-06-06T03:20:44.409890" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '961', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;32768&lt;/peer-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:20:44.409954" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:44.410064" 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-06-06T03:20:44.396368" elapsed="0.013722"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.393837" elapsed="0.016299"/>
</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-06-06T03:20:44.410323" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.410162" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.393817" elapsed="0.016595"/>
</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-06-06T03:20:44.414035" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.411382" elapsed="0.002697"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.411158" elapsed="0.002956"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.411139" elapsed="0.003000"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.417070" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.414421" elapsed="0.002694"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.414195" elapsed="0.002955"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.414178" elapsed="0.002997"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.417740" 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-06-06T03:20:44.417344" elapsed="0.000424"/>
</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-06-06T03:20:44.418082" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.417839" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.418625" 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-06-06T03:20:44.418328" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.418163" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.417821" elapsed="0.000905"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.419251" 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-06-06T03:20:44.418890" elapsed="0.000388"/>
</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-06-06T03:20:44.419586" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.419348" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.420175" 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-06-06T03:20:44.419879" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.419683" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.419329" elapsed="0.000929"/>
</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-06-06T03:20:44.420411" elapsed="0.000360"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:44.421257" 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-06-06T03:20:44.420974" elapsed="0.000309"/>
</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-06-06T03:20:44.421443" elapsed="0.002657"/>
</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-06-06T03:20:44.410801" elapsed="0.013363"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:44.424337" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:20:44.424232" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.424212" elapsed="0.000210"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:20:44.424575" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.424658" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:20:44.427191" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:20:44.388663" elapsed="0.038554"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.427282" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:44.427435" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:44.193942" elapsed="0.233518"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.427840" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.427558" elapsed="0.000354"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.427541" elapsed="0.000395"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.427969" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ebgp_peers</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:20:44.189099" elapsed="0.238994"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.429128" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-ebgp-peer2 | IP=127.0.0.4 | HOLDTIME=180 | PEER_PORT=17900 | PEER_ROLE=ebgp | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPEN...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-ebgp-peer2</arg>
<arg>IP=${eBGP_PEER2_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PEER_ROLE=ebgp</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>RR_CLIENT=false</arg>
<arg>AS_NUMBER=${eBGP_PEER2_AS}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.428266" elapsed="0.000891"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.466259" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.465884" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.467009" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.466804" elapsed="0.000268">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.467165" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.466453" elapsed="0.000736"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.467756" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.467355" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.468114" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:44.468255" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:44.467977" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.468738" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.468476" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.469752" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer2', 'IP': '127.0.0.4', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ebgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'RR_CLIENT': 'false', 'AS_NUMBER': '32768'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.469471" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.470224" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.469962" elapsed="0.000288"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.470936" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.470624" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.471702" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.471469" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.471778" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.471944" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.471150" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.472130" elapsed="0.000224"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:20:44.470486" elapsed="0.001908"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.472950" level="INFO">${value} = example-ebgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.472654" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.473848" level="INFO">${encoded} = example-ebgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.473620" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.473925" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.474072" level="INFO">${encoded_value} = example-ebgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.473160" elapsed="0.000937"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.474252" elapsed="0.000219"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-ebgp-peer2</var>
<status status="PASS" start="2026-06-06T03:20:44.472505" elapsed="0.002007"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.475070" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.474774" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.475825" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.475599" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.475927" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.476077" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.475280" elapsed="0.000821"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.476254" elapsed="0.000219"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:20:44.474622" elapsed="0.001892"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.477069" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.476774" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.477818" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.477593" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.477892" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.478038" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.477277" elapsed="0.000785"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.478215" elapsed="0.000217"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:20:44.476623" elapsed="0.001884"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.479067" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.478771" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.479823" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.479595" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.479914" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.480062" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.479278" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.480240" elapsed="0.000219"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:20:44.478620" elapsed="0.001879"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.481054" level="INFO">${value} = ebgp</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.480759" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.481927" level="INFO">${encoded} = ebgp</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.481586" elapsed="0.000367"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.482002" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.482149" level="INFO">${encoded_value} = ebgp</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.481266" elapsed="0.000907"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.482326" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_ROLE</var>
<var name="${value}">ebgp</var>
<status status="PASS" start="2026-06-06T03:20:44.480609" elapsed="0.001979"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.483147" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.482851" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.484119" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.483699" elapsed="0.000447"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.484198" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:44.484349" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.483358" elapsed="0.001014"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.484529" elapsed="0.000238"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:20:44.482715" elapsed="0.002093"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.485347" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.485052" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.486103" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.485893" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.486178" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.486325" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.485559" elapsed="0.000790"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.486502" elapsed="0.000241"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.484918" elapsed="0.001866"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.487324" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.487030" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.488098" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.487871" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.488174" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.488321" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.487536" elapsed="0.000810"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.488500" elapsed="0.000233"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:20:44.486895" elapsed="0.001921"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.489360" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.489066" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.490119" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.489910" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.490196" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.490343" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.489574" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.490521" elapsed="0.000235"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.488930" elapsed="0.001868"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.491339" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.491044" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.492137" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.491922" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.492214" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.492362" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.491552" elapsed="0.000835"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.492541" elapsed="0.000255"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:20:44.490909" elapsed="0.001928"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.493378" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.493083" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.494138" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.493928" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.494215" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.494361" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.493590" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.494539" elapsed="0.000240"/>
</kw>
<var name="${key}">RR_CLIENT</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:20:44.492948" elapsed="0.001871"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.495538" level="INFO">${value} = 32768</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:20:44.495063" elapsed="0.000501"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:20:44.496318" level="INFO">${encoded} = 32768</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.496109" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:20:44.496394" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.496541" level="INFO">${encoded_value} = 32768</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:20:44.495776" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:20:44.496737" elapsed="0.000221"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">32768</var>
<status status="PASS" start="2026-06-06T03:20:44.494929" elapsed="0.002070"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:20:44.470298" elapsed="0.026735"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:20:44.497075" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:20:44.497234" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer2', 'IP': '127.0.0.4', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ebgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:20:44.469143" elapsed="0.028118"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.468849" elapsed="0.028443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.497468" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.497318" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.468831" elapsed="0.028712"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.498452" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:44.497704" elapsed="0.000823"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.498581" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:44.465251" elapsed="0.033472"/>
</kw>
<msg time="2026-06-06T03:20:44.498779" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:44.451099" elapsed="0.047726"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.512867" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.526620" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.540412" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.540610" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.540806" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.541168" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.541021" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:44.541006" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.541392" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.541565" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.541751" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:44.540979" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.540882" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.541979" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.542054" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:44.542173" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:44.446410" elapsed="0.095790"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.571806" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.571408" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.572576" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.572370" elapsed="0.000288">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.572755" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.572027" elapsed="0.000753"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.573331" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.572948" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.573675" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:20:44.573804" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:20:44.573522" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.574233" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;$AS_NUMBER&lt;/peer-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.573992" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:20:44.574661" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.574357" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.575192" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer2', 'IP': '127.0.0.4', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PEER_ROLE': 'ebgp', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', '...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.574895" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.574746" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.574338" elapsed="0.000937"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.576268" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:20:44.575422" elapsed="0.000876"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.576347" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:20:44.570781" elapsed="0.005689"/>
</kw>
<msg time="2026-06-06T03:20:44.576527" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:44.556385" elapsed="0.020189"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.590355" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.604211" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.618160" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.618360" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.618539" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.618922" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.618775" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:20:44.618761" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.619144" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.619314" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.619485" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:20:44.618732" elapsed="0.000805"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.618613" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.619725" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.619803" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:20:44.619937" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:20:44.553495" elapsed="0.066471"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:20:44.621244" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.621014" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:20:44.621398" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.620666" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.621760" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.621492" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.622300" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.622009" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.621841" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.621473" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.625128" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:20:44.622535" elapsed="0.002619"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:20:44.625237" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:20:44.625394" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:20:44.620320" elapsed="0.005099"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.626827" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.626560" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.627266" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;32768&lt;/peer-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.627029" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.627734" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.627477" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.628202" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.627933" elapsed="0.000313"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:44.629060" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:20:44.628874" elapsed="0.000211"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:20:44.629412" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:20:44.629242" elapsed="0.000196"/>
</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-06-06T03:20:44.629589" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.630207" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.629962" elapsed="0.000288"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:20:44.630291" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.630442" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:20:44.628448" elapsed="0.002019"/>
</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-06-06T03:20:44.647014" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '961', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;32768&lt;/peer-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:20:44.647076" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:44.647163" 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-06-06T03:20:44.632843" elapsed="0.014344"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.630536" elapsed="0.016695"/>
</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-06-06T03:20:44.647446" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.647285" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.630518" elapsed="0.017016"/>
</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-06-06T03:20:44.651282" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.648513" elapsed="0.002813"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.648290" elapsed="0.003071"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.648271" elapsed="0.003114"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.654292" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.651681" elapsed="0.002658"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.651442" elapsed="0.002931"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.651424" elapsed="0.002973"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.654960" 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-06-06T03:20:44.654565" elapsed="0.000422"/>
</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-06-06T03:20:44.655301" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.655058" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.655864" 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-06-06T03:20:44.655547" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.655383" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.655039" elapsed="0.000907"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.656499" 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-06-06T03:20:44.656138" elapsed="0.000388"/>
</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-06-06T03:20:44.656851" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.656594" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.657388" 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-06-06T03:20:44.657096" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:20:44.656931" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.656576" elapsed="0.000893"/>
</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-06-06T03:20:44.657627" elapsed="0.000357"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:20:44.658421" 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-06-06T03:20:44.658151" elapsed="0.000295"/>
</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-06-06T03:20:44.658603" elapsed="0.002644"/>
</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-06-06T03:20:44.647912" elapsed="0.013397"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:20:44.661478" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:44.661374" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.661356" elapsed="0.000206"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:20:44.661729" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.661797" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:20:44.664340" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:20:44.625765" elapsed="0.038601"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.664430" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:20:44.664581" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:20:44.434305" elapsed="0.230300"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.664953" elapsed="0.000060"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.664718" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.664700" elapsed="0.000384"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:20:44.665117" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ebgp_peers</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:20:44.429445" elapsed="0.235795"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:44.665847" elapsed="0.000240"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:44.665520" elapsed="0.000631"/>
</kw>
<doc>Configure an iBGP and two eBGP peers</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:43.823209" elapsed="0.842981"/>
</test>
<test id="s1-s9-t2" name="Connect_iBGP_Peer1" line="144">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:44.669684" elapsed="0.000207"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:44.669394" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.670939" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:44.670830" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.670811" elapsed="0.000196"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.677621" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:44.677514" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.677497" elapsed="0.000210"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.678718" 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-06-06T03:20:44.678322" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.679204" 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-06-06T03:20:44.678908" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:44.679273" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:20:44.679425" 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-06-06T03:20:44.677943" elapsed="0.001507"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:44.685414" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:44.685308" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.685289" elapsed="0.000193"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:44.686674" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:44.686545" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.686526" elapsed="0.000219"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:44.687188" 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-06-06T03:20:44.686892" elapsed="0.000323"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:44.687595" level="INFO">${current_connection_index} = 9</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-06-06T03:20:44.687376" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:44.716516" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:44.688172" elapsed="0.028542"/>
</kw>
<msg time="2026-06-06T03:20:44.716885" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:44.716932" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:44.687809" elapsed="0.029160"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:44.738001" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:20:44.717507" elapsed="0.020597"/>
</kw>
<msg time="2026-06-06T03:20:44.738296" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:44.738343" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "...</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-06-06T03:20:44.717147" elapsed="0.021233"/>
</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-06-06T03:20:44.738708" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.738458" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.738438" elapsed="0.000351"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.739231" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:20:44.738932" elapsed="0.000364"/>
</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-06-06T03:20:44.739582" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.739362" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.739344" elapsed="0.000339"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:44.739717" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:44.742421" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:20:44.742629" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:44.741353" elapsed="0.001424"/>
</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="NOT RUN" start="2026-06-06T03:20:44.743061" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.743395" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:44.740549" elapsed="0.003030"/>
</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-06-06T03:20:44.739982" elapsed="0.003683"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:44.686242" elapsed="0.057524"/>
</kw>
<msg time="2026-06-06T03:20:44.743857" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:44.743901" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:44.685635" elapsed="0.058303"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:44.744315" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:20:44.744014" elapsed="0.000364"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.743995" elapsed="0.000408"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.744822" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.745154" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:44.745226" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:44.684972" elapsed="0.060360"/>
</kw>
<msg time="2026-06-06T03:20:44.745423" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:44.745466" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:44.679829" elapsed="0.065674"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:44.745848" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:44.745576" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:44.745559" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:44.679683" elapsed="0.066266"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:44.679499" elapsed="0.066477"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:44.677149" elapsed="0.068878"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:44.670526" elapsed="0.075555"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:44.670100" elapsed="0.076061"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:44.667030" elapsed="0.079184"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:44.746371" elapsed="0.000106"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.755966" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 0 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:44.755625" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.756422" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 0 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.756155" elapsed="0.000314"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:44.760422" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 0 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log</msg>
<msg time="2026-06-06T03:20:44.760518" level="INFO">${output} =  python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 0 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:44.756624" elapsed="0.003921"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:44.760970" level="INFO"> python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 0 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer1.log &amp;&gt;bgp_peer1.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:44.760724" elapsed="0.000293"/>
</kw>
<arg>${iBGP_PEER1_COMMAND}</arg>
<arg>${iBGP_PEER1_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:20:44.755243" elapsed="0.005829"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:20:54.763216" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.762686" elapsed="10.001279">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.764298" elapsed="0.000032"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:20:44.762397" elapsed="10.002054">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:20:44.761995" elapsed="10.002587"/>
</kw>
<msg time="2026-06-06T03:20:54.764722" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:44.761620" elapsed="10.003130"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:20:54.764943" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:20:54.764845" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.764819" elapsed="0.000210"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.765266" elapsed="0.000027"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.765458" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:20:44.761339" elapsed="10.004201"/>
</kw>
<kw name="Check_Example_IPv4_Topology_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:20:54.774773" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:20:54.774910" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Set-Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:20:54 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:20:54.775027" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:20:54.766217" elapsed="0.008838"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.778442" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:54.775227" elapsed="0.003282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.782677" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:54.778885" elapsed="0.003863"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:20:54.782987" elapsed="0.003683"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Check the example-ipv4-topology does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:20:54.765789" elapsed="0.020947"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:20:54.787349" elapsed="0.000253"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:20:54.787032" elapsed="0.000651"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:44.666524" elapsed="10.121198"/>
</test>
<test id="s1-s9-t3" name="Connect_eBGP_Peer1" line="152">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:20:54.791217" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:20:54.790948" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:54.792506" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:54.792390" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.792370" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:20:54.798160" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:54.798052" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.798033" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.799253" 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-06-06T03:20:54.798866" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.799767" 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-06-06T03:20:54.799448" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:20:54.799839" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:20:54.800000" 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-06-06T03:20:54.798460" elapsed="0.001565"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:20:54.806229" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:54.806119" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.806099" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:20:54.807482" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:20:54.807374" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.807355" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:20:54.808032" 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-06-06T03:20:54.807726" elapsed="0.000333"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:20:54.808444" level="INFO">${current_connection_index} = 7</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-06-06T03:20:54.808225" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:54.836521" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:54.809007" elapsed="0.027611"/>
</kw>
<msg time="2026-06-06T03:20:54.836832" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:20:54.836878" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:20:54.808637" elapsed="0.028277"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:20:54.856811" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:20:54.837437" elapsed="0.019478"/>
</kw>
<msg time="2026-06-06T03:20:54.857074" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:20:54.857158" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "...</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-06-06T03:20:54.837090" elapsed="0.020108"/>
</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-06-06T03:20:54.857528" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:54.857275" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.857255" elapsed="0.000355"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.858079" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:20:54.857779" elapsed="0.000365"/>
</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-06-06T03:20:54.858432" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:54.858212" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.858194" elapsed="0.000316"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:20:54.858543" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:54.861052" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:20:54.861255" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:20:54.860025" elapsed="0.001359"/>
</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="NOT RUN" start="2026-06-06T03:20:54.861755" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.862098" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:20:54.859382" elapsed="0.002902"/>
</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-06-06T03:20:54.858847" elapsed="0.003500"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:20:54.807069" elapsed="0.055376"/>
</kw>
<msg time="2026-06-06T03:20:54.862536" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:54.862580" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:54.806457" elapsed="0.056161"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:20:54.862828" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:20:54.862718" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.862698" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.863307" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.863660" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:20:54.863734" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:20:54.805767" elapsed="0.058074"/>
</kw>
<msg time="2026-06-06T03:20:54.863933" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:20:54.863976" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:20:54.800403" elapsed="0.063609"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:20:54.864340" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:20:54.864085" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:20:54.864068" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:20:54.800254" elapsed="0.064187"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:20:54.800079" elapsed="0.064391"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:20:54.797684" elapsed="0.066838"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:20:54.792095" elapsed="0.072480"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:20:54.791652" elapsed="0.073019"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:20:54.788546" elapsed="0.076180"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ebgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:20:54.864883" elapsed="0.000106"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.874768" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 1.1.1.1 --asnumber 32768 --debug --logfile ebgp_peer1.lo...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:20:54.874422" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.875199" level="INFO">python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 1.1.1.1 --asnumber 32768 --debug --logfile ebgp_peer1.log &amp;&gt;ebgp_peer1.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:54.874956" elapsed="0.000289"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:20:54.879288" level="INFO">python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 1.1.1.1 --asnumber 32768 --debug --logfile ebgp_peer1.log &amp;&gt;ebgp_peer1.log</msg>
<msg time="2026-06-06T03:20:54.879380" level="INFO">${output} =  python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 1.1.1.1 --asnumber 32768 --debug --logfile ebgp_peer1.l...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:20:54.875400" elapsed="0.004006"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:20:54.879832" level="INFO"> python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 1.1.1.1 --asnumber 32768 --debug --logfile ebgp_peer1.log &amp;&gt;ebgp_peer1.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:20:54.879568" elapsed="0.000311"/>
</kw>
<arg>${eBGP_PEER1_COMMAND}</arg>
<arg>${eBGP_PEER1_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:20:54.874035" elapsed="0.005900"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:21:04.882110" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:20:54.881572" elapsed="10.001331">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.883232" elapsed="0.000032"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:20:54.881252" elapsed="10.002134">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:20:54.880847" elapsed="10.002663"/>
</kw>
<msg time="2026-06-06T03:21:04.883627" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:20:54.880471" elapsed="10.003198"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:21:04.883860" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:21:04.883766" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.883738" elapsed="0.000211"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.884190" elapsed="0.000027"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.884373" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:20:54.880191" elapsed="10.004262"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:21:04.885132" elapsed="0.000309"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:21:04.884758" elapsed="0.000750"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:20:54.788094" elapsed="10.097453"/>
</test>
<test id="s1-s9-t4" name="Check_IPv4_Topology_For_First_Path" line="159">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:21:04.889667" elapsed="0.000218"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:21:04.889371" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:04.891023" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:04.890900" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.890880" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:04.896963" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:04.896697" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.896676" elapsed="0.000367"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:21:04.898126" 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-06-06T03:21:04.897709" elapsed="0.000446"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:21:04.898633" 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-06-06T03:21:04.898325" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:21:04.898723" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:21:04.898900" 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-06-06T03:21:04.897296" elapsed="0.001630"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:21:04.904947" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:04.904836" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.904816" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:21:04.906224" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:04.906114" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.906095" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:21:04.906811" 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-06-06T03:21:04.906449" elapsed="0.000389"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:21:04.907229" level="INFO">${current_connection_index} = 8</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-06-06T03:21:04.907006" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:04.936474" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:04.907787" elapsed="0.028974"/>
</kw>
<msg time="2026-06-06T03:21:04.937129" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:21:04.937234" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:21:04.907423" elapsed="0.029893"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:21:04.960389" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "_ "F "o "r "_ "F "i "r "s "t "_ "P "a "t "h "[K"
[?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-06-06T03:21:04.938548" elapsed="0.022122"/>
</kw>
<msg time="2026-06-06T03:21:04.960919" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:21:04.960972" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "...</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-06-06T03:21:04.937749" elapsed="0.023263"/>
</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-06-06T03:21:04.961487" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:04.961133" elapsed="0.000417"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.961095" elapsed="0.000483"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:04.962170" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "_ "F "o "r "_ "F "i "r "s "t "_ "P "a "t "h "[K"
[?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-06-06T03:21:04.961758" elapsed="0.000494"/>
</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-06-06T03:21:04.962569" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:04.962330" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.962310" elapsed="0.000359"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:21:04.962712" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:04.965736" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:21:04.965971" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:21:04.964434" elapsed="0.001681"/>
</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="NOT RUN" start="2026-06-06T03:21:04.966692" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.967268" elapsed="0.000082"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:21:04.963763" elapsed="0.003705"/>
</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-06-06T03:21:04.963122" elapsed="0.004414"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:21:04.905807" elapsed="0.061848"/>
</kw>
<msg time="2026-06-06T03:21:04.967765" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:04.967812" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:04.905173" elapsed="0.062681"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:21:04.968074" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:21:04.967947" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.967920" elapsed="0.000246"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.968629" elapsed="0.000043"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.969005" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:21:04.969078" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:21:04.904480" elapsed="0.064710"/>
</kw>
<msg time="2026-06-06T03:21:04.969293" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:04.969340" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:21:04.899310" elapsed="0.070069"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:04.969753" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:04.969459" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:04.969441" elapsed="0.000392"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:21:04.899161" elapsed="0.070698"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:21:04.898983" elapsed="0.070912"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:21:04.896285" elapsed="0.073672"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:21:04.890545" elapsed="0.079475"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:04.890102" elapsed="0.079969"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:21:04.886622" elapsed="0.083508"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:04.977839" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:04.978001" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:04.978132" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:04.971519" elapsed="0.006642"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:04.982846" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:04.978403" elapsed="0.004521"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:04.987286" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:04.983181" elapsed="0.004233"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:04.990482" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:04.987579" elapsed="0.002985">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:04.971066" elapsed="0.019637">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:05.998275" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:05.998469" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:05.998617" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:05.991986" elapsed="0.006700"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:06.002939" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:05.998948" elapsed="0.004059"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:06.007080" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:06.003255" elapsed="0.003895"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:06.010794" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:06.007440" elapsed="0.003431">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:05.991370" elapsed="0.019617">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:07.021621" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:07.021845" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:07.021995" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:07.013034" elapsed="0.008998"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:07.026144" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:07.022290" elapsed="0.003938"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:07.030230" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:07.026461" elapsed="0.003835"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:07.034221" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:07.030688" elapsed="0.003609">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:07.011915" elapsed="0.022498">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:08.044890" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:08.045125" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:08.045317" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:08.036594" elapsed="0.008773"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:08.049473" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:08.045629" elapsed="0.003911"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:08.053511" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:08.049790" elapsed="0.003768"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:08.056560" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:08.053736" elapsed="0.002896">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:08.035414" elapsed="0.021346">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:09.067011" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:09.067219" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:09.067398" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:09.058740" elapsed="0.008699"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:09.071945" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:09.067754" elapsed="0.004265"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:09.078531" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:09.072295" elapsed="0.006342"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:09.083521" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:09.079004" elapsed="0.004630">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:09.057617" elapsed="0.026222">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:10.093599" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:10.093828" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:10.093987" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:10.086030" elapsed="0.008073"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:10.098958" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:10.094394" elapsed="0.004633"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:10.103383" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:10.099262" elapsed="0.004192"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:10.108258" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:10.103760" elapsed="0.004635">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:10.084794" elapsed="0.023814">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:11.119711" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:11.119922" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:11.120128" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:11.110910" elapsed="0.009270"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:11.124462" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:11.120437" elapsed="0.004132"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:11.128977" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:11.124924" elapsed="0.004120"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:11.132620" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:11.129270" elapsed="0.003444">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:11.109603" elapsed="0.023231">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:12.143233" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:12.143511" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:12.143689" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:12.134909" elapsed="0.008820"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:12.147999" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:12.143982" elapsed="0.004084"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:12.151959" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:12.148332" elapsed="0.003675"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:12.155358" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:12.152168" elapsed="0.003264">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:12.133780" elapsed="0.021830">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:13.166413" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:13.166699" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:13.166854" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:13.157739" elapsed="0.009164"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:13.171332" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:13.167198" elapsed="0.004205"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:13.175663" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:13.171674" elapsed="0.004040"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:13.178690" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:13.175878" elapsed="0.002893">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:13.156543" elapsed="0.022347">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:14.189575" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:14.189802" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:14.189957" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:14.180975" elapsed="0.009022"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:14.194406" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:14.190268" elapsed="0.004207"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:14.198780" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:14.194739" elapsed="0.004110"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:14.203316" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:14.199083" elapsed="0.004337">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:14.179864" elapsed="0.023725">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:15.212937" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:15.213296" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:15.213514" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:15.205368" elapsed="0.008202"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.219939" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:15.213972" elapsed="0.006045"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.223315" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:15.220359" elapsed="0.003006"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.226887" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:15.223534" elapsed="0.003456">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:15.204492" elapsed="0.022651">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<msg time="2026-06-06T03:21:15.227266" level="FAIL">Keyword 'BgpOperations.Check_Example_IPv4_Topology_Content' failed after retrying for 10 seconds. The last error was: '{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</msg>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER1_NEXT_HOP}"</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:21:04.970322" elapsed="10.257074">Keyword 'BgpOperations.Check_Example_IPv4_Topology_Content' failed after retrying for 10 seconds. The last error was: '{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<arg>${CONFIG_SESSION}</arg>
<arg>"prefix":"${eBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="NOT RUN" start="2026-06-06T03:21:15.227791" elapsed="0.000039"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.229886" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:21:15.229434" elapsed="0.000512"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:21:15.228894" elapsed="0.001121"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:21:15.228403" elapsed="0.001687"/>
</kw>
<doc>The IPv4 topology shall contain the route announced by the first eBGP</doc>
<status status="FAIL" start="2026-06-06T03:21:04.885952" elapsed="10.344190">Keyword 'BgpOperations.Check_Example_IPv4_Topology_Content' failed after retrying for 10 seconds. The last error was: '{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"1.1.1.1"'</status>
</test>
<test id="s1-s9-t5" name="iBGP_Check_Log_For_Introduced_Prefixes" line="171">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:21:15.235083" elapsed="0.000316"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:21:15.234709" elapsed="0.000769"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:15.236713" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:15.236551" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.236526" elapsed="0.000279"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:15.242951" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:15.242817" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.242794" elapsed="0.000241"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.244294" 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-06-06T03:21:15.243810" elapsed="0.000515"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.244923" 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-06-06T03:21:15.244539" elapsed="0.000412"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:21:15.244999" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:21:15.245177" 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-06-06T03:21:15.243359" elapsed="0.001848"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:21:15.254241" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:15.254089" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.254060" elapsed="0.000269"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:21:15.256120" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:15.255977" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.255950" elapsed="0.000316"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:21:15.256936" 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-06-06T03:21:15.256473" elapsed="0.000501"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:21:15.257441" level="INFO">${current_connection_index} = 8</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-06-06T03:21:15.257200" elapsed="0.000268"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:15.290892" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:15.258184" elapsed="0.032934"/>
</kw>
<msg time="2026-06-06T03:21:15.291358" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:21:15.291407" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:21:15.257712" elapsed="0.033733"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:21:15.321090" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:21:15.292180" elapsed="0.029181"/>
</kw>
<msg time="2026-06-06T03:21:15.321678" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:21:15.321746" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</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-06-06T03:21:15.291732" elapsed="0.030065"/>
</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-06-06T03:21:15.322354" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:15.321934" elapsed="0.000500"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.321894" elapsed="0.000577"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.323174" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "I "n "t "r "o "d "u "c "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:21:15.322695" elapsed="0.000577"/>
</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-06-06T03:21:15.323671" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:15.323359" elapsed="0.000387"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.323335" elapsed="0.000610"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:21:15.323993" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:15.327508" elapsed="0.000221"/>
</kw>
<msg time="2026-06-06T03:21:15.327823" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:21:15.325930" elapsed="0.002083"/>
</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="NOT RUN" start="2026-06-06T03:21:15.328457" elapsed="0.000103"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:15.328939" elapsed="0.000099"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:21:15.325177" elapsed="0.004007"/>
</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-06-06T03:21:15.324473" elapsed="0.004800"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:21:15.255545" elapsed="0.073862"/>
</kw>
<msg time="2026-06-06T03:21:15.329539" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:15.329601" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:15.254592" elapsed="0.075203"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:21:15.330036" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:21:15.329901" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.329874" elapsed="0.000258"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:15.330619" elapsed="0.000049"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:15.331006" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:21:15.331080" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:21:15.253560" elapsed="0.077643"/>
</kw>
<msg time="2026-06-06T03:21:15.331310" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:15.331358" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:21:15.245745" elapsed="0.085652"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:15.331876" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:15.331494" elapsed="0.000440"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:15.331470" elapsed="0.000490"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:21:15.245567" elapsed="0.086418"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:21:15.245364" elapsed="0.086657"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:21:15.242342" elapsed="0.089739"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:21:15.236231" elapsed="0.095909"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:15.235706" elapsed="0.096491"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:21:15.231398" elapsed="0.100912"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:15.332486" elapsed="0.000139"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.333212" level="INFO">${total_prefix_count} = 2</msg>
<var>${total_prefix_count}</var>
<arg>${eBGP_PEER1_PREFIX_COUNT}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:21:15.332810" elapsed="0.000431"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:15.349713" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:15.363124" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:15.363360" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:15.349462" elapsed="0.013932"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.364183" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:15.363749" elapsed="0.000495"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:15.364897" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:15.365035" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:15.364493" elapsed="0.000634">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:15.348749" elapsed="0.016531">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:16.386497" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:16.400463" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:16.400733" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:16.386296" elapsed="0.014522"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:16.401921" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:16.401234" elapsed="0.000789"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:16.403137" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:16.403359" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:16.402373" elapsed="0.001137">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:16.385748" elapsed="0.018039">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:17.425620" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:17.438825" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:17.439062" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:17.425414" elapsed="0.013705"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:17.440184" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:17.439510" elapsed="0.000774"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:17.441474" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:17.441720" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:17.440631" elapsed="0.001242">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:17.424829" elapsed="0.017281">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:18.462345" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:18.475675" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:18.475840" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:18.462140" elapsed="0.013736"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:18.476566" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:18.476139" elapsed="0.000490"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:18.477269" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:18.477411" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:18.476876" elapsed="0.000630">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:18.461546" elapsed="0.016134">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:19.498829" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:19.512500" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:19.512682" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:19.498609" elapsed="0.014113"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:19.513454" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:19.512995" elapsed="0.000524"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:19.514185" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:19.514328" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:19.513775" elapsed="0.000683">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:19.498046" elapsed="0.016572">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:20.533668" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:20.547137" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:20.547380" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:20.533454" elapsed="0.013984"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:20.548523" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:20.547875" elapsed="0.000750"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:20.549696" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:20.549904" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:20.549016" elapsed="0.001034">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:20.532914" elapsed="0.017369">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:21.572782" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:21.586442" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:21.586842" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:21.572560" elapsed="0.014364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:21.588316" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:21.587416" elapsed="0.001012"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:21.589829" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:21.590169" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:21.588927" elapsed="0.001470">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:21.571960" elapsed="0.018813">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:22.610631" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:22.624258" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:22.624523" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:22.610430" elapsed="0.014153"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:22.625807" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:22.625073" elapsed="0.000846"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:22.627020" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:22.627242" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:22.626294" elapsed="0.001102">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:22.609873" elapsed="0.017812">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:23.650276" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:23.663762" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:23.664116" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:23.650074" elapsed="0.014105"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:23.665577" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:23.664718" elapsed="0.001051"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:23.666847" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:23.667056" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:23.666149" elapsed="0.001052">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:23.649514" elapsed="0.017924">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:24.690018" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:24.704329" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:24.704580" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:24.689752" elapsed="0.014920"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:24.705932" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:24.705098" elapsed="0.000944"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:24.707160" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:24.707378" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:24.706422" elapsed="0.001111">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:24.688971" elapsed="0.018846">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:25.727594" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:25.741335" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:25.741576" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:25.727392" elapsed="0.014238"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:25.742814" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:25.742125" elapsed="0.000795"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:25.744035" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:25.744254" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:25.743316" elapsed="0.001102">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:25.726796" elapsed="0.017887">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:26.766745" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:26.780867" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:26.781148" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:26.766533" elapsed="0.014676"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:26.782395" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:26.781626" elapsed="0.000875"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:26.783565" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:26.783805" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:26.782896" elapsed="0.001055">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:26.765951" elapsed="0.018234">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:27.803227" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:27.816788" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:27.817100" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:27.802999" elapsed="0.014164"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:27.818332" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:27.817622" elapsed="0.000813"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:27.819598" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:27.819849" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:27.818874" elapsed="0.001124">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:27.802385" elapsed="0.017857">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:28.840279" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:28.853941" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:28.854189" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:28.840076" elapsed="0.014174"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:28.855404" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:28.854722" elapsed="0.000781"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:28.856501" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:28.856740" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:28.855880" elapsed="0.001006">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:28.839498" elapsed="0.017620">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:29.878491" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:29.892055" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:29.892285" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:29.878293" elapsed="0.014050"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:29.893624" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:29.892779" elapsed="0.000976"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:29.894872" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:29.895078" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:29.894102" elapsed="0.001121">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:29.877751" elapsed="0.017703">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:30.913921" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:30.927532" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:30.927809" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:30.913726" elapsed="0.014142"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:30.928953" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:30.928270" elapsed="0.000813"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:30.930125" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:30.930355" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:30.929442" elapsed="0.001065">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:30.913180" elapsed="0.017661">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:31.952022" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:31.965446" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:31.965598" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:31.951830" elapsed="0.013805"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:31.966413" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:31.965922" elapsed="0.000592"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:31.967546" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:31.967780" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:31.966911" elapsed="0.001012">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:31.951304" elapsed="0.016962">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:32.988143" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:33.001799" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:33.001982" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:32.987942" elapsed="0.014079"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:33.003025" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:33.002298" elapsed="0.000837"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:33.004261" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:33.004478" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:33.003511" elapsed="0.001119">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:32.987355" elapsed="0.017563">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:34.027280" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:34.041083" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:34.041231" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:34.027087" elapsed="0.014180"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:34.041968" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:34.041524" elapsed="0.000509"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:34.042677" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:34.042812" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:34.042257" elapsed="0.000649">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:34.026556" elapsed="0.016499">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:35.063906" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:35.077443" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:35.077628" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:35.063702" elapsed="0.013990"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:35.078523" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:35.078018" elapsed="0.000608"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:35.079677" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:35.079883" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:35.079010" elapsed="0.001016">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:35.063102" elapsed="0.017154">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:36.100766" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:36.114781" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:36.114979" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:36.100555" elapsed="0.014464"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.115968" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:36.115322" elapsed="0.000748"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.117081" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:36.117280" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:36.116418" elapsed="0.001002">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:36.100025" elapsed="0.017655">0 != 2</status>
</kw>
<msg time="2026-06-06T03:21:36.117880" level="FAIL">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:21:15.333417" elapsed="20.784659">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</status>
</kw>
<kw name="Count_Key_Value_Pairs" owner="BGPcliKeywords">
<var>${count}</var>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>Network Address of Next Hop</arg>
<arg>${eBGP_PEER1_NEXT_HOP}</arg>
<doc>Check file for ${keyword} or ${keyword} ${value} pair and returns number of occurences</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.133800" elapsed="0.000031"/>
</kw>
<kw name="Should Be Equal As Integers" owner="BuiltIn">
<arg>${count}</arg>
<arg>${eBGP_PEER1_PREFIX_COUNT}</arg>
<doc>Fails if objects are unequal after converting them to integers.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.134005" elapsed="0.000021"/>
</kw>
<kw name="Count_Key_Value_Pairs" owner="BGPcliKeywords">
<var>${count}</var>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>Network Address of Next Hop</arg>
<arg>${eBGP_PEER2_NEXT_HOP}</arg>
<doc>Check file for ${keyword} or ${keyword} ${value} pair and returns number of occurences</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.146306" elapsed="0.000104"/>
</kw>
<kw name="Should Be Equal As Integers" owner="BuiltIn">
<arg>${count}</arg>
<arg>0</arg>
<doc>Fails if objects are unequal after converting them to integers.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.146580" elapsed="0.000021"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.148169" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:21:36.147848" elapsed="0.000366"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:21:36.147280" elapsed="0.000985"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:21:36.146924" elapsed="0.001400"/>
</kw>
<doc>Check incomming updates for introduced routes</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:21:15.230659" elapsed="20.917706">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</status>
</test>
<test id="s1-s9-t6" name="Connect_eBGP_Peer2" line="194">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:21:36.152191" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:21:36.151913" elapsed="0.000571"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:36.153569" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:36.153431" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.153408" elapsed="0.000253"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:36.159258" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:36.159149" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.159130" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.160355" 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-06-06T03:21:36.159964" elapsed="0.000419"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.160865" 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-06-06T03:21:36.160548" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:21:36.160936" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:21:36.161098" 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-06-06T03:21:36.159560" elapsed="0.001563"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:21:36.167325" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:36.167214" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.167195" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:21:36.168605" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:36.168498" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.168479" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:21:36.169154" 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-06-06T03:21:36.168853" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:21:36.169585" level="INFO">${current_connection_index} = 7</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-06-06T03:21:36.169346" elapsed="0.000265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:36.200210" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:36.170148" elapsed="0.030173"/>
</kw>
<msg time="2026-06-06T03:21:36.200504" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:21:36.200552" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:21:36.169807" elapsed="0.030783"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:21:36.220875" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:21:36.201157" elapsed="0.019825"/>
</kw>
<msg time="2026-06-06T03:21:36.221211" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:21:36.221259" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "...</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-06-06T03:21:36.200799" elapsed="0.020497"/>
</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-06-06T03:21:36.221625" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:36.221382" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.221359" elapsed="0.000380"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.222196" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:21:36.221888" elapsed="0.000375"/>
</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-06-06T03:21:36.222556" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:36.222332" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.222313" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:21:36.222690" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:36.225392" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:21:36.225601" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:21:36.224255" elapsed="0.001505"/>
</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="NOT RUN" start="2026-06-06T03:21:36.226088" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.226444" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:21:36.223592" elapsed="0.003043"/>
</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-06-06T03:21:36.222990" elapsed="0.003735"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:21:36.168195" elapsed="0.058632"/>
</kw>
<msg time="2026-06-06T03:21:36.226925" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:36.226973" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:36.167561" elapsed="0.059453"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:21:36.227208" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:21:36.227096" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.227076" elapsed="0.000240"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.227813" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.228161" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:21:36.228234" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:21:36.166848" elapsed="0.061498"/>
</kw>
<msg time="2026-06-06T03:21:36.228446" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:36.228497" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:21:36.161505" elapsed="0.067030"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:36.228893" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:36.228612" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:36.228594" elapsed="0.000378"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:21:36.161358" elapsed="0.067639"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:21:36.161179" elapsed="0.067852"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:21:36.158757" elapsed="0.070330"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:21:36.153127" elapsed="0.076016"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:36.152667" elapsed="0.076567"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:21:36.149279" elapsed="0.080012"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ebgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:36.229458" elapsed="0.000111"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.239730" level="INFO">${start_cmd} = python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 2.2.2.2 --asnumber 32768 --debug --logfile ebgp_peer2.lo...</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:21:36.239326" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.240209" level="INFO">python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 2.2.2.2 --asnumber 32768 --debug --logfile ebgp_peer2.log &amp;&gt;ebgp_peer2.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:36.239929" elapsed="0.000331"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:36.244524" level="INFO">python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 2.2.2.2 --asnumber 32768 --debug --logfile ebgp_peer2.log &amp;&gt;ebgp_peer2.log</msg>
<msg time="2026-06-06T03:21:36.244621" level="INFO">${output} =  python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 2.2.2.2 --asnumber 32768 --debug --logfile ebgp_peer2.l...</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:36.240423" elapsed="0.004238"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:36.245077" level="INFO"> python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 2 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --nexthop 2.2.2.2 --asnumber 32768 --debug --logfile ebgp_peer2.log &amp;&gt;ebgp_peer2.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:36.244829" elapsed="0.000296"/>
</kw>
<arg>${eBGP_PEER2_COMMAND}</arg>
<arg>${eBGP_PEER2_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:21:36.238890" elapsed="0.006291"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:21:46.247465" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:21:36.246859" elapsed="10.001364">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.248554" elapsed="0.000031"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:21:36.246527" elapsed="10.002194">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:21:36.246115" elapsed="10.002736"/>
</kw>
<msg time="2026-06-06T03:21:46.248987" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:21:36.245749" elapsed="10.003265"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:21:46.249202" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:21:46.249111" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.249084" elapsed="0.000202"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.249514" elapsed="0.000026"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.249713" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:21:36.245448" elapsed="10.004353"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:21:46.250496" elapsed="0.000324"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:21:46.250096" elapsed="0.000789"/>
</kw>
<doc>Connect BGP peer and check empty topology</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:21:36.148760" elapsed="10.102163"/>
</test>
<test id="s1-s9-t7" name="Disconnect_eBGP_Peer1" line="201">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:21:46.254848" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:21:46.254554" elapsed="0.000565"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:46.256149" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:46.256026" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.256007" elapsed="0.000210"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:46.261855" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:46.261748" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.261727" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:21:46.262959" 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-06-06T03:21:46.262553" elapsed="0.000434"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:21:46.263452" 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-06-06T03:21:46.263154" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:21:46.263523" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:21:46.263695" 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-06-06T03:21:46.262167" elapsed="0.001553"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:21:46.269693" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:46.269568" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.269549" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:21:46.270985" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:46.270876" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.270856" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:21:46.271514" 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-06-06T03:21:46.271204" elapsed="0.000337"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:21:46.271948" level="INFO">${current_connection_index} = 9</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-06-06T03:21:46.271727" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:46.302840" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:46.272483" elapsed="0.030455"/>
</kw>
<msg time="2026-06-06T03:21:46.303116" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:21:46.303164" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:21:46.272140" elapsed="0.031060"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:21:46.325357" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:21:46.303749" elapsed="0.021722"/>
</kw>
<msg time="2026-06-06T03:21:46.325635" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:21:46.325703" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "...</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-06-06T03:21:46.303377" elapsed="0.022369"/>
</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-06-06T03:21:46.326056" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:46.325825" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.325805" elapsed="0.000332"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:46.326603" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:21:46.326295" elapsed="0.000394"/>
</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-06-06T03:21:46.326983" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:46.326759" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.326740" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:21:46.327096" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:46.329652" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:21:46.329860" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:21:46.328561" elapsed="0.001488"/>
</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="NOT RUN" start="2026-06-06T03:21:46.330359" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.330736" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:21:46.327935" elapsed="0.002992"/>
</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-06-06T03:21:46.327377" elapsed="0.003615"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:21:46.270542" elapsed="0.060549"/>
</kw>
<msg time="2026-06-06T03:21:46.331184" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:46.331229" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:46.269919" elapsed="0.061347"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:21:46.331452" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:21:46.331344" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.331324" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.331966" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.332316" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:21:46.332388" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:21:46.269229" elapsed="0.063267"/>
</kw>
<msg time="2026-06-06T03:21:46.332591" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:46.332635" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:21:46.264095" elapsed="0.068594"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:46.333027" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:46.332768" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:46.332750" elapsed="0.000356"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:21:46.263948" elapsed="0.069181"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:21:46.263776" elapsed="0.069383"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:21:46.261361" elapsed="0.071852"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:21:46.255729" elapsed="0.077541"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:46.255275" elapsed="0.078042"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:21:46.251876" elapsed="0.081495"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ebgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:46.333531" elapsed="0.000122"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:21:46.334793" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:21:46.334458" elapsed="0.000363"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:46.334980" elapsed="0.000348"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:21:46.334163" elapsed="0.001235"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:21:48.336300" level="INFO">^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:21:48.336801" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:21:46.335554" elapsed="2.001343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.338564" level="INFO">^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:48.337595" elapsed="0.001164"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:21:46.333843" elapsed="2.005110"/>
</kw>
<kw name="Store_File_To_Workspace">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:48.392907" level="INFO">Executing command 'cat ebgp_peer1.log'.</msg>
<msg time="2026-06-06T03:21:48.406752" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:48.406863" level="INFO">${output_log} = 2026-06-06 03:20:54,964 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:54,964 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:20:54,964 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:48.392742" elapsed="0.014149"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.407369" level="INFO">2026-06-06 03:20:54,964 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:54,964 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:20:54,964 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:20:54,964 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:20:54,965 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:20:54,965 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 2
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   Prefix base: 8.0.0.0/28
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   My Autonomous System number: 32768
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706435
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   Next Hop: 1.1.1.1
2026-06-06 03:20:54,967 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 2
2026-06-06 03:20:54,968 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 1]
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:20:54,968 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:20:54,968 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:20:54,968 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:54,968 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:20:54,968 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:20:54,968 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job):   My Autonomous System=32768 (0x8000)
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706435 (0x7f000003)
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206410400008000
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104800000b47f0000031002060104000100010206410400008000'
2026-06-06 03:20:54,969 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104800000b47f0000031002060104000100010206410400008000
2026-06-06 03:20:54,970 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:54,970 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:54,970 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:54,971 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 2
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:20:54,971 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.0.0')]
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x400101004002060201000080004005040000006440030401010101)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):     AS path=32768
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):     Next hop=1.1.1.1
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.0.0')]/28 (0x1c08000000)
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000800040050400000064400304010101011c08000000
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:20:54,972 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:20:54,973 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:20:54,974 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:20:54,975 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:20:54,975 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.0.16')]
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:20:54,976 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x400101004002060201000080004005040000006440030401010101)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):     AS path=32768
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):     Next hop=1.1.1.1
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.0.16')]/28 (0x1c08000010)
2026-06-06 03:20:54,977 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000800040050400000064400304010101011c08000010
2026-06-06 03:20:54,977 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:20:54,977 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:20:54,977 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Number of iterations: 2
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 2
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0061686038970947266s
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job):   
2026-06-06 03:20:54,978 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:20:54,978 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:20:54,978 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:54,978 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000800040050400000064)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):     AS path=32768
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):     Next hop=1.1.1.1
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000800040050400000064
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:54,979 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:54,980 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:21:04,989 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:21:04,990 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.009s
2026-06-06 03:21:04,990 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:04,990 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:04,990 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:15,000 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:15,000 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.019s
2026-06-06 03:21:15,001 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:15,001 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:15,001 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:25,011 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:25,011 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.029s
2026-06-06 03:21:25,011 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:25,011 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:25,011 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:35,022 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:35,022 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.039s
2026-06-06 03:21:35,022 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:35,022 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:35,022 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:45,032 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:45,033 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 50.050s
2026-06-06 03:21:45,033 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:45,034 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:45,034 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:48.407070" elapsed="0.000513"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:21:48.408207" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/ebgp_peer1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/ebgp_peer1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:21:48.407798" elapsed="0.000466"/>
</kw>
<arg>${eBGP_PEER1_LOG_FILE}</arg>
<arg>${eBGP_PEER1_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:21:48.392152" elapsed="0.016176"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:21:48.408961" elapsed="0.000280"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:21:48.408626" elapsed="0.000682"/>
</kw>
<doc>Stop BGP peer, log topology and store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:21:46.251374" elapsed="2.157973"/>
</test>
<test id="s1-s9-t8" name="Check_IPv4_Topology_For_Second_Path" line="208">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:21:48.412955" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:21:48.412674" elapsed="0.000566"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:48.414304" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:48.414169" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.414146" elapsed="0.000231"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:48.420072" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:48.419964" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.419945" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.421168" 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-06-06T03:21:48.420776" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.421698" 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-06-06T03:21:48.421379" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:21:48.421770" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:21:48.421935" 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-06-06T03:21:48.420374" elapsed="0.001586"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:21:48.427987" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:48.427874" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.427853" elapsed="0.000205"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:21:48.429276" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:48.429152" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.429133" elapsed="0.000211"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:21:48.429822" 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-06-06T03:21:48.429496" elapsed="0.000352"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:21:48.430232" level="INFO">${current_connection_index} = 8</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-06-06T03:21:48.430014" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:48.464468" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:48.430784" elapsed="0.033781"/>
</kw>
<msg time="2026-06-06T03:21:48.464749" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:21:48.464795" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:21:48.430423" elapsed="0.034407"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:21:48.488872" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "_ "F "o "r "_ "S "e "c "o "n "d "_ "P "a "t "h "[K"
[?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-06-06T03:21:48.465372" elapsed="0.023644"/>
</kw>
<msg time="2026-06-06T03:21:48.489205" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:21:48.489350" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "...</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-06-06T03:21:48.465004" elapsed="0.024385"/>
</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-06-06T03:21:48.489792" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:48.489488" elapsed="0.000368"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.489460" elapsed="0.000422"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.490402" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "_ "F "o "r "_ "S "e "c "o "n "d "_ "P "a "t "h "[K"
[?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-06-06T03:21:48.490033" elapsed="0.000439"/>
</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-06-06T03:21:48.490785" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:48.490540" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.490521" elapsed="0.000344"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:21:48.490901" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:48.493793" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:21:48.494012" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:21:48.492463" elapsed="0.001680"/>
</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="NOT RUN" start="2026-06-06T03:21:48.494426" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:48.494787" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:21:48.491820" elapsed="0.003159"/>
</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-06-06T03:21:48.491226" elapsed="0.003820"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:21:48.428847" elapsed="0.066299"/>
</kw>
<msg time="2026-06-06T03:21:48.495240" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:48.495285" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:48.428216" elapsed="0.067105"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:21:48.495507" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:21:48.495398" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.495379" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:48.496187" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:48.496533" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:21:48.496606" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:21:48.427514" elapsed="0.069218"/>
</kw>
<msg time="2026-06-06T03:21:48.496826" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:48.496871" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "I "P "v "4 "_ "T "o "p "o "l "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:21:48.422352" elapsed="0.074554"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:48.497236" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:48.496981" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:48.496964" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:21:48.422202" elapsed="0.075162"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:21:48.422025" elapsed="0.075371"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:21:48.419576" elapsed="0.077875"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:21:48.413865" elapsed="0.083643"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:48.413401" elapsed="0.084193"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:21:48.410265" elapsed="0.087422"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:48.504765" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:48.504905" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:48.505018" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:48.498912" elapsed="0.006133"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.507962" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:48.505217" elapsed="0.002792"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.510866" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:48.508174" elapsed="0.002740"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:48.513932" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:48.511077" elapsed="0.002931">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:48.498485" elapsed="0.015635">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:49.524793" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:49.524989" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:49.525134" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:49.516208" elapsed="0.008964"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:49.529632" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:49.525427" elapsed="0.004292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:49.533760" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:49.529952" elapsed="0.003877"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:49.537136" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:49.534055" elapsed="0.003155">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:49.515096" elapsed="0.022228">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:50.546375" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:50.546679" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:50.546835" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:50.539303" elapsed="0.007588"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:50.554268" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:50.547331" elapsed="0.007051"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:50.558809" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:50.554820" elapsed="0.004039"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:50.562044" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:50.559037" elapsed="0.003095">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:50.538267" elapsed="0.023995">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:51.572967" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:51.573240" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:51.573464" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:51.564461" elapsed="0.009062"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:51.577790" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:51.573949" elapsed="0.003909"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:51.581845" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:51.578092" elapsed="0.003820"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:51.586283" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:51.582138" elapsed="0.004220">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:51.563317" elapsed="0.023153">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:52.596865" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:52.597067" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:52.597236" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:52.588474" elapsed="0.008804"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:52.601802" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:52.597574" elapsed="0.004349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:52.606332" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:52.602191" elapsed="0.004303"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:52.611041" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:52.606763" elapsed="0.004356">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:52.587380" elapsed="0.023859">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:53.621675" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:53.621875" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:53.622029" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:53.613412" elapsed="0.008655"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:53.626304" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:53.622326" elapsed="0.004045"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:53.630444" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:53.626605" elapsed="0.003907"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:53.634130" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:53.630760" elapsed="0.003453">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:53.612236" elapsed="0.022105">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:54.644950" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:54.645138" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:54.645282" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:54.636590" elapsed="0.008730"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:54.649752" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:54.645573" elapsed="0.004247"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:54.653885" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:54.650055" elapsed="0.003897"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:54.657553" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:54.654180" elapsed="0.003446">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:54.635305" elapsed="0.022451">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:55.667713" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:55.667985" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:55.668159" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:55.659956" elapsed="0.008240"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:55.672265" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:55.668452" elapsed="0.003878"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:55.676313" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:55.672560" elapsed="0.003819"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:55.679591" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:55.676640" elapsed="0.003058">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:55.658783" elapsed="0.021072">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:56.690498" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:56.690740" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:56.690909" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:56.682028" elapsed="0.008922"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:56.695498" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:56.691252" elapsed="0.004315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:56.699278" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:56.695833" elapsed="0.003492"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:56.702568" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:56.699487" elapsed="0.003174">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:56.680823" elapsed="0.021959">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:57.713517" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:57.713863" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:57.714113" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:57.705054" elapsed="0.009261"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:57.721817" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:57.714791" elapsed="0.007143"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:57.725528" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:57.722389" elapsed="0.003188"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:57.728623" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:57.725755" elapsed="0.002964">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:57.703824" elapsed="0.025014">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:21:58.739436" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:21:58.739620" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:21:58.739799" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:21:58.730873" elapsed="0.008964"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.743912" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:58.740090" elapsed="0.003889"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.747784" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:58.744224" elapsed="0.003607"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.750849" level="FAIL">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:21:58.747992" elapsed="0.002948">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="FAIL" start="2026-06-06T03:21:58.729773" elapsed="0.021284">'{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<msg time="2026-06-06T03:21:58.751149" level="FAIL">Keyword 'BgpOperations.Check_Example_IPv4_Topology_Content' failed after retrying for 10 seconds. The last error was: '{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</msg>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Content</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>"node-id":"${eBGP_PEER2_NEXT_HOP}"</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:21:48.497874" elapsed="10.253369">Keyword 'BgpOperations.Check_Example_IPv4_Topology_Content' failed after retrying for 10 seconds. The last error was: '{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</kw>
<kw name="Check_Example_IPv4_Topology_Content" owner="BgpOperations">
<arg>${CONFIG_SESSION}</arg>
<arg>"prefix":"${eBGP_PEER2_FIRST_PREFIX_IP}/${PREFIX_LEN}"</arg>
<doc>Check the example-ipv4-topology content for string</doc>
<status status="NOT RUN" start="2026-06-06T03:21:58.751492" elapsed="0.000032"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.752892" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:21:58.752537" elapsed="0.000399"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:21:58.752157" elapsed="0.000831"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:21:58.751840" elapsed="0.001205"/>
</kw>
<doc>The IPv4 topology shall contain the route announced by the second eBGP now</doc>
<status status="FAIL" start="2026-06-06T03:21:48.409680" elapsed="10.343404">Keyword 'BgpOperations.Check_Example_IPv4_Topology_Content' failed after retrying for 10 seconds. The last error was: '{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}' does not contain '"node-id":"2.2.2.2"'</status>
</test>
<test id="s1-s9-t9" name="iBGP_Check_Log_For_Updated_Prefixes" line="220">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:21:58.757075" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:21:58.756787" elapsed="0.000562"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:58.758423" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:58.758299" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.758275" elapsed="0.000220"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:21:58.764260" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:58.764151" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.764132" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.765349" 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-06-06T03:21:58.764965" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.765860" 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-06-06T03:21:58.765541" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:21:58.765931" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:21:58.766087" 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-06-06T03:21:58.764561" elapsed="0.001551"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:21:58.772159" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:58.772048" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.772028" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:21:58.773450" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:21:58.773342" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.773322" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:21:58.774003" 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-06-06T03:21:58.773696" elapsed="0.000340"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:21:58.774436" level="INFO">${current_connection_index} = 8</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-06-06T03:21:58.774210" elapsed="0.000252"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:21:58.803850" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:21:58.775036" elapsed="0.028916"/>
</kw>
<msg time="2026-06-06T03:21:58.804130" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:21:58.804177" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:21:58.774625" elapsed="0.029586"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:21:58.828589" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "U "p "d "a "t "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:21:58.804761" elapsed="0.023954"/>
</kw>
<msg time="2026-06-06T03:21:58.828877" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:21:58.828924" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</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-06-06T03:21:58.804387" elapsed="0.024572"/>
</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-06-06T03:21:58.829270" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:58.829037" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.829016" elapsed="0.000334"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.829830" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "U "p "d "a "t "e "d "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:21:58.829497" elapsed="0.000403"/>
</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-06-06T03:21:58.830236" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:58.830011" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.829991" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:21:58.830348" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:58.832935" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:21:58.833141" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:21:58.831852" elapsed="0.001419"/>
</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="NOT RUN" start="2026-06-06T03:21:58.833555" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:58.833931" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:21:58.831203" elapsed="0.002913"/>
</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-06-06T03:21:58.830628" elapsed="0.003554"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:21:58.773035" elapsed="0.061245"/>
</kw>
<msg time="2026-06-06T03:21:58.834372" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:58.834417" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:58.772387" elapsed="0.062065"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:21:58.834671" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:21:58.834539" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.834520" elapsed="0.000240"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:58.835189" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:58.835530" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:21:58.835603" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:21:58.771705" elapsed="0.064022"/>
</kw>
<msg time="2026-06-06T03:21:58.835822" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:21:58.835867" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:21:58.766488" elapsed="0.069415"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:21:58.836235" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:21:58.835979" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:21:58.835962" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:21:58.766341" elapsed="0.069996"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:21:58.766168" elapsed="0.070198"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:21:58.763780" elapsed="0.072640"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:21:58.757985" elapsed="0.078491"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:21:58.757511" elapsed="0.079011"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:21:58.754113" elapsed="0.082462"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:21:58.836751" elapsed="0.000109"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.837388" level="INFO">${total_prefix_count} = 4</msg>
<var>${total_prefix_count}</var>
<arg>${eBGP_PEER1_PREFIX_COUNT} + ${eBGP_PEER2_PREFIX_COUNT}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:21:58.837017" elapsed="0.000398"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:58.851674" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:58.864799" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:58.865017" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:58.851495" elapsed="0.013577"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.866063" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:58.865444" elapsed="0.000718"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:58.867229" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:58.867422" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:58.866509" elapsed="0.001050">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:58.851079" elapsed="0.016736">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:21:59.887689" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:21:59.901211" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:21:59.901451" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:21:59.887479" elapsed="0.014030"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:21:59.902706" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:21:59.902046" elapsed="0.000765"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:21:59.903814" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:21:59.904018" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:21:59.903158" elapsed="0.000999">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:21:59.886941" elapsed="0.017626">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:00.923900" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:00.936895" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:00.937131" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:00.923705" elapsed="0.013483"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:00.938241" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:00.937588" elapsed="0.000754"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:00.939350" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:00.939548" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:00.938726" elapsed="0.000995">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:00.923125" elapsed="0.016829">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:01.960520" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:01.973770" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:01.973997" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:01.960325" elapsed="0.013731"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:01.975146" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:01.974445" elapsed="0.000805"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:01.976265" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:01.976468" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:01.975601" elapsed="0.001011">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:01.959758" elapsed="0.017122">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:02.997391" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:03.010413" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:03.010560" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:02.997202" elapsed="0.013393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:03.011267" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:03.010868" elapsed="0.000461"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:03.012001" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:03.012133" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:03.011584" elapsed="0.000643">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:02.996689" elapsed="0.015686">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:04.032436" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:04.046095" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:04.046245" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:04.032233" elapsed="0.014049"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:04.047010" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:04.046573" elapsed="0.000502"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:04.048027" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:04.048231" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:04.047316" elapsed="0.001061">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:04.031632" elapsed="0.016974">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:05.066086" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:05.078952" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:05.079153" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:05.065891" elapsed="0.013300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:05.079993" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:05.079488" elapsed="0.000576"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:05.080705" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:05.080848" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:05.080283" elapsed="0.000662">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:05.065339" elapsed="0.015758">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:06.102482" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:06.115477" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:06.115751" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:06.102260" elapsed="0.013551"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:06.116917" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:06.116224" elapsed="0.000794"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:06.118020" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:06.118217" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:06.117365" elapsed="0.000991">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:06.101659" elapsed="0.016928">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:07.137577" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:07.150612" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:07.150868" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:07.137385" elapsed="0.013542"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:07.152034" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:07.151308" elapsed="0.000830"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:07.153156" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:07.153362" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:07.152487" elapsed="0.001024">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:07.136863" elapsed="0.016918">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:08.171633" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:08.184836" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:08.185085" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:08.171430" elapsed="0.013714"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:08.186244" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:08.185553" elapsed="0.000793"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:08.187534" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:08.187784" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:08.186880" elapsed="0.001055">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:08.170887" elapsed="0.017290">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:09.207950" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:09.221948" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:09.222260" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:09.207749" elapsed="0.014571"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:09.223498" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:09.222825" elapsed="0.000778"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:09.224638" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:09.224799" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:09.223994" elapsed="0.000899">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:09.207171" elapsed="0.017877">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:10.244458" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:10.257613" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:10.257881" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:10.244262" elapsed="0.013678"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:10.259011" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:10.258347" elapsed="0.000767"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:10.260124" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:10.260328" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:10.259464" elapsed="0.001005">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:10.243693" elapsed="0.017042">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:11.280207" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:11.293415" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:11.293567" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:11.280006" elapsed="0.013601"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:11.294793" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:11.294093" elapsed="0.000803"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:11.295919" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:11.296126" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:11.295248" elapsed="0.001024">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:11.279449" elapsed="0.017059">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:12.316322" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:12.329598" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:12.329766" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:12.316126" elapsed="0.013696"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:12.330475" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:12.330077" elapsed="0.000460"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:12.331502" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:12.331734" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:12.330872" elapsed="0.001013">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:12.315592" elapsed="0.016520">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:13.351523" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:13.364564" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:13.364764" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:13.351322" elapsed="0.013500"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:13.365893" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:13.365208" elapsed="0.000786"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:13.366998" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:13.367204" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:13.366339" elapsed="0.001012">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:13.350767" elapsed="0.016819">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:14.386623" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:14.399568" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:14.399783" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:14.386424" elapsed="0.013387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:14.400402" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:14.400059" elapsed="0.000390"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:14.400931" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:14.401035" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:14.400625" elapsed="0.000481">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:14.385872" elapsed="0.015347">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:15.421178" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:15.433972" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:15.434079" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:15.420984" elapsed="0.013122"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:15.434582" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:15.434284" elapsed="0.000345"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:15.435086" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:15.435187" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:15.434806" elapsed="0.000452">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:15.420438" elapsed="0.014950">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:16.455587" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:16.468382" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:16.468610" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:16.455394" elapsed="0.013305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:16.469741" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:16.469086" elapsed="0.000760"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:16.470899" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:16.471103" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:16.470230" elapsed="0.001015">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:16.454881" elapsed="0.016595">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:17.490889" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:17.503955" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:17.504244" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:17.490684" elapsed="0.013625"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:17.505370" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:17.504737" elapsed="0.000734"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:17.506481" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:17.506720" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:17.505847" elapsed="0.001023">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:17.490036" elapsed="0.017068">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:18.527992" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:18.541559" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:18.541904" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:18.527794" elapsed="0.014180"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:18.543303" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:18.542568" elapsed="0.000851"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:18.544510" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:18.544756" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:18.543817" elapsed="0.001090">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:18.527234" elapsed="0.017951">0 != 4</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:19.566055" level="INFO">Executing command 'grep -o 'nlri_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:19.579633" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:19.579929" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:19.565856" elapsed="0.014135"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.581210" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:19.580470" elapsed="0.000852"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.582423" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:19.582675" level="FAIL">0 != 4</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:19.581732" elapsed="0.001139">0 != 4</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:19.565276" elapsed="0.017858">0 != 4</status>
</kw>
<msg time="2026-06-06T03:22:19.583352" level="FAIL">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 4</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>nlri_prefix_received:</arg>
<arg>${total_prefix_count}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:21:58.837579" elapsed="20.745990">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 4</status>
</kw>
<kw name="Count_Key_Value_Pairs" owner="BGPcliKeywords">
<var>${count}</var>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>Network Address of Next Hop</arg>
<arg>${eBGP_PEER1_NEXT_HOP}</arg>
<doc>Check file for ${keyword} or ${keyword} ${value} pair and returns number of occurences</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.600321" elapsed="0.000031"/>
</kw>
<kw name="Should Be Equal As Integers" owner="BuiltIn">
<arg>${count}</arg>
<arg>${eBGP_PEER1_PREFIX_COUNT}</arg>
<doc>Fails if objects are unequal after converting them to integers.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.600524" elapsed="0.000023"/>
</kw>
<kw name="Count_Key_Value_Pairs" owner="BGPcliKeywords">
<var>${count}</var>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>Network Address of Next Hop</arg>
<arg>${eBGP_PEER2_NEXT_HOP}</arg>
<doc>Check file for ${keyword} or ${keyword} ${value} pair and returns number of occurences</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.613013" elapsed="0.000027"/>
</kw>
<kw name="Should Be Equal As Integers" owner="BuiltIn">
<arg>${count}</arg>
<arg>${eBGP_PEER2_PREFIX_COUNT}</arg>
<doc>Fails if objects are unequal after converting them to integers.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.613207" elapsed="0.000021"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.614507" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:19.614039" elapsed="0.000496"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="NOT RUN" start="2026-06-06T03:22:19.614797" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:19.614624" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.614599" elapsed="0.000269"/>
</if>
<kw name="Comment" owner="BuiltIn">
<arg>Jira tickets are {PROJECT}-{NUMBER} while Bugzilla tickets are {NUMBER}</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="PASS" start="2026-06-06T03:22:19.615056" elapsed="0.000221"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.616212" level="FAIL">'4834' does not contain '-'</msg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:22:19.615840" elapsed="0.000435">'4834' does not contain '-'</status>
</kw>
<msg time="2026-06-06T03:22:19.616369" level="INFO">${match} = False</msg>
<var>${match}</var>
<arg>Should Contain</arg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:19.615446" elapsed="0.000949"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.616931" level="INFO">${bug_url} = https://bugs.opendaylight.org/show_bug.cgi?id=4834</msg>
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:19.616570" elapsed="0.000388"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.617421" level="INFO">${msg} = This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4834</msg>
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:19.617126" elapsed="0.000322"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.617931" level="INFO">${newline} = 
</msg>
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:19.617610" elapsed="0.000348"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.618490" level="INFO">Set test message to:
This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4834

Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 4</msg>
<arg>${msg}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="PASS" start="2026-06-06T03:22:19.618118" elapsed="0.000422"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.618961" level="INFO">This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4834</msg>
<arg>${msg}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:19.618717" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.619688" level="INFO">Set tag 'https://bugs.opendaylight.org/show_bug.cgi?id=4834'.</msg>
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="PASS" start="2026-06-06T03:22:19.619322" elapsed="0.000416"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:19.619074" elapsed="0.000699"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.619055" elapsed="0.000743"/>
</if>
<arg>4834</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:22:19.613664" elapsed="0.006182"/>
</kw>
<doc>Check incomming updates for updated routes</doc>
<tag>critical</tag>
<tag>https://bugs.opendaylight.org/show_bug.cgi?id=4834</tag>
<status status="FAIL" start="2026-06-06T03:21:58.753533" elapsed="20.866410">This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4834

Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 4</status>
</test>
<test id="s1-s9-t10" name="Disconnect_eBGP_Peer2" line="244">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:19.623902" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:19.623612" elapsed="0.000578"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:19.625220" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:19.625106" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.625086" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:19.630868" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:19.630758" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.630740" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.631964" 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-06-06T03:22:19.631559" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.632476" 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-06-06T03:22:19.632159" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:19.632548" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:22:19.632727" 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-06-06T03:22:19.631175" elapsed="0.001578"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:19.638771" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:19.638658" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.638625" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:19.640041" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:19.639931" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.639912" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:19.640577" 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-06-06T03:22:19.640274" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:19.641008" level="INFO">${current_connection_index} = 7</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-06-06T03:22:19.640784" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:19.674656" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:19.641539" elapsed="0.033255"/>
</kw>
<msg time="2026-06-06T03:22:19.674980" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:19.675028" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:19.641197" elapsed="0.033866"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:19.697837" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:22:19.675674" elapsed="0.022269"/>
</kw>
<msg time="2026-06-06T03:22:19.698108" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:19.698156" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "...</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-06-06T03:22:19.675262" elapsed="0.022930"/>
</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-06-06T03:22:19.698534" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:19.698281" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.698256" elapsed="0.000362"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.699110" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "e "e "r "2 "[K"
[?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-06-06T03:22:19.698791" elapsed="0.000445"/>
</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-06-06T03:22:19.699534" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:19.699306" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.699287" elapsed="0.000326"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:19.699671" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:19.702360" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:22:19.702575" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:19.701244" elapsed="0.001483"/>
</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="NOT RUN" start="2026-06-06T03:22:19.703037" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.703381" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:19.700576" elapsed="0.002992"/>
</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-06-06T03:22:19.699977" elapsed="0.003659"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:19.639595" elapsed="0.064169"/>
</kw>
<msg time="2026-06-06T03:22:19.703859" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:19.703909" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:19.638995" elapsed="0.064951"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:19.704133" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:19.704024" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.704005" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.704639" elapsed="0.000049"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.705013" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:19.705085" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:19.638301" elapsed="0.066893"/>
</kw>
<msg time="2026-06-06T03:22:19.705288" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:19.705332" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "e "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:19.633135" elapsed="0.072233"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:19.705765" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:19.705445" elapsed="0.000377"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:19.705428" elapsed="0.000418"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:19.632987" elapsed="0.072883"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:19.632810" elapsed="0.073094"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:19.630376" elapsed="0.075583"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:19.624804" elapsed="0.081211"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:19.624349" elapsed="0.081712"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:19.620992" elapsed="0.085122"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ebgp_peer2_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:19.706285" elapsed="0.000111"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:19.707577" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:19.707229" elapsed="0.000376"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:19.707786" elapsed="0.000342"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:22:19.706950" elapsed="0.001314"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.709173" level="INFO">^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:22:21.709512" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:22:19.708486" elapsed="2.001090"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.710776" level="INFO">^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:21.710093" elapsed="0.000792"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:22:19.706585" elapsed="2.004436"/>
</kw>
<kw name="Store_File_To_Workspace">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.726748" level="INFO">Executing command 'cat ebgp_peer2.log'.</msg>
<msg time="2026-06-06T03:22:21.740554" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:21.740901" level="INFO">${output_log} = 2026-06-06 03:21:36,323 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:21:36,324 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.4
2026-06-06 03:21:36,324 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:21.726568" elapsed="0.014396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.742112" level="INFO">2026-06-06 03:21:36,323 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:21:36,324 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.4
2026-06-06 03:21:36,324 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:21:36,324 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:21:36,324 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:21:36,325 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:21:36,325 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:21:36,325 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:21:36,325 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 2
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Prefix base: 8.0.0.0/28
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   My Autonomous System number: 32768
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706436
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Next Hop: 2.2.2.2
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 2
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 1]
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:21:36,326 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   My Autonomous System=32768 (0x8000)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706436 (0x7f000004)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206410400008000
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104800000b47f0000041002060104000100010206410400008000'
2026-06-06 03:21:36,326 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104800000b47f0000041002060104000100010206410400008000
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:21:36,327 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:21:36,328 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:21:36,328 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:21:36,331 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 2
2026-06-06 03:21:36,331 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:21:36,331 DEBUG BGP-Thread-1 (job): Remaining prefixes: 2
2026-06-06 03:21:36,332 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:21:36,332 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:21:36,332 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:21:36,332 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:21:36,332 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.0.0')]
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x400101004002060201000080004005040000006440030402020202)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):     AS path=32768
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):     Next hop=2.2.2.2
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.0.0')]/28 (0x1c08000000)
2026-06-06 03:21:36,339 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000800040050400000064400304020202021c08000000
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): ########## Iteration: 1 ##########
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:21:36,340 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix indexes: [1]
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.0.16')]
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix slot index: 1
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x400101004002060201000080004005040000006440030402020202)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):     AS path=32768
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):     Next hop=2.2.2.2
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.0.16')]/28 (0x1c08000010)
2026-06-06 03:21:36,341 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000800040050400000064400304020202021c08000010
2026-06-06 03:21:36,341 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:21:36,341 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:21:36,341 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:21:36,341 INFO BGP-Thread-1 (job): Number of iterations: 2
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 2
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.009801387786865234s
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job):   
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job):   
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job):   
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job):   
2026-06-06 03:21:36,342 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:21:36,342 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:21:36,342 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:36,342 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:21:36,342 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000800040050400000064)
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):     AS path=32768
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):     Next hop=2.2.2.2
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:21:36,343 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000800040050400000064
2026-06-06 03:21:46,352 INFO BGP-Thread-1 (job): ... idle for 10.008s
2026-06-06 03:21:46,353 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.008s
2026-06-06 03:21:46,353 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:46,353 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:46,353 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:56,361 INFO BGP-Thread-1 (job): ... idle for 10.008s
2026-06-06 03:21:56,362 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.017s
2026-06-06 03:21:56,362 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:56,362 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:56,362 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:22:06,371 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:22:06,371 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.026s
2026-06-06 03:22:06,371 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:06,372 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:06,372 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:22:16,382 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:22:16,382 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.036s
2026-06-06 03:22:16,382 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:16,382 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:16,382 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:21.741426" elapsed="0.001186"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:21.743850" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/ebgp_peer2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/ebgp_peer2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:22:21.743086" elapsed="0.000889"/>
</kw>
<arg>${eBGP_PEER2_LOG_FILE}</arg>
<arg>${eBGP_PEER2_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:21.726066" elapsed="0.018053"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:22:21.745495" elapsed="0.000586"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:22:21.744784" elapsed="0.001438"/>
</kw>
<doc>Stop BGP peer, store logs and wait for empty topology</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:22:19.620429" elapsed="2.125879"/>
</test>
<test id="s1-s9-t11" name="Check_For_Empty_IPv4_Topology" line="251">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:21.752362" elapsed="0.000366"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:21.751836" elapsed="0.000980"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:21.754531" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.754339" elapsed="0.000267"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.754305" elapsed="0.000356"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:21.760707" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.760557" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.760537" elapsed="0.000242"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.761833" 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-06-06T03:22:21.761409" elapsed="0.000452"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.762334" 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-06-06T03:22:21.762030" elapsed="0.000331"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:21.762407" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:22:21.762570" 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-06-06T03:22:21.761016" elapsed="0.001579"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:21.768908" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.768794" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.768773" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:21.770220" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.770111" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.770092" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:21.770763" 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-06-06T03:22:21.770440" elapsed="0.000350"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.771177" level="INFO">${current_connection_index} = 9</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-06-06T03:22:21.770958" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.801563" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:21.771764" elapsed="0.030056"/>
</kw>
<msg time="2026-06-06T03:22:21.802054" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:21.802103" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:21.771369" elapsed="0.030769"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.829315" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:22:21.802874" elapsed="0.026751"/>
</kw>
<msg time="2026-06-06T03:22:21.830072" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:21.830288" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "I "...</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-06-06T03:22:21.802399" elapsed="0.027973"/>
</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-06-06T03:22:21.831195" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.830575" elapsed="0.000746"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.830520" elapsed="0.000856"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.832325" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "I "P "v "4 "_ "T "o "p "o "l "o "g "y "[K"
[?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-06-06T03:22:21.831779" elapsed="0.000647"/>
</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-06-06T03:22:21.832881" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.832527" elapsed="0.000436"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.832500" elapsed="0.000498"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:21.833052" elapsed="0.000052"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:21.836973" elapsed="0.000219"/>
</kw>
<msg time="2026-06-06T03:22:21.837289" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:21.835319" elapsed="0.002165"/>
</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="NOT RUN" start="2026-06-06T03:22:21.837939" elapsed="0.000116"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.838445" elapsed="0.000111"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:21.834348" elapsed="0.004394"/>
</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-06-06T03:22:21.833499" elapsed="0.005339"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:21.769804" elapsed="0.069182"/>
</kw>
<msg time="2026-06-06T03:22:21.839126" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:21.839194" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "I "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:21.769142" elapsed="0.070109"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:21.839527" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:22:21.839366" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.839338" elapsed="0.000375"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.840198" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.840543" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:21.840615" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:21.768421" elapsed="0.072320"/>
</kw>
<msg time="2026-06-06T03:22:21.840838" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:21.840885" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "C "h "e "c "k "_ "F "o "r "_ "E "m "p "t "y "_ "I "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:21.763000" elapsed="0.077923"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.841259" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.841000" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.840982" elapsed="0.000356"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:21.762845" elapsed="0.078517"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:21.762666" elapsed="0.078729"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:21.760187" elapsed="0.081265"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:21.753889" elapsed="0.087620"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:21.753198" elapsed="0.088418"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:21.748121" elapsed="0.093614"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_Example_IPv4_Topology_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:21.848678" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0wlpqowx8h2ln1f3v2zfl3l4gy18.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:21.848871" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '172'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:22:21.849044" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_TOPOLOGY_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:22:21.842918" elapsed="0.006167"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.853530" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:21.849362" elapsed="0.004241"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.857348" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:21.853873" elapsed="0.003525"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${string_to_check}</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:22:21.857562" elapsed="0.003032"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Check the example-ipv4-topology does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:22:21.842543" elapsed="0.018139"/>
</kw>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_IPv4_Topology_Does_Not_Contain</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>prefix</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:22:21.841918" elapsed="0.018822"/>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.862033" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:21.861578" elapsed="0.000483"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:22:21.862301" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:22:21.862148" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.862124" elapsed="0.000270"/>
</if>
<kw name="Comment" owner="BuiltIn">
<arg>Jira tickets are {PROJECT}-{NUMBER} while Bugzilla tickets are {NUMBER}</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.862585" elapsed="0.000023"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<var>${match}</var>
<arg>Should Contain</arg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.862789" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.862983" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.863170" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.863347" elapsed="0.000020"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.863521" elapsed="0.000021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.863738" elapsed="0.000022"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.863997" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.863825" elapsed="0.000226"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:21.863808" elapsed="0.000266"/>
</if>
<arg>4835</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:22:21.861193" elapsed="0.002933"/>
</kw>
<doc>The IPv4 topology shall be empty</doc>
<status status="PASS" start="2026-06-06T03:22:21.746987" elapsed="0.117185"/>
</test>
<test id="s1-s9-t12" name="iBGP_Check_Log_For_Withdrawn_Prefixes" line="261">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:21.867873" elapsed="0.000221"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:21.867572" elapsed="0.000581"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:21.869257" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.869141" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.869121" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:21.874999" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.874888" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.874869" elapsed="0.000201"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.876112" 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-06-06T03:22:21.875718" elapsed="0.000422"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.876607" 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-06-06T03:22:21.876308" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:21.876696" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:22:21.876858" 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-06-06T03:22:21.875304" elapsed="0.001580"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:21.883315" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.883157" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.883136" elapsed="0.000254"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:21.884668" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:21.884531" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.884512" elapsed="0.000230"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:21.885204" 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-06-06T03:22:21.884895" elapsed="0.000336"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.885620" level="INFO">${current_connection_index} = 9</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-06-06T03:22:21.885401" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.915140" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:21.886182" elapsed="0.029179"/>
</kw>
<msg time="2026-06-06T03:22:21.915577" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:21.915624" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:21.885836" elapsed="0.029851"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.939588" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:22:21.916411" elapsed="0.023501"/>
</kw>
<msg time="2026-06-06T03:22:21.940190" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:21.940254" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</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-06-06T03:22:21.915983" elapsed="0.024320"/>
</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-06-06T03:22:21.940882" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.940446" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.940403" elapsed="0.000592"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.941701" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "r "_ "W "i "t "h "d "r "a "w "n "_ "P "r "e "f "i "x "e "s "[K"
[?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-06-06T03:22:21.941194" elapsed="0.000605"/>
</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-06-06T03:22:21.942183" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.941889" elapsed="0.000369"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.941862" elapsed="0.000430"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:21.942342" elapsed="0.000051"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:21.945911" elapsed="0.000185"/>
</kw>
<msg time="2026-06-06T03:22:21.946172" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:21.944483" elapsed="0.001856"/>
</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="NOT RUN" start="2026-06-06T03:22:21.946730" elapsed="0.000091"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.947161" elapsed="0.000093"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:21.943596" elapsed="0.003800"/>
</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-06-06T03:22:21.942862" elapsed="0.004618"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:21.884220" elapsed="0.063391"/>
</kw>
<msg time="2026-06-06T03:22:21.947790" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:21.947852" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:21.883555" elapsed="0.064347"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:21.948146" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:22:21.948007" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.947981" elapsed="0.000277"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.948812" elapsed="0.000033"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.949264" elapsed="0.000033"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:21.949358" elapsed="0.000021"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:21.882794" elapsed="0.066706"/>
</kw>
<msg time="2026-06-06T03:22:21.949624" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:21.949718" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "i "B "G "P "_ "C "h "e "c "k "_ "L "o "g "_ "F "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:21.877265" elapsed="0.072503"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:21.950199" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:21.949868" elapsed="0.000403"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:21.949845" elapsed="0.000458"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:21.877118" elapsed="0.073218"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:21.876941" elapsed="0.073440"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:21.874504" elapsed="0.075954"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:21.868845" elapsed="0.081689"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:21.868311" elapsed="0.082286"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:21.865115" elapsed="0.085678"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:21.951025" elapsed="0.000166"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.951997" level="INFO">${prefixes_to_be_removed} = 2</msg>
<var>${prefixes_to_be_removed}</var>
<arg>max(${eBGP_PEER1_PREFIX_COUNT}, ${eBGP_PEER2_PREFIX_COUNT})</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:21.951403" elapsed="0.000629"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:21.976316" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:21.989320" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:21.989618" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:21.976039" elapsed="0.013672"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.990862" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:21.990176" elapsed="0.000888"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:21.992537" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:21.992789" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:21.991703" elapsed="0.001229">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:21.975220" elapsed="0.017881">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:23.014403" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:23.027358" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:23.027594" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:23.014202" elapsed="0.013485"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:23.028773" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:23.028096" elapsed="0.000781"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:23.029943" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:23.030161" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:23.029261" elapsed="0.001050">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:23.013607" elapsed="0.016943">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:24.051819" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:24.064770" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:24.064929" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:24.051603" elapsed="0.013362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:24.066030" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:24.065349" elapsed="0.000784"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:24.067209" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:24.067411" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:24.066527" elapsed="0.001027">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:24.051012" elapsed="0.016812">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:25.086942" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:25.100322" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:25.100570" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:25.086744" elapsed="0.013889"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:25.101816" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:25.101076" elapsed="0.000842"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:25.103032" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:25.103242" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:25.102276" elapsed="0.001111">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:25.086178" elapsed="0.017508">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:26.121921" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:26.135341" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:26.135567" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:26.121716" elapsed="0.013908"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:26.136699" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:26.136054" elapsed="0.000771"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:26.137824" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:26.138024" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:26.137178" elapsed="0.000987">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:26.121131" elapsed="0.017260">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:27.158963" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:27.172174" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:27.172417" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:27.158761" elapsed="0.013717"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:27.173599" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:27.172933" elapsed="0.000836"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:27.175008" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:27.175226" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:27.174280" elapsed="0.001098">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:27.158197" elapsed="0.017431">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:28.197433" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:28.210880" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:28.211075" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:28.197233" elapsed="0.013878"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:28.212304" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:28.211558" elapsed="0.000859"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:28.213522" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:28.213778" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:28.212830" elapsed="0.001106">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:28.196682" elapsed="0.017512">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:29.233718" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:29.246684" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:29.246862" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:29.233501" elapsed="0.013388"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:29.247472" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:29.247136" elapsed="0.000383"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:29.248011" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:29.248119" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:29.247720" elapsed="0.000471">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:29.232961" elapsed="0.015350">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:30.271441" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:30.285191" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:30.285399" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:30.271239" elapsed="0.014190"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:30.286083" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:30.285726" elapsed="0.000404"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:30.286582" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:30.286708" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:30.286292" elapsed="0.000488">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:30.270620" elapsed="0.016275">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:31.309455" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:31.322548" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:31.322823" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:31.309135" elapsed="0.013731"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:31.323721" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:31.323214" elapsed="0.000570"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:31.324376" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:31.324507" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:31.323977" elapsed="0.000631">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:31.308456" elapsed="0.016345">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:32.347339" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:32.360464" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:32.360748" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:32.347140" elapsed="0.013676"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:32.361972" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:32.361244" elapsed="0.000974"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:32.363345" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:32.363566" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:32.362612" elapsed="0.001142">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:32.346569" elapsed="0.017439">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:33.384150" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:33.396839" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:33.397041" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:33.383936" elapsed="0.013146"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:33.397913" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:33.397381" elapsed="0.000598"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:33.398602" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:33.398773" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:33.398205" elapsed="0.000680">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:33.383286" elapsed="0.015755">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:34.420957" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:34.433670" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:34.433821" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:34.420757" elapsed="0.013102"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:34.434536" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:34.434117" elapsed="0.000486"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:34.435277" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:34.435420" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:34.434859" elapsed="0.000657">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:34.420231" elapsed="0.015463">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:35.456346" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:35.469755" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:35.469982" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:35.456145" elapsed="0.013892"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:35.471120" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:35.470446" elapsed="0.000775"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:35.472226" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:35.472428" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:35.471571" elapsed="0.000998">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:35.455550" elapsed="0.017279">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:36.493249" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:36.506420" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:36.506690" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:36.493050" elapsed="0.013701"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:36.507813" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:36.507150" elapsed="0.000769"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:36.508940" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:36.509142" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:36.508270" elapsed="0.001016">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:36.492485" elapsed="0.017029">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:37.530108" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:37.543165" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:37.543460" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:37.529887" elapsed="0.013648"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:37.544851" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:37.544129" elapsed="0.000830"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:37.545994" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:37.546203" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:37.545318" elapsed="0.001030">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:37.529288" elapsed="0.017293">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:38.567380" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:39.430759" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:39.431108" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:38.567124" elapsed="0.864044"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:39.432430" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:39.431723" elapsed="0.000810"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:39.433669" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:39.433890" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:39.432955" elapsed="0.001085">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:38.566531" elapsed="0.867753">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:40.454027" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:40.466806" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:40.467038" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:40.453827" elapsed="0.013267"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:40.468191" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:40.467485" elapsed="0.000807"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:40.469297" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:40.469500" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:40.468670" elapsed="0.001008">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:40.453271" elapsed="0.016645">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:41.492127" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:41.505172" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:41.505407" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:41.491926" elapsed="0.013538"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:41.506765" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:41.506064" elapsed="0.000812"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:41.507971" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:41.508189" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:41.507234" elapsed="0.001105">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:41.491306" elapsed="0.017272">0 != 2</status>
</kw>
<kw name="Check_File_For_Word_Count" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:42.529110" level="INFO">Executing command 'grep -o 'withdrawn_prefix_received:' bgp_peer1.log | wc -l'.</msg>
<msg time="2026-06-06T03:22:42.542229" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:42.542595" level="INFO">${output_log} = 0</msg>
<var>${output_log}</var>
<arg>grep -o '${word}' ${file_name} | wc -l</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:42.528906" elapsed="0.013790"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.543955" level="INFO">0</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:42.543206" elapsed="0.000851"/>
</kw>
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.545078" level="INFO">Argument types are:
&lt;class 'str'&gt;
&lt;class 'int'&gt;</msg>
<msg time="2026-06-06T03:22:42.545327" level="FAIL">0 != 2</msg>
<arg>${output_log}</arg>
<arg>${expected_count}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:22:42.544407" elapsed="0.001072">0 != 2</status>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Count ${word} in ${file_name}. Expect ${expected_count} occurence(s)</doc>
<status status="FAIL" start="2026-06-06T03:22:42.528320" elapsed="0.017435">0 != 2</status>
</kw>
<msg time="2026-06-06T03:22:42.545969" level="FAIL">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</msg>
<arg>${DEFAULT_LOG_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_LOG_CHECK_PERIOD}</arg>
<arg>Check_File_For_Word_Count</arg>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>withdrawn_prefix_received:</arg>
<arg>${prefixes_to_be_removed}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:22:21.952261" elapsed="20.593913">Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</status>
</kw>
<kw name="Report Failure Due To Bug" owner="Utils" type="TEARDOWN">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.549336" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:42.548281" elapsed="0.001119"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="NOT RUN" start="2026-06-06T03:22:42.549851" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:42.549584" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.549533" elapsed="0.000417"/>
</if>
<kw name="Comment" owner="BuiltIn">
<arg>Jira tickets are {PROJECT}-{NUMBER} while Bugzilla tickets are {NUMBER}</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="PASS" start="2026-06-06T03:22:42.550208" elapsed="0.000301"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Should Contain" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.551781" level="FAIL">'4835' does not contain '-'</msg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="FAIL" start="2026-06-06T03:22:42.551276" elapsed="0.000589">'4835' does not contain '-'</status>
</kw>
<msg time="2026-06-06T03:22:42.551994" level="INFO">${match} = False</msg>
<var>${match}</var>
<arg>Should Contain</arg>
<arg>${number}</arg>
<arg>-</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:42.550764" elapsed="0.001265"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.552758" level="INFO">${bug_url} = https://bugs.opendaylight.org/show_bug.cgi?id=4835</msg>
<var>${bug_url}</var>
<arg>${match}</arg>
<arg>https://jira.opendaylight.org/browse/${number}</arg>
<arg>https://bugs.opendaylight.org/show_bug.cgi?id=${number}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:42.552271" elapsed="0.000524"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.553449" level="INFO">${msg} = This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4835</msg>
<var>${msg}</var>
<arg>This test fails due to ${bug_url}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:42.553024" elapsed="0.000462"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.554148" level="INFO">${newline} = 
</msg>
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:42.553738" elapsed="0.000448"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.554939" level="INFO">Set test message to:
This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4835

Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</msg>
<arg>${msg}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="PASS" start="2026-06-06T03:22:42.554403" elapsed="0.000602"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.555560" level="INFO">This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4835</msg>
<arg>${msg}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:42.555226" elapsed="0.000396"/>
</kw>
<if>
<branch type="IF" condition="&quot;${include_bug_in_tags}&quot;==&quot;True&quot;">
<kw name="Set Tags" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.556606" level="INFO">Set tag 'https://bugs.opendaylight.org/show_bug.cgi?id=4835'.</msg>
<arg>${bug_url}</arg>
<doc>Adds given ``tags`` for the current test or all tests in a suite.</doc>
<status status="PASS" start="2026-06-06T03:22:42.556121" elapsed="0.000574"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:42.555768" elapsed="0.000975"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.555730" elapsed="0.001049"/>
</if>
<arg>4835</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:22:42.547400" elapsed="0.009442"/>
</kw>
<doc>Check incomming updates for withdrawn routes</doc>
<tag>critical</tag>
<tag>https://bugs.opendaylight.org/show_bug.cgi?id=4835</tag>
<status status="FAIL" start="2026-06-06T03:22:21.864533" elapsed="20.692373">This test fails due to https://bugs.opendaylight.org/show_bug.cgi?id=4835

Keyword 'Check_File_For_Word_Count' failed after retrying for 20 seconds. The last error was: 0 != 2</status>
</test>
<test id="s1-s9-t13" name="Disconnect_iBGP_Peer1" line="275">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:42.562287" elapsed="0.000207"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:42.562018" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:42.563563" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:42.563450" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.563430" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:42.569264" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:42.569157" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.569139" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.570349" 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-06-06T03:22:42.569966" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.570858" 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-06-06T03:22:42.570541" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:42.570931" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:22:42.571094" 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-06-06T03:22:42.569565" elapsed="0.001554"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:42.577208" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:42.577098" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.577078" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:42.578462" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:42.578354" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.578335" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:42.579009" 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-06-06T03:22:42.578704" elapsed="0.000332"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:42.579419" level="INFO">${current_connection_index} = 7</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-06-06T03:22:42.579200" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:42.609793" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:42.579973" elapsed="0.029921"/>
</kw>
<msg time="2026-06-06T03:22:42.610074" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:42.610121" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:42.579608" elapsed="0.030548"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:42.630728" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:22:42.610704" elapsed="0.020126"/>
</kw>
<msg time="2026-06-06T03:22:42.630992" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:42.631049" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "i "B "G "P "_ "P "...</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-06-06T03:22:42.610332" elapsed="0.020766"/>
</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-06-06T03:22:42.631416" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:42.631182" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.631160" elapsed="0.000368"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.631997" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "i "B "G "P "_ "P "e "e "r "1 "[K"
[?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-06-06T03:22:42.631696" elapsed="0.000365"/>
</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-06-06T03:22:42.632351" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:42.632129" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.632111" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:42.632480" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:42.635034" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:22:42.635242" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:42.633950" elapsed="0.001419"/>
</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="NOT RUN" start="2026-06-06T03:22:42.635667" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:42.636014" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:42.633312" elapsed="0.002888"/>
</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-06-06T03:22:42.632774" elapsed="0.003497"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:42.578051" elapsed="0.058360"/>
</kw>
<msg time="2026-06-06T03:22:42.636536" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:42.636583" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "i "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:42.577431" elapsed="0.059188"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:42.636901" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:42.636788" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.636766" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:42.637386" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:42.637737" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:42.637809" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:42.576741" elapsed="0.061175"/>
</kw>
<msg time="2026-06-06T03:22:42.638009" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:42.638054" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "i "s "c "o "n "n "e "c "t "_ "i "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:42.571550" elapsed="0.066539"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:42.638418" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:42.638165" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:42.638148" elapsed="0.000348"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:42.571400" elapsed="0.067120"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:42.571217" elapsed="0.067333"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:42.568780" elapsed="0.069824"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:42.563158" elapsed="0.075517"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:42.562722" elapsed="0.076000"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:42.558159" elapsed="0.080617"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:42.638939" elapsed="0.000108"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:42.640259" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:42.639931" elapsed="0.000355"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:42.640500" elapsed="0.000256"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:22:42.639577" elapsed="0.001240"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:22:44.641689" level="INFO">^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:22:44.642067" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:22:42.640991" elapsed="2.001142"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.643396" level="INFO">^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.642678" elapsed="0.000826"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:22:42.639242" elapsed="2.004427"/>
</kw>
<kw name="Store_File_To_Workspace">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:22:44.659210" level="INFO">Executing command 'cat bgp_peer1.log'.</msg>
<msg time="2026-06-06T03:22:44.672705" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:22:44.672981" level="INFO">${output_log} = 2026-06-06 03:20:44,838 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:44,838 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:20:44,838 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:22:44.659064" elapsed="0.013990"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.674340" level="INFO">2026-06-06 03:20:44,838 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:20:44,838 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.1
2026-06-06 03:20:44,838 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:20:44,838 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:20:44,838 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:20:44,839 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:20:44,841 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:20:44,841 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:20:44,841 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:20:44,841 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:20:44,841 INFO BGP-Thread-1 (job):   Prefix base: 8.1.0.0/28
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706433
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:20:44,842 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:20:44,842 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:20:44,842 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706433 (0x7f000001)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf0
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0'
2026-06-06 03:20:44,843 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf000b47f000001100206010400010001020641040000fbf0
2026-06-06 03:20:44,845 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:44,846 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:20:44,851 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:20:44,852 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:44,852 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:20:44,853 INFO BGP-Thread-1 (job): ... idle for 0.001s
2026-06-06 03:20:44,853 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.001s
2026-06-06 03:20:44,853 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:20:44,853 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:20:44,854 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:20:44,855 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:20:44,855 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:20:44,855 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:20:44,855 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:20:44,855 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:20:54,865 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:20:54,865 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.011s
2026-06-06 03:20:54,866 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:20:54,866 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:20:54,866 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:04,876 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:04,876 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.021s
2026-06-06 03:21:04,876 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:04,876 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:04,876 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:14,887 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:14,887 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.031s
2026-06-06 03:21:14,887 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:14,887 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:14,887 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:24,897 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:24,898 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.041s
2026-06-06 03:21:24,898 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:24,898 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:24,898 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:34,908 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:34,910 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 50.051s
2026-06-06 03:21:34,910 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:34,910 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:34,911 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:44,856 INFO BGP-Thread-1 (job): ... idle for 9.946s
2026-06-06 03:21:44,857 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 59.997s
2026-06-06 03:21:44,857 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:21:44,857 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:21:44,857 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:21:44,857 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:21:44,857 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:21:44,857 INFO BGP-Thread-1 (job): KEEP ALIVE is sent.
2026-06-06 03:21:44,857 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:44,857 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:44,857 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:21:44,858 INFO BGP-Thread-1 (job): KEEP ALIVE message received: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:21:54,868 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:21:54,869 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 70.008s
2026-06-06 03:21:54,869 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:21:54,869 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:21:54,869 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:22:04,879 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:22:04,879 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 80.018s
2026-06-06 03:22:04,880 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:04,880 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:04,880 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:22:14,890 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:22:14,890 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.028s
2026-06-06 03:22:14,890 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:14,890 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:14,891 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:22:24,901 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:22:24,901 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 100.038s
2026-06-06 03:22:24,901 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:24,901 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:24,901 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:22:34,911 INFO BGP-Thread-1 (job): ... idle for 10.009s
2026-06-06 03:22:34,912 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 110.047s
2026-06-06 03:22:34,912 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:34,912 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:34,912 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.673561" elapsed="0.001330"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:44.676539" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/bgp_peer1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:22:44.675515" elapsed="0.001224"/>
</kw>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<arg>${iBGP_PEER1_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:44.658633" elapsed="0.018227"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:22:44.677944" elapsed="0.000406"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:22:44.677341" elapsed="0.001134"/>
</kw>
<doc>Stop BGP peer, log topology and store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:22:42.557376" elapsed="2.121168"/>
</test>
<test id="s1-s9-t14" name="Delete_BGP_Peers_Configuration" line="282">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:44.684234" elapsed="0.000365"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:44.683798" elapsed="0.000935"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:44.685951" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:44.685794" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.685767" elapsed="0.000280"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:44.692172" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:44.692063" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.692044" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.693286" 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-06-06T03:22:44.692878" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.693835" 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-06-06T03:22:44.693489" elapsed="0.000381"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:44.693929" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:22:44.694100" 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-06-06T03:22:44.692474" elapsed="0.001652"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:44.700792" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:44.700672" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.700638" elapsed="0.000224"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:44.702099" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:44.701991" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.701972" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:44.702618" 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-06-06T03:22:44.702316" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:44.703049" level="INFO">${current_connection_index} = 7</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-06-06T03:22:44.702829" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:44.736225" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:44.703593" elapsed="0.032777"/>
</kw>
<msg time="2026-06-06T03:22:44.736549" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:44.736596" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:44.703239" elapsed="0.033392"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:44.759700" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:22:44.737230" elapsed="0.022582"/>
</kw>
<msg time="2026-06-06T03:22:44.759993" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:44.760120" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "...</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-06-06T03:22:44.736853" elapsed="0.023305"/>
</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-06-06T03:22:44.760508" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.760259" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.760226" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.761091" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:22:44.760781" elapsed="0.000378"/>
</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-06-06T03:22:44.761451" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.761227" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.761208" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:44.761566" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:44.764542" elapsed="0.000190"/>
</kw>
<msg time="2026-06-06T03:22:44.764813" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:44.763289" elapsed="0.001681"/>
</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="NOT RUN" start="2026-06-06T03:22:44.765336" elapsed="0.000096"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.765739" elapsed="0.000095"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:44.762508" elapsed="0.003458"/>
</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-06-06T03:22:44.761894" elapsed="0.004140"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:44.701675" elapsed="0.064462"/>
</kw>
<msg time="2026-06-06T03:22:44.766233" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:44.766278" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:44.701021" elapsed="0.065295"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:44.766534" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:22:44.766408" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.766382" elapsed="0.000242"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.767171" elapsed="0.000032"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.767570" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:44.767683" elapsed="0.000023"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:44.700306" elapsed="0.067523"/>
</kw>
<msg time="2026-06-06T03:22:44.767947" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:44.768006" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "D "e "l "e "t "e "_ "B "G "P "_ "P "e "e "r "s "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:44.694513" elapsed="0.073534"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.768432" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.768127" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.768109" elapsed="0.000423"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:44.694363" elapsed="0.074194"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:44.694183" elapsed="0.074417"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:44.691694" elapsed="0.077003"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:44.685424" elapsed="0.083352"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:44.684899" elapsed="0.083976"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:44.680096" elapsed="0.088837"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.769804" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | NAME=example-ibgp-peer1 | IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>NAME=example-ibgp-peer1</arg>
<arg>IP=${iBGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.769150" elapsed="0.000684"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.818796" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:44.818379" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:44.819585" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:44.819339" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:44.819776" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:44.818999" elapsed="0.000801"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.820353" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:44.819970" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:44.820700" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ibgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:44.820878" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:44.820546" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.821312" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.821066" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.822333" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ibgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.822075" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.822849" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.822540" elapsed="0.000335"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.823543" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.823247" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.824323" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.824100" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.824400" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:44.824553" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.823778" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.824752" elapsed="0.000244"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:22:44.823105" elapsed="0.001932"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.825577" level="INFO">${value} = example-ibgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.825283" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.826484" level="INFO">${encoded} = example-ibgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.826125" elapsed="0.000385"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.826562" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:44.826799" level="INFO">${encoded_value} = example-ibgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.825807" elapsed="0.001017"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.826981" elapsed="0.000223"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-ibgp-peer1</var>
<status status="PASS" start="2026-06-06T03:22:44.825149" elapsed="0.002095"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.827803" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.827491" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.828548" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.828336" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.828625" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:22:44.828795" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.828016" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.828978" elapsed="0.000225"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:44.827356" elapsed="0.001888"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.829808" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.829492" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.830555" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.830344" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.830632" elapsed="0.000057"/>
</return>
<msg time="2026-06-06T03:22:44.830812" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.830022" elapsed="0.000815"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.830992" elapsed="0.000218"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:44.829357" elapsed="0.001895"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:44.822927" elapsed="0.008360"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:44.831329" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:22:44.831486" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ibgp-peer1', 'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:44.821750" elapsed="0.009762"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.821428" elapsed="0.010115"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.831737" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.831569" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.821408" elapsed="0.010409"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.832580" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:44.831965" elapsed="0.000643"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:44.832672" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:44.817755" elapsed="0.015049"/>
</kw>
<msg time="2026-06-06T03:22:44.832858" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:44.803450" elapsed="0.029455"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.846810" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.862328" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ibgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.876472" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.876703" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.876892" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.877289" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.877136" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:44.877119" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.877514" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.877699" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.877875" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:44.877085" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:44.876975" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.878102" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:44.878179" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:44.878319" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:44.798321" elapsed="0.080037"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.879607" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.879320" elapsed="0.000365"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:44.892425" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:44.892477" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:44.892593" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:22:44.882034" elapsed="0.010588"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.879763" elapsed="0.012933"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.893114" elapsed="0.000135"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.892757" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.879744" elapsed="0.013650"/>
</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-06-06T03:22:44.901839" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.895728" elapsed="0.006222"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.895198" elapsed="0.006840"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.895157" elapsed="0.006941"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.905460" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.902803" elapsed="0.002704"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.902296" elapsed="0.003246"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.902251" elapsed="0.003315"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.906227" 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-06-06T03:22:44.905800" elapsed="0.000454"/>
</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-06-06T03:22:44.906705" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.906430" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.907262" 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-06-06T03:22:44.906958" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.906788" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.906407" elapsed="0.000938"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.907887" 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-06-06T03:22:44.907509" elapsed="0.000405"/>
</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-06-06T03:22:44.908221" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.907984" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.908779" 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-06-06T03:22:44.908468" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.908302" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.907966" elapsed="0.000896"/>
</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-06-06T03:22:44.909023" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:22:44.909861" 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-06-06T03:22:44.909543" elapsed="0.000344"/>
</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-06-06T03:22:44.910050" elapsed="0.003753"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:22:44.894245" elapsed="0.019630"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:22:44.913926" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:22:44.916499" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:22:44.878657" elapsed="0.037870"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:44.916582" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ibgp_peers</arg>
<arg>mapping=${mapping}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:22:44.770117" elapsed="0.146606"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${mapping}</arg>
<arg>NAME=example-ebgp-peer1</arg>
<arg>IP=${eBGP_PEER1_IP}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.916890" elapsed="0.000241"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.977478" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:44.976952" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:44.978600" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:44.978275" elapsed="0.000440">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:44.978942" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:44.977813" elapsed="0.001163"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.979719" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:44.979211" elapsed="0.000544"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:44.980151" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:44.980385" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:44.979974" elapsed="0.000446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.980955" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.980629" elapsed="0.000386"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.982376" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer1', 'IP': '127.0.0.3', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:44.982041" elapsed="0.000395"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.983023" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.982672" elapsed="0.000384"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.983942" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.983539" elapsed="0.000437"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.984942" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.984653" elapsed="0.000323"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.985044" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:22:44.985249" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.984224" elapsed="0.001057"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.985489" elapsed="0.000340"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:22:44.983353" elapsed="0.002526"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.986574" level="INFO">${value} = example-ebgp-peer1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.986200" elapsed="0.000408"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.987870" level="INFO">${encoded} = example-ebgp-peer1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.987576" elapsed="0.000328"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.987969" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:22:44.988162" level="INFO">${encoded_value} = example-ebgp-peer1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.986866" elapsed="0.001328"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.988399" elapsed="0.000300"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-ebgp-peer1</var>
<status status="PASS" start="2026-06-06T03:22:44.986020" elapsed="0.002732"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.989441" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.989067" elapsed="0.000405"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.990414" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.990155" elapsed="0.000290"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.990505" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:22:44.990712" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.989749" elapsed="0.000995"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.990943" elapsed="0.000272"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:22:44.988889" elapsed="0.002377"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.992030" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:44.991632" elapsed="0.000432"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:44.993018" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.992753" elapsed="0.000297"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:44.993111" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:22:44.993293" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:44.992308" elapsed="0.001015"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:44.993524" elapsed="0.000296"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:44.991457" elapsed="0.002406"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:44.983126" elapsed="0.010771"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:44.993942" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:44.994101" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer1', 'IP': '127.0.0.3', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:44.981576" elapsed="0.012551"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:44.981120" elapsed="0.013039"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:44.994344" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:44.994187" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:44.981085" elapsed="0.013334"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:44.995242" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:44.994569" elapsed="0.000703"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:44.995321" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:44.976087" elapsed="0.019358"/>
</kw>
<msg time="2026-06-06T03:22:44.995502" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:44.957053" elapsed="0.038499"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.009525" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.023754" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.037880" elapsed="0.000043"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.038152" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.038349" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.038891" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.038731" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:45.038712" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.039122" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.039293" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.039461" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:45.038668" elapsed="0.000846"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.038516" elapsed="0.001026"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.039709" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.039793" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:22:45.039962" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:44.950593" elapsed="0.089400"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.041283" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.040956" elapsed="0.000389"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:45.054426" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.054475" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.054574" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:22:45.044723" elapsed="0.009877"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.041413" elapsed="0.013251"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.055022" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.054694" elapsed="0.000464"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.041394" elapsed="0.013811"/>
</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-06-06T03:22:45.063535" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.057519" elapsed="0.006115"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.056979" elapsed="0.006765"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.056938" elapsed="0.006864"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.067855" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.064428" elapsed="0.003473"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.063927" elapsed="0.004009"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.063890" elapsed="0.004071"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.068562" 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-06-06T03:22:45.068158" elapsed="0.000432"/>
</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-06-06T03:22:45.068930" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.068679" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.069513" 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-06-06T03:22:45.069205" elapsed="0.000414"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.069015" elapsed="0.000661"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.068658" elapsed="0.001040"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.070241" 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-06-06T03:22:45.069873" elapsed="0.000395"/>
</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-06-06T03:22:45.070579" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.070338" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.071360" 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-06-06T03:22:45.070886" elapsed="0.000500"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.070678" elapsed="0.000745"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.070320" elapsed="0.001124"/>
</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-06-06T03:22:45.071604" elapsed="0.000370"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:22:45.072442" 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-06-06T03:22:45.072145" elapsed="0.000323"/>
</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-06-06T03:22:45.072628" elapsed="0.002854"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:22:45.056033" elapsed="0.019519"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:22:45.075601" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:22:45.078184" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:22:45.040293" elapsed="0.037918"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.078266" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ebgp_peers</arg>
<arg>mapping=${mapping}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:22:44.917377" elapsed="0.161014"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${mapping}</arg>
<arg>NAME=example-ebgp-peer2</arg>
<arg>IP=${eBGP_PEER2_IP}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.078556" elapsed="0.000265"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.126188" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.125805" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.127009" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.126751" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.127181" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.126391" elapsed="0.000814"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.127776" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.127376" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.128109" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/ebgp_peers/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:45.128316" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:45.127969" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.128790" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.128508" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.129918" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer2', 'IP': '127.0.0.4', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.129604" elapsed="0.000360"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.130403" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.130130" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.131164" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.130852" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.131943" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.131724" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.132022" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.132177" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.131382" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.132358" elapsed="0.000240"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:22:45.130677" elapsed="0.001985"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.133395" level="INFO">${value} = example-ebgp-peer2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.132919" elapsed="0.000503"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.134167" level="INFO">${encoded} = example-ebgp-peer2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.133955" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.134245" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:45.134396" level="INFO">${encoded_value} = example-ebgp-peer2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.133613" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.134577" elapsed="0.000239"/>
</kw>
<var name="${key}">NAME</var>
<var name="${value}">example-ebgp-peer2</var>
<status status="PASS" start="2026-06-06T03:22:45.132782" elapsed="0.002076"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.135406" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.135106" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.136184" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.135971" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.136260" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.136411" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.135624" elapsed="0.000812"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.136618" elapsed="0.000258"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:22:45.134969" elapsed="0.001948"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.137463" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.137166" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.138226" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.138016" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.138302" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.138452" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.137693" elapsed="0.000784"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.138632" elapsed="0.000281"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:45.137030" elapsed="0.001925"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:45.130482" elapsed="0.008509"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:45.139034" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:22:45.139192" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'NAME': 'example-ebgp-peer2', 'IP': '127.0.0.4', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:45.129275" elapsed="0.009944"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.128967" elapsed="0.010284"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.139476" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.139318" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.128944" elapsed="0.010609"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.140337" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:45.139718" elapsed="0.000647"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.140415" elapsed="0.000027"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:45.125170" elapsed="0.015379"/>
</kw>
<msg time="2026-06-06T03:22:45.140605" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.110975" elapsed="0.029698"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.154734" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.168608" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//ebgp_peers/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.182549" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.182766" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.182949" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.183318" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.183170" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:45.183154" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.183541" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.183726" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.183898" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:45.183126" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.183026" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.184125" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.184200" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:45.184338" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:45.106144" elapsed="0.078259"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.185527" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.185274" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:45.196103" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.196173" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.196271" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:22:45.187936" elapsed="0.008362"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.185656" elapsed="0.010683"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.196528" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.196367" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.185623" elapsed="0.010988"/>
</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-06-06T03:22:45.200513" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.197834" elapsed="0.002722"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.197584" elapsed="0.003008"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.197566" elapsed="0.003051"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.205101" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.201005" elapsed="0.004164"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.200692" elapsed="0.004530"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.200674" elapsed="0.004584"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.206120" 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-06-06T03:22:45.205522" elapsed="0.000638"/>
</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-06-06T03:22:45.206625" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.206266" elapsed="0.000466"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.207458" 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-06-06T03:22:45.207017" elapsed="0.000479"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.206769" elapsed="0.000779"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.206238" elapsed="0.001341"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.208392" 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-06-06T03:22:45.207845" elapsed="0.000587"/>
</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-06-06T03:22:45.208913" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.208534" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.209741" 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-06-06T03:22:45.209280" elapsed="0.000500"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.209034" elapsed="0.000799"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.208507" elapsed="0.001357"/>
</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-06-06T03:22:45.210096" elapsed="0.000519"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:22:45.211311" 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-06-06T03:22:45.210893" elapsed="0.000511"/>
</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-06-06T03:22:45.211676" elapsed="0.003006"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:22:45.197165" elapsed="0.017583"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:22:45.214798" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:22:45.217357" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:22:45.184694" elapsed="0.032691"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.217441" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}ebgp_peers</arg>
<arg>mapping=${mapping}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:22:45.079064" elapsed="0.138503"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:22:45.218178" elapsed="0.000245"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:22:45.217868" elapsed="0.000621"/>
</kw>
<doc>Delete all previously configured BGP peers.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:22:44.679100" elapsed="0.539428"/>
</test>
<test id="s1-s9-t15" name="TC_LAS_Reconfigure_Odl_To_Accept_Connection" line="296">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:45.222139" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:45.221869" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.223410" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.223299" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.223280" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.229160" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.229053" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.229035" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.230246" 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-06-06T03:22:45.229860" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.230757" 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-06-06T03:22:45.230441" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:45.230829" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.230984" 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-06-06T03:22:45.229460" elapsed="0.001550"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:45.237007" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.236898" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.236878" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:45.238254" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.238147" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.238128" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:45.238795" 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-06-06T03:22:45.238474" elapsed="0.000348"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.239205" level="INFO">${current_connection_index} = 7</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-06-06T03:22:45.238989" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.270313" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:45.239754" elapsed="0.030663"/>
</kw>
<msg time="2026-06-06T03:22:45.270584" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:45.270631" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:45.239397" elapsed="0.031405"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.296089" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:22:45.271355" elapsed="0.024840"/>
</kw>
<msg time="2026-06-06T03:22:45.296355" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:45.296401" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "R "e "c "o "n "f "i "g "u "r "...</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-06-06T03:22:45.270993" elapsed="0.025443"/>
</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-06-06T03:22:45.296766" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.296514" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.296493" elapsed="0.000355"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.297429" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "R "e "c "o "n "f "i "g "u "r "e "_ "O "d "l "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:22:45.297129" elapsed="0.000371"/>
</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-06-06T03:22:45.297816" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.297569" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.297550" elapsed="0.000346"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:45.297930" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:45.300430" elapsed="0.000295"/>
</kw>
<msg time="2026-06-06T03:22:45.300793" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.299387" elapsed="0.001536"/>
</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="NOT RUN" start="2026-06-06T03:22:45.301210" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.301556" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:45.298757" elapsed="0.003012"/>
</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-06-06T03:22:45.298203" elapsed="0.003633"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:45.237844" elapsed="0.064091"/>
</kw>
<msg time="2026-06-06T03:22:45.302028" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:45.302074" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "R "e "c "o "n "f "i "g "u "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:45.237232" elapsed="0.064878"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:45.302297" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:45.302188" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.302169" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.302804" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.303143" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.303216" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:45.236542" elapsed="0.066782"/>
</kw>
<msg time="2026-06-06T03:22:45.303440" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:45.303488" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "R "e "c "o "n "f "i "g "u "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:45.231384" elapsed="0.072140"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.303879" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.303600" elapsed="0.000369"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.303583" elapsed="0.000412"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:45.231238" elapsed="0.072782"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:45.231064" elapsed="0.072986"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:45.228689" elapsed="0.075415"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:45.223012" elapsed="0.081147"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:45.222560" elapsed="0.081645"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:45.219469" elapsed="0.084790"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.305054" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${iBGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.304452" elapsed="0.000631"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.342250" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.341873" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.343043" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.342805" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.343232" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.342449" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.343851" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.343436" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.344184" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:45.344367" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:45.344045" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.344824" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.344555" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.345863" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.345586" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.346568" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.346071" elapsed="0.000524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.347308" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.346987" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.348103" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.347880" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.348181" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:22:45.348337" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.347526" elapsed="0.000836"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.348524" elapsed="0.000254"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:45.346845" elapsed="0.002017"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.349417" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.349115" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.350189" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.349974" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.350266" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.350419" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.349631" elapsed="0.000813"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.350600" elapsed="0.000247"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:45.348978" elapsed="0.001912"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.351465" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.351164" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.352238" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.352024" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.352314" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.352465" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.351698" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.352659" elapsed="0.000225"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:45.351003" elapsed="0.001922"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.353473" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.353173" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.354242" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.354030" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.354318" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.354469" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.353702" elapsed="0.000792"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.354664" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:45.353037" elapsed="0.001890"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.355486" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.355189" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.356256" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.356043" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.356331" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:45.356480" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.355719" elapsed="0.000786"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.356676" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:45.355041" elapsed="0.001899"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:45.346662" elapsed="0.010312"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:45.357016" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:22:45.357176" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:45.345253" elapsed="0.011949"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.344943" elapsed="0.012292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.357413" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.357260" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.344922" elapsed="0.012566"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.358481" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:45.357636" elapsed="0.000909"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.358597" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:45.341232" elapsed="0.017509"/>
</kw>
<msg time="2026-06-06T03:22:45.358796" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.327087" elapsed="0.031757"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.372787" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.386633" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.400536" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.400749" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.400930" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.401299" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.401149" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:45.401134" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.401525" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.401712" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.401885" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:45.401105" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.401006" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.402115" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.402191" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:45.402312" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:45.322364" elapsed="0.079976"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.431788" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.431391" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.432532" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.432320" elapsed="0.000278">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.432708" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.431984" elapsed="0.000750"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.433418" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.432901" elapsed="0.000545"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.433763" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:45.433893" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:45.433609" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.434321" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.434079" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:22:45.434788" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.434446" elapsed="0.000400"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.435316" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.435021" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.434872" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.434427" elapsed="0.000972"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.436253" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:45.435548" elapsed="0.000736"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.436333" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:45.430773" elapsed="0.005683"/>
</kw>
<msg time="2026-06-06T03:22:45.436513" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.416604" elapsed="0.019956"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.450691" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.464573" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.478406" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.478603" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.478800" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.479164" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.479017" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:45.479002" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.479387" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.479558" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.479741" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:45.478974" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.478874" elapsed="0.000951"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.479973" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.480047" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:45.480177" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:45.413733" elapsed="0.066473"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.481464" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.481226" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.481618" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.480881" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.481978" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.481729" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.482559" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.482258" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.482058" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.481710" elapsed="0.000949"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.485208" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.482818" elapsed="0.002417"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:45.485285" elapsed="0.000068"/>
</return>
<msg time="2026-06-06T03:22:45.485484" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:45.480535" elapsed="0.004974"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.486929" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.486679" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.487373" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.487133" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.487850" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.487587" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.488288" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.488049" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:45.489151" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:22:45.488961" elapsed="0.000216"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:22:45.489505" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:22:45.489332" elapsed="0.000198"/>
</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-06-06T03:22:45.489697" elapsed="0.000199"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.490314" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.490054" elapsed="0.000305"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:22:45.490401" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:45.490658" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:22:45.488534" elapsed="0.002151"/>
</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-06-06T03:22:45.507911" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '1075', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:22:45.508056" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.508275" 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-06-06T03:22:45.494437" elapsed="0.013897"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.490763" elapsed="0.017744"/>
</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-06-06T03:22:45.508962" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.508568" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.490739" elapsed="0.018424"/>
</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-06-06T03:22:45.516378" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.511360" elapsed="0.005078"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.510853" elapsed="0.005635"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.510811" elapsed="0.005712"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.520607" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.516947" elapsed="0.003744"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.516602" elapsed="0.004140"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.516578" elapsed="0.004200"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.521543" 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-06-06T03:22:45.521015" elapsed="0.000566"/>
</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-06-06T03:22:45.522058" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.521705" elapsed="0.000436"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.522852" 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-06-06T03:22:45.522408" elapsed="0.000483"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.522175" elapsed="0.000766"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.521677" elapsed="0.001294"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.523733" 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-06-06T03:22:45.523203" elapsed="0.000569"/>
</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-06-06T03:22:45.524208" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.523870" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.524991" 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-06-06T03:22:45.524554" elapsed="0.000474"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.524323" elapsed="0.000756"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.523845" elapsed="0.001263"/>
</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-06-06T03:22:45.525324" elapsed="0.000509"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:22:45.526487" 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-06-06T03:22:45.526100" elapsed="0.000425"/>
</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-06-06T03:22:45.526771" elapsed="0.002616"/>
</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-06-06T03:22:45.509992" elapsed="0.019459"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:22:45.529627" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:22:45.529519" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.529500" elapsed="0.000229"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:22:45.529881" elapsed="0.000034"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.529964" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:45.532493" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:22:45.485852" elapsed="0.046668"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.532585" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:45.532754" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:22:45.310201" elapsed="0.222578"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.533284" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.532915" elapsed="0.000438"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.532896" elapsed="0.000481"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.533411" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:22:45.305354" elapsed="0.228180"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.534438" level="INFO">&amp;{mapping} = { IP=127.0.0.3 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | AS_NUMBER=65432 | PEER_AS=64497 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${eBGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>AS_NUMBER=${LOCAL_AS}</arg>
<arg>PEER_AS=${eBGP_AS}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.533741" elapsed="0.000727"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.571975" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.571577" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.572773" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.572514" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.572941" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.572174" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.573518" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.573134" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.573891" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:45.574049" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:45.573744" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.574480" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.574237" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.575501" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.575242" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.575990" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.575725" elapsed="0.000291"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.576699" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.576387" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.577455" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.577237" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.577534" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:45.577725" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.576914" elapsed="0.000837"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.577915" elapsed="0.000227"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:22:45.576249" elapsed="0.001934"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.578792" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.578475" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.579712" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.579480" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.579792" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.579945" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.579010" elapsed="0.000960"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.580129" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:45.578338" elapsed="0.002055"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.580963" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.580658" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.581763" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.581505" elapsed="0.000285"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.581841" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.581996" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.581181" elapsed="0.000844"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.582182" elapsed="0.000222"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:45.580507" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.583011" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.582710" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.583780" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.583547" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.583858" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.584010" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.583225" elapsed="0.000810"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.584190" elapsed="0.000221"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:45.582559" elapsed="0.001893"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.585017" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.584714" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.585805" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.585569" elapsed="0.000263"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.585882" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.586033" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.585231" elapsed="0.000827"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.586214" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:45.584564" elapsed="0.001914"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.587047" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.586743" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.587812" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.587584" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.587890" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.588041" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.587263" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.588221" elapsed="0.000223"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:45.586591" elapsed="0.001896"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.589088" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:45.588789" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:45.589874" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.589660" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:45.589952" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.590103" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:45.589304" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:45.590283" elapsed="0.000220"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:45.588635" elapsed="0.001911"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:45.576067" elapsed="0.014514"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:45.590624" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:22:45.590813" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:45.574913" elapsed="0.015927"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.574596" elapsed="0.016277"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.591053" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.590899" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.574576" elapsed="0.016555"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.592162" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:45.591278" elapsed="0.000915"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.592243" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:45.570953" elapsed="0.021415"/>
</kw>
<msg time="2026-06-06T03:22:45.592424" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.556827" elapsed="0.035644"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.606613" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.620561" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.634488" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.634704" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.634887" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.635298" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.635147" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:45.635132" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.635525" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.635714" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.635889" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:45.635102" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.634998" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.636122" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.636200" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:45.636322" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:45.552070" elapsed="0.084280"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.665921" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.665528" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.666669" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.666451" elapsed="0.000283">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.666827" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.666114" elapsed="0.000738"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.667407" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.667020" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.667752" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:45.667885" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:45.667600" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.668317" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;$PEER_AS&lt;/peer-as&gt;
        &lt;local-as&gt;$AS_NUMBER&lt;/local-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.668075" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:22:45.668751" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.668444" elapsed="0.000397"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.669331" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.669021" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.668869" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.668424" elapsed="0.000991"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.670298" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:45.669565" elapsed="0.000764"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.670380" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:45.664897" elapsed="0.005608"/>
</kw>
<msg time="2026-06-06T03:22:45.670563" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.650735" elapsed="0.019875"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.684678" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.698588" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.712598" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.712823" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.713007" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.713372" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.713225" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:45.713210" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.713595" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.713788" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.713958" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:45.713182" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.713081" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.714185" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.714294" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:22:45.714428" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:45.647834" elapsed="0.066622"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:45.715733" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.715478" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:45.715891" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:45.715134" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.716235" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.715987" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.716816" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.716491" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.716317" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.715968" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.719461" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.717055" elapsed="0.002434"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:45.719541" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.719709" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:45.714804" elapsed="0.004931"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.721135" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.720887" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.721575" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;64497&lt;/peer-as&gt;
        &lt;local-as&gt;65432&lt;/local-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.721339" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.722044" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.721803" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.722477" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.722241" elapsed="0.000279"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:45.723332" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:22:45.723145" elapsed="0.000214"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:22:45.723702" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:22:45.723514" elapsed="0.000214"/>
</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-06-06T03:22:45.723880" elapsed="0.000196"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.724482" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.724236" elapsed="0.000323"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:22:45.724602" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:45.724787" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:22:45.722736" elapsed="0.002076"/>
</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-06-06T03:22:45.738626" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '996', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
        &lt;peer-as&gt;64497&lt;/peer-as&gt;
        &lt;local-as&gt;65432&lt;/local-as&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:22:45.738725" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.738825" 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-06-06T03:22:45.727355" elapsed="0.011497"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.724887" elapsed="0.014011"/>
</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-06-06T03:22:45.739085" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.738926" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.724864" elapsed="0.014310"/>
</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-06-06T03:22:45.742797" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.740137" elapsed="0.002703"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.739912" elapsed="0.002963"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.739894" elapsed="0.003006"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.745815" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.743184" elapsed="0.002677"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.742958" elapsed="0.002937"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.742940" elapsed="0.002980"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.746465" 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-06-06T03:22:45.746090" elapsed="0.000402"/>
</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-06-06T03:22:45.746826" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.746563" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.747383" 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-06-06T03:22:45.747079" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.746910" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.746545" elapsed="0.000921"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.748020" 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-06-06T03:22:45.747634" elapsed="0.000413"/>
</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-06-06T03:22:45.748359" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.748118" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.749081" 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-06-06T03:22:45.748630" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.748440" elapsed="0.000704"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.748099" elapsed="0.001102"/>
</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-06-06T03:22:45.749360" elapsed="0.000370"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:22:45.750184" 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-06-06T03:22:45.749903" elapsed="0.000308"/>
</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-06-06T03:22:45.750370" elapsed="0.002663"/>
</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-06-06T03:22:45.739531" elapsed="0.013564"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:22:45.753270" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:22:45.753162" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.753143" 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>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.753508" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.753576" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:45.756137" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:22:45.720061" elapsed="0.036102"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.756228" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:45.756381" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:22:45.539613" elapsed="0.216793"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.756780" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.756503" elapsed="0.000345"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.756486" elapsed="0.000386"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:22:45.756905" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/ebgp_peer</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:22:45.534760" elapsed="0.222266"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.758267" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.757890" elapsed="0.000438"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.757872" elapsed="0.000480"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.758501" elapsed="0.000343"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.764702" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:45.764241" elapsed="0.000490"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:22:45.764957" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:22:45.764811" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.764792" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.765193" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.765372" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.765551" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.765737" elapsed="0.000022"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.765960" elapsed="0.000022"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.766137" elapsed="0.000021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.766308" elapsed="0.000021"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:22:45.763914" elapsed="0.002473"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:45.757674" elapsed="0.008765"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:22:45.757301" elapsed="0.009181"/>
</kw>
<doc>Configure neighbors. One ibgp and one ebgp neighbor with local-as configured.</doc>
<status status="PASS" start="2026-06-06T03:22:45.218871" elapsed="0.547652"/>
</test>
<test id="s1-s9-t16" name="TC_LAS_Start_iBgp_Speaker_And_Verify_Connected" line="316">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:45.770182" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:45.769913" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.771460" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.771349" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.771329" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.777105" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.776998" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.776980" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.778324" 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-06-06T03:22:45.777805" elapsed="0.000546"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.778837" 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-06-06T03:22:45.778518" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:45.778910" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:45.779066" 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-06-06T03:22:45.777403" elapsed="0.001688"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:45.785271" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.785161" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.785142" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:45.786524" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:45.786417" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.786398" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:45.787074" 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-06-06T03:22:45.786763" elapsed="0.000338"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.787485" level="INFO">${current_connection_index} = 7</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-06-06T03:22:45.787266" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.817382" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:45.788034" elapsed="0.029455"/>
</kw>
<msg time="2026-06-06T03:22:45.817674" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:45.817723" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:45.787690" elapsed="0.030070"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.844171" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "i "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V "e "r "i "f "y "_ "C "o "n "n "e "c "t "e "d "[K"
[?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-06-06T03:22:45.818310" elapsed="0.026030"/>
</kw>
<msg time="2026-06-06T03:22:45.844507" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:45.844554" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "i "B "g "p "...</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-06-06T03:22:45.817942" elapsed="0.026647"/>
</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-06-06T03:22:45.844942" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.844701" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.844677" elapsed="0.000346"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.845475" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "i "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V "e "r "i "f "y "_ "C "o "n "n "e "c "t "e "d "[K"
[?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-06-06T03:22:45.845170" elapsed="0.000378"/>
</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-06-06T03:22:45.845860" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.845615" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.845596" elapsed="0.000342"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:45.845972" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:45.848550" elapsed="0.000167"/>
</kw>
<msg time="2026-06-06T03:22:45.848786" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:45.847446" elapsed="0.001469"/>
</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="NOT RUN" start="2026-06-06T03:22:45.849195" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.849537" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:45.846817" elapsed="0.002923"/>
</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-06-06T03:22:45.846256" elapsed="0.003549"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:45.786111" elapsed="0.063791"/>
</kw>
<msg time="2026-06-06T03:22:45.849995" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:45.850050" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "i "B "g "p "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:45.785497" elapsed="0.064589"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:45.850272" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:22:45.850164" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.850145" elapsed="0.000209"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.850769" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.851106" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.851176" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:45.784816" elapsed="0.066467"/>
</kw>
<msg time="2026-06-06T03:22:45.851380" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:45.851424" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "i "B "g "p "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:45.779464" elapsed="0.071995"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:45.851811" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:45.851534" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:45.851517" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:45.779317" elapsed="0.072594"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:45.779145" elapsed="0.072811"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:45.776618" elapsed="0.075393"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:45.771058" elapsed="0.081045"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:45.770605" elapsed="0.081545"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:45.767443" elapsed="0.084760"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:45.852366" elapsed="0.000107"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.853193" level="INFO">${speaker_args} = --firstprefix 8.1.0.0 --prefixlen 28 --amount 1 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug</msg>
<var>${speaker_args}</var>
<arg>--firstprefix ${iBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${PREFIX_LEN} --amount 1 --myip=${iBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.852631" elapsed="0.000589"/>
</kw>
<kw name="Start_BGP_Speaker_And_Verify_Connected" owner="BGPSpeaker">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.854880" level="INFO">${command} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 1 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.854314" elapsed="0.000596"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.855316" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 1 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:45.855072" elapsed="0.000291"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:45.859565" level="INFO">python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 1 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:22:45.859677" level="INFO">${output} = python3 play.py --firstprefix 8.1.0.0 --prefixlen 28 --amount 1 --myip=127.0.0.1 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:45.855518" elapsed="0.004191"/>
</kw>
<arg>${arguments}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:22:45.853991" elapsed="0.005781"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.861235" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:45.860932" elapsed="0.000329"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:45.861824" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:45.861426" elapsed="0.000426"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:45.868223" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:45.868358" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:45.868457" level="FAIL">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.862012" elapsed="0.006991">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig Expected status: 409 != 200</status>
</kw>
<return>
<value>${response.content}</value>
<status status="NOT RUN" start="2026-06-06T03:22:45.869103" elapsed="0.000025"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:22:45.860465" elapsed="0.008791">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.872235" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:47.871420" elapsed="0.000884"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.873614" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:47.872726" elapsed="0.000979"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:47.883038" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:47.884247" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.1?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1119'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.1.0.0/28","prefix":"8.1.0.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.1.0.0/28","prefix":"8.1.0.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:22:47.884401" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:22:47.874069" elapsed="0.010370"/>
</kw>
<return>
<value>${response.content}</value>
<status status="PASS" start="2026-06-06T03:22:47.884523" elapsed="0.000054"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:22:47.870186" elapsed="0.018119"/>
</kw>
<msg time="2026-06-06T03:22:47.888437" level="INFO">${message} = {"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bg...</msg>
<var>${message}</var>
<arg>5x</arg>
<arg>2s</arg>
<arg>Verify_BGP_Speaker_Connection</arg>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:22:45.859957" elapsed="2.028519"/>
</kw>
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:47.888559" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:22:47.888828" level="INFO">${output} = {"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bg...</msg>
<var>${output}</var>
<arg>${speaker_args}</arg>
<arg>session=default</arg>
<arg>speaker_ip=${iBGP_PEER1_IP}</arg>
<doc>Start the BGP speaker python utility, and verifies it's connection.
We can change connected variable to false to verify Speaker did not connect.</doc>
<status status="PASS" start="2026-06-06T03:22:45.853457" elapsed="2.035419"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.889657" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.1","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.1.0.0/28","prefix":"8.1.0.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.1.0.0/28","prefix":"8.1.0.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64496]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"peer-role":"ibgp"}]}</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:47.889271" elapsed="0.000464"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:22:47.890557" elapsed="0.000367"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:22:47.890123" elapsed="0.000891"/>
</kw>
<doc>Verify that peer is present in odl's rib. Peer is configured with local-as.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:22:45.766851" elapsed="2.124217"/>
</test>
<test id="s1-s9-t17" name="TC_LAS_Start_eBgp_Speaker_And_Verify_Connected" line="328">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:47.896493" elapsed="0.000338"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:47.896114" elapsed="0.000801"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:47.898354" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:47.898187" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.898156" elapsed="0.000297"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:47.904999" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:47.904890" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.904871" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.906106" 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-06-06T03:22:47.905713" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.906687" 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-06-06T03:22:47.906300" elapsed="0.000415"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:47.906761" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:47.906923" 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-06-06T03:22:47.905301" elapsed="0.001646"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:47.913061" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:47.912951" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.912931" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:47.914326" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:47.914218" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.914198" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:47.914878" 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-06-06T03:22:47.914545" elapsed="0.000360"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:47.915291" level="INFO">${current_connection_index} = 7</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-06-06T03:22:47.915071" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:47.946993" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:47.915847" elapsed="0.031257"/>
</kw>
<msg time="2026-06-06T03:22:47.947269" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:47.947316" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:47.915482" elapsed="0.031868"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:47.974384" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "e "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V "e "r "i "f "y "_ "C "o "n "n "e "c "t "e "d "[K"
[?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-06-06T03:22:47.947896" elapsed="0.026598"/>
</kw>
<msg time="2026-06-06T03:22:47.974683" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:47.974730" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "e "B "g "p "...</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-06-06T03:22:47.947526" elapsed="0.027240"/>
</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-06-06T03:22:47.975080" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:47.974845" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.974824" elapsed="0.000336"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.975609" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "e "B "g "p "_ "S "p "e "a "k "e "r "_ "A "n "d "_ "V "e "r "i "f "y "_ "C "o "n "n "e "c "t "e "d "[K"
[?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-06-06T03:22:47.975305" elapsed="0.000393"/>
</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-06-06T03:22:47.975991" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:47.975765" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.975747" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:47.976102" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:47.978721" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:22:47.978929" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:47.977587" elapsed="0.001470"/>
</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="NOT RUN" start="2026-06-06T03:22:47.979335" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:47.979696" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:47.976967" elapsed="0.002917"/>
</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-06-06T03:22:47.976405" elapsed="0.003542"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:47.913914" elapsed="0.066130"/>
</kw>
<msg time="2026-06-06T03:22:47.980137" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:47.980182" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "e "B "g "p "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:47.913287" elapsed="0.066968"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:47.980459" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:47.980335" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.980315" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:47.980978" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:47.981323" elapsed="0.000032"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:47.981402" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:47.912560" elapsed="0.068949"/>
</kw>
<msg time="2026-06-06T03:22:47.981604" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:47.981673" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "S "t "a "r "t "_ "e "B "g "p "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:47.907409" elapsed="0.074301"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:47.982048" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:47.981788" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:47.981770" elapsed="0.000356"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:47.907260" elapsed="0.074891"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:47.907077" elapsed="0.075105"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:47.904496" elapsed="0.077740"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:47.897773" elapsed="0.084521"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:47.897134" elapsed="0.085206"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:47.892394" elapsed="0.089999"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ebgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:47.982559" elapsed="0.000126"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.983415" level="INFO">${speaker_args} = --firstprefix 8.0.0.0 --prefixlen 28 --amount 1 --asnumber=64497 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug</msg>
<var>${speaker_args}</var>
<arg>--firstprefix ${eBGP_PEER1_FIRST_PREFIX_IP} --prefixlen ${PREFIX_LEN} --amount 1 --asnumber=${eBGP_AS} --myip=${eBGP_PEER1_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:47.982847" elapsed="0.000596"/>
</kw>
<kw name="Start_BGP_Speaker_And_Verify_Connected" owner="BGPSpeaker">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.985140" level="INFO">${command} = python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 1 --asnumber=64497 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:47.984791" elapsed="0.000379"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.985582" level="INFO">python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 1 --asnumber=64497 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:47.985335" elapsed="0.000294"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:47.989249" level="INFO">python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 1 --asnumber=64497 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:22:47.989344" level="INFO">${output} = python3 play.py --firstprefix 8.0.0.0 --prefixlen 28 --amount 1 --asnumber=64497 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:47.985801" elapsed="0.003571"/>
</kw>
<arg>${arguments}</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:22:47.984395" elapsed="0.005040"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.990883" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:47.990566" elapsed="0.000344"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:47.991444" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:47.991072" elapsed="0.000434"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:47.999231" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:47.999368" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:47.999481" level="FAIL">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig Expected status: 409 != 200</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:22:47.991686" elapsed="0.008265">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig Expected status: 409 != 200</status>
</kw>
<return>
<value>${response.content}</value>
<status status="NOT RUN" start="2026-06-06T03:22:48.000023" elapsed="0.000020"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:22:47.990132" elapsed="0.010007">Url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig Expected status: 409 != 200</status>
</kw>
<kw name="Verify_BGP_Speaker_Connection" owner="BGPSpeaker">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.003870" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>200</arg>
<arg>404</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:50.003011" elapsed="0.000932"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.005255" level="INFO">${url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig</msg>
<var>${url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F${ip}?content=nonconfig</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:50.004343" elapsed="0.000974"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:22:50.603314" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:50.604025" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F127.0.0.3?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '864'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.3","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.0.0.0/28","prefix":"8.0.0.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64497]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"peer-role":"ebgp"}]} 
 </msg>
<msg time="2026-06-06T03:22:50.604198" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${url}</arg>
<arg>expected_status=${exp_status_code}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:22:50.005714" elapsed="0.598514"/>
</kw>
<return>
<value>${response.content}</value>
<status status="PASS" start="2026-06-06T03:22:50.604312" elapsed="0.000049"/>
</return>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Verifies peer's presence in bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:22:50.001052" elapsed="0.606101"/>
</kw>
<msg time="2026-06-06T03:22:50.607253" level="INFO">${message} = {"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.3","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bg...</msg>
<var>${message}</var>
<arg>5x</arg>
<arg>2s</arg>
<arg>Verify_BGP_Speaker_Connection</arg>
<arg>${session}</arg>
<arg>${speaker_ip}</arg>
<arg>${connected}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:22:47.989606" elapsed="2.617674"/>
</kw>
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:50.607338" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.607494" level="INFO">${output} = {"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.3","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bg...</msg>
<var>${output}</var>
<arg>${speaker_args}</arg>
<arg>session=default</arg>
<arg>speaker_ip=${eBGP_PEER1_IP}</arg>
<doc>Start the BGP speaker python utility, and verifies it's connection.
We can change connected variable to false to verify Speaker did not connect.</doc>
<status status="PASS" start="2026-06-06T03:22:47.983776" elapsed="2.623744"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.608076" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://127.0.0.3","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"8.0.0.0/28","prefix":"8.0.0.0/28","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"as-path":{"segments":[{"as-sequence":[64497]}]},"ipv4-next-hop":{"global":"192.0.2.1"}}}]}}]},"peer-role":"ebgp"}]}</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:50.607756" elapsed="0.000445"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:22:50.608848" elapsed="0.000252"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:22:50.608500" elapsed="0.000665"/>
</kw>
<doc>Verify that peer is present in odl's rib. Peer is configured with local-as.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:22:47.891510" elapsed="2.717694"/>
</test>
<test id="s1-s9-t18" name="TC_LAS_Verify_iBGP_Rib_Out" line="340">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:22:50.612908" elapsed="0.000218"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:22:50.612622" elapsed="0.000560"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.614240" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:50.614120" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.614098" elapsed="0.000210"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.619883" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:50.619775" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.619756" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.620973" 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-06-06T03:22:50.620568" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.621467" 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-06-06T03:22:50.621169" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:22:50.621564" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:50.621751" 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-06-06T03:22:50.620183" elapsed="0.001594"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:22:50.629574" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:50.629450" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.629431" elapsed="0.000229"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:22:50.630863" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:50.630747" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.630728" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:22:50.631384" 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-06-06T03:22:50.631083" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:22:50.631810" level="INFO">${current_connection_index} = 8</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-06-06T03:22:50.631576" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:22:50.661699" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:22:50.632345" elapsed="0.029516"/>
</kw>
<msg time="2026-06-06T03:22:50.662066" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:22:50.662113" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:22:50.632004" elapsed="0.030144"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:22:50.700623" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "i "B "G "P "_ "R "i "b "_ "O "u "t "[K"
[?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-06-06T03:22:50.662810" elapsed="0.037926"/>
</kw>
<msg time="2026-06-06T03:22:50.700898" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:22:50.700946" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "i "B "G "...</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-06-06T03:22:50.662376" elapsed="0.038606"/>
</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-06-06T03:22:50.701348" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.701076" elapsed="0.000422"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.701049" elapsed="0.000478"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.702005" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "i "B "G "P "_ "R "i "b "_ "O "u "t "[K"
[?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-06-06T03:22:50.701697" elapsed="0.000374"/>
</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-06-06T03:22:50.702362" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.702139" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.702120" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:22:50.702477" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:22:50.705136" elapsed="0.000162"/>
</kw>
<msg time="2026-06-06T03:22:50.705362" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:50.704034" elapsed="0.001462"/>
</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="NOT RUN" start="2026-06-06T03:22:50.705794" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.706136" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:22:50.703377" elapsed="0.002947"/>
</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-06-06T03:22:50.702815" elapsed="0.003574"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:22:50.630419" elapsed="0.076070"/>
</kw>
<msg time="2026-06-06T03:22:50.706584" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:50.706631" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "i "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:50.629819" elapsed="0.076870"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:22:50.706878" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:50.706769" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.706750" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.707371" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.707728" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.707802" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:22:50.629107" elapsed="0.078804"/>
</kw>
<msg time="2026-06-06T03:22:50.708006" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:22:50.708051" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "i "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:22:50.622158" elapsed="0.085931"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.708423" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.708167" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.708149" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:22:50.622010" elapsed="0.086515"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:22:50.621835" elapsed="0.086723"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:22:50.619393" elapsed="0.089222"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:22:50.613819" elapsed="0.094870"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:22:50.613341" elapsed="0.095395"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:22:50.610232" elapsed="0.098557"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.709807" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | AS_NUMBER=65432 | PEER_AS=64497 | PREFIXLEN=8.0.0.0/28 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${iBGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>AS_NUMBER=${LOCAL_AS}</arg>
<arg>PEER_AS=${eBGP_AS}</arg>
<arg>PREFIXLEN=${eBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.708987" elapsed="0.000882"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.765202" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:50.764796" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:50.766032" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:50.765762" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:50.766202" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:50.765403" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.766801" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:50.766398" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:50.767134" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:50.767295" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:50.766995" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.767745" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:50.767484" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.768772" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:50.768490" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.769268" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.768985" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.770014" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.769683" elapsed="0.000357"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.770952" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.770582" elapsed="0.000397"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.771032" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:50.771185" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.770233" elapsed="0.000977"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.771367" elapsed="0.000305"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:50.769528" elapsed="0.002187"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.772302" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.771979" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.773486" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.773045" elapsed="0.000468"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.773567" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.773736" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.772681" elapsed="0.001080"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.773919" elapsed="0.000312"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:50.771827" elapsed="0.002447"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.774860" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.774522" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.775772" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.775418" elapsed="0.000381"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.775850" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.776000" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.775075" elapsed="0.000950"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.776180" elapsed="0.000268"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:50.774385" elapsed="0.002106"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.777109" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.776753" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.778024" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.777687" elapsed="0.000363"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.778102" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.778252" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.777328" elapsed="0.000949"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.778432" elapsed="0.000286"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:50.776601" elapsed="0.002159"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.779332" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.779011" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.780254" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.779918" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.780331" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:50.780483" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.779545" elapsed="0.000963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.780681" elapsed="0.000273"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:50.778872" elapsed="0.002132"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.781574" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.781255" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.782498" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.782152" elapsed="0.000373"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.782575" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.782763" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.781807" elapsed="0.000980"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.782942" elapsed="0.000268"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:50.781117" elapsed="0.002135"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.783839" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.783500" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.784748" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.784398" elapsed="0.000377"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.784825" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.784974" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.784055" elapsed="0.000956"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.785167" elapsed="0.000460"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:50.783363" elapsed="0.002356"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.786296" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:50.785974" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:50.787222" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.786891" elapsed="0.000357"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:50.787298" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:50.787447" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:50.786508" elapsed="0.000964"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:50.787628" elapsed="0.000284"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:50.785835" elapsed="0.002119"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:50.769347" elapsed="0.018641"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:50.788031" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:22:50.788188" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:50.768162" elapsed="0.020053"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:50.767860" elapsed="0.020387"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.788422" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.788272" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.767840" elapsed="0.020658"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.789368" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:50.788657" elapsed="0.000739"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:50.789446" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:50.764158" elapsed="0.025412"/>
</kw>
<msg time="2026-06-06T03:22:50.789625" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:50.750012" elapsed="0.039678"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.803865" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.818047" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.831974" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.832245" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.832432" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.832859" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.832689" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:50.832671" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.833285" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.833457" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.833626" elapsed="0.000033"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:50.832622" elapsed="0.001072"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.832514" elapsed="0.001206"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.833873" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.833955" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:22:50.834102" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:50.745273" elapsed="0.088856"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:50.835514" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:50.835221" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:50.835704" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:50.834830" elapsed="0.000900"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.836062" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.835802" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.836622" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:50.836328" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:50.836143" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.835783" elapsed="0.000938"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.839524" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:50.836910" elapsed="0.002642"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:50.839604" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:50.839774" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:50.834460" elapsed="0.005339"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:50.841061" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:50.840820" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:50.841217" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:50.840444" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:50.841450" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:22:50.841314" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:50.841294" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.841733" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.841913" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.841980" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:50.844136" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:50.840112" elapsed="0.004051"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.845592" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:50.845335" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:50.846062" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:50.845815" elapsed="0.000292"/>
</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-06-06T03:22:50.855529" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:50.855688" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:50.855805" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:50.848481" elapsed="0.007730">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:50.846175" elapsed="0.010122">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:50.856488" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.856330" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:50.846157" elapsed="0.010420">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:50.856980" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.857112" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:50.857076" elapsed="0.000076"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:50.857058" elapsed="0.000116"/>
</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-06-06T03:22:50.857321" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.857391" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:50.844472" elapsed="0.013023">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.857570" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:50.719949" elapsed="0.137731">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:50.858001" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:50.857810" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:50.857792" elapsed="0.000307"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:50.858133" elapsed="0.000014"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:50.715172" elapsed="0.143058">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.921156" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:51.920750" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:51.922037" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:51.921777" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:51.922207" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:51.921406" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.922809" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:51.922403" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:51.923144" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:51.923310" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:51.923004" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.923769" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:51.923500" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.924827" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:51.924540" elapsed="0.000334"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.925317" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.925044" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.926196" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.925764" elapsed="0.000459"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.927147" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.926800" elapsed="0.000374"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.927228" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:22:51.927389" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.926420" elapsed="0.000994"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.927575" elapsed="0.000318"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:51.925604" elapsed="0.002383"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.928573" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.928245" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.929695" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.929338" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.929773" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:51.929927" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.928971" elapsed="0.000981"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.930110" elapsed="0.000275"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:51.928106" elapsed="0.002322"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.931022" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.930696" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.931955" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.931590" elapsed="0.000392"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.932034" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:51.932186" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.931242" elapsed="0.000970"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.932367" elapsed="0.000288"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:51.930543" elapsed="0.002156"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.933273" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.932951" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.934217" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.933881" elapsed="0.000363"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.934295" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:51.934447" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.933516" elapsed="0.000955"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.934628" elapsed="0.000286"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:51.932814" elapsed="0.002144"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.935530" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.935208" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.936455" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.936123" elapsed="0.000359"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.936533" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:51.936704" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.935775" elapsed="0.000955"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.936889" elapsed="0.000274"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:51.935072" elapsed="0.002135"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.937819" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.937475" elapsed="0.000371"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.938739" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.938386" elapsed="0.000380"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.938817" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:51.938969" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.938038" elapsed="0.000956"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.939150" elapsed="0.000271"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:51.937337" elapsed="0.002128"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.940121" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.939794" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.941041" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.940703" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.941119" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:51.941272" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.940340" elapsed="0.000971"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.941471" elapsed="0.000490"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:51.939617" elapsed="0.002389"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.942591" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:51.942268" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:51.943505" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.943173" elapsed="0.000358"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:51.943583" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:51.943773" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:51.942827" elapsed="0.000971"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:51.943955" elapsed="0.000277"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:51.942128" elapsed="0.002147"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:51.925413" elapsed="0.018897"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:51.944353" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:51.944516" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:51.924204" elapsed="0.020339"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:51.923893" elapsed="0.020682"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.944771" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:51.944601" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:51.923870" elapsed="0.020981"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.945739" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:51.945001" elapsed="0.000767"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:51.945818" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:51.920108" elapsed="0.025837"/>
</kw>
<msg time="2026-06-06T03:22:51.946000" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:51.905665" elapsed="0.040383"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.960024" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.973943" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.988046" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.988248" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.988433" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.988826" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:51.988671" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:51.988653" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.989056" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.989248" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.989427" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:51.988611" elapsed="0.000870"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:51.988510" elapsed="0.000997"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.989676" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:51.989754" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:51.989878" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:51.900773" elapsed="0.089132"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:51.991171" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:51.990933" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:51.991330" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:51.990566" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.991696" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:51.991427" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.992426" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:51.991961" elapsed="0.000492"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:51.991780" elapsed="0.000708"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:51.991408" elapsed="0.001102"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:51.995472" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:51.992683" elapsed="0.002817"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:51.995553" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:51.995722" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:51.990233" elapsed="0.005515"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:51.997009" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:51.996766" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:51.997217" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:51.996400" elapsed="0.000842"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:51.997454" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:51.997315" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:51.997296" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.997707" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:51.997885" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:51.997953" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:52.000100" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:51.996066" elapsed="0.004061"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:52.001548" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:52.001294" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:52.002023" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:52.001773" elapsed="0.000295"/>
</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-06-06T03:22:52.010329" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:52.010465" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:52.010563" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:52.004444" elapsed="0.006500">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:52.002135" elapsed="0.008897">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:52.011226" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:52.011066" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:52.002116" elapsed="0.009198">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:52.011707" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:52.011842" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:52.011804" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:52.011787" elapsed="0.000119"/>
</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-06-06T03:22:52.012056" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:52.012127" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:52.000440" elapsed="0.011791">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:52.012351" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:51.873457" elapsed="0.138992">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:52.012749" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:52.012545" elapsed="0.000279"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:52.012527" elapsed="0.000321"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:52.012882" elapsed="0.000014"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:51.866608" elapsed="0.146374">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.076788" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:53.076334" elapsed="0.000488"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:53.077628" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:53.077370" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:53.077817" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:53.077013" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.078448" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:53.078017" elapsed="0.000459"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:53.078806" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:53.078976" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:53.078660" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.079416" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:53.079168" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.080501" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:53.080237" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.081010" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.080738" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.081806" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.081417" elapsed="0.000415"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.082821" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.082388" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.082904" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:22:53.083072" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.082026" elapsed="0.001072"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.083261" elapsed="0.000289"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:53.081276" elapsed="0.002317"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.084368" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.083864" elapsed="0.000531"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.085295" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.084956" elapsed="0.000366"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.085375" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:53.085528" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.084589" elapsed="0.000964"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.085728" elapsed="0.000275"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:53.083725" elapsed="0.002327"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.086830" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.086483" elapsed="0.000374"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.087745" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.087392" elapsed="0.000380"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.087823" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:53.087974" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.087048" elapsed="0.000951"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.088155" elapsed="0.000273"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:53.086346" elapsed="0.002125"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.089064" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.088739" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.089989" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.089628" elapsed="0.000388"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.090100" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:22:53.090256" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.089281" elapsed="0.001001"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.090440" elapsed="0.000307"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:53.088584" elapsed="0.002205"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.091373" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.091041" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.092289" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.091956" elapsed="0.000360"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.092367" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:53.092518" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.091592" elapsed="0.000951"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.092714" elapsed="0.000270"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:53.090904" elapsed="0.002122"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.093735" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.093273" elapsed="0.000489"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.094701" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.094323" elapsed="0.000467"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.094845" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:53.095000" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.093955" elapsed="0.001070"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.095180" elapsed="0.000275"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:53.093138" elapsed="0.002360"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.096094" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.095765" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.097194" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.096668" elapsed="0.000553"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.097274" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:53.097424" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.096310" elapsed="0.001139"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.097604" elapsed="0.000285"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:53.095610" elapsed="0.002320"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.098524" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:53.098201" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:53.099464" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.099127" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:53.099542" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:53.099713" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:53.098776" elapsed="0.000962"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:53.099895" elapsed="0.000363"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:53.098065" elapsed="0.002237"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:53.081091" elapsed="0.019245"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:53.100380" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:53.100544" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:53.079899" elapsed="0.020672"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:53.079542" elapsed="0.021062"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.100811" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:53.100632" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:53.079518" elapsed="0.021372"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.101839" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:53.101042" elapsed="0.000828"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:53.101922" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:53.075650" elapsed="0.026445"/>
</kw>
<msg time="2026-06-06T03:22:53.102169" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:53.060238" elapsed="0.041986"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.117279" elapsed="0.000056"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.131726" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.145571" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.145815" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.146027" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.146451" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:53.146294" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:53.146275" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.146700" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.146875" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.147044" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:53.146235" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.146117" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.147276" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.147355" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:22:53.147509" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:53.055395" elapsed="0.092142"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:53.148949" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:53.148663" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:53.149123" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:53.148249" elapsed="0.000899"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.149487" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:53.149220" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.150099" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:53.149771" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:53.149571" elapsed="0.000592"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:53.149201" elapsed="0.000984"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.154221" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:53.150344" elapsed="0.003904"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:53.154302" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:53.154504" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:53.147891" elapsed="0.006638"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:53.155816" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:53.155543" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:53.155977" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:53.155196" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:53.156215" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:53.156076" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:53.156057" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.156451" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.156625" elapsed="0.000037"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.156710" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:53.158894" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:53.154858" elapsed="0.004063"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.160340" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:53.160078" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:53.160819" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:53.160550" elapsed="0.000314"/>
</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-06-06T03:22:53.170965" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:53.171101" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:53.171208" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:53.163279" elapsed="0.008294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:53.160933" elapsed="0.010748">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:53.171876" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:53.171717" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:53.160914" elapsed="0.011051">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:53.172356" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.172528" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:53.172453" elapsed="0.000119"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:53.172436" elapsed="0.000160"/>
</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-06-06T03:22:53.172758" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.172830" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:53.159234" elapsed="0.013701">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.173012" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:53.028617" elapsed="0.144491">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:53.173387" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:53.173202" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:53.173185" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:53.173518" elapsed="0.000014"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:53.023689" elapsed="0.149926">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.236253" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:54.235793" elapsed="0.000501"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:54.237260" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:54.236935" elapsed="0.000417">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:54.237461" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:54.236511" elapsed="0.000978"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.238162" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:54.237710" elapsed="0.000483"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:54.238571" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:54.238790" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:54.238401" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.239334" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:54.239012" elapsed="0.000375"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.240623" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:54.240298" elapsed="0.000509"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.241358" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.241036" elapsed="0.000349"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.242175" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.241808" elapsed="0.000394"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.243128" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.242770" elapsed="0.000385"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.243228" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:22:54.243398" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.242395" elapsed="0.001027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.243584" elapsed="0.000313"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:54.241660" elapsed="0.002281"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.244516" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.244194" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.245617" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.245282" elapsed="0.000376"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.245712" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:54.245864" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.244930" elapsed="0.000959"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.246047" elapsed="0.000271"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:54.244057" elapsed="0.002303"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.246946" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.246609" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.247898" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.247538" elapsed="0.000387"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.247976" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:54.248126" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.247162" elapsed="0.000989"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.248309" elapsed="0.000320"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:54.246472" elapsed="0.002240"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.249456" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.249079" elapsed="0.000405"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.250398" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.250061" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.250475" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:22:54.250630" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.249705" elapsed="0.000972"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.250834" elapsed="0.000276"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:54.248874" elapsed="0.002278"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.251779" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.251417" elapsed="0.000390"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.252703" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.252347" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.252781" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:54.252934" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.251999" elapsed="0.000961"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.253184" elapsed="0.000276"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:54.251279" elapsed="0.002225"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.254104" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.253776" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.255020" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.254685" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.255099" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:54.255265" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.254322" elapsed="0.000968"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.255447" elapsed="0.000316"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:54.253620" elapsed="0.002187"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.256382" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.256057" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.257496" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.256963" elapsed="0.000560"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.257574" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:54.257744" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.256599" elapsed="0.001171"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.257930" elapsed="0.000271"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:54.255920" elapsed="0.002322"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.258830" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:54.258492" elapsed="0.000363"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:54.259797" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.259423" elapsed="0.000402"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:54.259876" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:54.260029" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:54.259045" elapsed="0.001009"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:54.260212" elapsed="0.000270"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:54.258356" elapsed="0.002168"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:54.241445" elapsed="0.019115"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:54.260604" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:54.260789" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:54.239901" elapsed="0.020915"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:54.239482" elapsed="0.021368"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.261039" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:54.260879" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:54.239450" elapsed="0.021667"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.261995" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:54.261268" elapsed="0.000756"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:54.262074" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:54.234940" elapsed="0.027260"/>
</kw>
<msg time="2026-06-06T03:22:54.262292" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:54.220276" elapsed="0.042072"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.276670" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.290596" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.304420" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.304670" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.304869" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.305294" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:54.305138" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:54.305119" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.305525" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.305712" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.305885" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:54.305079" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.304957" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.306245" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.306327" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:22:54.306487" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:54.215352" elapsed="0.091165"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:54.308020" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:54.307677" elapsed="0.000418">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:54.308192" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:54.307258" elapsed="0.000959"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.308634" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:54.308359" elapsed="0.000356"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.309230" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:54.308929" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:54.308741" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:54.308338" elapsed="0.000977"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.312181" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:54.309475" elapsed="0.002734"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:54.312263" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:54.312422" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:54.306881" elapsed="0.005567"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:54.313713" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:54.313458" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:54.313874" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:54.313112" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:54.314108" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:22:54.313971" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:54.313952" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.314341" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.314519" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.314584" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:54.316754" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:54.312775" elapsed="0.004007"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.318196" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:54.317937" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:54.318670" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:54.318407" elapsed="0.000309"/>
</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-06-06T03:22:54.327221" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:54.327356" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:54.327452" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:54.321122" elapsed="0.006718">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:54.318783" elapsed="0.009141">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:54.328196" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:54.328027" elapsed="0.000236"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:54.318765" elapsed="0.009522">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:54.328683" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.328820" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:54.328781" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:54.328763" elapsed="0.000122"/>
</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-06-06T03:22:54.329037" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.329108" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:54.317093" elapsed="0.012118">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.329288" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:54.189396" elapsed="0.139988">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:54.329675" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:54.329478" elapsed="0.000273"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:54.329461" elapsed="0.000314"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:54.329809" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:54.184415" elapsed="0.145491">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.392534" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:55.392134" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:55.393390" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:55.393129" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:55.393566" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:55.392779" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.394172" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:55.393782" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:55.394508" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:55.394761" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:55.394367" elapsed="0.000422"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.395209" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:55.394954" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.396267" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:55.395998" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.396797" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.396483" elapsed="0.000340"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.397608" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.397208" elapsed="0.000463"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.398887" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.398390" elapsed="0.000535"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.398991" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:22:55.399170" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.397959" elapsed="0.001237"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.399385" elapsed="0.000363"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:55.397067" elapsed="0.002740"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.400819" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.400115" elapsed="0.000742"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.401876" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.401426" elapsed="0.000481"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.401959" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:22:55.402143" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.401069" elapsed="0.001100"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.402357" elapsed="0.000357"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:55.399934" elapsed="0.002840"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.403477" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.403100" elapsed="0.000405"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.404601" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.404179" elapsed="0.000505"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.404740" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:55.404899" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.403743" elapsed="0.001181"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.405126" elapsed="0.000288"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:55.402916" elapsed="0.002541"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.406078" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.405728" elapsed="0.000378"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.407040" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.406691" elapsed="0.000376"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.407117" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:55.407422" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.406304" elapsed="0.001142"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.407607" elapsed="0.000294"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:55.405571" elapsed="0.002373"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.408591" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.408262" elapsed="0.000408"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.409571" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.409223" elapsed="0.000375"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.409680" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:55.409840" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.408869" elapsed="0.000997"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.410023" elapsed="0.000275"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:55.408120" elapsed="0.002223"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.410947" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.410597" elapsed="0.000377"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.411879" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.411519" elapsed="0.000386"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.411958" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:55.412113" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.411167" elapsed="0.000972"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.412295" elapsed="0.000282"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:55.410458" elapsed="0.002195"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.413261" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.412910" elapsed="0.000378"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.414523" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.413988" elapsed="0.000563"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.414602" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:55.414775" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.413477" elapsed="0.001324"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.414957" elapsed="0.000272"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:55.412771" elapsed="0.002501"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.415862" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:55.415521" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:55.416820" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.416426" elapsed="0.000422"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:55.416901" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:55.417055" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:55.416080" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:55.417246" elapsed="0.000280"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:55.415384" elapsed="0.002185"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:55.396880" elapsed="0.020726"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:55.417680" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:55.417851" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:55.395662" elapsed="0.022218"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:55.395336" elapsed="0.022578"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.418102" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:55.417942" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:55.395313" elapsed="0.022868"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.419076" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:55.418332" elapsed="0.000810"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:55.419196" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:55.391491" elapsed="0.027834"/>
</kw>
<msg time="2026-06-06T03:22:55.419382" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:55.377155" elapsed="0.042280"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.434258" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.448677" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.463054" elapsed="0.000041"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.463329" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.463523" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.463976" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:55.463819" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:55.463800" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.464214" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.464393" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.464601" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:55.463759" elapsed="0.000914"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.463613" elapsed="0.001089"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.464859" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.464939" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:22:55.465096" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:55.372252" elapsed="0.092873"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:55.466629" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:55.466337" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:55.466815" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:55.465930" elapsed="0.000910"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.467185" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:55.466912" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.467772" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:55.467454" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:55.467269" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:55.466893" elapsed="0.000963"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.471325" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:55.468014" elapsed="0.003349"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:55.471437" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:22:55.471675" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:55.465550" elapsed="0.006162"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:55.473453" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:55.473129" elapsed="0.000412">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:55.473693" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:55.472627" elapsed="0.001102"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:55.474021" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:22:55.473831" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:55.473804" elapsed="0.000334"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.474346" elapsed="0.000030"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.474592" elapsed="0.000028"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.474708" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:22:55.477552" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:55.472147" elapsed="0.005432"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.479006" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:55.478747" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:55.479456" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:55.479212" elapsed="0.000287"/>
</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-06-06T03:22:55.489335" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:55.489470" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:55.489567" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:55.481878" elapsed="0.008113">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:55.479565" elapsed="0.010511">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:55.490275" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:55.490111" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:55.479547" elapsed="0.010819">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:55.490795" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.490938" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:55.490898" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:55.490878" elapsed="0.000126"/>
</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-06-06T03:22:55.491164" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.491236" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:55.477906" elapsed="0.013441">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.491424" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:55.346104" elapsed="0.145419">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:55.491827" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:55.491620" elapsed="0.000281"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:55.491602" elapsed="0.000323"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:55.491958" elapsed="0.000014"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:55.341140" elapsed="0.150916">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.555120" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:56.554718" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:56.555960" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:56.555709" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:56.556135" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:56.555348" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.556818" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:56.556408" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:56.557157" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:56.557303" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:56.557015" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.557758" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:56.557494" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.558838" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:56.558552" elapsed="0.000333"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.559323" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.559051" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.560098" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.559746" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.561037" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.560687" elapsed="0.000377"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.561120" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:22:56.561278" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.560318" elapsed="0.000985"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.561472" elapsed="0.000306"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:56.559589" elapsed="0.002231"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.562580" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.562070" elapsed="0.000537"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.563503" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.563162" elapsed="0.000368"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.563581" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:56.563750" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.562817" elapsed="0.000958"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.563931" elapsed="0.000271"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:56.561935" elapsed="0.002309"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.564826" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.564492" elapsed="0.000359"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.565751" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.565384" elapsed="0.000394"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.565830" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:56.565980" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.565040" elapsed="0.000964"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.566159" elapsed="0.000300"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:56.564356" elapsed="0.002147"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.567095" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.566775" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.567995" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.567663" elapsed="0.000393"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.568110" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:56.568262" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.567309" elapsed="0.000977"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.568441" elapsed="0.000285"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:56.566619" elapsed="0.002149"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.569339" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.569016" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.570248" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.569920" elapsed="0.000355"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.570327" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:56.570493" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.569552" elapsed="0.000965"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.570691" elapsed="0.000269"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:56.568879" elapsed="0.002122"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.571571" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.571251" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.572483" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.572152" elapsed="0.000358"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.572560" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:56.572729" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.571805" elapsed="0.000949"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.572910" elapsed="0.000273"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:56.571114" elapsed="0.002112"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.573831" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.573473" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.574937" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.574586" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.575014" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:56.575165" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.574046" elapsed="0.001144"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.575349" elapsed="0.000273"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:56.573336" elapsed="0.002371"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.576423" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:56.575957" elapsed="0.000494"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:56.577353" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.577017" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:56.577428" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:56.577577" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:56.576667" elapsed="0.000936"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:56.577793" elapsed="0.000271"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:56.575820" elapsed="0.002286"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:56.559404" elapsed="0.018737"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:56.578185" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:22:56.578375" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:56.558207" elapsed="0.020239"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:56.557887" elapsed="0.020595"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.578688" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:56.578510" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:56.557863" elapsed="0.020904"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.579618" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:56.578915" elapsed="0.000748"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:56.579714" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:56.554021" elapsed="0.025819"/>
</kw>
<msg time="2026-06-06T03:22:56.579896" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:56.539701" elapsed="0.040246"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.593945" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.607797" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.621615" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.621827" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.622011" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.622417" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:56.622238" elapsed="0.000238"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:56.622221" elapsed="0.000279"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.622660" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.622837" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.623007" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:56.622191" elapsed="0.000870"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.622089" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.623269" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.623365" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:22:56.623553" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:56.534740" elapsed="0.088846"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:56.624949" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:56.624631" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:56.625120" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:56.624277" elapsed="0.000872"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.625476" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:56.625222" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.626059" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:56.625762" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:56.625558" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:56.625203" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.630250" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:56.626326" elapsed="0.003975"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:56.630355" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:56.630511" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:56.623945" elapsed="0.006591"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:56.631797" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:56.631544" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:56.631955" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:56.631200" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:56.632188" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:22:56.632051" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:56.632032" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.632425" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.632604" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.632698" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:22:56.634888" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:56.630865" elapsed="0.004050"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.636318" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:56.636064" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:56.636796" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:56.636523" elapsed="0.000317"/>
</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-06-06T03:22:56.645749" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:56.645967" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:56.646108" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:56.639229" elapsed="0.007403">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:56.636907" elapsed="0.009841">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:56.646987" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:56.646789" elapsed="0.000265"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:56.636888" elapsed="0.010191">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:56.647509" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.647671" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:56.647612" elapsed="0.000106"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:56.647592" elapsed="0.000149"/>
</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-06-06T03:22:56.647894" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.647968" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:56.635225" elapsed="0.012891">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.648226" elapsed="0.000029"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:56.508460" elapsed="0.139922">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:56.648707" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:56.648494" elapsed="0.000289"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:56.648474" elapsed="0.000334"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:56.648842" elapsed="0.000016"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:56.503561" elapsed="0.145381">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.714405" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:57.714007" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:57.715319" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:57.715067" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:57.715490" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:57.714714" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.716098" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:57.715704" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:57.716462" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:57.716620" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:57.716293" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.717087" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:57.716836" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.718138" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:57.717870" elapsed="0.000315"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.718624" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.718351" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.719404" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.719052" elapsed="0.000378"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.720342" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.719992" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.720438" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:22:57.720600" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.719621" elapsed="0.001004"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.720805" elapsed="0.000290"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:57.718911" elapsed="0.002226"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.721734" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.721396" elapsed="0.000365"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.722833" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.722475" elapsed="0.000386"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.722914" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:57.723070" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.722118" elapsed="0.000977"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.723255" elapsed="0.000275"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:57.721258" elapsed="0.002314"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.724170" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.723844" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.725125" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.724788" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.725204" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:57.725356" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.724414" elapsed="0.000967"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.725577" elapsed="0.000292"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:57.723703" elapsed="0.002209"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.726492" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.726166" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.727420" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.727085" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.727498" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:57.727685" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.726735" elapsed="0.000977"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.727870" elapsed="0.000273"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:57.726026" elapsed="0.002160"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.728827" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.728470" elapsed="0.000384"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.729735" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.729388" elapsed="0.000374"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.729814" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:57.729966" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.729045" elapsed="0.000947"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.730149" elapsed="0.000272"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:57.728301" elapsed="0.002163"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.731056" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.730731" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.731974" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.731622" elapsed="0.000380"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.732053" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:57.732223" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.731273" elapsed="0.000976"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.732418" elapsed="0.000314"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:57.730579" elapsed="0.002199"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.733411" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.733075" elapsed="0.000362"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.734521" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.733995" elapsed="0.000553"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.734600" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:57.734770" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.733629" elapsed="0.001166"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.734958" elapsed="0.000270"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:57.732922" elapsed="0.002348"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.735859" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:57.735518" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:57.736856" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.736459" elapsed="0.000424"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:57.736933" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:57.737115" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:57.736074" elapsed="0.001073"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:57.737528" elapsed="0.000331"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:57.735381" elapsed="0.002524"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:57.718724" elapsed="0.019220"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:57.737991" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:57.738164" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:57.717519" elapsed="0.020674"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:57.717212" elapsed="0.021016"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.738419" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:57.738255" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:57.717189" elapsed="0.021309"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.739393" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:57.738666" elapsed="0.000756"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:57.739472" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:57.713362" elapsed="0.026235"/>
</kw>
<msg time="2026-06-06T03:22:57.739672" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:57.698931" elapsed="0.040797"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.753978" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.767953" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.782073" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.782313" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.782518" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.782952" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:57.782797" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:57.782779" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.783185" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.783357" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.783599" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:57.782741" elapsed="0.000929"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.782612" elapsed="0.001088"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.783856" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.783936" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:57.784076" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:57.693854" elapsed="0.090251"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:57.785513" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:57.785235" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:57.785700" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:57.784839" elapsed="0.000886"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.786066" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:57.785799" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.786630" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:57.786333" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:57.786148" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:57.785779" elapsed="0.000952"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.789561" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:57.786889" elapsed="0.002700"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:57.789655" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:22:57.789815" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:57.784464" elapsed="0.005376"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:57.791109" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:57.790875" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:57.791267" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:57.790490" elapsed="0.000802"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:57.791499" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:22:57.791363" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:57.791344" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.791749" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.791925" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.791991" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:22:57.797540" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:57.790158" elapsed="0.007469"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.801284" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:57.800615" elapsed="0.000782"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:57.802526" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:57.801956" elapsed="0.000673"/>
</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-06-06T03:22:57.816840" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:57.816979" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:57.817093" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:57.808109" elapsed="0.009380">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:57.802832" elapsed="0.014741">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:57.817788" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:57.817608" elapsed="0.000247"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:57.802781" elapsed="0.015098">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:57.818278" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.818416" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:57.818375" elapsed="0.000086"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:57.818357" elapsed="0.000127"/>
</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-06-06T03:22:57.818635" elapsed="0.000037"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.818723" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:57.798552" elapsed="0.020276">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.818904" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:57.665840" elapsed="0.153161">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:57.819284" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:57.819097" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:57.819080" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:57.819415" elapsed="0.000014"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:57.660454" elapsed="0.159059">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.883021" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:58.882587" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:58.883878" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:58.883591" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:58.884054" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:58.883247" elapsed="0.000833"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.884666" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:58.884257" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:22:58.885018" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:22:58.885184" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:22:58.884866" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.885626" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:58.885376" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.886767" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:58.886435" elapsed="0.000380"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.887270" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.886986" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.888076" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.887704" elapsed="0.000399"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.889060" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.888697" elapsed="0.000391"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.889144" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:22:58.889316" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.888312" elapsed="0.001030"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.889507" elapsed="0.000325"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:22:58.887541" elapsed="0.002334"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.890712" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.890128" elapsed="0.000613"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.891677" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.891299" elapsed="0.000407"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.891760" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:22:58.891917" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.890939" elapsed="0.001003"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.892103" elapsed="0.000280"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:22:58.889990" elapsed="0.002436"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.893093" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.892759" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.894050" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.893699" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.894128" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:58.894281" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.893316" elapsed="0.000990"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.894465" elapsed="0.000334"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:22:58.892600" elapsed="0.002244"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.895426" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.895100" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.896371" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.896029" elapsed="0.000368"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.896448" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:58.896601" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.895659" elapsed="0.000967"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.896815" elapsed="0.000280"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:22:58.894959" elapsed="0.002178"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.897749" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.897392" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.898740" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.898340" elapsed="0.000428"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.898819" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:22:58.898982" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.897987" elapsed="0.001021"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.899166" elapsed="0.000276"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:22:58.897254" elapsed="0.002230"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.900094" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.899752" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.901024" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.900681" elapsed="0.000370"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.901109" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:22:58.901266" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.900313" elapsed="0.000978"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.901447" elapsed="0.000319"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:22:58.899597" elapsed="0.002214"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.902407" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.902063" elapsed="0.000370"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.903554" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.903021" elapsed="0.000561"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.903635" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:22:58.903807" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.902663" elapsed="0.001170"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.903992" elapsed="0.000278"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:22:58.901925" elapsed="0.002387"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.904966" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:22:58.904581" elapsed="0.000412"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:22:58.905930" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.905545" elapsed="0.000413"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:22:58.906009" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:58.906161" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:22:58.905185" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:22:58.906346" elapsed="0.000344"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:22:58.904441" elapsed="0.002294"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:22:58.887353" elapsed="0.019418"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:22:58.906815" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:22:58.906981" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:22:58.886095" elapsed="0.020914"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:58.885770" elapsed="0.021272"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.907225" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:58.907068" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:58.885746" elapsed="0.021558"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.908183" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:22:58.907454" elapsed="0.000758"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:22:58.908263" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:22:58.881937" elapsed="0.026453"/>
</kw>
<msg time="2026-06-06T03:22:58.908447" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:22:58.867092" elapsed="0.041404"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.922622" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.936671" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.950818" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.951030" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.951225" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.951685" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:58.951515" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:58.951498" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.951918" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.952092" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.952262" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:22:58.951467" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.951360" elapsed="0.000993"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.952508" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.952586" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:22:58.952735" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:22:58.862169" elapsed="0.090595"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:58.954115" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:58.953844" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:58.954284" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:58.953458" elapsed="0.000850"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.954703" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:58.954380" elapsed="0.000384"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.955272" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:22:58.954974" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:22:58.954789" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:58.954361" elapsed="0.000993"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.958149" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:22:58.955510" elapsed="0.002666"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:22:58.958228" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:22:58.958381" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:58.953102" elapsed="0.005304"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:22:58.959884" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:22:58.959621" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:22:58.960044" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:22:58.959145" elapsed="0.000924"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:22:58.960278" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:22:58.960141" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:22:58.960122" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.960542" elapsed="0.000030"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.960793" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.960905" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:22:58.963056" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:22:58.958808" elapsed="0.004275"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.964490" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:58.964237" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:22:58.964955" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:22:58.964711" elapsed="0.000287"/>
</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-06-06T03:22:58.974719" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:22:58.974910" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:22:58.975052" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:22:58.967384" elapsed="0.008404">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:22:58.965065" elapsed="0.010846">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:22:58.976196" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:58.975961" elapsed="0.000336"/>
</branch>
<status status="FAIL" start="2026-06-06T03:22:58.965046" elapsed="0.011284">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:22:58.976884" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.977073" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:22:58.977019" elapsed="0.000113"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:58.976995" elapsed="0.000168"/>
</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-06-06T03:22:58.977370" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.977468" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:22:58.963402" elapsed="0.014210">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.977742" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:58.836002" elapsed="0.141876">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:22:58.978325" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:22:58.978059" elapsed="0.000368"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:22:58.978033" elapsed="0.000466"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:22:58.978548" elapsed="0.000021"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:58.830791" elapsed="0.147916">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.041130" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:00.040628" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:00.041997" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:00.041736" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:00.042171" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:00.041359" elapsed="0.000838"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.042787" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:00.042371" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:00.043126" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:00.043294" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:00.042982" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.043750" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:00.043485" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.044864" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:00.044581" elapsed="0.000330"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.045385" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.045111" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.046169" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.045812" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.047131" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.046775" elapsed="0.000382"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.047211" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:23:00.047374" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.046394" elapsed="0.001005"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.047560" elapsed="0.000308"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:23:00.045669" elapsed="0.002240"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.048703" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.048160" elapsed="0.000570"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.049739" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.049384" elapsed="0.000382"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.049818" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:00.049972" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.049028" elapsed="0.000969"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.050155" elapsed="0.000273"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:00.048023" elapsed="0.002448"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.051061" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.050737" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.051985" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.051623" elapsed="0.000389"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.052062" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:00.052214" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.051277" elapsed="0.000963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.052401" elapsed="0.000292"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:00.050584" elapsed="0.002152"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.053338" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.053006" elapsed="0.000359"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.054259" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.053919" elapsed="0.000367"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.054336" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:00.054489" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.053556" elapsed="0.000958"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.054685" elapsed="0.000275"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:00.052849" elapsed="0.002153"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.055573" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.055251" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.056501" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.056168" elapsed="0.000361"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.056579" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:00.056748" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.055823" elapsed="0.000951"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.056929" elapsed="0.000285"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:00.055114" elapsed="0.002145"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.057979" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.057633" elapsed="0.000372"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.058903" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.058545" elapsed="0.000385"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.058980" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:00.059132" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.058195" elapsed="0.000962"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.059312" elapsed="0.000273"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:00.057375" elapsed="0.002252"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.060247" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.059928" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.061485" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.061141" elapsed="0.000371"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.061564" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:00.061737" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.060464" elapsed="0.001298"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.061919" elapsed="0.000274"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:23:00.059792" elapsed="0.002443"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.062829" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:00.062485" elapsed="0.000371"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:00.063781" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.063394" elapsed="0.000414"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:00.063860" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:00.064011" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:00.063049" elapsed="0.000987"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:00.064193" elapsed="0.000270"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:00.062348" elapsed="0.002157"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:00.045467" elapsed="0.019073"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:00.064585" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:00.064777" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:00.044241" elapsed="0.020563"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:00.043881" elapsed="0.020957"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.065046" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:00.064868" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:00.043856" elapsed="0.021269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.066007" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:00.065276" elapsed="0.000760"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:00.066087" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:00.039838" elapsed="0.026374"/>
</kw>
<msg time="2026-06-06T03:23:00.066269" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:00.025227" elapsed="0.041096"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.080577" elapsed="0.000057"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.094695" elapsed="0.000054"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.108890" elapsed="0.000057"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.109194" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.109390" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.109853" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:00.109695" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:00.109675" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.110086" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.110259" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.110430" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:00.109617" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.109480" elapsed="0.001030"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.110677" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.110759" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:23:00.110919" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:00.020072" elapsed="0.090877"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:00.112403" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:00.112112" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:00.112572" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:00.111700" elapsed="0.000896"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.113002" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:00.112685" elapsed="0.000376"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.113568" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:00.113270" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:00.113086" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:00.112665" elapsed="0.001003"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.117723" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:00.113826" elapsed="0.003925"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:00.117809" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:23:00.117977" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:00.111319" elapsed="0.006683"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:00.119340" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:00.119075" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:00.119577" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:00.118710" elapsed="0.000892"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:00.119841" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:00.119693" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:00.119672" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.120080" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.120259" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.120326" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:23:00.122505" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:00.118337" elapsed="0.004196"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.124005" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:00.123735" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:00.124494" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:00.124215" elapsed="0.000340"/>
</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-06-06T03:23:00.135005" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:00.135162" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:00.135326" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:00.127071" elapsed="0.008830">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:00.124660" elapsed="0.011376">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:00.136374" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:00.136093" elapsed="0.000380"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:00.124615" elapsed="0.011894">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:00.137181" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.137391" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:00.137330" elapsed="0.000124"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:00.137302" elapsed="0.000186"/>
</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-06-06T03:23:00.137730" elapsed="0.000033"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.137838" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:00.122877" elapsed="0.015120">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.138188" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:22:59.994572" elapsed="0.143759">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:00.138771" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:00.138471" elapsed="0.000410"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:00.138447" elapsed="0.000471"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:00.138966" elapsed="0.000022"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:22:59.989561" elapsed="0.149547">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.203016" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:01.202589" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.203948" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.203675" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:01.204122" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:01.203233" elapsed="0.000914"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.204726" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:01.204320" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.205064" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:01.205230" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:01.204921" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.205692" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.205425" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.206750" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.206467" elapsed="0.000331"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.207236" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.206964" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.208059" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.207696" elapsed="0.000390"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.209001" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.208627" elapsed="0.000455"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.209140" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:01.209304" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.208277" elapsed="0.001052"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.209490" elapsed="0.000314"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:23:01.207538" elapsed="0.002310"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.210602" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.210101" elapsed="0.000528"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.211729" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.211356" elapsed="0.000400"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.211809" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:01.211963" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.211005" elapsed="0.000984"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.212147" elapsed="0.000272"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:01.209962" elapsed="0.002499"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.213068" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.212740" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.213997" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.213636" elapsed="0.000388"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.214075" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:01.214228" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.213288" elapsed="0.000965"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.214410" elapsed="0.000289"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:01.212575" elapsed="0.002167"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.215313" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.214991" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.216435" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.216102" elapsed="0.000360"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.216513" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.216679" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.215753" elapsed="0.000953"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.216862" elapsed="0.000274"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:01.214854" elapsed="0.002324"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.217786" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.217429" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.218700" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.218352" elapsed="0.000375"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.218779" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:01.218932" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.218004" elapsed="0.000954"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.219115" elapsed="0.000306"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:01.217290" elapsed="0.002201"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.220148" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.219811" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.221113" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.220766" elapsed="0.000375"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.221238" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:01.221402" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.220370" elapsed="0.001059"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.221589" elapsed="0.000310"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:01.219631" elapsed="0.002312"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.222595" level="INFO">${value} = 64497</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.222205" elapsed="0.000417"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.224032" level="INFO">${encoded} = 64497</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.223284" elapsed="0.000782"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.224126" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:01.224285" level="INFO">${encoded_value} = 64497</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.222849" elapsed="0.001462"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.224470" elapsed="0.000295"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64497</var>
<status status="PASS" start="2026-06-06T03:23:01.222057" elapsed="0.002752"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.225391" level="INFO">${value} = 8.0.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.225058" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.226332" level="INFO">${encoded} = 8.0.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.225996" elapsed="0.000363"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.226410" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:01.226566" level="INFO">${encoded_value} = 8.0.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.225608" elapsed="0.000984"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.226769" elapsed="0.000273"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.0.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:01.224921" elapsed="0.002166"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:01.207321" elapsed="0.019802"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:01.227168" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.227333" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64497', 'PREFIXLEN': '8.0.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:01.206129" elapsed="0.021232"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:01.205818" elapsed="0.021576"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.227619" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.227421" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.205794" elapsed="0.021924"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.228589" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:01.227868" elapsed="0.000750"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:01.228687" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:01.201959" elapsed="0.026859"/>
</kw>
<msg time="2026-06-06T03:23:01.228876" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:01.187724" elapsed="0.041203"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.243131" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.257493" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.271749" elapsed="0.000063"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.272088" elapsed="0.000032"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.272309" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.272829" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.272637" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:01.272617" elapsed="0.000301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.273073" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.273250" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.273422" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:01.272570" elapsed="0.000906"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.272415" elapsed="0.001089"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.273674" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.273761" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:23:01.273964" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:01.182860" elapsed="0.091136"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.275670" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.275263" elapsed="0.000497">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:01.275860" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:01.274814" elapsed="0.001072"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.276244" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.275961" elapsed="0.000341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.276865" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:01.276533" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:01.276330" elapsed="0.000607"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.275940" elapsed="0.001021"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.280046" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:01.277126" elapsed="0.002949"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:01.280132" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:23:01.280497" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:01.274398" elapsed="0.006126"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.281913" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.281621" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:01.282082" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:01.281263" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:01.282326" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:23:01.282182" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.282162" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.282565" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.282763" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.282831" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:01.285108" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:01.280898" elapsed="0.004239"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.286741" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.286421" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.287326" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.287015" elapsed="0.000521"/>
</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-06-06T03:23:01.301961" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:01.302157" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:01.302324" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:01.293836" elapsed="0.009045">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:01.287934" elapsed="0.015077">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:01.303344" elapsed="0.000063"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.303066" elapsed="0.000413"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:01.287856" elapsed="0.015658">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:01.304149" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.304499" elapsed="0.000037"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:01.304295" elapsed="0.000309"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:01.304266" elapsed="0.000421"/>
</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-06-06T03:23:01.305035" elapsed="0.000050"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.305196" elapsed="0.000034"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:01.285505" elapsed="0.019937">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.305613" elapsed="0.000065"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.156900" elapsed="0.148966">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.306488" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.306076" elapsed="0.000604"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:01.306038" elapsed="0.000700"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.306814" elapsed="0.000032"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.151211" elapsed="0.155819">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<msg time="2026-06-06T03:23:01.307251" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:22:50.710063" elapsed="10.597424">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.310858" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:23:01.310090" elapsed="0.000869"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:23:01.309092" elapsed="0.001984"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:23:01.308301" elapsed="0.002903"/>
</kw>
<doc>Verifies iBGP's adj-rib-out output. Expects local-as, and ebgp peer-as presence.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:22:50.609542" elapsed="10.701749">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</test>
<test id="s1-s9-t19" name="TC_LAS_Verify_eBGP_Rib_Out" line="360">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:01.316083" elapsed="0.000217"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:01.315809" elapsed="0.000549"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.317401" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:01.317276" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.317256" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.323549" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:01.323423" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.323400" elapsed="0.000310"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.324817" 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-06-06T03:23:01.324381" elapsed="0.000464"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.325322" 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-06-06T03:23:01.325017" elapsed="0.000330"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:01.325393" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:01.325558" 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-06-06T03:23:01.323983" elapsed="0.001599"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:01.331746" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:01.331617" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.331596" elapsed="0.000219"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:01.333024" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:01.332915" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.332896" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:01.333551" 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-06-06T03:23:01.333244" elapsed="0.000334"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:01.333983" level="INFO">${current_connection_index} = 8</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-06-06T03:23:01.333761" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:01.365979" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:01.334514" elapsed="0.031682"/>
</kw>
<msg time="2026-06-06T03:23:01.366414" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:01.366462" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:01.334173" elapsed="0.032327"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:01.390379" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "e "B "G "P "_ "R "i "b "_ "O "u "t "[K"
[?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-06-06T03:23:01.367239" elapsed="0.023246"/>
</kw>
<msg time="2026-06-06T03:23:01.390663" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:01.390713" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "e "B "G "...</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-06-06T03:23:01.366785" elapsed="0.023965"/>
</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-06-06T03:23:01.391104" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.390844" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.390815" elapsed="0.000374"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.391717" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "e "B "G "P "_ "R "i "b "_ "O "u "t "[K"
[?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-06-06T03:23:01.391390" elapsed="0.000397"/>
</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-06-06T03:23:01.392079" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.391855" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.391836" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:01.392194" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:01.394890" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:23:01.395101" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:01.393771" elapsed="0.001464"/>
</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="NOT RUN" start="2026-06-06T03:23:01.395532" elapsed="0.000157"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.395959" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:01.393103" elapsed="0.003043"/>
</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-06-06T03:23:01.392519" elapsed="0.003693"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:01.332585" elapsed="0.063725"/>
</kw>
<msg time="2026-06-06T03:23:01.396403" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:01.396449" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "e "B "G "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:01.331975" elapsed="0.064513"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:01.396695" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:01.396566" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.396546" elapsed="0.000236"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.397192" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.397535" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.397608" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:01.331232" elapsed="0.066503"/>
</kw>
<msg time="2026-06-06T03:23:01.397830" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:01.397876" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "V "e "r "i "f "y "_ "e "B "G "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:01.326024" elapsed="0.071889"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.398246" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.397990" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.397972" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:01.325871" elapsed="0.072477"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:01.325661" elapsed="0.072719"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:01.322959" elapsed="0.075477"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:01.316976" elapsed="0.081518"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:01.316517" elapsed="0.082024"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:01.312872" elapsed="0.085725"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.399615" level="INFO">&amp;{mapping} = { IP=127.0.0.3 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | AS_NUMBER=65432 | PEER_AS=64496 | PREFIXLEN=8.1.0.0/28 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${eBGP_PEER1_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>AS_NUMBER=${LOCAL_AS}</arg>
<arg>PEER_AS=${DEFAULT_AS}</arg>
<arg>PREFIXLEN=${iBGP_PEER1_FIRST_PREFIX_IP}/${PREFIX_LEN}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.398817" elapsed="0.000848"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.456461" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:01.456061" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.457300" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.457042" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:01.457470" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:01.456694" elapsed="0.000881"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.458163" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:01.457767" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.458504" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:01.458679" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:01.458360" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.459120" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.458871" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.460182" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.459917" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.460685" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.460394" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.461441" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.461091" elapsed="0.000376"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.462378" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.462031" elapsed="0.000375"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.462459" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:01.462619" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.461680" elapsed="0.000980"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.462822" elapsed="0.000288"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:01.460951" elapsed="0.002201"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.463779" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.463435" elapsed="0.000371"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.464694" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.464342" elapsed="0.000379"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.464772" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.464922" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.463994" elapsed="0.000953"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.465103" elapsed="0.000276"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:01.463297" elapsed="0.002125"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.466190" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.465683" elapsed="0.000534"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.467118" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.466780" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.467219" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:01.467378" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.466410" elapsed="0.000993"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.467562" elapsed="0.000291"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:01.465532" elapsed="0.002364"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.468466" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.468144" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.469424" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.469086" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.469501" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.469669" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.468734" elapsed="0.000961"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.469856" elapsed="0.000273"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:01.468007" elapsed="0.002165"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.470776" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.470426" elapsed="0.000376"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.471722" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.471364" elapsed="0.000385"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.471800" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.471954" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.470991" elapsed="0.000987"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.472136" elapsed="0.000272"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:01.470284" elapsed="0.002166"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.473038" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.472713" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.473951" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.473598" elapsed="0.000381"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.474031" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.474183" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.473253" elapsed="0.000955"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.474370" elapsed="0.000307"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:01.472561" elapsed="0.002160"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.475324" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.474971" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.476325" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.475903" elapsed="0.000448"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.476402" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.476552" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.475540" elapsed="0.001036"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.476748" elapsed="0.000273"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:01.474834" elapsed="0.002229"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.477630" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:01.477312" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:01.478801" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.478246" elapsed="0.000583"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:01.478879" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:01.479030" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:01.477900" elapsed="0.001154"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:01.479225" elapsed="0.000274"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:01.477176" elapsed="0.002364"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:01.460766" elapsed="0.018808"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:01.479617" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:23:01.479797" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:01.459568" elapsed="0.020290"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:01.459257" elapsed="0.020635"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.480074" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.479918" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.459234" elapsed="0.020916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.481020" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:01.480298" elapsed="0.000752"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:01.481100" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:01.455410" elapsed="0.025816"/>
</kw>
<msg time="2026-06-06T03:23:01.481282" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:01.441087" elapsed="0.040243"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.495494" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.509423" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.523407" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.523619" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.523823" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.524220" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.524066" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:01.524049" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.524453" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.524625" elapsed="0.000036"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.524814" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:01.524014" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.523906" elapsed="0.000987"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.525042" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.525168" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:01.525307" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:01.436163" elapsed="0.089172"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.526699" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.526409" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:01.526868" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:01.526033" elapsed="0.000860"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.527241" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.526964" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.527859" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:01.527510" elapsed="0.000378"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:01.527324" elapsed="0.000600"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.526945" elapsed="0.001001"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.530767" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:01.528107" elapsed="0.002690"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:01.530853" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:01.531020" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:01.525682" elapsed="0.005363"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:01.532367" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.532114" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:01.532531" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:01.531758" elapsed="0.000797"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:01.532783" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:01.532627" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:01.532607" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.533017" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.533194" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.533260" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:23:01.535478" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:01.531388" elapsed="0.004117"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.536940" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.536680" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:01.537393" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:01.537146" elapsed="0.000290"/>
</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-06-06T03:23:01.545573" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:01.545838" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:01.545972" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:01.539831" elapsed="0.006633">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:01.537502" elapsed="0.009076">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:01.546871" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.546625" elapsed="0.000338"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:01.537483" elapsed="0.009513">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:01.547541" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.547746" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:01.547694" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:01.547667" elapsed="0.000170"/>
</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-06-06T03:23:01.548046" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.548143" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:01.535838" elapsed="0.012448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.548389" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.409954" elapsed="0.138565">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:01.548925" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:01.548665" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:01.548623" elapsed="0.000436"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:01.549106" elapsed="0.000020"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.404824" elapsed="0.144413">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.612097" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:02.611678" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:02.613076" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:02.612782" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:02.613259" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:02.612409" elapsed="0.000875"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.613912" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:02.613461" elapsed="0.000480"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:02.614253" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:02.614420" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:02.614109" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.614880" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:02.614611" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.615941" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:02.615675" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.616425" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.616154" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.617198" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.616846" elapsed="0.000378"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.618171" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.617797" elapsed="0.000401"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.618252" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:23:02.618415" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.617415" elapsed="0.001024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.618598" elapsed="0.000309"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:02.616706" elapsed="0.002244"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.620988" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.619200" elapsed="0.001816"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.621965" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.621566" elapsed="0.000427"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.622045" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:02.622202" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.621212" elapsed="0.001016"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.622391" elapsed="0.000298"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:02.619063" elapsed="0.003669"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.623315" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.622986" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.624238" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.623897" elapsed="0.000369"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.624318" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:02.624471" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.623532" elapsed="0.000964"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.624721" elapsed="0.000280"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:02.622847" elapsed="0.002198"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.625624" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.625298" elapsed="0.000380"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.626597" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.626259" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.626705" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:02.626858" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.625910" elapsed="0.000974"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.627040" elapsed="0.000274"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:02.625158" elapsed="0.002199"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.627949" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.627607" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.628863" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.628511" elapsed="0.000379"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.628943" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:02.629096" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.628165" elapsed="0.000956"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.629278" elapsed="0.000274"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:02.627470" elapsed="0.002123"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.630223" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.629894" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.631165" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.630827" elapsed="0.000367"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.631245" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:02.631397" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.630442" elapsed="0.000979"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.631578" elapsed="0.000288"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:02.629736" elapsed="0.002173"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.632486" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.632159" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.633607" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.633066" elapsed="0.000568"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.633715" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:02.633889" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.632718" elapsed="0.001198"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.634077" elapsed="0.000278"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:02.632022" elapsed="0.002375"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.635014" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:02.634685" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:02.635933" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.635580" elapsed="0.000381"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:02.636012" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:02.636166" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:02.635232" elapsed="0.000959"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:02.636396" elapsed="0.000292"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:02.634510" elapsed="0.002222"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:02.616505" elapsed="0.020262"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:02.636812" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:02.636975" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:02.615330" elapsed="0.021672"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:02.615004" elapsed="0.022031"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.637222" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:02.637064" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:02.614982" elapsed="0.022319"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.638228" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:02.637452" elapsed="0.000807"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:02.638310" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:02.611012" elapsed="0.027423"/>
</kw>
<msg time="2026-06-06T03:23:02.638492" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:02.596782" elapsed="0.041761"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.652697" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.666786" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.680783" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.681008" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.681199" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.681606" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:02.681452" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:02.681434" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.681872" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.682049" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.682300" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:02.681396" elapsed="0.000965"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.681285" elapsed="0.001104"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.682544" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.682623" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:02.682788" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:02.591812" elapsed="0.091005"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:02.684231" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:02.683931" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:02.684406" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:02.683515" elapsed="0.000916"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.684790" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:02.684503" elapsed="0.000346"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.685358" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:02.685059" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:02.684874" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:02.684484" elapsed="0.000958"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.688327" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:02.685601" elapsed="0.002755"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:02.688413" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:02.688572" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:02.683156" elapsed="0.005442"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:02.689986" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:02.689729" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:02.690147" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:02.689351" elapsed="0.000821"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:02.690388" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:02.690244" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:02.690225" elapsed="0.000248"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.690625" elapsed="0.000037"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.690822" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.690890" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:02.693201" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:02.688929" elapsed="0.004299"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.694836" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:02.694413" elapsed="0.000470"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:02.695350" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:02.695096" elapsed="0.000299"/>
</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-06-06T03:23:02.704097" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:02.704233" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:02.704345" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:02.697827" elapsed="0.006917">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:02.695463" elapsed="0.009367">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:02.705031" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:02.704865" elapsed="0.000232"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:02.695444" elapsed="0.009677">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:02.705507" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.705657" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:02.705604" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:02.705586" elapsed="0.000139"/>
</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-06-06T03:23:02.705894" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.705966" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:02.693543" elapsed="0.012527">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.706145" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:02.566424" elapsed="0.139816">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:02.706518" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:02.706334" elapsed="0.000257"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:02.706317" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:02.706665" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:02.560551" elapsed="0.146212">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.769425" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:03.768994" elapsed="0.000464"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:03.770305" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:03.770028" elapsed="0.000420">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:03.770570" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:03.769649" elapsed="0.000946"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.771190" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:03.770793" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:03.771532" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:03.771723" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:03.771387" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.772171" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:03.771917" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.773249" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:03.772964" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.773754" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.773462" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.774558" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.774172" elapsed="0.000414"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.775509" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.775155" elapsed="0.000381"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.775590" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:03.775776" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.774804" elapsed="0.000997"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.775962" elapsed="0.000294"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:03.774029" elapsed="0.002269"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.777063" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.776547" elapsed="0.000543"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.777990" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.777634" elapsed="0.000383"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.778068" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:03.778220" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.777285" elapsed="0.000960"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.778402" elapsed="0.000472"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:03.776411" elapsed="0.002518"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.779786" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.779286" elapsed="0.000540"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.781190" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.780654" elapsed="0.000575"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.781304" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:23:03.781530" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.780126" elapsed="0.001440"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.781821" elapsed="0.000398"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:03.779131" elapsed="0.003150"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.783466" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.782652" elapsed="0.000864"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.784758" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.784357" elapsed="0.000429"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.784845" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:23:03.785030" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.783899" elapsed="0.001156"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.785222" elapsed="0.000299"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:03.782446" elapsed="0.003119"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.786193" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.785860" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.787145" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.786785" elapsed="0.000388"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.787224" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:03.787379" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.786412" elapsed="0.000992"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.787566" elapsed="0.000305"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:03.785717" elapsed="0.002196"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.788491" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.788164" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.789452" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.789112" elapsed="0.000370"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.789535" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:03.789708" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.788763" elapsed="0.000971"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.789889" elapsed="0.000271"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:03.788028" elapsed="0.002175"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.790792" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.790449" elapsed="0.000370"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.792056" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.791453" elapsed="0.000630"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.792137" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:03.792290" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.791093" elapsed="0.001221"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.792507" elapsed="0.000308"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:03.790315" elapsed="0.002542"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.793501" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:03.793105" elapsed="0.000423"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:03.794418" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.794085" elapsed="0.000360"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:03.794495" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:03.794651" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:03.793739" elapsed="0.000961"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:03.794859" elapsed="0.000308"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:03.792968" elapsed="0.002242"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:03.773839" elapsed="0.021407"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:03.795295" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:03.795502" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:03.772608" elapsed="0.022931"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:03.772296" elapsed="0.023291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.795883" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:03.795630" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:03.772272" elapsed="0.023720"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.797260" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:03.796204" elapsed="0.001097"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:03.797373" elapsed="0.000040"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:03.768295" elapsed="0.029257"/>
</kw>
<msg time="2026-06-06T03:23:03.797632" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:03.753557" elapsed="0.044175"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.812775" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.826692" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.840519" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.840736" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.840925" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.841350" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:03.841198" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:03.841181" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.841582" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.841773" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.841947" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:03.841149" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.841042" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.842178" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.842254" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:03.842383" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:03.748795" elapsed="0.093615"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:03.843741" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:03.843457" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:03.843913" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:03.843097" elapsed="0.000840"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.844259" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:03.844007" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.844854" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:03.844539" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:03.844341" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:03.843988" elapsed="0.000948"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.847701" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:03.845091" elapsed="0.002638"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:03.847781" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:03.847935" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:03.842761" elapsed="0.005199"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:03.849230" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:03.848997" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:03.849387" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:03.848634" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:03.849620" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:23:03.849486" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:03.849467" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.849872" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.850046" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.850147" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:03.852301" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:03.848267" elapsed="0.004061"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.853785" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:03.853511" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:03.854242" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:03.853990" elapsed="0.000296"/>
</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-06-06T03:23:03.862735" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:03.862879" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:03.862975" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:03.856865" elapsed="0.006484">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:03.854353" elapsed="0.009081">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:03.863627" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:03.863468" elapsed="0.000243"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:03.854334" elapsed="0.009401">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:03.864124" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.864258" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:03.864220" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:03.864202" elapsed="0.000120"/>
</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-06-06T03:23:03.864474" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.864545" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:03.852681" elapsed="0.011971">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.864743" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:03.723103" elapsed="0.141737">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:03.865220" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:03.865023" elapsed="0.000272"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:03.864954" elapsed="0.000366"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:03.865353" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:03.716514" elapsed="0.148977">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.926583" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:04.926177" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:04.927481" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:04.927199" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:04.927656" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:04.926855" elapsed="0.000840"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.928254" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:04.927868" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:04.928775" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:04.928932" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:04.928481" elapsed="0.000479"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.929367" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:04.929122" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.930402" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:04.930142" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.930904" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.930614" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.931682" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.931315" elapsed="0.000395"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.932628" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.932246" elapsed="0.000409"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.932728" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:04.932889" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.931900" elapsed="0.001014"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.933074" elapsed="0.000287"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:04.931174" elapsed="0.002228"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.934140" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.933655" elapsed="0.000511"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.935136" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.934799" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.935214" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.935363" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.934422" elapsed="0.000966"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.935545" elapsed="0.000294"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:04.933515" elapsed="0.002372"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.936453" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.936134" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.937394" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.937061" elapsed="0.000360"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.937471" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.937619" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.936718" elapsed="0.000929"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.937822" elapsed="0.000269"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:04.935997" elapsed="0.002136"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.938836" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.938380" elapsed="0.000482"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.939748" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.939401" elapsed="0.000374"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.939825" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.939974" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.939049" elapsed="0.000949"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.940152" elapsed="0.000266"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:04.938244" elapsed="0.002216"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.941079" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.940754" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.941993" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.941633" elapsed="0.000387"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.942070" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.942219" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.941293" elapsed="0.000950"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.942398" elapsed="0.000284"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:04.940570" elapsed="0.002156"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.943297" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.942977" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.944206" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.943873" elapsed="0.000359"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.944282" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.944433" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.943510" elapsed="0.000947"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.944611" elapsed="0.000308"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:04.942842" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.945526" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.945206" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.946678" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.946160" elapsed="0.000547"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.946758" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.946914" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.945781" elapsed="0.001161"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.947098" elapsed="0.000269"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:04.945071" elapsed="0.002337"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.947993" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:04.947658" elapsed="0.000361"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:04.948932" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.948547" elapsed="0.000411"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:04.949009" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:04.949158" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:04.948207" elapsed="0.000976"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:04.949337" elapsed="0.000268"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:04.947518" elapsed="0.002133"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:04.930987" elapsed="0.018735"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:04.949767" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:04.949927" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:04.929813" elapsed="0.020140"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:04.929489" elapsed="0.020496"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.950169" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:04.950011" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:04.929466" elapsed="0.020780"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.951094" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:04.950392" elapsed="0.000731"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:04.951172" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:04.925523" elapsed="0.025772"/>
</kw>
<msg time="2026-06-06T03:23:04.951348" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:04.911131" elapsed="0.040265"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.965367" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.979227" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.993363" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.993592" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.993791" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.994186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:04.994037" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:04.994021" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.994411" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.994590" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.994778" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:04.993992" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:04.993873" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.995009" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:04.995083" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:04.995205" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:04.906348" elapsed="0.088884"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:04.996499" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:04.996257" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:04.996659" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:04.995903" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:04.997017" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:04.996769" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:04.997573" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:04.997279" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:04.997097" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:04.996750" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:05.000421" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:04.997826" elapsed="0.002622"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:05.000501" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:05.000657" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:04.995554" elapsed="0.005142"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:05.001934" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:05.001702" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:05.002140" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:05.001336" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:05.002374" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:23:05.002237" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:05.002218" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:05.002607" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:05.002801" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:05.002868" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:05.004996" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:05.001005" elapsed="0.004017"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:05.006448" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:05.006160" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:05.006917" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:05.006656" elapsed="0.000305"/>
</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-06-06T03:23:05.015852" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:05.015986" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:05.016080" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:05.009332" elapsed="0.007121">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:05.007027" elapsed="0.009539">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:05.016860" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:05.016613" elapsed="0.000338"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:05.007008" elapsed="0.009976">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:05.017503" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:05.017710" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:05.017635" elapsed="0.000135"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:05.017610" elapsed="0.000191"/>
</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-06-06T03:23:05.018007" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:05.018105" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:05.005329" elapsed="0.012919">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:05.018399" elapsed="0.000026"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:04.880993" elapsed="0.137578">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:05.018984" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:05.018726" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:05.018701" elapsed="0.000417"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:05.019164" elapsed="0.000020"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:04.876096" elapsed="0.143199">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.081673" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:06.081257" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:06.082536" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:06.082272" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:06.082728" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:06.081893" elapsed="0.000861"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.083313" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:06.082923" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:06.083653" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:06.083843" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:06.083505" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.084281" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:06.084031" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.085339" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:06.085071" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.085845" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.085551" elapsed="0.000320"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.086648" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.086283" elapsed="0.000416"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.087595" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.087241" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.087760" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:23:06.087927" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.086895" elapsed="0.001057"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.088113" elapsed="0.000328"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:06.086111" elapsed="0.002372"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.090437" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.088753" elapsed="0.001711"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.091370" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.091034" elapsed="0.000364"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.091451" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:06.091606" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.090681" elapsed="0.000950"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.091808" elapsed="0.000275"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:06.088596" elapsed="0.003531"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.092735" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.092380" elapsed="0.000382"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.093629" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.093295" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.093727" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:06.093883" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.092952" elapsed="0.000957"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.094065" elapsed="0.000273"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:06.092242" elapsed="0.002138"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.095003" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.094675" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.095927" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.095571" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.096005" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:06.096157" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.095221" elapsed="0.000962"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.096339" elapsed="0.000274"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:06.094521" elapsed="0.002138"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.097250" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.096929" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.098155" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.097825" elapsed="0.000356"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.098231" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:06.098382" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.097464" elapsed="0.000944"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.098593" elapsed="0.000294"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:06.096793" elapsed="0.002137"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.099501" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.099179" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.100414" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.100082" elapsed="0.000359"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.100532" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:06.100726" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.099736" elapsed="0.001017"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.100911" elapsed="0.000271"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:06.099043" elapsed="0.002181"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.101820" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.101474" elapsed="0.000373"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.102941" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.102380" elapsed="0.000589"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.103022" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:06.103178" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.102036" elapsed="0.001166"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.103360" elapsed="0.000275"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:06.101337" elapsed="0.002356"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.104273" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:06.103947" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:06.105211" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.104862" elapsed="0.000375"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:06.105288" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:06.105440" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:06.104487" elapsed="0.000978"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:06.105620" elapsed="0.000288"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:06.103809" elapsed="0.002142"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:06.085925" elapsed="0.020061"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:06.106028" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:06.106187" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:06.084738" elapsed="0.021475"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:06.084406" elapsed="0.021839"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.106422" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:06.106269" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:06.084382" elapsed="0.022115"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.107464" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:06.106645" elapsed="0.000849"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:06.107546" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:06.080608" elapsed="0.027081"/>
</kw>
<msg time="2026-06-06T03:23:06.107745" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:06.066357" elapsed="0.041437"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.121770" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.135906" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.150001" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.150223" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.150412" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.150835" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:06.150679" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:06.150649" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.151064" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.151236" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.151405" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:06.150607" elapsed="0.000851"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.150495" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.151682" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.151765" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:06.151911" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:06.061366" elapsed="0.090573"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:06.153327" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:06.153045" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:06.153497" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:06.152633" elapsed="0.000889"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.153879" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:06.153593" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.154440" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:06.154146" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:06.153961" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:06.153574" elapsed="0.000948"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.157358" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:06.154697" elapsed="0.002687"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:06.157437" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:06.157653" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:06.152276" elapsed="0.005415"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:06.158948" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:06.158711" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:06.159106" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:06.158340" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:06.159338" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:23:06.159202" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:06.159183" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.159573" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.159798" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.159868" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:06.162078" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:06.158004" elapsed="0.004100"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.163524" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:06.163268" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:06.164014" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:06.163743" elapsed="0.000315"/>
</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-06-06T03:23:06.173050" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:06.173186" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:06.173295" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:06.166422" elapsed="0.007268">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:06.164125" elapsed="0.009653">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:06.173997" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:06.173815" elapsed="0.000251"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:06.164106" elapsed="0.009983">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:06.174508" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.174729" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:06.174606" elapsed="0.000172"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:06.174587" elapsed="0.000214"/>
</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-06-06T03:23:06.174953" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.175033" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:06.162427" elapsed="0.012716">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.175220" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:06.035098" elapsed="0.140220">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:06.175606" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:06.175412" elapsed="0.000286"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:06.175394" elapsed="0.000329"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:06.175756" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:06.030205" elapsed="0.145649">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.242377" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:07.241934" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:07.243247" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:07.242990" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:07.243420" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:07.242605" elapsed="0.000840"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.244033" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:07.243619" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:07.244371" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:07.244541" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:07.244228" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.245064" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:07.244807" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.246225" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:07.245957" elapsed="0.000387"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.246883" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.246570" elapsed="0.000341"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.247699" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.247311" elapsed="0.000422"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.248683" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.248297" elapsed="0.000439"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.248799" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:23:07.248969" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.247936" elapsed="0.001059"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.249159" elapsed="0.000298"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:07.247165" elapsed="0.002335"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.250307" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.249777" elapsed="0.000557"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.251256" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.250905" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.251335" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:07.251491" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.250531" elapsed="0.000985"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.251770" elapsed="0.000288"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:07.249617" elapsed="0.002485"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.252721" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.252353" elapsed="0.000398"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.253712" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.253348" elapsed="0.000392"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.253791" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:07.253944" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.252990" elapsed="0.000983"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.254131" elapsed="0.000277"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:07.252215" elapsed="0.002235"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.255044" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.254717" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.255996" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.255613" elapsed="0.000411"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.256074" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:07.256228" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.255260" elapsed="0.000993"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.256408" elapsed="0.000309"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:07.254563" elapsed="0.002197"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.257389" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.257058" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.258323" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.257978" elapsed="0.000371"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.258400" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:07.258564" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.257607" elapsed="0.000982"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.258813" elapsed="0.000288"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:07.256917" elapsed="0.002229"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.259763" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.259399" elapsed="0.000394"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.260733" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.260343" elapsed="0.000418"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.260813" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:07.261018" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.259989" elapsed="0.001056"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.261205" elapsed="0.000285"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:07.259261" elapsed="0.002274"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.262136" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.261807" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.263277" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.262736" elapsed="0.000570"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.263358" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:07.263513" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.262353" elapsed="0.001185"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.263731" elapsed="0.000282"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:07.261655" elapsed="0.002400"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.264630" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:07.264303" elapsed="0.000371"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:07.265603" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.265250" elapsed="0.000381"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:07.265701" elapsed="0.000064"/>
</return>
<msg time="2026-06-06T03:23:07.265899" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:07.264869" elapsed="0.001055"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:07.266083" elapsed="0.000281"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:07.264166" elapsed="0.002240"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:07.246970" elapsed="0.019471"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:07.266486" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:07.266652" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:07.245581" elapsed="0.021114"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:07.245200" elapsed="0.021532"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.266935" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:07.266772" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:07.245173" elapsed="0.021841"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.267940" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:07.267164" elapsed="0.000805"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:07.268021" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:07.241140" elapsed="0.027014"/>
</kw>
<msg time="2026-06-06T03:23:07.268249" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:07.226137" elapsed="0.042167"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.282589" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.298167" elapsed="0.000066"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.314287" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.314547" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.314761" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.315197" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:07.315040" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:07.315021" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.315430" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.315607" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.315796" elapsed="0.000081"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:07.314979" elapsed="0.000944"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.314851" elapsed="0.001100"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.316115" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.316197" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:23:07.316363" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:07.220910" elapsed="0.095483"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:07.317891" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:07.317563" elapsed="0.000446">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:07.318115" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:07.317150" elapsed="0.000991"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.318562" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:07.318283" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.319199" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:07.318856" elapsed="0.000383"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:07.318651" elapsed="0.000639"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:07.318263" elapsed="0.001051"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.322310" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:07.319476" elapsed="0.002862"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:07.322407" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:23:07.322614" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:07.316767" elapsed="0.005873"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:07.323939" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:07.323693" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:07.324105" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:07.323322" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:07.324397" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:23:07.324213" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:07.324190" elapsed="0.000295"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.324649" elapsed="0.000037"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.324872" elapsed="0.000025"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.324945" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:07.327369" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:07.322980" elapsed="0.004436"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.328946" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:07.328637" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:07.329487" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:07.329229" elapsed="0.000304"/>
</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-06-06T03:23:07.339568" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:07.339737" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:07.339846" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:07.332093" elapsed="0.008142">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:07.329603" elapsed="0.010722">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:07.340602" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:07.340416" elapsed="0.000304"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:07.329584" elapsed="0.011177">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:07.341206" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.341350" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:07.341309" elapsed="0.000085"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:07.341290" elapsed="0.000126"/>
</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-06-06T03:23:07.341568" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.341644" elapsed="0.000028"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:07.327806" elapsed="0.013964">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.341847" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:07.193884" elapsed="0.148061">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:07.342228" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:07.342040" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:07.342023" elapsed="0.000304"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:07.342371" elapsed="0.000020"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:07.188564" elapsed="0.154009">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.406672" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:08.406209" elapsed="0.000499"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:08.407525" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:08.407265" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:08.407723" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:08.406900" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.408363" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:08.407931" elapsed="0.000461"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:08.408731" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:08.408969" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:08.408564" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.409427" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:08.409166" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.410555" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:08.410275" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.411071" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.410792" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.411866" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.411490" elapsed="0.000403"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.412866" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.412472" elapsed="0.000427"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.412956" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:08.413121" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.412092" elapsed="0.001055"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.413309" elapsed="0.000295"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:08.411347" elapsed="0.002304"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.414427" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.413924" elapsed="0.000531"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.415378" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.415026" elapsed="0.000382"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.415461" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:08.415616" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.414672" elapsed="0.000974"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.415832" elapsed="0.000279"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:08.413783" elapsed="0.002373"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.416856" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.416498" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.417800" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.417425" elapsed="0.000402"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.417878" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:08.418049" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.417073" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.418238" elapsed="0.000271"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:08.416354" elapsed="0.002214"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.419169" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.418843" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.420094" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.419749" elapsed="0.000382"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.420181" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:08.420401" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.419383" elapsed="0.001051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.420679" elapsed="0.000292"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:08.418704" elapsed="0.002310"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.421647" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.421315" elapsed="0.000395"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.422701" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.422317" elapsed="0.000420"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.422800" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:23:08.422994" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.421954" elapsed="0.001071"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.423189" elapsed="0.000283"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:08.421177" elapsed="0.002338"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.424190" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.423815" elapsed="0.000403"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.425334" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.424954" elapsed="0.000416"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.425451" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:08.425622" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.424470" elapsed="0.001181"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.425853" elapsed="0.000323"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:08.423634" elapsed="0.002586"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.426827" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.426485" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.428020" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.427637" elapsed="0.000410"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.428098" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:08.428251" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.427062" elapsed="0.001213"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.428452" elapsed="0.000367"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:08.426333" elapsed="0.002547"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.429531" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:08.429175" elapsed="0.000382"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:08.430568" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.430153" elapsed="0.000442"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:08.430650" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:23:08.430826" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:08.429808" elapsed="0.001043"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:08.431054" elapsed="0.000314"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:08.429022" elapsed="0.002388"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:08.411158" elapsed="0.020295"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:08.431497" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:08.431824" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:08.409932" elapsed="0.021925"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:08.409563" elapsed="0.022328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.432135" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:08.431921" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:08.409538" elapsed="0.022680"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.433203" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:08.432368" elapsed="0.000915"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:08.433340" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:08.405457" elapsed="0.028011"/>
</kw>
<msg time="2026-06-06T03:23:08.433532" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:08.390867" elapsed="0.042718"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.447533" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.461496" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.476298" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.476511" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.476714" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.477107" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:08.476942" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:08.476927" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.477371" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.477567" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.477753" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:08.476896" elapsed="0.000912"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.476794" elapsed="0.001039"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.477982" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.478057" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:08.478192" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:08.386132" elapsed="0.092088"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:08.479580" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:08.479323" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:08.479764" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:08.478968" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.480110" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:08.479858" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.480699" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:08.480383" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:08.480191" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:08.479839" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.483753" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:08.480938" elapsed="0.002843"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:08.483846" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:08.484008" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:08.478590" elapsed="0.005443"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:08.485462" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:08.485152" elapsed="0.000400">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:08.485646" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:08.484731" elapsed="0.000956"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:08.485906" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:08.485769" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:08.485749" elapsed="0.000252"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.486159" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.486379" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.486447" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:08.488869" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:08.484369" elapsed="0.004527"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.490441" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:08.490188" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:08.490904" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:08.490646" elapsed="0.000302"/>
</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-06-06T03:23:08.499576" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:08.499796" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:08.499935" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:08.493293" elapsed="0.007206">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:08.491013" elapsed="0.009613">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:08.500940" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:08.500703" elapsed="0.000334"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:08.490995" elapsed="0.010077">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:08.501853" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.502053" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:08.501997" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:08.501971" elapsed="0.000177"/>
</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-06-06T03:23:08.502367" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.502470" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:08.489258" elapsed="0.013363">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.502752" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:08.355936" elapsed="0.146957">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:08.503296" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:08.503028" elapsed="0.000374"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:08.503004" elapsed="0.000433"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:08.503484" elapsed="0.000021"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:08.349409" elapsed="0.154213">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.573466" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:09.573008" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:09.574363" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:09.574085" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:09.574539" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:09.573716" elapsed="0.000848"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.575284" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:09.574878" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:09.575630" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:09.575817" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:09.575483" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.576262" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:09.576007" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.577449" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:09.577180" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.577957" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.577680" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.578760" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.578365" elapsed="0.000422"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.579712" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.579339" elapsed="0.000400"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.579795" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:09.579958" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.578984" elapsed="0.000999"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.580150" elapsed="0.000289"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:09.578223" elapsed="0.002258"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.582301" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.580750" elapsed="0.001578"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.583235" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.582897" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.583313" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:09.583466" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.582524" elapsed="0.000966"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.583843" elapsed="0.000277"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:09.580595" elapsed="0.003568"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.584753" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.584411" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.585703" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.585345" elapsed="0.000522"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.585918" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:09.586069" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.584968" elapsed="0.001126"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.586250" elapsed="0.000271"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:09.584275" elapsed="0.002288"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.587156" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.586834" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.588084" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.587750" elapsed="0.000414"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.588216" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:09.588370" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.587370" elapsed="0.001025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.588550" elapsed="0.000296"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:09.586696" elapsed="0.002196"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.589509" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.589179" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.590417" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.590086" elapsed="0.000358"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.590494" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:09.590666" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.589743" elapsed="0.000949"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.590848" elapsed="0.000271"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:09.589006" elapsed="0.002155"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.591763" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.591409" elapsed="0.000380"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.592673" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.592325" elapsed="0.000376"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.592752" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:09.592905" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.591978" elapsed="0.000952"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.593085" elapsed="0.000308"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:09.591274" elapsed="0.002162"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.594033" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.593703" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.639957" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.594610" elapsed="0.045391"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.640077" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:23:09.640280" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.594251" elapsed="0.046056"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.640501" elapsed="0.000350"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:09.593549" elapsed="0.047346"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.641526" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:09.641162" elapsed="0.000391"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:09.642522" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.642184" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:09.642600" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:09.642774" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:09.641818" elapsed="0.000982"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:09.642957" elapsed="0.000273"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:09.641020" elapsed="0.002251"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:09.578038" elapsed="0.065268"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:09.643351" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:09.643514" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:09.576784" elapsed="0.066819"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:09.576393" elapsed="0.067250"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.643999" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:09.643685" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:09.576368" elapsed="0.067708"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.645146" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:09.644222" elapsed="0.000954"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:09.645226" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:09.572138" elapsed="0.073212"/>
</kw>
<msg time="2026-06-06T03:23:09.645407" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:09.557413" elapsed="0.088045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.659501" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.673490" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.687888" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.688094" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.688281" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.688679" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:09.688513" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:09.688496" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.688908" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.689079" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.689250" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:09.688465" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.688359" elapsed="0.000971"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.689482" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.689557" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:09.689746" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:09.552365" elapsed="0.137409"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:09.691134" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:09.690861" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:09.691303" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:09.690478" elapsed="0.000850"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.691681" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:09.691402" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.692247" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:09.691948" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:09.691766" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:09.691383" elapsed="0.000949"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.694932" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:09.692490" elapsed="0.002469"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:09.695012" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:09.695167" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:09.690107" elapsed="0.005086"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:09.696444" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:09.696208" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:09.696602" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:09.695863" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:09.696855" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:09.696717" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:09.696697" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.697092" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.697267" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.697334" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:09.701272" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:09.695505" elapsed="0.005832"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.704292" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:09.703902" elapsed="0.000463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:09.704996" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:09.704606" elapsed="0.000457"/>
</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-06-06T03:23:09.716070" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:09.716247" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:09.716357" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:09.708643" elapsed="0.008110">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:09.705163" elapsed="0.011675">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:09.717035" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:09.716873" elapsed="0.000228"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:09.705135" elapsed="0.011990">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:09.717505" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.717641" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:09.717600" elapsed="0.000099"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:09.717583" elapsed="0.000139"/>
</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-06-06T03:23:09.717871" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.717942" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:09.702084" elapsed="0.015963">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.718123" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:09.519267" elapsed="0.198950">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:09.718494" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:09.718311" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:09.718293" elapsed="0.000300"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:09.718628" elapsed="0.000018"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:09.513514" elapsed="0.205262">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.779465" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:10.779059" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:10.780432" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:10.780163" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:10.780610" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:10.779805" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.781226" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:10.780831" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:10.781567" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:10.781767" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:10.781424" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.782253" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:10.781960" elapsed="0.000345"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.783335" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:10.783067" elapsed="0.000315"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.783875" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.783550" elapsed="0.000353"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.784671" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.784289" elapsed="0.000410"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.785595" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.785246" elapsed="0.000377"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.785699" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:10.785862" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.784895" elapsed="0.000992"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.786046" elapsed="0.000286"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:10.784146" elapsed="0.002229"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.787165" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.786627" elapsed="0.000565"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.788207" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.787833" elapsed="0.000401"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.788285" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:10.788438" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.787385" elapsed="0.001078"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.788620" elapsed="0.000291"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:10.786489" elapsed="0.002463"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.789725" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.789200" elapsed="0.000553"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.790629" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.790290" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.790727" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:10.790881" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.789943" elapsed="0.000962"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.791122" elapsed="0.000280"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:10.789064" elapsed="0.002381"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.792076" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.791716" elapsed="0.000386"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.793011" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.792669" elapsed="0.000369"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.793090" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:10.793243" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.792296" elapsed="0.000972"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.793423" elapsed="0.000308"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:10.791559" elapsed="0.002217"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.794356" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.794031" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.795275" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.794940" elapsed="0.000361"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.795353" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:10.795503" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.794574" elapsed="0.000954"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.795707" elapsed="0.000293"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:10.793891" elapsed="0.002151"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.796705" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.796351" elapsed="0.000381"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.797605" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.797268" elapsed="0.000365"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.797725" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:10.797879" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.796922" elapsed="0.000982"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.798059" elapsed="0.000273"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:10.796155" elapsed="0.002220"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.798975" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.798631" elapsed="0.000370"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.799939" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.799540" elapsed="0.000425"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.800017" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:10.800169" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.799191" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.800348" elapsed="0.000272"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:10.798489" elapsed="0.002190"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.801255" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:10.800932" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:10.802397" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.802057" elapsed="0.000367"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:10.802475" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:10.802628" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:10.801472" elapsed="0.001200"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:10.802879" elapsed="0.000276"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:10.800793" elapsed="0.002405"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:10.783958" elapsed="0.019276"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:10.803279" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:10.803443" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:10.782733" elapsed="0.020738"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:10.782383" elapsed="0.021121"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.803708" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:10.803532" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:10.782359" elapsed="0.021428"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.804680" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:10.803953" elapsed="0.000757"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:10.804761" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:10.778394" elapsed="0.026493"/>
</kw>
<msg time="2026-06-06T03:23:10.804944" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:10.764048" elapsed="0.040948"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.819134" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.834313" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.849038" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.849326" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.849572" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.850294" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:10.850088" elapsed="0.000279"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:10.850065" elapsed="0.000336"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.850596" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.850846" elapsed="0.000027"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.851153" elapsed="0.000028"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:10.850014" elapsed="0.001211"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.849705" elapsed="0.001556"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.851470" elapsed="0.000029"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.851574" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:23:10.851777" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:10.759174" elapsed="0.092641"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:10.853601" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:10.853246" elapsed="0.000468">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:10.853839" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:10.852750" elapsed="0.001121"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.854307" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:10.853964" elapsed="0.000415"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.855051" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:10.854670" elapsed="0.000416"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:10.854411" elapsed="0.000722"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:10.853940" elapsed="0.001222"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.858883" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:10.855370" elapsed="0.003547"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:10.858982" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:23:10.859182" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:10.852250" elapsed="0.006964"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:10.860840" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:10.860516" elapsed="0.000408">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:10.861042" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:10.860052" elapsed="0.001023"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:10.861342" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:23:10.861165" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:10.861141" elapsed="0.000311"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.861680" elapsed="0.000031"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.861916" elapsed="0.000027"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.862000" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:23:10.864906" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:10.859606" elapsed="0.005333"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.866772" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:10.866423" elapsed="0.000409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:10.867418" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:10.867095" elapsed="0.000380"/>
</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-06-06T03:23:10.877851" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:10.877992" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:10.878094" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:10.870682" elapsed="0.007792">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:10.867562" elapsed="0.010997">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:10.878794" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:10.878594" elapsed="0.000268"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:10.867537" elapsed="0.011349">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:10.879281" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.879418" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:10.879379" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:10.879361" elapsed="0.000123"/>
</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-06-06T03:23:10.879701" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.879801" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:10.865349" elapsed="0.014594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.880044" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:10.733399" elapsed="0.146773">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:10.880483" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:10.880289" elapsed="0.000269"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:10.880271" elapsed="0.000313"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:10.880621" elapsed="0.000022"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:10.728490" elapsed="0.152301">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.937404" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:11.937004" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:11.938250" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:11.937991" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:11.938423" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:11.937619" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.939034" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:11.938623" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:11.939375" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:11.939540" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=no...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:11.939232" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.940042" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB_OPENCONFIG/peer=bgp%3A%2F%2F$IP/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:11.939751" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.941110" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:11.940841" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.941601" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.941327" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.942390" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.942031" elapsed="0.000386"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.943338" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.942988" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.943422" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:23:11.943581" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.942610" elapsed="0.000996"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.943793" elapsed="0.000313"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:11.941888" elapsed="0.002261"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.944934" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.944401" elapsed="0.000560"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.945858" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.945501" elapsed="0.000385"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.945938" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:11.946092" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.945154" elapsed="0.000963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.946274" elapsed="0.000271"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:11.944263" elapsed="0.002324"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.947244" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.946912" elapsed="0.000359"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.948206" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.947835" elapsed="0.000398"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.948285" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:11.948438" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.947464" elapsed="0.000998"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.948620" elapsed="0.000289"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:11.946771" elapsed="0.002181"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.949526" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.949204" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.950442" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.950111" elapsed="0.000358"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.950520" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:11.950687" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.949766" elapsed="0.000947"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.950870" elapsed="0.000271"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:11.949066" elapsed="0.002117"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.951791" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.951435" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.952722" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.952372" elapsed="0.000377"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.952801" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:11.952952" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.952009" elapsed="0.000968"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.953133" elapsed="0.000270"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:11.951297" elapsed="0.002149"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.954048" level="INFO">${value} = 65432</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.953724" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.954959" level="INFO">${encoded} = 65432</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.954606" elapsed="0.000380"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.955037" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:11.955187" level="INFO">${encoded_value} = 65432</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.954263" elapsed="0.000948"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.955366" elapsed="0.000272"/>
</kw>
<var name="${key}">AS_NUMBER</var>
<var name="${value}">65432</var>
<status status="PASS" start="2026-06-06T03:23:11.953560" elapsed="0.002159"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.956324" level="INFO">${value} = 64496</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.955969" elapsed="0.000381"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.957423" level="INFO">${encoded} = 64496</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.957087" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.957501" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:11.957671" level="INFO">${encoded_value} = 64496</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.956540" elapsed="0.001157"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.957855" elapsed="0.000271"/>
</kw>
<var name="${key}">PEER_AS</var>
<var name="${value}">64496</var>
<status status="PASS" start="2026-06-06T03:23:11.955833" elapsed="0.002335"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.958808" level="INFO">${value} = 8.1.0.0/28</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:11.958416" elapsed="0.000418"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:11.959749" level="INFO">${encoded} = 8.1.0.0/28</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.959369" elapsed="0.000407"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:11.959827" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:11.959978" level="INFO">${encoded_value} = 8.1.0.0/28</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:11.959024" elapsed="0.000979"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:11.960175" elapsed="0.000271"/>
</kw>
<var name="${key}">PREFIXLEN</var>
<var name="${value}">8.1.0.0/28</var>
<status status="PASS" start="2026-06-06T03:23:11.958280" elapsed="0.002208"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:11.941701" elapsed="0.018823"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:11.960568" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:11.960753" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'AS_NUMBER': '65432', 'PEER_AS': '64496', 'PREFIXLEN': '8.1.0.0/28'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:11.940487" elapsed="0.020293"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:11.940171" elapsed="0.020643"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:11.961000" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:11.960841" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:11.940147" elapsed="0.020930"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:11.961967" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:11.961226" elapsed="0.000771"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:11.962047" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:11.936352" elapsed="0.025821"/>
</kw>
<msg time="2026-06-06T03:23:11.962230" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:11.921938" elapsed="0.040344"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:11.976344" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:11.990325" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.004257" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.004466" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.004696" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.005145" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.004992" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:12.004975" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.005372" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.005545" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.005734" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:12.004942" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.004833" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.005968" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.006045" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:12.006175" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:11.917063" elapsed="0.089140"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:12.007725" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:12.007437" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:12.007894" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:12.007063" elapsed="0.000856"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.008256" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.007992" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.008862" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:12.008526" elapsed="0.000362"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.008339" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.007973" elapsed="0.000971"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.011757" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:12.009102" elapsed="0.002683"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:12.011837" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:12.011995" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:12.006715" elapsed="0.005305"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:12.013310" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:12.013067" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/adj_rib_out/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:12.013471" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:12.012715" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:12.013730" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.013567" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.013548" elapsed="0.000267"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.013968" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.014145" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.014260" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:12.016411" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/adj_rib_out/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:12.012334" elapsed="0.004104"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.017912" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.017633" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.018370" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.018122" elapsed="0.000292"/>
</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-06-06T03:23:12.027010" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:12.027155" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:12.027265" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:23:12.020846" elapsed="0.006828">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:23:12.018482" elapsed="0.009284">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</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-06-06T03:23:12.027984" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.027803" elapsed="0.000248"/>
</branch>
<status status="FAIL" start="2026-06-06T03:23:12.018463" elapsed="0.009612">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:23:12.028488" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.028626" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.028587" elapsed="0.000100"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:12.028568" elapsed="0.000143"/>
</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-06-06T03:23:12.028905" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.028977" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:23:12.016796" elapsed="0.012290">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.029163" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:23:11.891126" elapsed="0.138132">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.029602" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.029409" elapsed="0.000316"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:12.029391" elapsed="0.000372"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.029813" elapsed="0.000022"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:23:11.886152" elapsed="0.143807">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<msg time="2026-06-06T03:23:12.030106" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</msg>
<arg>${DEFAULT_TOPOLOGY_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_TOPOLOGY_CHECK_PERIOD}</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/adj_rib_out</arg>
<arg>mapping=${mapping}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:23:01.399857" elapsed="10.630395">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.032365" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:23:12.031888" elapsed="0.000542"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:23:12.031285" elapsed="0.001224"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:23:12.030802" elapsed="0.001792"/>
</kw>
<doc>Verifies eBGP's adj-rib-out output. Expects local-as, and ibgp peer-as presence.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:23:01.312198" elapsed="10.720486">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig</status>
</test>
<test id="s1-s9-t20" name="TC_LAS_Kill_iBgp_Speaker_After_Talking" line="380">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:12.038192" elapsed="0.000224"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:12.037910" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.039528" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.039399" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.039378" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.045260" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.045141" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.045121" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.046403" 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-06-06T03:23:12.045993" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.046920" 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-06-06T03:23:12.046598" elapsed="0.000348"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:12.046991" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:12.047153" 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-06-06T03:23:12.045581" elapsed="0.001596"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:12.053267" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.053151" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.053130" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:12.054569" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.054459" elapsed="0.000256"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.054441" elapsed="0.000303"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:12.055219" 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-06-06T03:23:12.054903" elapsed="0.000344"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.055639" level="INFO">${current_connection_index} = 8</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-06-06T03:23:12.055417" elapsed="0.000269"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.085209" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:12.056214" elapsed="0.029198"/>
</kw>
<msg time="2026-06-06T03:23:12.085631" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:12.085710" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:12.055857" elapsed="0.029891"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.110334" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "i "B "g "p "_ "S "p "e "a "k "e "r "_ "A "f "t "e "r "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:23:12.086389" elapsed="0.024109"/>
</kw>
<msg time="2026-06-06T03:23:12.110731" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:12.110780" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "i "B "g "p "_ "...</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-06-06T03:23:12.085974" elapsed="0.024843"/>
</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-06-06T03:23:12.111227" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.110924" elapsed="0.000362"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.110893" elapsed="0.000419"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.111845" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "i "B "g "p "_ "S "p "e "a "k "e "r "_ "A "f "t "e "r "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:23:12.111463" elapsed="0.000456"/>
</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-06-06T03:23:12.112216" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.111989" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.111970" elapsed="0.000325"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:12.112335" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:12.115005" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:23:12.115219" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.113948" elapsed="0.001402"/>
</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="NOT RUN" start="2026-06-06T03:23:12.115633" elapsed="0.000097"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.115994" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:12.113260" elapsed="0.002919"/>
</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-06-06T03:23:12.112676" elapsed="0.003568"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:12.054152" elapsed="0.062191"/>
</kw>
<msg time="2026-06-06T03:23:12.116440" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.116485" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "i "B "g "p "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.053501" elapsed="0.063023"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:12.116732" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.116602" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.116582" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.117238" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.117693" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.117768" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:12.052756" elapsed="0.065124"/>
</kw>
<msg time="2026-06-06T03:23:12.117978" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.118024" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "i "B "g "p "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:12.047567" elapsed="0.070492"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.118401" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.118138" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.118120" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:12.047418" elapsed="0.071088"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:12.047235" elapsed="0.071304"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:12.044707" elapsed="0.073888"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:12.039102" elapsed="0.079571"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.038635" elapsed="0.080088"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:12.033979" elapsed="0.084800"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ibgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:12.118951" elapsed="0.000111"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.120300" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:12.119976" elapsed="0.000351"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:12.120490" elapsed="0.000305"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:23:12.119694" elapsed="0.001163"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.143245" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:12.121379" elapsed="0.022115"/>
</kw>
<msg time="2026-06-06T03:23:12.143844" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.143954" level="INFO">${message} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.121035" elapsed="0.022979"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.145844" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:23:12.159120" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:12.159350" level="INFO">${output_log} = 2026-06-06 03:22:48,077 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:22:48,078 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:12.145443" elapsed="0.013969"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.160508" level="INFO">2026-06-06 03:22:48,077 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:22:48,079 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:22:48,080 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:22:48,080 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104ff9800b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 1
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Prefix base: 8.0.0.0/28
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   My Autonomous System number: 64497
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706435
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 1
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 0]
2026-06-06 03:22:48,082 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:22:48,082 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   My Autonomous System=64497 (0xfbf1)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706435 (0x7f000003)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf1
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf100b47f000003100206010400010001020641040000fbf1'
2026-06-06 03:22:48,083 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf100b47f000003100206010400010001020641040000fbf1
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:22:48,086 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 1
2026-06-06 03:22:48,086 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:22:48,086 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.0.0')]
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf140050400000064400304c0000201)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):     AS path=64497
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.0.0')]/28 (0x1c08000000)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf140050400000064400304c00002011c08000000
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Number of iterations: 1
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 1
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0010790824890136719s
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:22:48,090 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:22:48,090 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf140050400000064)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):     AS path=64497
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf140050400000064
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): NLRI prefix list: []22026-06-06 03:22:58,103 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 022026-06-06 03:23:08,111 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:23:08,111 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.017s
2026-06-06 03:23:08,112 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:23:08,112 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:23:08,112 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.159852" elapsed="0.001169"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:23:12.144607" elapsed="0.016553"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:23:12.161627" elapsed="0.000117"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.161334" elapsed="0.000486"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.161279" elapsed="0.000599"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.162295" elapsed="0.000055"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.162736" elapsed="0.000050"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:23:12.119331" elapsed="0.043590"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.164883" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:23:12.164083" elapsed="0.000900"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:23:12.163370" elapsed="0.001748"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:12.166459" elapsed="0.001250"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:23:12.165745" elapsed="0.002095"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:12.033155" elapsed="0.134774"/>
</test>
<test id="s1-s9-t21" name="TC_LAS_Kill_eBgp_Speaker_After_Talking" line="390">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:12.173241" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:12.172968" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.174610" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.174496" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.174470" elapsed="0.000231"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.180373" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.180263" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.180245" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.181490" 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-06-06T03:23:12.181088" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.182028" 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-06-06T03:23:12.181711" elapsed="0.000350"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:12.182117" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:23:12.182322" 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-06-06T03:23:12.180696" elapsed="0.001652"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:12.188551" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.188440" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.188420" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:12.189859" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.189748" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.189728" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:12.190410" 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-06-06T03:23:12.190083" elapsed="0.000357"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.190997" level="INFO">${current_connection_index} = 7</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-06-06T03:23:12.190615" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.222729" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:12.191537" elapsed="0.031299"/>
</kw>
<msg time="2026-06-06T03:23:12.223006" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:12.223055" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:12.191190" elapsed="0.031948"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.251267" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "e "B "g "p "_ "S "p "e "a "k "e "r "_ "A "f "t "e "r "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:23:12.223720" elapsed="0.027679"/>
</kw>
<msg time="2026-06-06T03:23:12.251570" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:12.251617" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "e "B "g "p "_ "...</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-06-06T03:23:12.223326" elapsed="0.028356"/>
</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-06-06T03:23:12.252036" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.251776" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.251749" elapsed="0.000371"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.252595" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "e "B "g "p "_ "S "p "e "a "k "e "r "_ "A "f "t "e "r "_ "T "a "l "k "i "n "g "[K"
[?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-06-06T03:23:12.252271" elapsed="0.000421"/>
</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-06-06T03:23:12.253004" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.252762" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.252743" elapsed="0.000341"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:12.253119" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:12.255957" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:23:12.256174" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.254663" elapsed="0.001646"/>
</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="NOT RUN" start="2026-06-06T03:23:12.256594" elapsed="0.000101"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.256964" elapsed="0.000128"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:12.254011" elapsed="0.003200"/>
</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-06-06T03:23:12.253430" elapsed="0.003849"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:12.189409" elapsed="0.067970"/>
</kw>
<msg time="2026-06-06T03:23:12.257475" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.257520" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "e "B "g "p "_ "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.188796" elapsed="0.068759"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:12.257831" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.257646" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.257622" elapsed="0.000296"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.258334" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.258710" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.258783" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:12.188095" elapsed="0.070799"/>
</kw>
<msg time="2026-06-06T03:23:12.258991" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.259080" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "K "i "l "l "_ "e "B "g "p "_ "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:12.182776" elapsed="0.076348"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.259467" elapsed="0.000063"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.259201" elapsed="0.000365"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.259183" elapsed="0.000408"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:12.182603" elapsed="0.077012"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:12.182417" elapsed="0.077250"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:12.179896" elapsed="0.079834"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:12.174164" elapsed="0.085623"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.173695" elapsed="0.086137"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:12.170051" elapsed="0.089837"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<arg>ebgp_peer1_console</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:12.260058" elapsed="0.000111"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.261601" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:12.261058" elapsed="0.000571"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:12.261825" elapsed="0.000239"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:23:12.260783" elapsed="0.001341"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.282355" level="INFO">[?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:12.262645" elapsed="0.019771"/>
</kw>
<msg time="2026-06-06T03:23:12.282511" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.282555" level="INFO">${message} = [?2004l^C
[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.262303" elapsed="0.020277"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.283228" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:23:12.296085" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:12.296305" level="INFO">${output_log} = 2026-06-06 03:22:48,077 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:22:48,078 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:12.283081" elapsed="0.013285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.297363" level="INFO">2026-06-06 03:22:48,077 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:22:48,078 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:22:48,079 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:22:48,080 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:22:48,080 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104ff9800b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 1
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Prefix base: 8.0.0.0/28
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   My Autonomous System number: 64497
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706435
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:22:48,081 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 1
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 0]
2026-06-06 03:22:48,082 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:22:48,082 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Length=45 (0x002d)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   My Autonomous System=64497 (0xfbf1)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706435 (0x7f000003)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=16 (0x10)
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x0206010400010001020641040000fbf1
2026-06-06 03:22:48,082 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff002d0104fbf100b47f000003100206010400010001020641040000fbf1'
2026-06-06 03:22:48,083 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff002d0104fbf100b47f000003100206010400010001020641040000fbf1
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:22:48,084 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:22:48,086 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 1
2026-06-06 03:22:48,086 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:22:48,086 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.0.0')]
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:22:48,088 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Length=55 (0x0037)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=27 (0x001b)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf140050400000064400304c0000201)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):     AS path=64497
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[IPv4Address('8.0.0.0')]/28 (0x1c08000000)
2026-06-06 03:22:48,089 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff0037020000001b4001010040020602010000fbf140050400000064400304c00002011c08000000
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Number of iterations: 1
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 1
2026-06-06 03:22:48,089 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0010790824890136719s
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job):   
2026-06-06 03:22:48,090 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:22:48,090 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:22:48,090 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf140050400000064)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):     AS path=64497
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf140050400000064
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:22:48,091 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:22:48,092 DEBUG BGP-Thread-1 (job): NLRI prefix list: []22026-06-06 03:22:58,103 INFO BGP-Thread-1 (job): ... idle for 10.010s
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:22:58,104 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 022026-06-06 03:23:08,111 INFO BGP-Thread-1 (job): ... idle for 10.007s
2026-06-06 03:23:08,111 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.017s
2026-06-06 03:23:08,112 INFO BGP-Thread-1 (job): total_received_update_message_counter: 1
2026-06-06 03:23:08,112 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:23:08,112 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0TTraceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.296786" elapsed="0.001026"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:23:12.282793" elapsed="0.015150"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:23:12.298343" elapsed="0.000062"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.298089" elapsed="0.000383"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.298046" elapsed="0.000482"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.298911" elapsed="0.000051"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.299299" elapsed="0.000045"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:23:12.260436" elapsed="0.039138"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.300796" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:23:12.300317" elapsed="0.000540"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:23:12.299917" elapsed="0.001021"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:12.301739" elapsed="0.000291"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:23:12.301299" elapsed="0.000805"/>
</kw>
<doc>Abort the Python speaker. Also, attempt to stop failing fast.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:12.168579" elapsed="0.133579"/>
</test>
<test id="s1-s9-t22" name="TC_LAS_Delete_Bgp_Peer_Configurations" line="400">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:12.307988" elapsed="0.000291"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:12.307583" elapsed="0.000773"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.309459" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.309348" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.309329" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.315715" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.315524" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.315505" elapsed="0.000293"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.316829" 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-06-06T03:23:12.316424" elapsed="0.000432"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.317322" 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-06-06T03:23:12.317024" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:12.317392" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:12.317548" 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-06-06T03:23:12.316034" elapsed="0.001539"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:12.323610" elapsed="0.000065"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.323500" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.323481" elapsed="0.000267"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:12.324958" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:12.324849" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.324830" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:12.325477" 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-06-06T03:23:12.325175" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.325900" level="INFO">${current_connection_index} = 8</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-06-06T03:23:12.325687" elapsed="0.000239"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.355784" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:12.326432" elapsed="0.029455"/>
</kw>
<msg time="2026-06-06T03:23:12.356119" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:12.356173" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:12.326090" elapsed="0.030172"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.380402" level="INFO">". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "s "[K"
[?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-06-06T03:23:12.356838" elapsed="0.023733"/>
</kw>
<msg time="2026-06-06T03:23:12.380864" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:12.380930" level="INFO">${message_wait} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "D "e "l "e "t "e "_ "B "g "p "...</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-06-06T03:23:12.356449" elapsed="0.024530"/>
</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-06-06T03:23:12.381440" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.381098" elapsed="0.000422"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.381066" elapsed="0.000489"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.382225" level="INFO"> ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "s "[K"
[?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-06-06T03:23:12.381787" elapsed="0.000535"/>
</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-06-06T03:23:12.382777" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.382418" elapsed="0.000439"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.382391" elapsed="0.000500"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:12.382939" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:12.386524" elapsed="0.000542"/>
</kw>
<msg time="2026-06-06T03:23:12.387162" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.385050" elapsed="0.002293"/>
</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="NOT RUN" start="2026-06-06T03:23:12.387767" elapsed="0.000220"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.388429" elapsed="0.000105"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:12.384117" elapsed="0.004595"/>
</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-06-06T03:23:12.383334" elapsed="0.005448"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:12.324514" elapsed="0.064368"/>
</kw>
<msg time="2026-06-06T03:23:12.388976" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.389021" level="INFO">${message} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "D "e "l "e "t "e "_ "B "g "p "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.323936" elapsed="0.065121"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:12.389245" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.389135" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.389115" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.389768" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.390107" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.390177" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:12.323158" elapsed="0.067127"/>
</kw>
<msg time="2026-06-06T03:23:12.390406" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:12.390453" level="INFO">${output} =  ". "t "x "t ". "E "b "g "p "[C "P "e "e "r "s "[C "B "a "s "i "c ". "T "C "_ "L "A "S "_ "D "e "l "e "t "e "_ "B "g "p "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:12.317972" elapsed="0.072517"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.390837" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.390565" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.390547" elapsed="0.000414"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:12.317824" elapsed="0.073162"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:12.317628" elapsed="0.073389"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:12.315150" elapsed="0.075923"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:12.309057" elapsed="0.082072"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:12.308571" elapsed="0.082604"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:12.304106" elapsed="0.087122"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.391926" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${iBGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.391424" elapsed="0.000530"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.442005" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:12.441509" elapsed="0.000525"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:12.442806" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:12.442545" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:12.442980" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:12.442203" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.443559" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:12.443174" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:12.443914" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:12.444095" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:12.443775" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.444529" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.444285" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.445562" level="INFO">mapping: {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.445305" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.446059" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.445795" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.446781" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:12.446452" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:12.447765" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.447520" elapsed="0.000271"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:12.447843" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:12.447996" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:12.446997" elapsed="0.001024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.448180" elapsed="0.000243"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:23:12.446311" elapsed="0.002154"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.449108" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:12.448774" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:12.449881" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.449666" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:12.449957" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:12.450107" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:12.449327" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.450287" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:12.448615" elapsed="0.001936"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:12.446138" elapsed="0.004447"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:12.450628" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:23:12.450804" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:12.444979" elapsed="0.005850"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.444646" elapsed="0.006215"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.451040" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.450886" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.444622" elapsed="0.006495"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.451864" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:12.451267" elapsed="0.000627"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:12.451943" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:12.440040" elapsed="0.012027"/>
</kw>
<msg time="2026-06-06T03:23:12.452120" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.424504" elapsed="0.027662"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.466248" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.480090" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.494097" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.494305" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.494489" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.494931" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.494734" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:12.494718" elapsed="0.000298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.495163" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.495336" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.495507" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:12.494686" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.494568" elapsed="0.001018"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.495754" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.495833" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:12.495966" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:12.419741" elapsed="0.076253"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.497147" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.496880" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:12.510132" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:12.510199" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:12.510327" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:12.499806" elapsed="0.010556"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.497264" elapsed="0.013156"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.510729" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.510456" elapsed="0.000363"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.497246" elapsed="0.013604"/>
</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-06-06T03:23:12.516141" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.512268" elapsed="0.003934"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.511954" elapsed="0.004299"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.511927" elapsed="0.004361"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.520568" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.516711" elapsed="0.003921"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.516367" elapsed="0.004339"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.516343" elapsed="0.004398"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.521527" 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-06-06T03:23:12.520986" elapsed="0.000626"/>
</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-06-06T03:23:12.522088" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.521742" elapsed="0.000426"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.522855" 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-06-06T03:23:12.522432" elapsed="0.000450"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.522201" elapsed="0.000760"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.521714" elapsed="0.001270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.523519" 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-06-06T03:23:12.523150" elapsed="0.000396"/>
</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-06-06T03:23:12.523878" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.523616" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.524427" 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-06-06T03:23:12.524125" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.523960" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.523598" elapsed="0.000911"/>
</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-06-06T03:23:12.524686" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:12.525496" 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-06-06T03:23:12.525209" elapsed="0.000313"/>
</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-06-06T03:23:12.525714" elapsed="0.002631"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:23:12.511354" elapsed="0.017054"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:12.528455" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:12.531133" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:23:12.496261" elapsed="0.034900"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:12.531215" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:23:12.392184" elapsed="0.139157"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.532013" level="INFO">&amp;{mapping} = { IP=127.0.0.3 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${eBGP_PEER1_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.531535" elapsed="0.000506"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.579778" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:12.579383" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:12.580553" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:12.580318" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:12.580743" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:12.579976" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.581322" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:12.580937" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:12.581665" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/local_as/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:12.581820" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:12.581513" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.582272" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.582009" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.583338" level="INFO">mapping: {'IP': '127.0.0.3', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.583080" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.583829" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.583545" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.584509" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:12.584215" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:12.585282" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.585067" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:12.585357" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:12.585507" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:12.584743" elapsed="0.000789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.585706" elapsed="0.000226"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:23:12.584076" elapsed="0.001897"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.586540" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:12.586245" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:12.587304" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.587092" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:12.587380" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:12.587529" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:12.586772" elapsed="0.000782"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.587725" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:12.586083" elapsed="0.001905"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:12.583906" elapsed="0.004116"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:12.588064" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:23:12.588219" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:12.582751" elapsed="0.005493"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.582426" elapsed="0.005850"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.588452" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.588301" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.582405" elapsed="0.006122"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.589445" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:12.588697" elapsed="0.000778"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:12.589525" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:12.578763" elapsed="0.010906"/>
</kw>
<msg time="2026-06-06T03:23:12.589727" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.564393" elapsed="0.025451"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.603798" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.617797" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//local_as/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.631707" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.631910" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.632089" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.632452" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.632307" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:12.632291" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.632697" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.632875" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.633044" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:12.632264" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.632164" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.633269" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:12.633343" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:12.633463" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:12.559593" elapsed="0.073897"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.634727" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.634426" elapsed="0.000349"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:12.645827" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0jk8nf270dsgijtze7qd6vedz17.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:12.645891" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:12.646011" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:12.637110" elapsed="0.008936"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.634843" elapsed="0.011259"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.646355" elapsed="0.000073"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.646138" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.634824" elapsed="0.011693"/>
</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-06-06T03:23:12.651865" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.647978" elapsed="0.003948"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.647633" elapsed="0.004343"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.647608" elapsed="0.004403"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.656012" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.652406" elapsed="0.003652"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.652090" elapsed="0.004003"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.652066" elapsed="0.004051"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.656679" 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-06-06T03:23:12.656286" elapsed="0.000421"/>
</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-06-06T03:23:12.657021" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.656780" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.657563" 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-06-06T03:23:12.657265" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.657101" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.656761" elapsed="0.000899"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.658199" 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-06-06T03:23:12.657834" 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-06-06T03:23:12.658533" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.658296" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.659134" 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-06-06T03:23:12.658816" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.658613" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.658278" elapsed="0.000940"/>
</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-06-06T03:23:12.659372" elapsed="0.000364"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:12.660179" 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-06-06T03:23:12.659907" elapsed="0.000298"/>
</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-06-06T03:23:12.660362" elapsed="0.002685"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:23:12.647067" elapsed="0.016051"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:12.663168" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:23:12.665736" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:23:12.633765" elapsed="0.031999"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:12.665818" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}local_as/ebgp_peer</arg>
<arg>mapping=${mapping}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:23:12.532272" elapsed="0.133671"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.667259" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:12.666856" elapsed="0.000464"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.666836" elapsed="0.000509"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.667499" elapsed="0.000344"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.673421" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:12.673010" elapsed="0.000488"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:12.673746" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.673578" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.673559" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.673981" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.674159" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.674338" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.674509" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.674702" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.674880" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.675091" elapsed="0.000022"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:12.672695" elapsed="0.002476"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:12.666623" elapsed="0.008599"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:12.666244" elapsed="0.009020"/>
</kw>
<doc>Delete peer configuration.</doc>
<status status="PASS" start="2026-06-06T03:23:12.302771" elapsed="0.372531"/>
</test>
<kw name="Teardown_Everything" owner="BgpOperations" type="TEARDOWN">
<kw name="Search_And_Kill_Remote_Python" owner="KillPythonTool">
<kw name="Search_For_Remote_Python_Processes" owner="KillPythonTool">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.677177" level="INFO">Executing command 'ps -elf | egrep python | egrep 'play.py' | egrep -v grep'.</msg>
<msg time="2026-06-06T03:23:12.699949" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:23:12.700168" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>ps -elf | egrep python | egrep ${filter} | egrep -v grep</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:12.677029" elapsed="0.023197"/>
</kw>
<return>
<value>${processes}</value>
<status status="PASS" start="2026-06-06T03:23:12.700337" elapsed="0.000070"/>
</return>
<msg time="2026-06-06T03:23:12.700738" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>${filter}</arg>
<doc>Only searches for the list of processes, in case something else than kill has to be done with them.</doc>
<status status="PASS" start="2026-06-06T03:23:12.676628" elapsed="0.024170"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.701770" level="INFO"/>
<arg>${processes}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:12.701165" elapsed="0.000701"/>
</kw>
<kw name="Kill_Remote_Processes" owner="KillPythonTool">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:23:12.703774" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:23:12.703945" level="INFO">${arg_length} = 0</msg>
<var>${arg_length}</var>
<arg>${pself_lines}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:23:12.703117" elapsed="0.000881"/>
</kw>
<if>
<branch type="IF" condition="${arg_length} == 0">
<return>
<status status="PASS" start="2026-06-06T03:23:12.704403" elapsed="0.000062"/>
</return>
<status status="PASS" start="2026-06-06T03:23:12.704157" elapsed="0.000374"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:12.704115" elapsed="0.000471"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${commands}</var>
<arg>echo '${pself_lines}' | awk '{print "kill -${signal}",$4}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.704975" elapsed="0.000050"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${commands}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.705373" elapsed="0.000046"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${stdout}</var>
<var>${stderr}</var>
<arg>echo 'set -exu; ${commands}' | sudo sh</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:12.705795" elapsed="0.000047"/>
</kw>
<arg>${processes}</arg>
<doc>Kill processes by PIDs from given list (no-op if the list is empty), using specified signal. Log the kill commands used.</doc>
<status status="PASS" start="2026-06-06T03:23:12.702404" elapsed="0.003581"/>
</kw>
<arg>'play\.py'</arg>
<doc>The main keyword. Search for processes, Log the list of them, kill them.</doc>
<status status="PASS" start="2026-06-06T03:23:12.676347" elapsed="0.029747"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:12.706587" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:23:12.706423" elapsed="0.000562"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:23:12.707414" elapsed="0.000842"/>
</kw>
<doc>Create and Log the diff between expected and actual responses, make sure Python tool was killed.
Tear down imported Resources.</doc>
<status status="PASS" start="2026-06-06T03:23:12.676071" elapsed="0.032245"/>
</kw>
<doc>Basic tests for eBGP application peers.

Copyright (c) 2015-2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

Test suite performs basic eBGP functional tests:
Two eBGP peers advertise the same group of prefixes (aka BGP HA)
https://wiki.opendaylight.org/view/BGP_LS_PCEP:BGP
Reported bugs:
Bug 4834 - ODL controller announces the same route twice (two eBGP scenario aka HA)
Bug 4835 - Routes not withdrawn when eBGP peers are disconnected (the same prefixes announced)

For versions Fluorine and above, there are test cases:
TC_LAS (test case local AS)
- configuration of ebgp with local-as and ibgp without local-as
- connect bgp speakers (play.py) to both peers and check their connection
- check adj-rib-out on both peers, expecting local-as in as-sequence on both peers.

TODO: Extend testsuite by tests dedicated to path selection algorithm
TODO: Choose keywords used by more than one test suite to be placed in a common place.</doc>
<status status="FAIL" start="2026-06-06T03:20:41.394837" elapsed="151.313509"/>
</suite>
<suite id="s1-s10" name="010 Bgp Flowspec" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/010_bgp_flowspec.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Open Connection" owner="SSHLibrary">
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:12.774281" elapsed="0.000363"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:23:12.776370" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:23:12.776451" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:23:12.776098" elapsed="0.000377"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.776621" elapsed="0.000346"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:23:12.777799" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:23:13.468451" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:23:13 UTC 2026

  System load:  0.0                Processes:             105
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:17:22 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:23:12.777465" elapsed="0.691134"/>
</kw>
<msg time="2026-06-06T03:23:13.468698" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:12.777124" elapsed="0.691651"/>
</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-06-06T03:23:12.775623" elapsed="0.693268"/>
</kw>
<msg time="2026-06-06T03:23:13.468944" 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-06-06T03:23:12.775218" elapsed="0.693773"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:23:12.774863" elapsed="0.694208"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:23:13.475193" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:23:13.474848" elapsed="0.000376"/>
</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-06-06T03:23:13.476759" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:23:13.745041" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:13.745431" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 117ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:23:13.745539" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:23:13.745630" 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-06-06T03:23:13.476535" elapsed="0.269196"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:23:13.747755" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:23:13.747098" elapsed="0.000765"/>
</kw>
<msg time="2026-06-06T03:23:13.748132" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:23:13.748235" 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-06-06T03:23:13.746222" elapsed="0.002065"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:13.749677" 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-06-06T03:23:13.748675" elapsed="0.001066"/>
</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-06-06T03:23:13.752204" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 117ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:13.751527" elapsed="0.000815"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:13.753077" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:13.752729" elapsed="0.000494"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:13.753785" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:13.753424" elapsed="0.000426"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:23:13.750739" elapsed="0.003188"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:13.749934" elapsed="0.004044"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:13.749881" elapsed="0.004133"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:23:13.754242" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:13.754093" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:13.754068" elapsed="0.000274"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:23:13.754541" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:23:13.754415" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:13.754393" elapsed="0.000299"/>
</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-06-06T03:23:13.754882" elapsed="0.000031"/>
</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-06-06T03:23:13.475990" elapsed="0.279061"/>
</kw>
<msg time="2026-06-06T03:23:13.755132" 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-06-06T03:23:13.475398" elapsed="0.279806"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:23:13.474207" elapsed="0.281152"/>
</kw>
<msg time="2026-06-06T03:23:13.755438" 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-06-06T03:23:13.470223" elapsed="0.285275"/>
</kw>
<arg>virtualenv ${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-06-06T03:23:13.469804" elapsed="0.285861"/>
</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-06-06T03:23:13.763691" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/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-06-06T03:23:13.763342" elapsed="0.000379"/>
</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-06-06T03:23:13.765569" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-06-06T03:23:15.948390" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:15.948918" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
Installing collected packages: pip
  Att...</msg>
<msg time="2026-06-06T03:23:15.949087" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:23:15.949236" 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-06-06T03:23:13.765225" elapsed="2.184095"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:23:15.953980" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:23:15.952976" elapsed="0.001243"/>
</kw>
<msg time="2026-06-06T03:23:15.954545" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:23:15.954738" 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-06-06T03:23:15.950071" elapsed="0.004751"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:15.957991" 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-06-06T03:23:15.955447" elapsed="0.002634"/>
</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-06-06T03:23:15.961389" level="INFO">Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
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.1.2</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:15.961011" elapsed="0.000477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:15.962375" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:15.962008" elapsed="0.000459"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:15.963190" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:15.962825" elapsed="0.000510"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:23:15.960110" elapsed="0.003337"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:15.958458" elapsed="0.005102"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:15.958403" elapsed="0.005190"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:23:15.963850" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:15.963670" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:15.963636" elapsed="0.000354"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:23:15.964206" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:23:15.964045" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:15.964029" elapsed="0.000345"/>
</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-06-06T03:23:15.964513" 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-06-06T03:23:13.764567" elapsed="2.200147"/>
</kw>
<msg time="2026-06-06T03:23:15.964774" 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-06-06T03:23:13.763874" elapsed="2.200956"/>
</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/defaultvenv/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-06-06T03:23:13.762745" elapsed="2.202168"/>
</kw>
<msg time="2026-06-06T03:23:15.964967" 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-06-06T03:23:13.758338" elapsed="2.206675"/>
</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-06-06T03:23:13.757562" elapsed="2.207531"/>
</kw>
<msg time="2026-06-06T03:23:15.965142" 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-06-06T03:23:13.757045" elapsed="2.208140"/>
</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-06-06T03:23:13.756561" elapsed="2.208700"/>
</kw>
<msg time="2026-06-06T03:23:15.965305" 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-06-06T03:23:13.755875" elapsed="2.209473"/>
</kw>
<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-06-06T03:23:13.469383" elapsed="2.496039"/>
</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-06-06T03:23:15.972670" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:23:15.972296" elapsed="0.000407"/>
</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-06-06T03:23:15.974621" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; deactivate'.</msg>
<msg time="2026-06-06T03:23:16.833987" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:16.834490" level="INFO">${stdout} = Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setupt...</msg>
<msg time="2026-06-06T03:23:16.834597" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:23:16.834753" 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-06-06T03:23:15.974259" elapsed="0.860557"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:23:16.839227" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:23:16.837973" elapsed="0.001620"/>
</kw>
<msg time="2026-06-06T03:23:16.839970" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:23:16.840070" 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-06-06T03:23:16.835427" elapsed="0.004695"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:16.842009" 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-06-06T03:23:16.840729" elapsed="0.001321"/>
</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-06-06T03:23:16.845186" level="INFO">Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setuptools
  Attempting uninstall: setuptools
    Found existing installation: setuptools 59.6.0
    Uninstalling setuptools-59.6.0:
      Successfully uninstalled setuptools-59.6.0
Successfully installed setuptools-44.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:16.844696" elapsed="0.000596"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:16.846205" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:16.845731" elapsed="0.000571"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:16.847243" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:16.846765" elapsed="0.000576"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:23:16.843344" elapsed="0.004108"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:16.842261" elapsed="0.005330"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:16.842223" elapsed="0.005412"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:23:16.848079" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:16.847864" elapsed="0.000358"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:16.847837" elapsed="0.000425"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:23:16.848709" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-06-06T03:23:16.848472" elapsed="0.000391"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:16.848439" elapsed="0.000452"/>
</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-06-06T03:23:16.849031" 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-06-06T03:23:15.973508" elapsed="0.875665"/>
</kw>
<msg time="2026-06-06T03:23:16.849233" 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-06-06T03:23:15.972869" elapsed="0.876418"/>
</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/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:23:15.971669" elapsed="0.877718"/>
</kw>
<msg time="2026-06-06T03:23:16.849444" 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-06-06T03:23:15.967716" elapsed="0.881772"/>
</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-06-06T03:23:15.967063" elapsed="0.882516"/>
</kw>
<msg time="2026-06-06T03:23:16.849630" 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-06-06T03:23:15.966689" elapsed="0.883002"/>
</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-06-06T03:23:15.966311" elapsed="0.883471"/>
</kw>
<msg time="2026-06-06T03:23:16.849825" 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-06-06T03:23:15.965947" elapsed="0.883922"/>
</kw>
<arg>setuptools==44.0.0</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-06-06T03:23:15.965610" elapsed="0.884341"/>
</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-06-06T03:23:16.857037" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:23:16.856690" elapsed="0.000376"/>
</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-06-06T03:23:16.858812" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; deactivate'.</msg>
<msg time="2026-06-06T03:23:18.758996" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:18.759597" level="INFO">${stdout} = Collecting exabgp==3.4.16
  Downloading exabgp-3.4.16.tar.gz (240 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to bu...</msg>
<msg time="2026-06-06T03:23:18.759814" level="INFO">${stderr} =   error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        ...</msg>
<msg time="2026-06-06T03:23:18.759962" 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-06-06T03:23:16.858439" elapsed="1.901593"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:23:18.764827" level="INFO">Length is 1821.</msg>
<msg time="2026-06-06T03:23:18.765873" level="FAIL">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:23:18.763515" elapsed="0.002886">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</status>
</kw>
<msg time="2026-06-06T03:23:18.766852" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:23:18.766968" level="INFO">${result} = '  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
       ...</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-06-06T03:23:18.760877" elapsed="0.006154"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:18.769547" 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-06-06T03:23:18.767520" elapsed="0.002184"/>
</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-06-06T03:23:18.772054" level="INFO">Collecting exabgp==3.4.16
  Downloading exabgp-3.4.16.tar.gz (240 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 'error'</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:18.771698" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:18.772833" level="INFO">  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-9dysi7f_/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:18.772455" elapsed="0.000527"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:18.773615" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:18.773270" elapsed="0.000469"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:23:18.770771" elapsed="0.003046"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:18.769977" elapsed="0.003934"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:18.769942" elapsed="0.004001"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:23:18.774154" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:18.774002" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:18.773984" elapsed="0.000297"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:23:18.774472" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:23:18.774337" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:18.774321" elapsed="0.000296"/>
</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-06-06T03:23:18.774827" elapsed="0.000024"/>
</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-06-06T03:23:16.857841" elapsed="1.917143"/>
</kw>
<msg time="2026-06-06T03:23:18.775044" 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-06-06T03:23:16.857218" elapsed="1.917878"/>
</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/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:23:16.856034" elapsed="1.919161"/>
</kw>
<msg time="2026-06-06T03:23:18.775253" 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-06-06T03:23:16.852192" elapsed="1.923110"/>
</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-06-06T03:23:16.851534" elapsed="1.923860"/>
</kw>
<msg time="2026-06-06T03:23:18.775445" 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-06-06T03:23:16.851165" elapsed="1.924326"/>
</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-06-06T03:23:16.850796" elapsed="1.924785"/>
</kw>
<msg time="2026-06-06T03:23:18.775626" 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-06-06T03:23:16.850403" elapsed="1.925287"/>
</kw>
<arg>exabgp==3.4.16</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-06-06T03:23:16.850145" elapsed="1.925629"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:18.776235" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59ba5d0&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:23:18.775926" elapsed="0.000488"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:23:18.809373" level="INFO">[chan 5] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:23:18.829788" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec/bgp-flowspec.cfg' -&gt; '/home/jenkins/.//bgp-flowspec.cfg'</msg>
<msg time="2026-06-06T03:23:18.829949" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec/bgp-flowspec-redirect.cfg' -&gt; '/home/jenkins/.//bgp-flowspec-redirect.cfg'</msg>
<arg>${BGP_VARIABLES_FOLDER}</arg>
<arg>.</arg>
<doc>Uploads a directory, including its content, from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:23:18.776964" elapsed="0.053136"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:23:18.840329" level="INFO">4 files:
bgp-flowspec-redirect.cfg
bgp-flowspec.cfg
exa-md5.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:23:18.840536" level="INFO">@{cfgfiles} = [ bgp-flowspec-redirect.cfg | bgp-flowspec.cfg | exa-md5.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:23:18.830536" elapsed="0.010038"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:18.841481" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:23:18.854423" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:18.841183" elapsed="0.013378"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:18.855952" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:23:18.906775" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:18.854947" elapsed="0.051973"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:18.907689" level="INFO">Executing command 'cat bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:23:18.958762" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:18.959008" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:18.907290" elapsed="0.051783"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:18.960169" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;

        }
        then {
            redirect 65500:12345;
        }
    }
    route flow2 {
        match {
            source 10.0.0.2/32;
            destination 192.168.0.2/32;

        }
        then {
                redirect 1.2.3.4;
        }
    }
    route flow4 {
        match {
            source 10.0.0.4/32;
            destination 192.168.0.4/32;

        }
        next-hop 127.0.0.1;
        then {
                redirect-to-nexthop;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:18.959472" elapsed="0.000814"/>
</kw>
<var name="${cfgfile}">bgp-flowspec-redirect.cfg</var>
<status status="PASS" start="2026-06-06T03:23:18.840968" elapsed="0.119400"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:18.961456" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:23:19.010931" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:18.961015" elapsed="0.050053"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.011988" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:23:19.063235" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.011448" elapsed="0.052018"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.064376" level="INFO">Executing command 'cat bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:23:19.114560" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:19.114832" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.063971" elapsed="0.050923"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.116033" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;
            port =80;
            destination-port &gt;8080&amp;&lt;8088;
            source-port &gt;1024;
            protocol tcp;
            packet-length &gt;400&amp;&lt;500;
            fragment =first-fragment;
            icmp-type echo-reply;
            icmp-code network-unreachable;
            tcp-flags =urgent;
            dscp 20;
        }
        then {
            action sample-terminal;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.115348" elapsed="0.000805"/>
</kw>
<var name="${cfgfile}">bgp-flowspec.cfg</var>
<status status="PASS" start="2026-06-06T03:23:18.960603" elapsed="0.155630"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.117195" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:23:19.162524" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.116806" elapsed="0.045894"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.163459" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:23:19.210486" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.163053" elapsed="0.047570"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.211354" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:23:19.266497" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:19.266857" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.211014" elapsed="0.055908"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.268199" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.267409" elapsed="0.000906"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:23:19.116483" elapsed="0.151910"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.269366" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:23:19.313784" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.268988" elapsed="0.044937"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.314808" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:23:19.366027" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.314380" elapsed="0.051784"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:19.366876" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:23:19.418820" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:19.419099" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:19.366512" elapsed="0.052657"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.420531" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.419705" elapsed="0.001008"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:23:19.268679" elapsed="0.152125"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:23:18.840711" elapsed="0.580173"/>
</for>
<arg>${BGP_VARIABLES_FOLDER}</arg>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:23:18.776623" elapsed="0.644415"/>
</kw>
<doc>Suite setup keyword</doc>
<status status="PASS" start="2026-06-06T03:23:12.774036" elapsed="6.647134"/>
</kw>
<test id="s1-s10-t1" name="Check_For_Empty_Topology_Before_Talking" line="41">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Empty_Flowspec_Data">
<kw name="Verify_Empty_Flowspec_Data_Neon">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.472536" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.472090" elapsed="0.000485"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.473536" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.473107" elapsed="0.000511">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.473745" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.472768" elapsed="0.001002"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.474349" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.473936" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.474705" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.474920" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.474529" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.475359" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.475099" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.476666" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.476156" elapsed="0.000578"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.477266" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.476888" elapsed="0.000406"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.477731" elapsed="0.000050"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.478342" elapsed="0.000051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.478710" elapsed="0.000049"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.477518" elapsed="0.001362"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.477350" elapsed="0.001597"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:19.479055" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:23:19.479235" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:19.475812" elapsed="0.003450"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.475488" elapsed="0.003807"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.479463" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.479322" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.475463" elapsed="0.004079"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.480158" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:19.479695" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.480239" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:19.471451" elapsed="0.008918"/>
</kw>
<msg time="2026-06-06T03:23:19.480426" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.459634" elapsed="0.020844"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.492117" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.503360" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.514589" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.514793" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.514960" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.515399" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.515220" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:19.515199" elapsed="0.000310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.515702" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.515871" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.516027" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.515160" elapsed="0.000920"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.515039" elapsed="0.001067"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.516240" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.516370" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:19.516498" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:19.455573" elapsed="0.060952"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.517836" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.517551" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.518003" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.517215" elapsed="0.000813"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.518341" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.518102" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.518900" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.518582" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.518425" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.518082" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.521148" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.519124" elapsed="0.002051"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:19.521228" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.521385" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:19.516892" elapsed="0.004518"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.522727" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.522512" elapsed="0.000272"/>
</kw>
<msg time="2026-06-06T03:23:19.522871" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.522043" elapsed="0.000853"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.523105" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:19.522967" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.522948" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.523506" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.523682" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.523323" elapsed="0.000386"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:23:19.524096" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.523856" elapsed="0.000266"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:23:19.524168" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.524324" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:19.521726" elapsed="0.002623"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.525762" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.525491" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.526361" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.525949" elapsed="0.000460"/>
</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-06-06T03:23:19.538393" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:19.538957" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Set-Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:23:19 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:23:19.539204" 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-06-06T03:23:19.528686" elapsed="0.010578"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.526536" elapsed="0.012825"/>
</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-06-06T03:23:19.539777" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.539421" elapsed="0.000506"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.526511" elapsed="0.013464"/>
</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-06-06T03:23:19.545252" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.542156" elapsed="0.003162"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.541838" elapsed="0.003529"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.541796" elapsed="0.003606"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.548721" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.545797" elapsed="0.002989"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.545481" elapsed="0.003385"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.545457" elapsed="0.003444"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.549667" 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-06-06T03:23:19.549108" elapsed="0.000599"/>
</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-06-06T03:23:19.550134" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.549807" elapsed="0.000386"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.550679" 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-06-06T03:23:19.550361" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.550217" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.549781" elapsed="0.000981"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.551267" 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-06-06T03:23:19.550905" elapsed="0.000388"/>
</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-06-06T03:23:19.551579" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.551363" elapsed="0.000274"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.552117" 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-06-06T03:23:19.551823" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.551678" elapsed="0.000500"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.551344" elapsed="0.000855"/>
</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-06-06T03:23:19.552336" elapsed="0.000362"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:19.553185" 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-06-06T03:23:19.552880" elapsed="0.000331"/>
</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-06-06T03:23:19.553355" elapsed="0.002077"/>
</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-06-06T03:23:19.540853" elapsed="0.014643"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.555729" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:19.555567" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.555547" elapsed="0.000254"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:19.560464" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:23:19.555942" elapsed="0.004587"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:23:19.560678" elapsed="0.000071"/>
</return>
<msg time="2026-06-06T03:23:19.561069" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:23:19.524662" elapsed="0.036465"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.561269" elapsed="0.000059"/>
</return>
<msg time="2026-06-06T03:23:19.561598" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:19.434431" elapsed="0.127252"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.592792" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.592050" elapsed="0.000771"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.594596" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.594065" elapsed="0.000707">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.594907" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.592988" elapsed="0.001944"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.595845" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.595088" elapsed="0.000785"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.596256" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.596493" level="INFO">${template} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.596024" elapsed="0.000497"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.597137" level="INFO">{
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
                "uptodate": "*"
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.596689" elapsed="0.000511"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:19.597825" elapsed="0.000077"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.597271" elapsed="0.000711"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.598791" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.598173" elapsed="0.000658"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.598010" elapsed="0.000901"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.597251" elapsed="0.001684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.599836" level="INFO">${final_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:19.599070" elapsed="0.000795"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.599915" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:19.591333" elapsed="0.008706"/>
</kw>
<msg time="2026-06-06T03:23:19.600129" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.579747" elapsed="0.020433"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.611616" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.622823" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.633999" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.634182" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.634346" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.634724" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.634577" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:19.634562" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.634939" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.635092" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.635244" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.634533" elapsed="0.000764"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.634426" elapsed="0.000897"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.635455" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.635529" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:19.635660" level="INFO">${expected_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:19.577277" elapsed="0.058412"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.635854" elapsed="0.002550"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:19.639580" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.639271" elapsed="0.000339"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:19.640050" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.639776" elapsed="0.000302"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:23:19.640224" elapsed="0.000336"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:23:19.638838" elapsed="0.001786"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.638554" elapsed="0.002123"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.640842" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.640704" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.638531" elapsed="0.002404"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:23:19.564227" elapsed="0.076774"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:23:19.562379" elapsed="0.078732"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.561873" elapsed="0.079316"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.561834" elapsed="0.079393"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.641280" elapsed="0.000036"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}empty_route</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:23:19.428785" elapsed="0.212641"/>
</kw>
<doc>Verify empty flowspec data on neon</doc>
<status status="PASS" start="2026-06-06T03:23:19.424844" elapsed="0.216649"/>
</kw>
<doc>Verify expected response.</doc>
<status status="PASS" start="2026-06-06T03:23:19.424055" elapsed="0.217487"/>
</kw>
<arg>60s</arg>
<arg>3s</arg>
<arg>Verify_Empty_Flowspec_Data</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:23:19.422919" elapsed="0.218669"/>
</kw>
<doc>Sanity check bgp-flowspec:flowspec-routes is up but empty.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:19.421320" elapsed="0.220409"/>
</test>
<test id="s1-s10-t2" name="Reconfigure_ODL_To_Accept_Connection" line="46">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.643249" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB_OPENCONFIG=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.642627" elapsed="0.000652"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.679056" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.678667" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.679839" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.679563" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.680011" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.679238" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.680588" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.680190" elapsed="0.000426"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.680926" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.681130" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.680785" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.681635" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.681304" elapsed="0.000398"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.684191" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.682384" elapsed="0.001856"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.684684" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.684393" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.685406" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.685071" elapsed="0.000362"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:19.686168" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.685945" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:19.686247" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:19.686403" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:19.685614" elapsed="0.000814"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.686569" elapsed="0.000257"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:23:19.684947" elapsed="0.001921"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.687397" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.687101" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:19.688123" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.687915" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:19.688200" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:19.688350" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:19.687596" elapsed="0.000778"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.688510" elapsed="0.000236"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:19.686982" elapsed="0.001806"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.689311" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.689018" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:19.690094" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.689881" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:19.690172" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.690323" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:19.689560" elapsed="0.000787"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.690487" elapsed="0.000238"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:19.688901" elapsed="0.001866"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.691293" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.690997" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:19.692032" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.691814" elapsed="0.000244"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:19.692109" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:19.692259" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:19.691493" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.692423" elapsed="0.000237"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:23:19.690880" elapsed="0.001823"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.693278" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.692978" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:19.694032" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.693820" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:19.694109" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.694259" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:19.693501" elapsed="0.000782"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.694420" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:19.692858" elapsed="0.001841"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.695229" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.694932" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:19.696147" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.695935" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:19.696225" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.696375" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:19.695609" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.696538" elapsed="0.000240"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:19.694812" elapsed="0.002007"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:19.684765" elapsed="0.012090"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:19.696898" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:19.697057" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:19.682070" elapsed="0.015012"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.681776" elapsed="0.015338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.697274" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.697139" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.681756" elapsed="0.015594"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.698191" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:19.697509" elapsed="0.000711"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.698269" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:19.678024" elapsed="0.020368"/>
</kw>
<msg time="2026-06-06T03:23:19.698446" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.666490" elapsed="0.032003"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.709801" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.721001" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.732353" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.732538" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.732719" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.733072" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.732941" elapsed="0.000186"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:19.732926" elapsed="0.000225"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.733278" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.733431" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.733624" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.732897" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.732796" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.733861" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.733943" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:19.734067" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:19.662591" elapsed="0.071644"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.758147" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.757769" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.758872" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.758643" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.759033" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.758323" elapsed="0.000735"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.759591" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.759207" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.759921" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.760063" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.759784" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.760481" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.760236" elapsed="0.000339"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:19.760944" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.760660" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.761458" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.761163" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.761029" elapsed="0.000494"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.760625" elapsed="0.000919"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.762436" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:19.761711" elapsed="0.000757"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.762520" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:19.757125" elapsed="0.005541"/>
</kw>
<msg time="2026-06-06T03:23:19.762728" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.745755" elapsed="0.017022"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.774277" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.785552" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.796788" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.796971" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.797135" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.797487" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.797355" elapsed="0.000188"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:19.797340" elapsed="0.000227"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.797714" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.797899" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.798057" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.797312" elapsed="0.000798"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.797212" elapsed="0.000924"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.798308" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.798386" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:19.798521" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:19.743283" elapsed="0.055267"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.799797" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.799529" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.799962" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.799201" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.800292" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.800058" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.800846" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.800530" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.800373" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.800038" elapsed="0.000891"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.803116" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.801071" elapsed="0.002071"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:19.803195" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:19.803349" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:19.798886" elapsed="0.004488"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.804755" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.804483" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.805187" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.804946" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.805631" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.805387" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.806109" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.805866" elapsed="0.000287"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:19.806953" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:23:19.806756" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:23:19.807294" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:23:19.807120" elapsed="0.000200"/>
</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-06-06T03:23:19.807499" elapsed="0.000243"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.808140" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.807889" elapsed="0.000296"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:23:19.808227" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.808383" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:23:19.806344" elapsed="0.002064"/>
</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-06-06T03:23:19.821502" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Content-Length': '1132', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:23:19.821568" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:19.821695" 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-06-06T03:23:19.810550" elapsed="0.011173"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.808479" elapsed="0.013291"/>
</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-06-06T03:23:19.821976" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.821796" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.808460" elapsed="0.013608"/>
</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-06-06T03:23:19.825143" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.823011" elapsed="0.002175"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.822800" elapsed="0.002421"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.822781" elapsed="0.002465"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.827579" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.825513" elapsed="0.002113"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.825304" elapsed="0.002371"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.825286" elapsed="0.002415"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.828235" 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-06-06T03:23:19.827850" elapsed="0.000413"/>
</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-06-06T03:23:19.828553" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.828334" elapsed="0.000276"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.829099" 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-06-06T03:23:19.828798" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.828635" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.828315" elapsed="0.000866"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.829703" 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-06-06T03:23:19.829325" elapsed="0.000406"/>
</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-06-06T03:23:19.830044" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.829800" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.830610" 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-06-06T03:23:19.830311" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.830162" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.829782" elapsed="0.000930"/>
</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-06-06T03:23:19.830852" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:19.831634" 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-06-06T03:23:19.831354" elapsed="0.000325"/>
</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-06-06T03:23:19.831824" elapsed="0.002080"/>
</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-06-06T03:23:19.822421" elapsed="0.011552"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:19.834289" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:19.834041" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.834022" elapsed="0.000355"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:23:19.834515" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.834585" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:19.836686" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:23:19.803707" elapsed="0.033007"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.836779" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:19.836934" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:19.650361" elapsed="0.186599"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.837283" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.837057" elapsed="0.000294"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.837039" elapsed="0.000336"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.837407" elapsed="0.000026"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:23:19.643539" elapsed="0.193991"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:23:19.642098" elapsed="0.195567"/>
</test>
<test id="s1-s10-t3" name="FlowSpec_Test_1" line="60">
<kw name="Setup_Testcase" type="SETUP">
<kw name="Verify_Empty_Flowspec_Data">
<kw name="Verify_Empty_Flowspec_Data_Neon">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.885369" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.884982" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.886302" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.885898" elapsed="0.000480">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.886474" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.885556" elapsed="0.000943"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.887067" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.886679" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.887450" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.887604" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.887307" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.888067" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.887798" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.889260" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.888802" elapsed="0.000504"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.889897" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:19.889454" elapsed="0.000472"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.890320" elapsed="0.000076"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.890816" elapsed="0.000079"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.891112" elapsed="0.000075"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.890160" elapsed="0.001120"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.889984" elapsed="0.001329"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:19.891360" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:19.891526" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:19.888475" elapsed="0.003075"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.888189" elapsed="0.003394"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.891783" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.891607" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.888166" elapsed="0.003697"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.892438" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:19.891995" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.892515" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:19.884366" elapsed="0.008272"/>
</kw>
<msg time="2026-06-06T03:23:19.892716" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.872783" elapsed="0.019984"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.904284" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.915710" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.926975" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.927164" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.927329" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.927706" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.927553" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:19.927538" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.927918" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.928073" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.928246" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:19.927507" elapsed="0.000802"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.927406" elapsed="0.000930"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.928472" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.928547" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:19.928693" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:19.868871" elapsed="0.059906"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.930004" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.929761" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.930164" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.929410" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:19.930520" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.930285" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.931061" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.930770" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.930601" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.930265" elapsed="0.000878"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.933306" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.931280" elapsed="0.002053"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:19.933387" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:19.933540" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:19.929095" elapsed="0.004469"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.934776" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.934571" elapsed="0.000260"/>
</kw>
<msg time="2026-06-06T03:23:19.934977" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.934202" elapsed="0.000811"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.935230" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:19.935092" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.935071" elapsed="0.000227"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.935600" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.935752" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.935432" elapsed="0.000346"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:23:19.936187" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:23:19.935941" elapsed="0.000272"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:23:19.936262" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:19.936414" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:19.933876" elapsed="0.002562"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.937808" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.937543" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.938238" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.937999" elapsed="0.000327"/>
</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-06-06T03:23:19.946901" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:19.947042" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:23:19.947140" 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-06-06T03:23:19.940474" elapsed="0.006692"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.938396" elapsed="0.008815"/>
</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-06-06T03:23:19.947380" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.947237" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.938377" elapsed="0.009090"/>
</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-06-06T03:23:19.950713" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.948467" elapsed="0.002294"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.948256" elapsed="0.002540"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.948238" elapsed="0.002582"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.953202" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.951091" elapsed="0.002157"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.950876" elapsed="0.002408"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.950859" elapsed="0.002450"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.953863" 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-06-06T03:23:19.953457" elapsed="0.000433"/>
</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-06-06T03:23:19.954187" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.953966" elapsed="0.000279"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.954774" 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-06-06T03:23:19.954453" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.954269" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.953947" elapsed="0.000945"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.955613" 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-06-06T03:23:19.955100" elapsed="0.000574"/>
</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-06-06T03:23:19.956083" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.955776" elapsed="0.000388"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.956839" 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-06-06T03:23:19.956395" elapsed="0.000480"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.956197" elapsed="0.000729"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.955750" elapsed="0.001204"/>
</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-06-06T03:23:19.957145" elapsed="0.000481"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:19.958271" 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-06-06T03:23:19.957864" elapsed="0.000444"/>
</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-06-06T03:23:19.958606" elapsed="0.002161"/>
</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-06-06T03:23:19.947828" elapsed="0.013004"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:19.961010" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:19.960903" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.960884" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:19.963635" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:23:19.961207" elapsed="0.002474"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:23:19.963733" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:19.963889" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:23:19.936753" elapsed="0.027162"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.963977" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:23:19.964124" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:19.848758" elapsed="0.115534"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.990270" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.989506" elapsed="0.000793"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.991519" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:19.991066" elapsed="0.000674">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:19.991874" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:19.990471" elapsed="0.001428"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.992710" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:19.992053" elapsed="0.000686"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:19.993123" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:19.993270" level="INFO">${template} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:19.992888" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.993911" level="INFO">{
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
                "uptodate": "*"
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:19.993442" elapsed="0.000516"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:19.994369" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:19.994028" elapsed="0.000537"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.995322" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:19.994754" elapsed="0.000674"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.994594" elapsed="0.001006"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.994009" elapsed="0.001617"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:19.996554" level="INFO">${final_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:19.995781" elapsed="0.000802"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:19.996632" elapsed="0.000047"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:19.988903" elapsed="0.007874"/>
</kw>
<msg time="2026-06-06T03:23:19.996831" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:19.977498" elapsed="0.019382"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.008215" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.019344" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.030442" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.030640" elapsed="0.000034"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.030819" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.031174" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:20.031045" elapsed="0.000184"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:20.031030" elapsed="0.000223"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.031381" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.031574" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.031749" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:20.031002" elapsed="0.000802"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:20.030898" elapsed="0.000933"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.031964" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:20.032039" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:20.032156" level="INFO">${expected_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:19.975062" elapsed="0.057121"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:20.032347" elapsed="0.002170"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:20.035560" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:20.035276" elapsed="0.000312"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:20.036024" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:20.035748" elapsed="0.000303"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:23:20.036192" elapsed="0.000325"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:23:20.034876" elapsed="0.001702"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:20.034597" elapsed="0.002015"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:20.036789" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:20.036637" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:20.034578" elapsed="0.002288"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:23:19.965399" elapsed="0.071515"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:23:19.964600" elapsed="0.072388"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:19.964375" elapsed="0.072658"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:19.964358" elapsed="0.072700"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:20.037090" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}empty_route</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:23:19.842888" elapsed="0.194329"/>
</kw>
<doc>Verify empty flowspec data on neon</doc>
<status status="PASS" start="2026-06-06T03:23:19.838969" elapsed="0.198308"/>
</kw>
<doc>Verify expected response.</doc>
<status status="PASS" start="2026-06-06T03:23:19.838747" elapsed="0.198578"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.040414" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:20.040094" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.040845" level="INFO">env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:20.040584" elapsed="0.000305"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:20.046708" level="INFO">source /tmp/defaultvenv/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-06-06T03:23:20.041503" elapsed="0.005288"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:20.055805" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:20.055913" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:20.046985" elapsed="0.008954"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.056559" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:20.056278" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:20.056020" elapsed="0.000619"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:20.055994" elapsed="0.000691"/>
</if>
<arg>log_output=${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-06-06T03:23:20.041159" elapsed="0.015577"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:20.058782" level="INFO">env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec.cfg</msg>
<msg time="2026-06-06T03:23:20.058874" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:20.056877" elapsed="0.002023"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.059300" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:20.059050" elapsed="0.000296"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:20.039788" elapsed="0.019615"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.061304" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:20.060950" elapsed="0.000381"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.063506" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:20.061481" elapsed="0.002053"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:20.068746" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:20.068879" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:20.068976" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:20.063702" elapsed="0.005301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.071349" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:20.069159" elapsed="0.002239"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:23:20.073821" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:23:20.071544" elapsed="0.002351">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:23:20.060463" elapsed="0.013548">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.077438" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.076435" elapsed="0.001084"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.082483" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.077977" elapsed="0.004573"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:23.094395" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:23.098140" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '3993'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ","attributes":{"extended-communities":[{"traffic-action-extended-community":{"sample":true,"terminal-action":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"},{"protocol-ips":[{"value":6,"op":"end-of-list equals"}]},{"ports":[{"value":80,"op":"end-of-list equals"}]},{"destination-ports":[{"value":8080,"op":"greater-than"},{"value":8088,"op":"end-of-list and-bit less-than"}]},{"source-ports":[{"value":1024,"op":"end-of-list greater-than"}]},{"types":[{"value":0,"op":"end-of-list equals"}]},{"codes":[{"value":0,"op":"end-of-list equals"}]},{"tcp-flags":[{"value":32,"op":"end-of-list match"}]},{"packet-lengths":[{"value":400,"op":"greater-than"},{"value":500,"op":"end-of-list and-bit less-than"}]},{"dscps":[{"value":20,"op":"end-of-list equals"}]},{"fragments":[{"value":"first","op":"end-of-list match"}]}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ","attributes":{"extended-communities":[{"traffic-action-extended-community":{"sample":true,"terminal-action":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"},{"protocol-ips":[{"value":6,"op":"end-of-list equals"}]},{"ports":[{"value":80,"op":"end-of-list equals"}]},{"destination-ports":[{"value":8080,"op":"greater-than"},{"value":8088,"op":"end-of-list and-bit less-than"}]},{"source-ports":[{"value":1024,"op":"end-of-list greater-than"}]},{"types":[{"value":0,"op":"end-of-list equals"}]},{"codes":[{"value":0,"op":"end-of-list equals"}]},{"tcp-flags":[{"value":32,"op":"end-of-list match"}]},{"packet-lengths":[{"value":400,"op":"greater-than"},{"value":500,"op":"end-of-list and-bit less-than"}]},{"dscps":[{"value":20,"op":"end-of-list equals"}]},{"fragments":[{"value":"first","op":"end-of-list match"}]}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:23:23.098537" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:23.082943" elapsed="0.015654"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.102920" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ","attributes":{"extended-communities":[{"traffic-action-extended-community":{"sample":true,"terminal-action":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"},{"protocol-ips":[{"value":6,"op":"end-of-list equals"}]},{"ports":[{"value":80,"op":"end-of-list equals"}]},{"destination-ports":[{"value":8080,"op":"greater-than"},{"value":8088,"op":"end-of-list and-bit less-than"}]},{"source-ports":[{"value":1024,"op":"end-of-list greater-than"}]},{"types":[{"value":0,"op":"end-of-list equals"}]},{"codes":[{"value":0,"op":"end-of-list equals"}]},{"tcp-flags":[{"value":32,"op":"end-of-list match"}]},{"packet-lengths":[{"value":400,"op":"greater-than"},{"value":500,"op":"end-of-list and-bit less-than"}]},{"dscps":[{"value":20,"op":"end-of-list equals"}]},{"fragments":[{"value":"first","op":"end-of-list match"}]}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ","attributes":{"extended-communities":[{"traffic-action-extended-community":{"sample":true,"terminal-action":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"},{"protocol-ips":[{"value":6,"op":"end-of-list equals"}]},{"ports":[{"value":80,"op":"end-of-list equals"}]},{"destination-ports":[{"value":8080,"op":"greater-than"},{"value":8088,"op":"end-of-list and-bit less-than"}]},{"source-ports":[{"value":1024,"op":"end-of-list greater-than"}]},{"types":[{"value":0,"op":"end-of-list equals"}]},{"codes":[{"value":0,"op":"end-of-list equals"}]},{"tcp-flags":[{"value":32,"op":"end-of-list match"}]},{"packet-lengths":[{"value":400,"op":"greater-than"},{"value":500,"op":"end-of-list and-bit less-than"}]},{"dscps":[{"value":20,"op":"end-of-list equals"}]},{"fragments":[{"value":"first","op":"end-of-list match"}]}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.098981" elapsed="0.004050"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:23:23.103248" elapsed="0.003472"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:23:23.074933" elapsed="0.031886"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:23:20.059958" elapsed="3.046942"/>
</kw>
<msg time="2026-06-06T03:23:23.107052" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:23.107118" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:20.059555" elapsed="3.047597"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.107735" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.107300" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.107263" elapsed="0.000593"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:23:23.108099" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:23:23.107937" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.107914" elapsed="0.000314"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:23:20.039604" elapsed="3.068665"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:23:20.039389" elapsed="3.068963"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.108567" elapsed="0.000032"/>
</kw>
<arg>${cfg_file}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>connection_retries=${3}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:23:20.037611" elapsed="3.071096"/>
</kw>
<arg>${CFG1}</arg>
<status status="PASS" start="2026-06-06T03:23:19.838444" elapsed="3.270355"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Flowspec_Data">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.155359" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.154965" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.156222" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.155960" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.156393" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.155611" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.157015" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.156604" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.157341" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:23.157502" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:23.157200" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.157943" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.157693" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.158987" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.158678" elapsed="0.000355"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.159457" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:23.159187" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.159826" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.160025" elapsed="0.000027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.160190" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:23:23.159702" elapsed="0.000546"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.159537" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:23.160325" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:23.160512" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:23.158352" elapsed="0.002185"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.158065" elapsed="0.002504"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.160746" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.160594" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.158043" elapsed="0.002781"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.161401" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:23.160957" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.161480" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:23.154350" elapsed="0.007256"/>
</kw>
<msg time="2026-06-06T03:23:23.161680" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.142955" elapsed="0.018775"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.173011" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.184159" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.195266" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.195457" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.195623" elapsed="0.000035"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.196004" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.195871" elapsed="0.000188"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:23.195855" elapsed="0.000229"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.196212" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.196365" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.196551" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:23.195823" elapsed="0.000784"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.195719" elapsed="0.000917"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.196787" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.196865" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:23.196992" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:23.139057" elapsed="0.057964"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.198284" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.198017" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.198450" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.197671" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.198800" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.198545" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.199330" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.199039" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.198882" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.198527" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.201619" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.199600" elapsed="0.002061"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:23.201715" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:23.201870" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:23.197334" elapsed="0.004561"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.203078" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.202838" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.203235" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.202496" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:23.203466" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:23.203331" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.203312" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.203702" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.203864" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.203930" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:23.207170" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:23.202185" elapsed="0.005013"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.208601" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.208324" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.209053" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.208806" elapsed="0.000291"/>
</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-06-06T03:23:23.218475" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:23.219444" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1466'} 
 body={"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ","attributes":{"extended-communities":[{"traffic-action-extended-community":{"sample":true,"terminal-action":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"},{"protocol-ips":[{"value":6,"op":"end-of-list equals"}]},{"ports":[{"value":80,"op":"end-of-list equals"}]},{"destination-ports":[{"value":8080,"op":"greater-than"},{"value":8088,"op":"end-of-list and-bit less-than"}]},{"source-ports":[{"value":1024,"op":"end-of-list greater-than"}]},{"types":[{"value":0,"op":"end-of-list equals"}]},{"codes":[{"value":0,"op":"end-of-list equals"}]},{"tcp-flags":[{"value":32,"op":"end-of-list match"}]},{"packet-lengths":[{"value":400,"op":"greater-than"},{"value":500,"op":"end-of-list and-bit less-than"}]},{"dscps":[{"value":20,"op":"end-of-list equals"}]},{"fragments":[{"value":"first","op":"end-of-list match"}]}]}]}} 
 </msg>
<msg time="2026-06-06T03:23:23.219562" 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-06-06T03:23:23.211120" elapsed="0.008469"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.209218" elapsed="0.010414"/>
</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-06-06T03:23:23.219818" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.219675" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.209196" elapsed="0.010744"/>
</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-06-06T03:23:23.224081" level="INFO">{"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ","attributes":{"extended-communities":[{"traffic-action-extended-community":{"sample":true,"terminal-action":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"},{"protocol-ips":[{"value":6,"op":"end-of-list equals"}]},{"ports":[{"value":80,"op":"end-of-list equals"}]},{"destination-ports":[{"value":8080,"op":"greater-than"},{"value":8088,"op":"end-of-list and-bit less-than"}]},{"source-ports":[{"value":1024,"op":"end-of-list greater-than"}]},{"types":[{"value":0,"op":"end-of-list equals"}]},{"codes":[{"value":0,"op":"end-of-list equals"}]},{"tcp-flags":[{"value":32,"op":"end-of-list match"}]},{"packet-lengths":[{"value":400,"op":"greater-than"},{"value":500,"op":"end-of-list and-bit less-than"}]},{"dscps":[{"value":20,"op":"end-of-list equals"}]},{"fragments":[{"value":"first","op":"end-of-list match"}]}]}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.220973" elapsed="0.003189"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.220764" elapsed="0.003446"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.220744" elapsed="0.003503"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.227528" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.224658" elapsed="0.002935"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.224329" elapsed="0.003331"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.224304" elapsed="0.003394"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.228447" 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-06-06T03:23:23.227910" elapsed="0.000576"/>
</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-06-06T03:23:23.228958" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.228588" elapsed="0.000453"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.229533" 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-06-06T03:23:23.229229" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.229075" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.228561" elapsed="0.001056"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.230153" 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-06-06T03:23:23.229780" elapsed="0.000400"/>
</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-06-06T03:23:23.230469" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.230251" elapsed="0.000275"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.231013" 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-06-06T03:23:23.230712" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.230551" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.230232" elapsed="0.000864"/>
</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-06-06T03:23:23.231235" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:23.232047" 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-06-06T03:23:23.231755" elapsed="0.000318"/>
</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-06-06T03:23:23.232217" elapsed="0.002085"/>
</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-06-06T03:23:23.220290" elapsed="0.014075"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.234544" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:23.234436" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.234417" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:23.238005" level="INFO">${text_normalized} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "traffic-action-extended-community": {
        "sample": true,
       ...</msg>
<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="PASS" start="2026-06-06T03:23:23.234762" elapsed="0.003273"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:23:23.238090" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:23.238247" level="INFO">${response_text} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "traffic-action-extended-community": {
        "sample": true,
       ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:23:23.207498" elapsed="0.030808"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.238373" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:23.238526" level="INFO">${response_text} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "traffic-action-extended-community": {
        "sample": true,
       ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:23.118726" elapsed="0.119826"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.264381" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.263907" elapsed="0.000503"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.265198" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.264927" elapsed="0.000389">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.265490" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.264563" elapsed="0.000953"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.266129" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.265688" elapsed="0.000468"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.266463" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:23.266623" level="INFO">${template} = {
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND whe...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:23.266306" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.267086" level="INFO">{
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND where IP protocol equals to 6 AND where port equals to 80 AND where destination port is greater than 8080 and is less than 8088 AND where source port is greater than 1024 AND where ICMP type equals to 0 AND where ICMP code equals to 0 AND where TCP flags does match 32 AND where packet length is greater than 400 and is less than 500 AND where DSCP equals to 20 AND where fragment does match 'IS FIRST' ",
                "attributes": {
                    "extended-communities": [
                        {
                            "transitive": true,
                            "traffic-action-extended-community": {
                                "sample": true,
                                "terminal-action": true
                            }
                        }
                    ],
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "flowspec": [
                    {
                        "destination-prefix": "192.168.0.1/32"
                    },
                    {
                        "source-prefix": "10.0.0.1/32"
                    },
                    {
                        "protocol-ips": [
                            {
                                "op": "end-of-list equals",
                                "value": 6
                            }
                        ]
                    },
                    {
                        "ports": [
                            {
                                "op": "end-of-list equals",
                                "value": 80
                            }
                        ]
                    },
                    {
                        "destination-ports": [
                            {
                                "op": "greater-than",
                                "value": 8080
                            },
                            {
                                "op": "end-of-list and-bit less-than",
                                "value": 8088
                            }
                        ]
                    },
                    {
                        "source-ports": [
                            {
                                "op": "end-of-list greater-than",
                                "value": 1024
                            }
                        ]
                    },
                    {
                        "types": [
                            {
                                "op": "end-of-list equals",
                                "value": 0
                            }
                        ]
                    },
                    {
                        "codes": [
                            {
                                "op": "end-of-list equals",
                                "value": 0
                            }
                        ]
                    },
                    {
                        "tcp-flags": [
                            {
                                "op": "end-of-list match",
                                "value": 32
                            }
                        ]
                    },
                    {
                        "packet-lengths": [
                            {
                                "op": "greater-than",
                                "value": 400
                            },
                            {
                                "op": "end-of-list and-bit less-than",
                                "value": 500
                            }
                        ]
                    },
                    {
                        "dscps": [
                            {
                                "op": "end-of-list equals",
                                "value": 20
                            }
                        ]
                    },
                    {
                        "fragments": [
                            {
                                "op": "end-of-list match",
                                "value": "first"
                            }
                        ]
                    }
                ]
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.266816" elapsed="0.000380"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:23.267668" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.267266" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.268395" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.267892" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.267757" elapsed="0.000701"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.267246" elapsed="0.001234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.269163" level="INFO">${final_text} = {
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND whe...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:23.268615" elapsed="0.000578"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.269244" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:23.263284" elapsed="0.006086"/>
</kw>
<msg time="2026-06-06T03:23:23.269446" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.251935" elapsed="0.017561"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.280786" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.291983" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.303174" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.303363" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.303529" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.303925" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.303791" elapsed="0.000190"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:23.303776" elapsed="0.000229"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.304132" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.304285" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.304438" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:23.303743" elapsed="0.000747"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.303612" elapsed="0.000904"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.304663" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.304786" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:23.304947" level="INFO">${expected_text} = {
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.1/32 AND from 10.0.0.1/32 AND whe...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:23.249465" elapsed="0.055509"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.305146" elapsed="0.002245"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:23.309618" level="INFO">${expected_normalized} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "traffic-action-extended-community": {
        "sample": true,
       ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:23.308126" elapsed="0.001539"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:23.311229" level="INFO">${actual_normalized} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "traffic-action-extended-community": {
        "sample": true,
       ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:23.309813" elapsed="0.001447"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:23:23.311406" elapsed="0.000353"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:23:23.307716" elapsed="0.004105"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.307472" elapsed="0.004384"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.312021" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.311883" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.307453" elapsed="0.004648"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:23:23.239684" elapsed="0.072468"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:23:23.238884" elapsed="0.073347"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.238635" elapsed="0.073643"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.238618" elapsed="0.073684"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.312336" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${exprspdir}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:23:23.113171" elapsed="0.199292"/>
</kw>
<arg>${EXP1}</arg>
<doc>Verify expected response</doc>
<status status="PASS" start="2026-06-06T03:23:23.109510" elapsed="0.203015"/>
</kw>
<arg>15s</arg>
<arg>1s</arg>
<arg>Verify_Flowspec_Data</arg>
<arg>${EXP1}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:23:23.109035" elapsed="0.203537"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib" type="TEARDOWN">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.313324" level="INFO">[?2004l03:23:20 | 2999   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:23:20 | 2999   | [01;34mversion      [0m | [1m4.2.17  [0m
03:23:20 | 2999   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:23:20 | 2999   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:23:20 | 2999   | [01;34minstallation [0m | [1m        [0m
03:23:20 | 2999   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:23:20 | 2999   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:23:20 | 2999   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:23:20 | 2999   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:23:20 | 2999   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:23:20 | 2999   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:23:20 | 2999   | configuration[0m | . local-as         | '64496'[0m
03:23:20 | 2999   | configuration[0m | . peer-as          | '64496'[0m
03:23:20 | 2999   | configuration[0m | &gt; family           | [0m
03:23:20 | 2999   | configuration[0m | . ipv4             | 'flow'[0m
03:23:20 | 2999   | configuration[0m | &lt; family           | [0m
03:23:20 | 2999   | configuration[0m | &gt; flow             | [0m
03:23:20 | 2999   | configuration[0m | &gt; route            | 'flow1'[0m
03:23:20 | 2999   | configuration[0m | &gt; match            | [0m
03:23:20 | 2999   | configuration[0m | . source           | '10.0.0.1/32'[0m
03:23:20 | 2999   | configuration[0m | . destination      | '192.168.0.1/32'[0m
03:23:20 | 2999   | configuration[0m | . port             | '=80'[0m
03:23:20 | 2999   | configuration[0m | . destination-port | '&gt;8080&amp;&lt;8088'[0m
03:23:20 | 2999   | configuration[0m | . source-port      | '&gt;1024'[0m
03:23:20 | 2999   | configuration[0m | . protocol         | 'tcp'[0m
03:23:20 | 2999   | configuration[0m | . packet-length    | '&gt;400&amp;&lt;500'[0m
03:23:20 | 2999   | configuration[0m | . fragment         | '=first-fragment'[0m
03:23:20 | 2999   | configuration[0m | . icmp-type        | 'echo-reply'[0m
03:23:20 | 2999   | configuration[0m | . icmp-code        | 'network-unreachable'[0m
03:23:20 | 2999   | configuration[0m | . tcp-flags        | '=urgent'[0m
03:23:20 | 2999   | configuration[0m | . dscp             | '20'[0m
03:23:20 | 2999   | configuration[0m | &lt; match            | [0m
03:23:20 | 2999   | configuration[0m | &gt; then             | [0m
03:23:20 | 2999   | configuration[0m | . action           | 'sample-terminal'[0m
03:23:20 | 2999   | configuration[0m | &lt; then             | [0m
03:23:20 | 2999   | configuration[0m | &lt; route            | [0m
03:23:20 | 2999   | configuration[0m | &lt; flow             | [0m
03:23:20 | 2999   | configuration[0m | &lt; neighbor         | [0m
03:23:20 | 2999   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:23:20 | 2999   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:23:20 | 2999   | reactor      [0m | initialising connection to peer-1[0m
03:23:20 | 2999   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 8502 0641 0400 00FB F002 0206 00[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 flow), Extended Message(65535), ASN4(64496)][0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0047 01[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  52) 04FB F000 B4C0 0002 022A 0228 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0085 0104 0001 0080 0104 0001 0085 4002 00B4 4700[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 flow,ipv4 mpls-vpn,ipv4 flow), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71][0m
03:23:20 | 2999   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1mthe connection can not carry the following family/families[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unicast[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/mpls-vpn[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1mtherefore no routes of this kind can be announced on the connection[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:23:20 | 2999   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:23:20 | 2999   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload ( 108) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 006C 0200 0000 5540 0101 0040 0200 4005 0400 0000 64C0 1008 8007 0000 0000 0003 800E 3900 0185 0000 3301 20C0 A800 0102 200A 0000 0103 8106 0481 5005 121F 90D4 1F98 0692 0400 0781 0008 8100 0981 200A 1201 90D4 01F4 0B81 140C 8104[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; 1 UPDATE(s)[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0185[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; EOR ipv4 flow[0m
03:23:20 | 2999   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:20 | 2999   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:20 | 2999   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:23:20 | 2999   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  10) 0000 0006 800F 0300 0185[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:20 | 2999   | parser       [0m | parsing UPDATE (  10) 0000 0006 800F 0300 0185[0m
03:23:20 | 2999   | routes       [0m | withdrawn NLRI none[0m
03:23:20 | 2999   | parser       [0m | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0001 85[0m
03:23:20 | 2999   | routes       [0m | announced NLRI none[0m
03:23:20 | 2999   | peer-1       [0m | &lt;&lt; UPDATE #2[0m
03:23:20 | 2999   | peer-1       [0m |    UPDATE #2 nlri  (  11) eor 1/133 (ipv4 flow)[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:20 | 2999   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:20 | 2999   | peer-1       [0m | &lt;&lt; UPDATE #3[0m
03:23:20 | 2999   | peer-1       [0m |    UPDATE #3 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:21 | 2999   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:23:21 | 2999   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:23:22 | 2999   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:23:22 | 2999   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
03:23:23 | 2999   | ka-outgoing-1[0m | receive-timer 177 second(s) left[0m
03:23:23 | 2999   | ka-outgoing-1[0m | send-timer 57 second(s) left[0m</msg>
<msg time="2026-06-06T03:23:23.313620" level="INFO">${output} = [?2004l03:23:20 | 2999   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:23:20 | 2999   | [01;34mversion      [0m | [1m4.2.17  [0m
03:23:20 | 2999   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:23:23.313187" elapsed="0.000489"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.314074" level="INFO">[?2004l03:23:20 | 2999   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:23:20 | 2999   | [01;34mversion      [0m | [1m4.2.17  [0m
03:23:20 | 2999   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:23:20 | 2999   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:23:20 | 2999   | [01;34minstallation [0m | [1m        [0m
03:23:20 | 2999   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:23:20 | 2999   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:23:20 | 2999   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:23:20 | 2999   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:23:20 | 2999   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:23:20 | 2999   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:23:20 | 2999   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:23:20 | 2999   | configuration[0m | . local-as         | '64496'[0m
03:23:20 | 2999   | configuration[0m | . peer-as          | '64496'[0m
03:23:20 | 2999   | configuration[0m | &gt; family           | [0m
03:23:20 | 2999   | configuration[0m | . ipv4             | 'flow'[0m
03:23:20 | 2999   | configuration[0m | &lt; family           | [0m
03:23:20 | 2999   | configuration[0m | &gt; flow             | [0m
03:23:20 | 2999   | configuration[0m | &gt; route            | 'flow1'[0m
03:23:20 | 2999   | configuration[0m | &gt; match            | [0m
03:23:20 | 2999   | configuration[0m | . source           | '10.0.0.1/32'[0m
03:23:20 | 2999   | configuration[0m | . destination      | '192.168.0.1/32'[0m
03:23:20 | 2999   | configuration[0m | . port             | '=80'[0m
03:23:20 | 2999   | configuration[0m | . destination-port | '&gt;8080&amp;&lt;8088'[0m
03:23:20 | 2999   | configuration[0m | . source-port      | '&gt;1024'[0m
03:23:20 | 2999   | configuration[0m | . protocol         | 'tcp'[0m
03:23:20 | 2999   | configuration[0m | . packet-length    | '&gt;400&amp;&lt;500'[0m
03:23:20 | 2999   | configuration[0m | . fragment         | '=first-fragment'[0m
03:23:20 | 2999   | configuration[0m | . icmp-type        | 'echo-reply'[0m
03:23:20 | 2999   | configuration[0m | . icmp-code        | 'network-unreachable'[0m
03:23:20 | 2999   | configuration[0m | . tcp-flags        | '=urgent'[0m
03:23:20 | 2999   | configuration[0m | . dscp             | '20'[0m
03:23:20 | 2999   | configuration[0m | &lt; match            | [0m
03:23:20 | 2999   | configuration[0m | &gt; then             | [0m
03:23:20 | 2999   | configuration[0m | . action           | 'sample-terminal'[0m
03:23:20 | 2999   | configuration[0m | &lt; then             | [0m
03:23:20 | 2999   | configuration[0m | &lt; route            | [0m
03:23:20 | 2999   | configuration[0m | &lt; flow             | [0m
03:23:20 | 2999   | configuration[0m | &lt; neighbor         | [0m
03:23:20 | 2999   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:23:20 | 2999   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:23:20 | 2999   | reactor      [0m | initialising connection to peer-1[0m
03:23:20 | 2999   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 8502 0641 0400 00FB F002 0206 00[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 flow), Extended Message(65535), ASN4(64496)][0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0047 01[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  52) 04FB F000 B4C0 0002 022A 0228 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0085 0104 0001 0080 0104 0001 0085 4002 00B4 4700[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 flow,ipv4 mpls-vpn,ipv4 flow), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71][0m
03:23:20 | 2999   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1mthe connection can not carry the following family/families[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unicast[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/mpls-vpn[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1mtherefore no routes of this kind can be announced on the connection[0m
03:23:20 | 2999   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:23:20 | 2999   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:23:20 | 2999   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload ( 108) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 006C 0200 0000 5540 0101 0040 0200 4005 0400 0000 64C0 1008 8007 0000 0000 0003 800E 3900 0185 0000 3301 20C0 A800 0102 200A 0000 0103 8106 0481 5005 121F 90D4 1F98 0692 0400 0781 0008 8100 0981 200A 1201 90D4 01F4 0B81 140C 8104[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; 1 UPDATE(s)[0m
03:23:20 | 2999   | outgoing-1   [0m | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0185[0m
03:23:20 | 2999   | outgoing-1   [0m | &gt;&gt; EOR ipv4 flow[0m
03:23:20 | 2999   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:20 | 2999   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:20 | 2999   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:23:20 | 2999   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  10) 0000 0006 800F 0300 0185[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:20 | 2999   | parser       [0m | parsing UPDATE (  10) 0000 0006 800F 0300 0185[0m
03:23:20 | 2999   | routes       [0m | withdrawn NLRI none[0m
03:23:20 | 2999   | parser       [0m | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0001 85[0m
03:23:20 | 2999   | routes       [0m | announced NLRI none[0m
03:23:20 | 2999   | peer-1       [0m | &lt;&lt; UPDATE #2[0m
03:23:20 | 2999   | peer-1       [0m |    UPDATE #2 nlri  (  11) eor 1/133 (ipv4 flow)[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:20 | 2999   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:20 | 2999   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:20 | 2999   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:20 | 2999   | peer-1       [0m | &lt;&lt; UPDATE #3[0m
03:23:20 | 2999   | peer-1       [0m |    UPDATE #3 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:21 | 2999   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:23:21 | 2999   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:23:22 | 2999   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:23:22 | 2999   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
03:23:23 | 2999   | ka-outgoing-1[0m | receive-timer 177 second(s) left[0m
03:23:23 | 2999   | ka-outgoing-1[0m | send-timer 57 second(s) left[0m
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.313822" elapsed="0.000486"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.315119" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:23.314808" elapsed="0.000339"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:23.315289" elapsed="0.000285"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:23:23.314500" elapsed="0.001133"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.443127" level="INFO">^C03:23:23 | 2999   | [00;31mreactor      [0m | [1m^C received[0m
03:23:23 | 2999   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:23:23 | 2999   | outgoing-1   [0m | stop, message [shutting down][0m
03:23:23 | 2999   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:23.443326" level="INFO">${output} = ^C03:23:23 | 2999   | [00;31mreactor      [0m | [1m^C received[0m
03:23:23 | 2999   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:23:23 | 2999   | outgoing-1   [0m | stop, messag...</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:23.315804" elapsed="0.127555"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.443938" level="INFO">^C03:23:23 | 2999   | [00;31mreactor      [0m | [1m^C received[0m
03:23:23 | 2999   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:23:23 | 2999   | outgoing-1   [0m | stop, message [shutting down][0m
03:23:23 | 2999   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.443583" elapsed="0.000412"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.447009" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:23.444859" elapsed="0.002210"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.447868" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:23.447952" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:23.447219" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.448566" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.448312" elapsed="0.000302"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.448054" elapsed="0.000610"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.448032" elapsed="0.000661"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:23:23.444419" elapsed="0.004322"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:23:23.312896" elapsed="0.135900"/>
</kw>
<doc>Testing flowspec values for bgp-flowspec.cfg</doc>
<status status="PASS" start="2026-06-06T03:23:19.838024" elapsed="3.610819"/>
</test>
<test id="s1-s10-t4" name="FlowSpec_Test_2" line="66">
<kw name="Setup_Testcase" type="SETUP">
<kw name="Verify_Empty_Flowspec_Data">
<kw name="Verify_Empty_Flowspec_Data_Neon">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.496252" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.495870" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.497144" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.496779" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.497344" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.496433" elapsed="0.000937"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.497941" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.497527" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.498260" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:23.498416" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:23.498122" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.498854" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.498585" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.500103" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.499619" elapsed="0.000530"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.500736" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:23.500298" elapsed="0.000466"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.501116" elapsed="0.000076"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.501626" elapsed="0.000095"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.501937" elapsed="0.000074"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:23:23.500961" elapsed="0.001144"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.500818" elapsed="0.001321"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:23.502188" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:23.502357" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:23.499311" elapsed="0.003089"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.499019" elapsed="0.003427"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.502623" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.502475" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.498998" elapsed="0.003741"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.503352" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:23.502878" elapsed="0.000504"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.503433" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:23.495249" elapsed="0.008311"/>
</kw>
<msg time="2026-06-06T03:23:23.503615" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.483724" elapsed="0.019963"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.515307" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.526482" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.537845" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.538057" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.538228" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.538725" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.538536" elapsed="0.000250"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:23.538459" elapsed="0.000353"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.538945" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.539106" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.539259" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:23.538425" elapsed="0.000887"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.538310" elapsed="0.001029"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.539472" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.539549" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:23.539706" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:23.479808" elapsed="0.059926"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.541050" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.540773" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.541218" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.540398" elapsed="0.000846"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.541600" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.541316" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.542155" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.541859" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.541699" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.541297" elapsed="0.000941"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.544407" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.542376" elapsed="0.002059"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:23.544488" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:23.544661" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:23.540059" elapsed="0.004629"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.545861" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:23:23.545667" elapsed="0.000248"/>
</kw>
<msg time="2026-06-06T03:23:23.546001" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.545306" elapsed="0.000719"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.546237" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:23.546096" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.546077" elapsed="0.000227"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.546612" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:23.546782" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:23.546437" elapsed="0.000371"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:23:23.547230" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:23:23.546988" elapsed="0.000268"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:23:23.547304" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:23.547459" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:23.544988" elapsed="0.002496"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.548878" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.548611" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.549314" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.549066" elapsed="0.000291"/>
</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-06-06T03:23:23.557209" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:23.557456" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '148'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}}]} 
 </msg>
<msg time="2026-06-06T03:23:23.557614" 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-06-06T03:23:23.551511" elapsed="0.006149"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.549423" elapsed="0.008283"/>
</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-06-06T03:23:23.557879" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.557733" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.549404" elapsed="0.008563"/>
</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-06-06T03:23:23.562443" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.559361" elapsed="0.003148"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.559060" elapsed="0.003498"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.559033" elapsed="0.003560"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.565905" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.562990" elapsed="0.002978"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.562695" elapsed="0.003323"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.562669" elapsed="0.003383"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.566592" 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-06-06T03:23:23.566203" elapsed="0.000416"/>
</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-06-06T03:23:23.566931" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.566709" elapsed="0.000279"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.567455" 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-06-06T03:23:23.567156" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.567012" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.566689" elapsed="0.000849"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.568064" 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-06-06T03:23:23.567700" elapsed="0.000391"/>
</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-06-06T03:23:23.568382" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.568161" elapsed="0.000278"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.568918" 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-06-06T03:23:23.568607" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.568463" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.568143" elapsed="0.000858"/>
</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-06-06T03:23:23.569175" elapsed="0.000377"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:23.570018" 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-06-06T03:23:23.569723" elapsed="0.000321"/>
</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-06-06T03:23:23.570187" elapsed="0.002195"/>
</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-06-06T03:23:23.558438" elapsed="0.014006"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.572622" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:23.572515" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.572495" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:23.575294" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:23:23.572842" elapsed="0.002480"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:23:23.575375" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:23.575531" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:23:23.547802" elapsed="0.027755"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.575621" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:23:23.575793" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:23.459746" elapsed="0.116073"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.602093" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.601291" elapsed="0.000831"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.603334" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.602865" elapsed="0.000680">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:23.603695" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:23.602275" elapsed="0.001446"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.604515" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.603873" elapsed="0.000670"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:23.604911" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/empty_route/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:23.605071" level="INFO">${template} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:23.604711" elapsed="0.000387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.605741" level="INFO">{
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
                "uptodate": "*"
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.605242" elapsed="0.000546"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:23.606207" elapsed="0.000068"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.605858" elapsed="0.000561"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.607188" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.606588" elapsed="0.000707"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.606448" elapsed="0.001022"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.605838" elapsed="0.001657"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.608441" level="INFO">${final_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:23.607632" elapsed="0.000838"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.608521" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:23.600693" elapsed="0.007969"/>
</kw>
<msg time="2026-06-06T03:23:23.608718" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.589151" elapsed="0.019617"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.620090" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.631191" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.642358" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.642541" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.642721" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.643091" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.642955" elapsed="0.000191"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:23.642940" elapsed="0.000229"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.643295" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.643451" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.643604" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:23.642911" elapsed="0.000762"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.642805" elapsed="0.000895"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.643833" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:23.643943" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:23.644065" level="INFO">${expected_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-flowspec:flowspec-subsequent-address-family",
            "attributes": {
             ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:23.586661" elapsed="0.057431"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.644257" elapsed="0.002209"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:23.647489" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:23.647197" elapsed="0.000320"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:23.647948" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-flowspec:flowspec-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:23.647674" elapsed="0.000302"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:23:23.648125" elapsed="0.000325"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:23:23.646793" elapsed="0.001717"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.646549" elapsed="0.001995"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:23.648722" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:23.648570" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.646529" elapsed="0.002271"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:23:23.576937" elapsed="0.071912"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:23:23.576132" elapsed="0.072794"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.575905" elapsed="0.073067"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.575887" elapsed="0.073109"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:23.649031" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}empty_route</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:23:23.454193" elapsed="0.194967"/>
</kw>
<doc>Verify empty flowspec data on neon</doc>
<status status="PASS" start="2026-06-06T03:23:23.450214" elapsed="0.199008"/>
</kw>
<doc>Verify expected response.</doc>
<status status="PASS" start="2026-06-06T03:23:23.449984" elapsed="0.199286"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.652364" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec-redirect.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.652039" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.652801" level="INFO">env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec-redirect.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.652537" elapsed="0.000309"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.655631" level="INFO">source /tmp/defaultvenv/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-06-06T03:23:23.653420" elapsed="0.002282"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.671545" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:23.671639" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:23.655853" elapsed="0.015834"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.672254" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.671999" elapsed="0.000301"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:23.671758" elapsed="0.000575"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:23.671737" elapsed="0.000660"/>
</if>
<arg>log_output=${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-06-06T03:23:23.653077" elapsed="0.019372"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:23.674525" level="INFO">env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec-redirect.cfg</msg>
<msg time="2026-06-06T03:23:23.674616" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec-redirect.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:23.672590" elapsed="0.002072"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.675061" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug bgp-flowspec-redirect.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.674813" elapsed="0.000295"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:23.651731" elapsed="0.023432"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.676993" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:23.676628" elapsed="0.000393"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.679135" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:23.677171" elapsed="0.001992"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:23.684745" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:23.684881" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:23:23.684976" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:23.679315" elapsed="0.005687"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.687990" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:23.685158" elapsed="0.002902"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:23:23.691708" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:23:23.688272" elapsed="0.003538">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:23:23.676181" elapsed="0.015794">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.695312" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:26.694220" elapsed="0.001175"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.700946" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:26.695859" elapsed="0.005157"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:26.710997" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:26.714152" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '3477'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.4/32 AND from 10.0.0.4/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"127.0.0.1"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.4/32"},{"source-prefix":"10.0.0.4/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.2/32 AND from 10.0.0.2/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"1.2.3.4"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.2/32"},{"source-prefix":"10.0.0.2/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32","attributes":{"extended-communities":[{"redirect-extended-community":{"global-administrator":65500,"local-administrator":"AAAwOQ=="},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.4/32 AND from 10.0.0.4/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"127.0.0.1"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.4/32"},{"source-prefix":"10.0.0.4/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.2/32 AND from 10.0.0.2/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"1.2.3.4"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.2/32"},{"source-prefix":"10.0.0.2/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32","attributes":{"extended-communities":[{"redirect-extended-community":{"global-administrator":65500,"local-administrator":"AAAwOQ=="},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:23:26.714622" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:26.701248" elapsed="0.013470"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.720549" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.4/32 AND from 10.0.0.4/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"127.0.0.1"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.4/32"},{"source-prefix":"10.0.0.4/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.2/32 AND from 10.0.0.2/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"1.2.3.4"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.2/32"},{"source-prefix":"10.0.0.2/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32","attributes":{"extended-communities":[{"redirect-extended-community":{"global-administrator":65500,"local-administrator":"AAAwOQ=="},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true},"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.4/32 AND from 10.0.0.4/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"127.0.0.1"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.4/32"},{"source-prefix":"10.0.0.4/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.2/32 AND from 10.0.0.2/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"1.2.3.4"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.2/32"},{"source-prefix":"10.0.0.2/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32","attributes":{"extended-communities":[{"redirect-extended-community":{"global-administrator":65500,"local-administrator":"AAAwOQ=="},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"}]}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.715106" elapsed="0.005650"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:23:26.721109" elapsed="0.002251"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:23:26.692902" elapsed="0.030527"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:23:23.675703" elapsed="3.047782"/>
</kw>
<msg time="2026-06-06T03:23:26.723592" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:26.723638" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:23.675311" elapsed="3.048366"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.724078" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.723787" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.723759" elapsed="0.000402"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:23:26.724351" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:23:26.724216" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.724200" elapsed="0.000250"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:23:23.651549" elapsed="3.072929"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:23:23.651334" elapsed="3.073181"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.724678" elapsed="0.000023"/>
</kw>
<arg>${cfg_file}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>connection_retries=${3}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:23:23.649554" elapsed="3.075210"/>
</kw>
<arg>${CFG2}</arg>
<status status="PASS" start="2026-06-06T03:23:23.449696" elapsed="3.275132"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Flowspec_Data">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.771570" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:26.771181" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:26.772486" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:26.772105" elapsed="0.000459">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:26.772679" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:26.771776" elapsed="0.000929"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.773256" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:26.772864" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:26.773577" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:26.773754" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:26.773434" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.774179" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.773928" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.775225" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.774918" elapsed="0.000353"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.775716" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:26.775421" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.776060" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.776260" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.776448" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:23:26.775938" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.775797" elapsed="0.000740"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:26.776583" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:26.776767" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:26.774588" elapsed="0.002205"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.774299" elapsed="0.002527"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.776986" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.776852" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.774277" elapsed="0.002785"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.777635" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:26.777193" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:26.777730" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:26.770563" elapsed="0.007292"/>
</kw>
<msg time="2026-06-06T03:23:26.777911" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:26.759126" elapsed="0.018833"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.789342" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.800591" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.811901" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.812088" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.812251" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.812619" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.812486" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:26.812470" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.812841" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.812996" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.813150" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:26.812428" elapsed="0.000778"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.812327" elapsed="0.000905"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.813364" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.813439" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:26.813559" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:26.755199" elapsed="0.058386"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:26.814824" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:26.814557" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:26.814983" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:26.814228" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.815312" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.815078" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.815859" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:26.815548" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.815393" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.815059" elapsed="0.000883"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.818099" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:26.816079" elapsed="0.002047"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:26.818213" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:26.818370" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:26.813913" elapsed="0.004482"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:26.819578" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:26.819340" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:26.819750" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:26.819018" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:23:26.819981" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:26.819846" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.819827" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.820198" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.820357" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.820421" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:26.822334" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:26.818705" elapsed="0.003656"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.823739" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.823475" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.824166" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.823925" elapsed="0.000285"/>
</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-06-06T03:23:26.832985" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:26.834124" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-flowspec%3Aflowspec-subsequent-address-family/bgp-flowspec:flowspec-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1208'} 
 body={"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.4/32 AND from 10.0.0.4/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"127.0.0.1"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.4/32"},{"source-prefix":"10.0.0.4/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.2/32 AND from 10.0.0.2/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"1.2.3.4"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.2/32"},{"source-prefix":"10.0.0.2/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32","attributes":{"extended-communities":[{"redirect-extended-community":{"global-administrator":65500,"local-administrator":"AAAwOQ=="},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"}]}]}} 
 </msg>
<msg time="2026-06-06T03:23:26.834303" 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-06-06T03:23:26.826164" elapsed="0.008179"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.824276" elapsed="0.010133"/>
</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-06-06T03:23:26.834681" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.834449" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.824257" elapsed="0.010554"/>
</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-06-06T03:23:26.839710" level="INFO">{"bgp-flowspec:flowspec-routes":{"flowspec-route":[{"path-id":0,"route-key":"all packets to 192.168.0.4/32 AND from 10.0.0.4/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"127.0.0.1"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.4/32"},{"source-prefix":"10.0.0.4/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.2/32 AND from 10.0.0.2/32","attributes":{"extended-communities":[{"redirect-ip-nh-extended-community":{"next-hop-address":"0.0.0.0","copy":false},"transitive":true}],"ipv4-next-hop":{"global":"1.2.3.4"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.2/32"},{"source-prefix":"10.0.0.2/32"}]},{"path-id":0,"route-key":"all packets to 192.168.0.1/32 AND from 10.0.0.1/32","attributes":{"extended-communities":[{"redirect-extended-community":{"global-administrator":65500,"local-administrator":"AAAwOQ=="},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"flowspec":[{"destination-prefix":"192.168.0.1/32"},{"source-prefix":"10.0.0.1/32"}]}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.836293" elapsed="0.003553"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.835981" elapsed="0.003918"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.835953" elapsed="0.003983"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.843443" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.840332" elapsed="0.003180"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.840019" elapsed="0.003544"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.839994" elapsed="0.003605"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.844416" 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-06-06T03:23:26.843850" elapsed="0.000606"/>
</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-06-06T03:23:26.844952" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.844598" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.845535" 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-06-06T03:23:26.845236" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.845073" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.844569" elapsed="0.001047"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.846133" 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-06-06T03:23:26.845775" elapsed="0.000384"/>
</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-06-06T03:23:26.846444" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.846229" elapsed="0.000271"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.846976" 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-06-06T03:23:26.846681" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.846524" elapsed="0.000512"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.846210" elapsed="0.000847"/>
</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-06-06T03:23:26.847196" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:26.848046" 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-06-06T03:23:26.847708" elapsed="0.000365"/>
</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-06-06T03:23:26.848220" elapsed="0.002069"/>
</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-06-06T03:23:26.835323" elapsed="0.015032"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.850536" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:26.850427" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.850408" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:26.853803" level="INFO">${text_normalized} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "redirect-ip-nh-extended-community": {
        "copy": false,
        ...</msg>
<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="PASS" start="2026-06-06T03:23:26.850756" elapsed="0.003077"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:23:26.853886" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:26.854052" level="INFO">${response_text} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "redirect-ip-nh-extended-community": {
        "copy": false,
        ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:23:26.822673" elapsed="0.031405"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:26.854142" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:23:26.854294" level="INFO">${response_text} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "redirect-ip-nh-extended-community": {
        "copy": false,
        ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:26.734843" elapsed="0.119477"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.881901" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:26.881393" elapsed="0.000539"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:26.882869" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:26.882556" elapsed="0.000437">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:26.883173" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:26.882089" elapsed="0.001110"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.883812" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:26.883355" elapsed="0.000485"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:26.884152" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_flowspec_redirect/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:26.884319" level="INFO">${template} = {
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.2/32 AND from 10.0.0.2/32",
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:26.883991" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.884829" level="INFO">{
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.2/32 AND from 10.0.0.2/32",
                "attributes": {
                    "extended-communities": [
                        {
                            "transitive": true,
                            "redirect-ip-nh-extended-community": {
                                "next-hop-address": "0.0.0.0",
                                "copy": false
                            }
                        }
                    ],
                    "ipv4-next-hop": {
                        "global": "1.2.3.4"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "flowspec": [
                    {
                        "destination-prefix": "192.168.0.2/32"
                    },
                    {
                        "source-prefix": "10.0.0.2/32"
                    }
                ]
            },
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.1/32 AND from 10.0.0.1/32",
                "attributes": {
                    "extended-communities": [
                        {
                            "transitive": true,
                            "redirect-extended-community": {
                                "global-administrator": 65500,
                                "local-administrator": "AAAwOQ=="
                            }
                        }
                    ],
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "flowspec": [
                    {
                        "destination-prefix": "192.168.0.1/32"
                    },
                    {
                        "source-prefix": "10.0.0.1/32"
                    }
                ]
            },
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.4/32 AND from 10.0.0.4/32",
                "attributes": {
                    "extended-communities": [
                        {
                            "transitive": true,
                            "redirect-ip-nh-extended-community": {
                                "next-hop-address": "0.0.0.0",
                                "copy": false
                            }
                        }
                    ],
                    "ipv4-next-hop": {
                        "global": "127.0.0.1"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "flowspec": [
                    {
                        "destination-prefix": "192.168.0.4/32"
                    },
                    {
                        "source-prefix": "10.0.0.4/32"
                    }
                ]
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.884491" elapsed="0.000408"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:26.885360" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.884972" elapsed="0.000449"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.886101" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:26.885581" elapsed="0.000547"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.885447" elapsed="0.000717"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.884950" elapsed="0.001235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.886834" level="INFO">${final_text} = {
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.2/32 AND from 10.0.0.2/32",
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:26.886321" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:26.886915" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:26.880789" elapsed="0.006287"/>
</kw>
<msg time="2026-06-06T03:23:26.887150" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:26.869324" elapsed="0.017879"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.898570" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.910052" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_flowspec_redirect/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.921469" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.921670" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.921838" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.922208" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.922074" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:26.922059" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.922421" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.922576" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.922745" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:26.922028" elapsed="0.000772"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.921920" elapsed="0.000907"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.922963" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:26.923038" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:26.923225" level="INFO">${expected_text} = {
    "bgp-flowspec:flowspec-routes": {
        "flowspec-route": [
            {
                "path-id": 0,
                "route-key": "all packets to 192.168.0.2/32 AND from 10.0.0.2/32",
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:26.866681" elapsed="0.056572"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:26.923456" elapsed="0.002278"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:26.927513" level="INFO">${expected_normalized} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "redirect-ip-nh-extended-community": {
        "copy": false,
        ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:26.926456" elapsed="0.001087"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:23:26.928722" level="INFO">${actual_normalized} = {
 "bgp-flowspec:flowspec-routes": {
  "flowspec-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "redirect-ip-nh-extended-community": {
        "copy": false,
        ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:23:26.927707" elapsed="0.001045"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:23:26.928901" elapsed="0.000338"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:23:26.926046" elapsed="0.003257"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.925816" elapsed="0.003522"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:26.929565" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:26.929364" elapsed="0.000258"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.925797" elapsed="0.003866"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:23:26.855447" elapsed="0.074270"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:23:26.854635" elapsed="0.075159"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:26.854403" elapsed="0.075437"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:26.854386" elapsed="0.075478"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:26.929899" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}${exprspdir}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:23:26.729289" elapsed="0.200739"/>
</kw>
<arg>${EXP2}</arg>
<doc>Verify expected response</doc>
<status status="PASS" start="2026-06-06T03:23:26.725455" elapsed="0.204634"/>
</kw>
<arg>15s</arg>
<arg>1s</arg>
<arg>Verify_Flowspec_Data</arg>
<arg>${EXP2}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:23:26.724993" elapsed="0.205141"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib" type="TEARDOWN">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:23:26.930873" level="INFO">[?2004l03:23:23 | 3003   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:23:23 | 3003   | [01;34mversion      [0m | [1m4.2.17  [0m
03:23:23 | 3003   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:23:23 | 3003   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:23:23 | 3003   | [01;34minstallation [0m | [1m        [0m
03:23:23 | 3003   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:23:23 | 3003   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:23:23 | 3003   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:23:23 | 3003   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:23:23 | 3003   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:23:23 | 3003   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:23:23 | 3003   | configuration[0m | . local-as         | '64496'[0m
03:23:23 | 3003   | configuration[0m | . peer-as          | '64496'[0m
03:23:23 | 3003   | configuration[0m | &gt; family           | [0m
03:23:23 | 3003   | configuration[0m | . ipv4             | 'flow'[0m
03:23:23 | 3003   | configuration[0m | &lt; family           | [0m
03:23:23 | 3003   | configuration[0m | &gt; flow             | [0m
03:23:23 | 3003   | configuration[0m | &gt; route            | 'flow1'[0m
03:23:23 | 3003   | configuration[0m | &gt; match            | [0m
03:23:23 | 3003   | configuration[0m | . source           | '10.0.0.1/32'[0m
03:23:23 | 3003   | configuration[0m | . destination      | '192.168.0.1/32'[0m
03:23:23 | 3003   | configuration[0m | &lt; match            | [0m
03:23:23 | 3003   | configuration[0m | &gt; then             | [0m
03:23:23 | 3003   | configuration[0m | . redirect         | '65500:12345'[0m
03:23:23 | 3003   | configuration[0m | &lt; then             | [0m
03:23:23 | 3003   | configuration[0m | &lt; route            | [0m
03:23:23 | 3003   | configuration[0m | &gt; route            | 'flow2'[0m
03:23:23 | 3003   | configuration[0m | &gt; match            | [0m
03:23:23 | 3003   | configuration[0m | . source           | '10.0.0.2/32'[0m
03:23:23 | 3003   | configuration[0m | . destination      | '192.168.0.2/32'[0m
03:23:23 | 3003   | configuration[0m | &lt; match            | [0m
03:23:23 | 3003   | configuration[0m | &gt; then             | [0m
03:23:23 | 3003   | configuration[0m | . redirect         | '1.2.3.4'[0m
03:23:23 | 3003   | configuration[0m | &lt; then             | [0m
03:23:23 | 3003   | configuration[0m | &lt; route            | [0m
03:23:23 | 3003   | configuration[0m | &gt; route            | 'flow4'[0m
03:23:23 | 3003   | configuration[0m | &gt; match            | [0m
03:23:23 | 3003   | configuration[0m | . source           | '10.0.0.4/32'[0m
03:23:23 | 3003   | configuration[0m | . destination      | '192.168.0.4/32'[0m
03:23:23 | 3003   | configuration[0m | &lt; match            | [0m
03:23:23 | 3003   | configuration[0m | . next-hop         | '127.0.0.1'[0m
03:23:23 | 3003   | configuration[0m | &gt; then             | [0m
03:23:23 | 3003   | configuration[0m | . redirect-to-nexthop | [0m
03:23:23 | 3003   | configuration[0m | &lt; then             | [0m
03:23:23 | 3003   | configuration[0m | &lt; route            | [0m
03:23:23 | 3003   | configuration[0m | &lt; flow             | [0m
03:23:23 | 3003   | configuration[0m | &lt; neighbor         | [0m
03:23:23 | 3003   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:23:23 | 3003   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:23:23 | 3003   | reactor      [0m | initialising connection to peer-1[0m
03:23:23 | 3003   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 8502 0641 0400 00FB F002 0206 00[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 flow), Extended Message(65535), ASN4(64496)][0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0047 01[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  52) 04FB F000 B4C0 0002 022A 0228 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0085 0104 0001 0080 0104 0001 0085 4002 00B4 4700[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 flow,ipv4 mpls-vpn,ipv4 flow), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71][0m
03:23:23 | 3003   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1mthe connection can not carry the following family/families[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unicast[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/mpls-vpn[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1mtherefore no routes of this kind can be announced on the connection[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:23:23 | 3003   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:23:23 | 3003   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  69) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0045 0200 0000 2E40 0101 0040 0200 4005 0400 0000 64C0 1008 8008 FFDC 0000 3039 800E 1200 0185 0000 0C01 20C0 A800 0102 200A 0000 01[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  73) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0049 0200 0000 3240 0101 0040 0200 4005 0400 0000 64C0 1008 0800 0000 0000 0000 800E 1600 0185 0401 0203 0400 0C01 20C0 A800 0202 200A 0000 02[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  73) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0049 0200 0000 3240 0101 0040 0200 4005 0400 0000 64C0 1008 0800 0000 0000 0000 800E 1600 0185 047F 0000 0100 0C01 20C0 A800 0402 200A 0000 04[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; 3 UPDATE(s)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:23 | 3003   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:23 | 3003   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:23:23 | 3003   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0185[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; EOR ipv4 flow[0m
03:23:23 | 3003   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  10) 0000 0006 800F 0300 0185[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:23 | 3003   | parser       [0m | parsing UPDATE (  10) 0000 0006 800F 0300 0185[0m
03:23:23 | 3003   | routes       [0m | withdrawn NLRI none[0m
03:23:23 | 3003   | parser       [0m | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0001 85[0m
03:23:23 | 3003   | routes       [0m | announced NLRI none[0m
03:23:23 | 3003   | peer-1       [0m | &lt;&lt; UPDATE #2[0m
03:23:23 | 3003   | peer-1       [0m |    UPDATE #2 nlri  (  11) eor 1/133 (ipv4 flow)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:23 | 3003   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:23 | 3003   | peer-1       [0m | &lt;&lt; UPDATE #3[0m
03:23:23 | 3003   | peer-1       [0m |    UPDATE #3 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:24 | 3003   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:23:24 | 3003   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:23:25 | 3003   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:23:25 | 3003   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
03:23:26 | 3003   | ka-outgoing-1[0m | receive-timer 177 second(s) left[0m
03:23:26 | 3003   | ka-outgoing-1[0m | send-timer 57 second(s) left[0m</msg>
<msg time="2026-06-06T03:23:26.931167" level="INFO">${output} = [?2004l03:23:23 | 3003   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:23:23 | 3003   | [01;34mversion      [0m | [1m4.2.17  [0m
03:23:23 | 3003   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:23:26.930733" elapsed="0.000467"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.931596" level="INFO">[?2004l03:23:23 | 3003   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:23:23 | 3003   | [01;34mversion      [0m | [1m4.2.17  [0m
03:23:23 | 3003   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:23:23 | 3003   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:23:23 | 3003   | [01;34minstallation [0m | [1m        [0m
03:23:23 | 3003   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:23:23 | 3003   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:23:23 | 3003   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:23:23 | 3003   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:23:23 | 3003   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:23:23 | 3003   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:23:23 | 3003   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:23:23 | 3003   | configuration[0m | . local-as         | '64496'[0m
03:23:23 | 3003   | configuration[0m | . peer-as          | '64496'[0m
03:23:23 | 3003   | configuration[0m | &gt; family           | [0m
03:23:23 | 3003   | configuration[0m | . ipv4             | 'flow'[0m
03:23:23 | 3003   | configuration[0m | &lt; family           | [0m
03:23:23 | 3003   | configuration[0m | &gt; flow             | [0m
03:23:23 | 3003   | configuration[0m | &gt; route            | 'flow1'[0m
03:23:23 | 3003   | configuration[0m | &gt; match            | [0m
03:23:23 | 3003   | configuration[0m | . source           | '10.0.0.1/32'[0m
03:23:23 | 3003   | configuration[0m | . destination      | '192.168.0.1/32'[0m
03:23:23 | 3003   | configuration[0m | &lt; match            | [0m
03:23:23 | 3003   | configuration[0m | &gt; then             | [0m
03:23:23 | 3003   | configuration[0m | . redirect         | '65500:12345'[0m
03:23:23 | 3003   | configuration[0m | &lt; then             | [0m
03:23:23 | 3003   | configuration[0m | &lt; route            | [0m
03:23:23 | 3003   | configuration[0m | &gt; route            | 'flow2'[0m
03:23:23 | 3003   | configuration[0m | &gt; match            | [0m
03:23:23 | 3003   | configuration[0m | . source           | '10.0.0.2/32'[0m
03:23:23 | 3003   | configuration[0m | . destination      | '192.168.0.2/32'[0m
03:23:23 | 3003   | configuration[0m | &lt; match            | [0m
03:23:23 | 3003   | configuration[0m | &gt; then             | [0m
03:23:23 | 3003   | configuration[0m | . redirect         | '1.2.3.4'[0m
03:23:23 | 3003   | configuration[0m | &lt; then             | [0m
03:23:23 | 3003   | configuration[0m | &lt; route            | [0m
03:23:23 | 3003   | configuration[0m | &gt; route            | 'flow4'[0m
03:23:23 | 3003   | configuration[0m | &gt; match            | [0m
03:23:23 | 3003   | configuration[0m | . source           | '10.0.0.4/32'[0m
03:23:23 | 3003   | configuration[0m | . destination      | '192.168.0.4/32'[0m
03:23:23 | 3003   | configuration[0m | &lt; match            | [0m
03:23:23 | 3003   | configuration[0m | . next-hop         | '127.0.0.1'[0m
03:23:23 | 3003   | configuration[0m | &gt; then             | [0m
03:23:23 | 3003   | configuration[0m | . redirect-to-nexthop | [0m
03:23:23 | 3003   | configuration[0m | &lt; then             | [0m
03:23:23 | 3003   | configuration[0m | &lt; route            | [0m
03:23:23 | 3003   | configuration[0m | &lt; flow             | [0m
03:23:23 | 3003   | configuration[0m | &lt; neighbor         | [0m
03:23:23 | 3003   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:23:23 | 3003   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:23:23 | 3003   | reactor      [0m | initialising connection to peer-1[0m
03:23:23 | 3003   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 8502 0641 0400 00FB F002 0206 00[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 flow), Extended Message(65535), ASN4(64496)][0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0047 01[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  52) 04FB F000 B4C0 0002 022A 0228 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0002 0085 0104 0001 0080 0104 0001 0085 4002 00B4 4700[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv6 flow,ipv4 mpls-vpn,ipv4 flow), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 180 , ASN4(64496), Unassigned 71][0m
03:23:23 | 3003   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1mthe connection can not carry the following family/families[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unicast[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/mpls-vpn[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1mtherefore no routes of this kind can be announced on the connection[0m
03:23:23 | 3003   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:23:23 | 3003   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:23:23 | 3003   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  69) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0045 0200 0000 2E40 0101 0040 0200 4005 0400 0000 64C0 1008 8008 FFDC 0000 3039 800E 1200 0185 0000 0C01 20C0 A800 0102 200A 0000 01[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  73) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0049 0200 0000 3240 0101 0040 0200 4005 0400 0000 64C0 1008 0800 0000 0000 0000 800E 1600 0185 0401 0203 0400 0C01 20C0 A800 0202 200A 0000 02[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  73) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0049 0200 0000 3240 0101 0040 0200 4005 0400 0000 64C0 1008 0800 0000 0000 0000 800E 1600 0185 047F 0000 0100 0C01 20C0 A800 0402 200A 0000 04[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; 3 UPDATE(s)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:23 | 3003   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:23 | 3003   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:23:23 | 3003   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:23 | 3003   | outgoing-1   [0m | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0185[0m
03:23:23 | 3003   | outgoing-1   [0m | &gt;&gt; EOR ipv4 flow[0m
03:23:23 | 3003   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  10) 0000 0006 800F 0300 0185[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:23 | 3003   | parser       [0m | parsing UPDATE (  10) 0000 0006 800F 0300 0185[0m
03:23:23 | 3003   | routes       [0m | withdrawn NLRI none[0m
03:23:23 | 3003   | parser       [0m | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0001 85[0m
03:23:23 | 3003   | routes       [0m | announced NLRI none[0m
03:23:23 | 3003   | peer-1       [0m | &lt;&lt; UPDATE #2[0m
03:23:23 | 3003   | peer-1       [0m |    UPDATE #2 nlri  (  11) eor 1/133 (ipv4 flow)[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:23:23 | 3003   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:23:23 | 3003   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:23:23 | 3003   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:23:23 | 3003   | peer-1       [0m | &lt;&lt; UPDATE #3[0m
03:23:23 | 3003   | peer-1       [0m |    UPDATE #3 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:23:24 | 3003   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:23:24 | 3003   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:23:25 | 3003   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:23:25 | 3003   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
03:23:26 | 3003   | ka-outgoing-1[0m | receive-timer 177 second(s) left[0m
03:23:26 | 3003   | ka-outgoing-1[0m | send-timer 57 second(s) left[0m
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:26.931346" elapsed="0.000503"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:26.932687" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:26.932327" elapsed="0.000398"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:26.932873" elapsed="0.000289"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:23:26.932042" elapsed="0.001194"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.058049" level="INFO">^C03:23:26 | 3003   | [00;31mreactor      [0m | [1m^C received[0m
03:23:26 | 3003   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:23:26 | 3003   | outgoing-1   [0m | stop, message [shutting down][0m
03:23:26 | 3003   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:27.058265" level="INFO">${output} = ^C03:23:26 | 3003   | [00;31mreactor      [0m | [1m^C received[0m
03:23:26 | 3003   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:23:26 | 3003   | outgoing-1   [0m | stop, messag...</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:26.933378" elapsed="0.124921"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.058890" level="INFO">^C03:23:26 | 3003   | [00;31mreactor      [0m | [1m^C received[0m
03:23:26 | 3003   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:23:26 | 3003   | outgoing-1   [0m | stop, message [shutting down][0m
03:23:26 | 3003   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.058536" elapsed="0.000410"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.061072" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:27.059639" elapsed="0.001494"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.062704" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:27.062794" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:23:27.061289" elapsed="0.001532"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.063412" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.063162" elapsed="0.000297"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.062902" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.062876" elapsed="0.000643"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:23:27.059224" elapsed="0.004343"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:23:26.930425" elapsed="0.133195"/>
</kw>
<doc>Testing flowspec values for bgp-flowspec-redirect.cfg</doc>
<status status="PASS" start="2026-06-06T03:23:23.449243" elapsed="3.614440"/>
</test>
<test id="s1-s10-t5" name="Deconfigure_ODL_To_Accept_Connection" line="72">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.065051" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.064501" elapsed="0.000578"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.103985" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:27.103589" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:27.104758" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:27.104495" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:27.104929" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:27.104168" elapsed="0.000786"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.105507" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:27.105122" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:27.105837" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpflowspec/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:27.106000" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:27.105696" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.106416" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.106172" elapsed="0.000347"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.107468" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.107210" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.107938" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.107673" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.108616" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:27.108320" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:27.109419" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.109195" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:27.109498" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:23:27.109673" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:27.108833" elapsed="0.000866"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.109842" elapsed="0.000240"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:23:27.108197" elapsed="0.001925"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.110659" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:27.110352" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:27.111522" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.111160" elapsed="0.000388"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:27.111599" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:27.111769" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:27.110858" elapsed="0.000935"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.111933" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:27.110235" elapsed="0.001963"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:27.108019" elapsed="0.004213"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:27.112276" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:23:27.112432" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:27.106899" elapsed="0.005558"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.106593" elapsed="0.005895"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.112664" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.112514" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.106571" elapsed="0.006171"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.113481" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:27.112874" elapsed="0.000636"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:27.113559" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:27.102979" elapsed="0.010720"/>
</kw>
<msg time="2026-06-06T03:23:27.113755" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:27.091260" elapsed="0.022541"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.125238" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.136481" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpflowspec/../../../variables/bgpflowspec//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.147669" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.147863" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.148032" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.148435" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.148298" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:27.148265" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.148664" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.148822" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.148977" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:27.148230" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:27.148115" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.149227" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:27.149305" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:27.149444" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:27.087320" elapsed="0.062152"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.150613" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.150330" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:27.160841" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node019f5dqnq9m55e416lm4lbnqx719.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:27.160911" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:27.161088" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:27.152664" elapsed="0.008464"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.150749" elapsed="0.010443"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:27.161544" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.161231" elapsed="0.000428"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.150731" elapsed="0.010962"/>
</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-06-06T03:23:27.166166" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.163099" elapsed="0.003130"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.162806" elapsed="0.003473"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.162779" elapsed="0.003535"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.169972" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.166712" elapsed="0.003325"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.166393" elapsed="0.003693"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.166369" elapsed="0.003750"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.170910" 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-06-06T03:23:27.170343" elapsed="0.000606"/>
</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-06-06T03:23:27.171358" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.171049" elapsed="0.000391"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.172123" 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-06-06T03:23:27.171699" elapsed="0.000464"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.171474" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.171023" elapsed="0.001222"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.172977" 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-06-06T03:23:27.172446" elapsed="0.000568"/>
</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-06-06T03:23:27.173489" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.173173" elapsed="0.000397"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.174221" 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-06-06T03:23:27.173827" elapsed="0.000420"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:27.173604" elapsed="0.000680"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.173135" elapsed="0.001170"/>
</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-06-06T03:23:27.174446" elapsed="0.000364"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:27.175259" 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-06-06T03:23:27.174966" elapsed="0.000319"/>
</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-06-06T03:23:27.175429" elapsed="0.002073"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:23:27.162205" elapsed="0.015360"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:27.177614" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:23:27.179673" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:23:27.149747" elapsed="0.029954"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:27.179756" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:23:27.065306" elapsed="0.114575"/>
</kw>
<doc>Deconfigure BGP peer.</doc>
<status status="PASS" start="2026-06-06T03:23:27.064018" elapsed="0.115989"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:23:27.180757" elapsed="0.000361"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:27.181338" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:23:27.181262" elapsed="0.000145"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:23:27.180533" elapsed="0.000928"/>
</kw>
<doc>Functional test for bgp flowspec.

Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html</doc>
<status status="PASS" start="2026-06-06T03:23:12.709274" elapsed="14.472217"/>
</suite>
<suite id="s1-s11" name="Ibgp Peer Lsp" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/ibgp_peer_lsp.robot">
<kw name="Setup_Everything" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.271729" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:23:27.267196" elapsed="0.004588"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:23:27.266956" elapsed="0.004899"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.276966" 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-06-06T03:23:27.273082" elapsed="0.003913"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:23:27.277216" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:27.277085" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.277060" elapsed="0.000259"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.277865" 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-06-06T03:23:27.277486" elapsed="0.000422"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.278392" 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-06-06T03:23:27.278079" elapsed="0.000339"/>
</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-06-06T03:23:27.278963" elapsed="0.000290"/>
</kw>
<msg time="2026-06-06T03:23:27.279352" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:27.279400" 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-06-06T03:23:27.278594" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.280001" 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-06-06T03:23:27.279600" elapsed="0.000427"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.281047" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:23:27.280779" elapsed="0.000295"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.281506" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:23:27.281231" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.282006" 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-06-06T03:23:27.281715" elapsed="0.000317"/>
</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-06-06T03:23:27.285402" elapsed="0.000219"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.286132" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:23:27.285806" elapsed="0.000352"/>
</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-06-06T03:23:27.286318" elapsed="0.000229"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.287364" 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-06-06T03:23:27.287062" elapsed="0.000328"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:23:27.287437" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:23:27.287596" 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-06-06T03:23:27.286763" elapsed="0.000857"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:27.288235" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5927cd0&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-06-06T03:23:27.287801" elapsed="0.000575"/>
</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-06-06T03:23:27.288546" elapsed="0.000207"/>
</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-06-06T03:23:27.284786" elapsed="0.004028"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:27.284575" elapsed="0.004283"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:23:27.282089" elapsed="0.006800"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.289594" 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-06-06T03:23:27.289058" elapsed="0.000580"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.290222" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:23:27.289824" elapsed="0.000497"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.290907" 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-06-06T03:23:27.290495" elapsed="0.000455"/>
</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-06-06T03:23:27.280300" elapsed="0.010708"/>
</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-06-06T03:23:27.272670" elapsed="0.018394"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:27.291245" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:27.291130" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.291111" elapsed="0.000201"/>
</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-06-06T03:23:27.294563" 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-06-06T03:23:27.294181" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.295074" 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-06-06T03:23:27.294776" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:27.295146" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:27.295302" 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-06-06T03:23:27.293845" elapsed="0.001481"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:27.296332" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:23:27.296068" elapsed="0.000291"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.297131" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:23:27.297231" 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-06-06T03:23:27.296963" elapsed="0.000294"/>
</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-06-06T03:23:27.300870" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.300269" elapsed="0.000689"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.300248" elapsed="0.000748"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.301721" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:23:27.301203" elapsed="0.000814"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.303119" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.302354" elapsed="0.000873"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.304459" 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-06-06T03:23:27.303513" elapsed="0.001001"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.306373" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:23:27.306552" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:23:27.306011" elapsed="0.000584"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:27.306958" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.308572" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:23:27.893709" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:23:27 UTC 2026

  System load:  0.03               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:20:43 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:23:27.308248" elapsed="0.585694"/>
</kw>
<msg time="2026-06-06T03:23:27.894024" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:27.307795" elapsed="0.586385"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:23:27.305000" elapsed="0.589345"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.895224" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:23:27.908489" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:23:27.908896" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:23:27.909125" 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-06-06T03:23:27.894735" elapsed="0.014501"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:27.909965" elapsed="0.001138"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.913771" 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-06-06T03:23:27.912491" elapsed="0.001511"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:23:27.915005" elapsed="0.000114"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:27.914415" elapsed="0.000835"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.914310" elapsed="0.000994"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:23:27.915766" elapsed="0.000087"/>
</return>
<status status="PASS" start="2026-06-06T03:23:27.915417" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.915393" elapsed="0.000626"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:23:27.916103" elapsed="0.000022"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:27.921011" elapsed="0.000796"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.922207" elapsed="0.000461"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:27.923061" elapsed="0.000280"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:27.916795" elapsed="0.006616"/>
</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-06-06T03:23:27.299307" elapsed="0.624282"/>
</kw>
<msg time="2026-06-06T03:23:27.923728" 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-06-06T03:23:27.298628" elapsed="0.625156"/>
</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-06-06T03:23:27.297980" elapsed="0.625887"/>
</kw>
<msg time="2026-06-06T03:23:27.923908" 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-06-06T03:23:27.297440" elapsed="0.626513"/>
</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-06-06T03:23:27.926712" elapsed="0.000313"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.927196" elapsed="0.000148"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:27.927499" elapsed="0.000097"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:27.924255" elapsed="0.003418"/>
</kw>
<msg time="2026-06-06T03:23:27.927806" 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-06-06T03:23:27.296582" elapsed="0.631249"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.928270" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.928019" elapsed="0.000292"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:23:27.928354" elapsed="0.000030"/>
</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-06-06T03:23:27.295704" elapsed="0.632774"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:27.295504" elapsed="0.633012"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:27.295378" elapsed="0.633171"/>
</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-06-06T03:23:27.291540" elapsed="0.637072"/>
</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-06-06T03:23:27.928803" elapsed="0.000214"/>
</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-06-06T03:23:27.943387" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:27.943275" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.943255" elapsed="0.000201"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.943769" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:23:27.943878" 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-06-06T03:23:27.943616" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.944320" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.944065" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:27.944790" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:27.944522" elapsed="0.000312"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:27.945590" 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-06-06T03:23:27.945369" elapsed="0.000341">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:23:27.945818" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:23:27.945863" 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-06-06T03:23:27.944999" elapsed="0.000887"/>
</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-06-06T03:23:27.946204" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:27.945962" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:27.945943" elapsed="0.000359"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:27.947106" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:23:27.946839" elapsed="0.000293"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:23:27.947180" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:23:27.947333" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:23:27.946542" elapsed="0.000815"/>
</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-06-06T03:23:27.947518" elapsed="0.000421"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.948240" level="INFO">index=4
host=10.30.170.38
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-06-06T03:23:27.948340" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:23:27.948136" elapsed="0.000230"/>
</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-06-06T03:23:27.948522" elapsed="0.002463"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:23:27.951417" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:23:28.149027" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:23:27.951157" elapsed="0.198069"/>
</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-06-06T03:23:28.152672" elapsed="0.000360"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:28.153209" elapsed="0.000163"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:28.153529" elapsed="0.000100"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:28.150295" elapsed="0.003410"/>
</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-06-06T03:23:28.149612" elapsed="0.004142"/>
</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-06-06T03:23:27.942993" elapsed="0.210817"/>
</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-06-06T03:23:27.929891" elapsed="0.223969"/>
</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-06-06T03:23:27.929364" elapsed="0.224549"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:27.929219" elapsed="0.224735"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:23:27.929073" elapsed="0.224917"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:23:27.272166" elapsed="0.881884"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:28.156835" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.156716" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.156694" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:28.161883" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.161775" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.161756" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.162958" 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-06-06T03:23:28.162527" elapsed="0.000458"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.163456" 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-06-06T03:23:28.163154" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:28.163526" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:23:28.163706" 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-06-06T03:23:28.162186" elapsed="0.001545"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:28.170802" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.170679" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.170659" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:28.172116" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.171987" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.171969" elapsed="0.000218"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:28.172688" 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-06-06T03:23:28.172341" elapsed="0.000375"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.173115" 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-06-06T03:23:28.172886" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.205925" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:28.173841" elapsed="0.032240"/>
</kw>
<msg time="2026-06-06T03:23:28.206231" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:28.206278" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:23:28.173312" elapsed="0.033207"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.275883" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "i "b "g "p "_ "p "e "[78Ce "[A[78Cr
 "_ "l "s "p ". "r "o "b "o "t "[K"
[?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-06-06T03:23:28.207335" elapsed="0.068700"/>
</kw>
<msg time="2026-06-06T03:23:28.276165" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:28.276211" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:23:28.206754" elapsed="0.069497"/>
</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-06-06T03:23:28.276612" elapsed="0.000068"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:28.276342" elapsed="0.000440"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.276317" elapsed="0.000494"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.277326" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "u "s "e "r "/ "i "b "g "p "_ "p "e "[78Ce "[A[78Cr
 "_ "l "s "p ". "r "o "b "o "t "[K"
[?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-06-06T03:23:28.276968" elapsed="0.000440"/>
</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-06-06T03:23:28.277740" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:28.277476" elapsed="0.000416"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.277457" elapsed="0.000462"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:28.277955" elapsed="0.000038"/>
</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-06-06T03:23:28.280038" elapsed="0.000457"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:28.280870" elapsed="0.000306"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:28.281523" elapsed="0.000263"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:28.279232" elapsed="0.002647"/>
</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-06-06T03:23:28.278278" elapsed="0.003742"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:28.171692" elapsed="0.110433"/>
</kw>
<msg time="2026-06-06T03:23:28.282223" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:28.282275" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:28.171035" elapsed="0.111278"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:28.282501" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:28.282393" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.282373" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.283202" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.283556" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:28.283628" elapsed="0.000030"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:28.170367" elapsed="0.113388"/>
</kw>
<msg time="2026-06-06T03:23:28.283851" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:28.283896" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:28.164107" elapsed="0.119827"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.284273" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:28.284010" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.283993" elapsed="0.000396"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:28.163958" elapsed="0.120456"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:28.163786" elapsed="0.120660"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:28.161463" elapsed="0.123038"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:23:28.154686" elapsed="0.129872"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:28.154222" elapsed="0.130380"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:23:27.266520" elapsed="1.018150"/>
</kw>
<kw name="Set Default Configuration" owner="SSHLibrary">
<arg>prompt=${TOOLS_SYSTEM_PROMPT}</arg>
<doc>Update the default `configuration`.</doc>
<status status="PASS" start="2026-06-06T03:23:28.284833" elapsed="0.000180"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:28.285178" elapsed="0.000180"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:23:28.287161" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:23:28.287245" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:23:28.286852" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:28.287436" elapsed="0.000571"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.288900" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:23:28.646386" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:23:13 UTC 2026

  System load:  0.0                Processes:             105
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:23:13 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:23:28.288561" elapsed="0.357966"/>
</kw>
<msg time="2026-06-06T03:23:28.646609" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:28.288189" elapsed="0.358513"/>
</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-06-06T03:23:28.286328" elapsed="0.360483"/>
</kw>
<msg time="2026-06-06T03:23:28.646864" 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-06-06T03:23:28.285926" elapsed="0.360983"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:23:28.285565" elapsed="0.361422"/>
</kw>
<kw name="Require_Python" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.648454" level="INFO">Executing command 'python3 --help'.</msg>
<msg time="2026-06-06T03:23:28.661107" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:28.661362" level="INFO">${stdout} = usage: python3 [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_ins...</msg>
<msg time="2026-06-06T03:23:28.661465" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:23:28.661557" 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-06-06T03:23:28.648223" elapsed="0.013385"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.663540" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:23:28.662937" elapsed="0.000794"/>
</kw>
<msg time="2026-06-06T03:23:28.663949" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:23:28.664050" 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-06-06T03:23:28.662078" elapsed="0.002024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.665491" 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-06-06T03:23:28.664498" elapsed="0.001053"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.666544" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:28.665765" elapsed="0.001061"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.665715" elapsed="0.001176"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:23:28.667246" elapsed="0.000067"/>
</return>
<status status="PASS" start="2026-06-06T03:23:28.667018" elapsed="0.000372"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.666981" elapsed="0.000467"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:23:28.667711" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.667595" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:28.667537" elapsed="0.000321"/>
</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-06-06T03:23:28.668197" elapsed="0.000052"/>
</kw>
<msg time="2026-06-06T03:23:28.668533" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>python3 --help</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-06-06T03:23:28.647835" elapsed="0.020754"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:23:28.668986" elapsed="0.000057"/>
</return>
<status status="PASS" start="2026-06-06T03:23:28.668778" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.668737" elapsed="0.000426"/>
</if>
<kw name="Fatal Error" owner="BuiltIn">
<arg>Python 3 is not installed!</arg>
<doc>Stops the whole test execution.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.669497" elapsed="0.000050"/>
</kw>
<doc>Verify current SSH connection leads to machine with python working. Fatal fail otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:28.647344" elapsed="0.022368"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.672409" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:23:28.730479" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:28.730764" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:23:28.730865" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:23:28.730959" 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-06-06T03:23:28.672182" elapsed="0.058829"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.732891" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:23:28.732279" elapsed="0.000712"/>
</kw>
<msg time="2026-06-06T03:23:28.733203" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:23:28.733301" 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-06-06T03:23:28.731430" elapsed="0.001922"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.734741" 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-06-06T03:23:28.733772" elapsed="0.001030"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.735843" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:28.734976" elapsed="0.001013"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.734933" elapsed="0.001111"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:23:28.736335" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:23:28.736167" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.736131" elapsed="0.000321"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:23:28.736577" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.736528" elapsed="0.000103"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:28.736506" elapsed="0.000178"/>
</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-06-06T03:23:28.736895" elapsed="0.000029"/>
</kw>
<msg time="2026-06-06T03:23:28.737098" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:23:28.671259" elapsed="0.065874"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:23:28.737355" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:23:28.737229" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.737204" elapsed="0.000259"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:28.737697" elapsed="0.000032"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:23:28.670272" elapsed="0.067541"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.776163" level="INFO">[chan 3] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:23:28.789308" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../../tools/fastbgp/play.py</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:23:28.738028" elapsed="0.051363"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:28.790050" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5c488d0&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:23:28.789633" elapsed="0.000690"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.792312" 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-06-06T03:23:28.791867" elapsed="0.000472"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="PASS" start="2026-06-06T03:23:28.792512" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:28.792412" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.792394" elapsed="0.000199"/>
</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-06-06T03:23:28.792774" elapsed="0.000022"/>
</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-06-06T03:23:28.792960" elapsed="0.000021"/>
</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-06-06T03:23:28.793145" 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-06-06T03:23:28.793332" elapsed="0.000020"/>
</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-06-06T03:23:28.793594" 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-06-06T03:23:28.791324" elapsed="0.002375"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:28.793874" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:28.793763" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.793745" elapsed="0.000195"/>
</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-06-06T03:23:28.797514" 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-06-06T03:23:28.797104" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.798033" 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-06-06T03:23:28.797729" elapsed="0.000335"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:28.798117" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:28.798280" 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-06-06T03:23:28.796683" elapsed="0.001621"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:28.799354" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:23:28.799082" elapsed="0.000299"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.800143" level="INFO">index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:23:28.800244" level="INFO">${current_connection} = index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:23:28.800020" elapsed="0.000251"/>
</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-06-06T03:23:28.802972" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:28.802616" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:28.802597" elapsed="0.000568"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.803433" level="INFO">index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:23:28.803556" level="INFO">${current_ssh_connection} = index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:23:28.803325" elapsed="0.000259"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.804698" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:28.803779" elapsed="0.000968"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.805622" level="INFO">${conn_id} = 8</msg>
<var>${conn_id}</var>
<arg>${system}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${prompt_timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:23:28.804955" elapsed="0.000710"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:23:28.806989" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:23:28.807195" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:23:28.806422" elapsed="0.000822"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:28.807539" elapsed="0.000656"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:23:28.809847" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:23:29.136526" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:23:27 UTC 2026

  System load:  0.03               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:23:27 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:23:28.809300" elapsed="0.327438"/>
</kw>
<msg time="2026-06-06T03:23:29.136846" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:28.808532" elapsed="0.328513"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:23:28.805893" elapsed="0.331425"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.137890" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:23:29.151810" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:23:29.152208" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:23:29.152344" 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-06-06T03:23:29.137561" elapsed="0.014846"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:29.152881" elapsed="0.000493"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.155277" 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-06-06T03:23:29.153951" elapsed="0.001444"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.155989" elapsed="0.000044"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.155582" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.155526" elapsed="0.000643"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:23:29.156758" elapsed="0.000072"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.156372" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.156263" elapsed="0.000711"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.157057" elapsed="0.000035"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.163023" elapsed="0.000489"/>
</kw>
<msg time="2026-06-06T03:23:29.163713" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.161282" elapsed="0.002662"/>
</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="NOT RUN" start="2026-06-06T03:23:29.164361" elapsed="0.000156"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.164843" elapsed="0.000111"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.157580" elapsed="0.007514"/>
</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-06-06T03:23:28.802135" elapsed="0.363094"/>
</kw>
<msg time="2026-06-06T03:23:29.165302" 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-06-06T03:23:28.801451" elapsed="0.364013"/>
</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-06-06T03:23:28.800967" elapsed="0.364588"/>
</kw>
<msg time="2026-06-06T03:23:29.165599" 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-06-06T03:23:28.800434" elapsed="0.365229"/>
</kw>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.169088" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:23:29.169297" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.168544" elapsed="0.000818"/>
</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="NOT RUN" start="2026-06-06T03:23:29.169532" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.169737" elapsed="0.000024"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.165975" elapsed="0.003851"/>
</kw>
<msg time="2026-06-06T03:23:29.169920" 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-06-06T03:23:28.799604" elapsed="0.370342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.170468" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.170192" elapsed="0.000321"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:23:29.170559" elapsed="0.000030"/>
</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-06-06T03:23:28.798715" elapsed="0.372005"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:28.798508" elapsed="0.372254"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:28.798363" elapsed="0.372434"/>
</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-06-06T03:23:28.794160" elapsed="0.376694"/>
</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-06-06T03:23:29.171023" elapsed="0.000217"/>
</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-06-06T03:23:29.185891" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.185778" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.185758" elapsed="0.000204"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.186257" level="INFO">index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:23:29.186362" level="INFO">${current_ssh_connection_object} = index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
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-06-06T03:23:29.186139" elapsed="0.000250"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.186831" level="INFO">{1: 4}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.186551" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.187288" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.187039" elapsed="0.000293"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<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-06-06T03:23:29.187891" elapsed="0.000187"/>
</kw>
<msg time="2026-06-06T03:23:29.188177" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.188223" level="INFO">${old_connection_index} = 4</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-06-06T03:23:29.187500" elapsed="0.000747"/>
</kw>
<if>
<branch type="IF" condition="'${status}'=='PASS'">
<kw name="Run Keywords" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${old_connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.189127" elapsed="0.000138"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.199945" level="INFO">logout</msg>
<arg>logout</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:29.189792" elapsed="0.010211"/>
</kw>
<arg>SSHLibrary.Write</arg>
<arg>logout</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.189439" elapsed="0.010615"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:23:29.200606" elapsed="0.000180"/>
</kw>
<arg>SSHLibrary.Close_Connection</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.200234" elapsed="0.000602"/>
</kw>
<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="PASS" start="2026-06-06T03:23:29.188587" elapsed="0.012294"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.188348" elapsed="0.012625"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.188304" elapsed="0.012696"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:29.201793" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:23:29.201503" elapsed="0.000317"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:23:29.201869" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:29.202021" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.201219" elapsed="0.000827"/>
</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-06-06T03:23:29.202209" elapsed="0.000454"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.202963" level="INFO">index=9
host=10.30.170.38
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-06-06T03:23:29.203063" level="INFO">${karaf_connection_object} = index=9
host=10.30.170.38
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-06-06T03:23:29.202857" elapsed="0.000232"/>
</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-06-06T03:23:29.203245" elapsed="0.002246"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.205941" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:23:29.386434" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.205680" elapsed="0.180906"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.392489" elapsed="0.000316"/>
</kw>
<msg time="2026-06-06T03:23:29.392871" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.391799" elapsed="0.001169"/>
</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="NOT RUN" start="2026-06-06T03:23:29.393215" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.393393" elapsed="0.000021"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.388025" elapsed="0.005455"/>
</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-06-06T03:23:29.387102" elapsed="0.006426"/>
</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-06-06T03:23:29.185478" elapsed="0.208103"/>
</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-06-06T03:23:29.172062" elapsed="0.221566"/>
</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-06-06T03:23:29.171596" elapsed="0.222108"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:29.171448" elapsed="0.222301"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:23:29.171299" elapsed="0.222485"/>
</for>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:23:28.790769" elapsed="0.603074"/>
</kw>
<doc>Initialize SetupUtils. SSH-login to mininet machine, create HTTP session,
prepare directories for responses, put Python tool to mininet machine, setup imported resources.</doc>
<status status="PASS" start="2026-06-06T03:23:27.266158" elapsed="2.127735"/>
</kw>
<test id="s1-s11-t1" name="TC1_Configure_iBGP_Peer" line="54">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:29.397113" elapsed="0.000219"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:29.396791" elapsed="0.000598"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.398434" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.398317" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.398292" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.403780" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.403671" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.403652" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.404887" 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-06-06T03:23:29.404470" elapsed="0.000445"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.405387" 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-06-06T03:23:29.405086" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:29.405460" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:29.405615" 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-06-06T03:23:29.404080" elapsed="0.001575"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:29.411492" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.411384" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.411363" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:29.412762" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.412619" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.412600" elapsed="0.000232"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:29.413292" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:29.412986" elapsed="0.000334"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.413722" level="INFO">${current_connection_index} = 7</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-06-06T03:23:29.413489" elapsed="0.000259"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.448094" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:29.414257" elapsed="0.034078"/>
</kw>
<msg time="2026-06-06T03:23:29.448768" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:29.448874" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "...</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-06-06T03:23:29.413915" elapsed="0.035042"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.496598" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:29.450189" elapsed="0.046520"/>
</kw>
<msg time="2026-06-06T03:23:29.496901" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:29.496948" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "...</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-06-06T03:23:29.449370" elapsed="0.047615"/>
</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-06-06T03:23:29.497305" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.497067" elapsed="0.000294"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.497046" elapsed="0.000339"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.497855" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:29.497534" elapsed="0.000388"/>
</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-06-06T03:23:29.498214" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.497990" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.497971" elapsed="0.000377"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:29.498385" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.500943" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:23:29.501149" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.499901" elapsed="0.001385"/>
</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="NOT RUN" start="2026-06-06T03:23:29.501570" elapsed="0.000092"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.501930" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.499251" elapsed="0.002867"/>
</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-06-06T03:23:29.498700" elapsed="0.003483"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:29.412314" elapsed="0.089969"/>
</kw>
<msg time="2026-06-06T03:23:29.502378" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.502423" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.411731" elapsed="0.090730"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:29.502670" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.502539" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.502520" elapsed="0.000238"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.503169" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.503680" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.503753" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:29.411039" elapsed="0.092825"/>
</kw>
<msg time="2026-06-06T03:23:29.503958" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.504003" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:29.406031" elapsed="0.098010"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.504372" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.504116" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.504099" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:29.405885" elapsed="0.098587"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:29.405713" elapsed="0.098791"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:29.403119" elapsed="0.101439"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:29.398013" elapsed="0.106603"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.397547" elapsed="0.107131"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:29.394542" elapsed="0.110192"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.505786" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=exam...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.504960" elapsed="0.000856"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.540765" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:29.540326" elapsed="0.000468"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:29.541569" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:29.541333" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:29.541753" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:29.540985" elapsed="0.000793"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.542339" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:29.541949" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:29.542685" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:29.542838" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:29.542534" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.543274" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.543027" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.544303" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.544039" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.544794" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.544515" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.545523" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.545225" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.546307" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.546085" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.546385" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:29.546536" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.545758" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.546740" elapsed="0.000240"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:23:29.545082" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.547571" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.547273" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.548500" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.548286" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.548576" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:29.548743" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.547806" elapsed="0.000963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.548941" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:23:29.547134" elapsed="0.002074"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.549780" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.549459" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.550534" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.550321" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.550663" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:29.550819" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.549998" elapsed="0.000846"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.551003" elapsed="0.000223"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:23:29.549320" elapsed="0.001947"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.551838" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.551517" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.552590" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.552378" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.552681" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:29.552834" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.552055" elapsed="0.000826"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.553042" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:29.551379" elapsed="0.001926"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.553872" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.553553" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.554620" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.554410" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.554711" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:29.554861" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.554088" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.555042" elapsed="0.000226"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:29.553416" elapsed="0.001892"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.555870" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.555556" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.556620" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.556408" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.556712" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:29.556882" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.556085" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.557066" elapsed="0.000224"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:23:29.555419" elapsed="0.001911"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.557898" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.557581" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.558884" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.558472" elapsed="0.000439"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.558961" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:29.559114" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.558125" elapsed="0.001014"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.559297" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:29.557442" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.560125" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.559827" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.560922" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.560679" elapsed="0.000270"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.561035" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:29.561187" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.560341" elapsed="0.000871"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.561371" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:29.559688" elapsed="0.001946"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.562211" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.561914" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.562972" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.562760" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.563047" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:29.563194" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.562424" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.563373" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:29.561761" elapsed="0.001871"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.564190" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:29.563898" elapsed="0.000318"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:29.564967" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.564744" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:29.565042" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:29.565190" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:29.564408" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:29.565369" elapsed="0.000219"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:29.563761" elapsed="0.001867"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:29.544898" elapsed="0.020779"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:29.565721" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:23:29.565879" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': ...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:29.543703" elapsed="0.022202"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.543387" elapsed="0.022550"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.566116" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.565962" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.543368" elapsed="0.022824"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.567075" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:29.566339" elapsed="0.000765"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:29.567153" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:29.539700" elapsed="0.027576"/>
</kw>
<msg time="2026-06-06T03:23:29.567330" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.526612" elapsed="0.040765"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.580447" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.593370" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.606353" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.606554" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.606754" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.607130" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.606977" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:29.606962" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.607359" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.607534" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.607721" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:29.606933" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.606832" elapsed="0.000970"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.607956" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.608032" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:29.608153" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:29.522195" elapsed="0.085985"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.635465" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:29.635089" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:29.636231" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:29.636025" elapsed="0.000270">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:29.636387" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:29.635679" elapsed="0.000733"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.637005" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:29.636582" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:29.637341" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:29.637502" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:29.637202" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.637961" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.637713" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:29.638383" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.638088" elapsed="0.000353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.638940" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': ...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:29.638622" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.638466" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.638069" elapsed="0.000957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.639962" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:29.639179" elapsed="0.000814"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:29.640043" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:29.634450" elapsed="0.005719"/>
</kw>
<msg time="2026-06-06T03:23:29.640227" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.621403" elapsed="0.018871"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.654410" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.667298" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.680199" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.680410" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.680658" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.681081" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.680898" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:29.680882" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.681323" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.681501" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.681691" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:29.680849" elapsed="0.000898"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.680743" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.681930" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.682009" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:29.682155" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:29.618658" elapsed="0.063527"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:29.683522" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:29.683266" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:29.683702" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:29.682889" elapsed="0.000839"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.684065" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.683801" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.684632" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:29.684334" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.684148" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.683782" elapsed="0.000949"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.687176" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:29.684891" elapsed="0.002312"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:29.687258" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:29.687414" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:29.682525" elapsed="0.004915"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.688861" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.688590" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.689337" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.689094" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.689863" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.689594" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.690317" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.690069" elapsed="0.000292"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:29.691202" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:23:29.691005" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:23:29.691566" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:23:29.691390" elapsed="0.000203"/>
</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-06-06T03:23:29.691766" elapsed="0.000206"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.692386" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.692136" elapsed="0.000295"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:23:29.692474" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:29.692630" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:23:29.690570" elapsed="0.002100"/>
</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-06-06T03:23:29.714265" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '1079', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:23:29.714333" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:23:29 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:29.714519" 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-06-06T03:23:29.695113" elapsed="0.019434"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.692743" elapsed="0.021850"/>
</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-06-06T03:23:29.714810" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.714619" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.692724" elapsed="0.022176"/>
</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-06-06T03:23:29.718382" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.715927" elapsed="0.002499"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.715693" elapsed="0.002918"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.715673" elapsed="0.002963"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.721336" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.718946" elapsed="0.002436"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.718709" elapsed="0.002708"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.718691" elapsed="0.002751"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.722014" 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-06-06T03:23:29.721612" elapsed="0.000429"/>
</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-06-06T03:23:29.722400" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.722113" elapsed="0.000348"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.722998" 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-06-06T03:23:29.722672" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.722486" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.722094" elapsed="0.000990"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.723625" 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-06-06T03:23:29.723255" elapsed="0.000413"/>
</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-06-06T03:23:29.723993" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.723742" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.724568" 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-06-06T03:23:29.724268" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.724093" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.723723" elapsed="0.000947"/>
</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-06-06T03:23:29.724830" elapsed="0.000378"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:29.725682" 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-06-06T03:23:29.725382" elapsed="0.000328"/>
</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-06-06T03:23:29.725874" elapsed="0.002376"/>
</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-06-06T03:23:29.715315" elapsed="0.012998"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:29.728488" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.728381" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.728362" 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>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.728754" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.728825" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:29.731168" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:23:29.687790" elapsed="0.043405"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:29.731265" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:29.731418" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:29.510941" elapsed="0.220502"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.731796" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.731540" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.731522" elapsed="0.000366"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:29.731921" elapsed="0.000027"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}${/}bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:23:29.506097" elapsed="0.225948"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.733333" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.732921" elapsed="0.000474"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.732903" elapsed="0.000517"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.733572" elapsed="0.000372"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.739303" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:29.738890" elapsed="0.000442"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:29.739553" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.739408" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.739389" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.739810" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.739992" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.740176" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.740353" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.740527" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.740720" elapsed="0.000022"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.740895" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:29.738556" elapsed="0.002416"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.732710" elapsed="0.008314"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:29.732329" elapsed="0.008738"/>
</kw>
<doc>Configure BGP peer module with initiate-connection set to false.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:29.393960" elapsed="0.347145"/>
</test>
<test id="s1-s11-t2" name="TC1_Check_Example_Bgp_Rib_Is_Empty" line="73">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:29.744374" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:29.744106" elapsed="0.000547"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.745680" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.745555" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.745536" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.750844" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.750737" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.750719" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.751925" 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-06-06T03:23:29.751524" elapsed="0.000428"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.752419" 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-06-06T03:23:29.752120" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:29.752490" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:29.752660" 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-06-06T03:23:29.751143" elapsed="0.001544"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:29.758528" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.758419" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.758400" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:29.759820" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.759705" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.759685" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:29.760340" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:29.760040" elapsed="0.000361"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.760812" level="INFO">${current_connection_index} = 7</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-06-06T03:23:29.760572" elapsed="0.000268"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.792116" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:29.761374" elapsed="0.030850"/>
</kw>
<msg time="2026-06-06T03:23:29.792405" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:29.792453" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:29.761008" elapsed="0.031484"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.819976" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:23:29.793056" elapsed="0.027024"/>
</kw>
<msg time="2026-06-06T03:23:29.820240" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:29.820286" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</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-06-06T03:23:29.792699" elapsed="0.027624"/>
</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-06-06T03:23:29.820627" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.820400" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.820380" elapsed="0.000354"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.821179" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:23:29.820885" elapsed="0.000393"/>
</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-06-06T03:23:29.821571" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.821347" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.821329" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:29.821700" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.824206" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:23:29.824410" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.823151" elapsed="0.001389"/>
</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="NOT RUN" start="2026-06-06T03:23:29.824843" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.825188" elapsed="0.000092"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.822507" elapsed="0.002888"/>
</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-06-06T03:23:29.821972" elapsed="0.003506"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:29.759378" elapsed="0.066207"/>
</kw>
<msg time="2026-06-06T03:23:29.825695" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.825741" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.758775" elapsed="0.067005"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:29.825965" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.825858" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.825838" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.826449" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.826812" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.826920" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:29.758076" elapsed="0.068955"/>
</kw>
<msg time="2026-06-06T03:23:29.827125" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.827169" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:29.753059" elapsed="0.074147"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.827537" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.827282" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.827264" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:29.752911" elapsed="0.074742"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:29.752740" elapsed="0.074946"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:29.750362" elapsed="0.077377"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:29.745267" elapsed="0.082526"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.744815" elapsed="0.083024"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:29.741865" elapsed="0.086026"/>
</kw>
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:29.838768" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:29.842245" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:29.842716" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:29.828554" elapsed="0.014223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.847304" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.843158" elapsed="0.004193"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.850289" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:29.847516" elapsed="0.002923"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:29.850605" elapsed="0.002947"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>${JSONKEYSTR}</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:29.828119" elapsed="0.025501"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.855629" elapsed="0.000092"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.854491" elapsed="0.001289"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.854472" elapsed="0.001344"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.856032" elapsed="0.000398"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.861718" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:29.861254" elapsed="0.000493"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:29.861971" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.861824" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.861805" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.862221" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.862403" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.862586" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.862779" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.862956" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.863132" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.863306" elapsed="0.000026"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:29.860924" elapsed="0.002466"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:29.854280" elapsed="0.009161"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:29.853909" elapsed="0.009583"/>
</kw>
<doc>Check RIB for none linkstate-routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:29.741349" elapsed="0.122184"/>
</test>
<test id="s1-s11-t3" name="TC1_Connect_BGP_Peer" line="78">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:29.866967" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:29.866688" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.868242" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.868132" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.868113" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.873673" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.873549" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.873530" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.874775" 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-06-06T03:23:29.874373" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.875268" 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-06-06T03:23:29.874971" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:29.875339" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:29.875495" 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-06-06T03:23:29.873980" elapsed="0.001609"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:29.881281" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.881170" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.881150" elapsed="0.000216"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:29.882580" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.882473" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.882454" elapsed="0.000220"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:29.883137" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:29.882830" elapsed="0.000334"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.883548" level="INFO">${current_connection_index} = 7</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-06-06T03:23:29.883332" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.914631" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:29.884105" elapsed="0.030647"/>
</kw>
<msg time="2026-06-06T03:23:29.914915" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:29.914962" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:29.883758" elapsed="0.031241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.935901" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:29.915526" elapsed="0.020475"/>
</kw>
<msg time="2026-06-06T03:23:29.936160" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:29.936206" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "...</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-06-06T03:23:29.915178" elapsed="0.021066"/>
</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-06-06T03:23:29.936550" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.936320" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.936300" elapsed="0.000329"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.937096" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:29.936799" elapsed="0.000361"/>
</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-06-06T03:23:29.937465" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.937228" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.937209" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:29.937577" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:29.940090" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:23:29.940295" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:29.939056" elapsed="0.001366"/>
</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="NOT RUN" start="2026-06-06T03:23:29.940718" elapsed="0.000212"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.941207" elapsed="0.000083"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:29.938423" elapsed="0.003026"/>
</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-06-06T03:23:29.937888" elapsed="0.003632"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:29.882168" elapsed="0.059453"/>
</kw>
<msg time="2026-06-06T03:23:29.941767" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.941813" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.881527" elapsed="0.060325"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:29.942039" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:29.941930" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.941911" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.942526" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.942892" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.942965" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:29.880826" elapsed="0.062249"/>
</kw>
<msg time="2026-06-06T03:23:29.943169" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:29.943215" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:29.875996" elapsed="0.067257"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:29.943585" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:29.943328" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.943311" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:29.875844" elapsed="0.067861"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:29.875665" elapsed="0.068069"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:29.873163" elapsed="0.070627"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:29.867841" elapsed="0.076005"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.867391" elapsed="0.076501"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:29.864397" elapsed="0.079548"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:29.951286" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.951176" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.951157" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.952374" 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-06-06T03:23:29.951988" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:29.952882" 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-06-06T03:23:29.952567" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:29.952953" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:29.953107" 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-06-06T03:23:29.951586" elapsed="0.001546"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:29.958820" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.958711" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.958692" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:29.959995" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:29.959889" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:29.959870" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:29.960431" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:29.960212" elapsed="0.000245"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:29.960847" level="INFO">${current_connection_index} = 7</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-06-06T03:23:29.960619" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:30.002799" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "E "r "r "o "r "[C "= "[C "W "E "L "L "_ "K "N "O "W "N "_ "A "T "T "R "_ "M "I "S "S "I "N "G "[78C[C "[A[78Ci</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:29.961385" elapsed="0.041498"/>
</kw>
<msg time="2026-06-06T03:23:30.002989" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:30.003037" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "E "r "r "o "r "[C "= "[C "W "E "L "L "_ "K "N "O "W "N "_ "A "T "...</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-06-06T03:23:29.961040" elapsed="0.042035"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:30.087652" level="INFO">"s "[C "E "X "P "E "C "T "E "D "[C "i "n "[C "t "h "i "s "[C "t "e "s "t "[C "c "a "s "e ", "[C "a "n "d "[C "s "h "o "u "l "d "[C "b "e "[C "t "h "r "o "w "n "[C "w "h "e "n "[C "m "i "s "s "i "n "g "[C "m "a "n "d "a "t "o "r "y "[C "a "t "t "r "[78Ci "[A[78Cb
 "u "t "e "s ". "[K"
[?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-06-06T03:23:30.003624" elapsed="0.084149"/>
</kw>
<msg time="2026-06-06T03:23:30.087891" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:30.087937" level="INFO">${message_wait} =  "s "[C "E "X "P "E "C "T "E "D "[C "i "n "[C "t "h "i "s "[C "t "e "s "t "[C "c "a "s "e ", "[C "a "n "d "[C "s "h "o "...</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-06-06T03:23:30.003259" elapsed="0.084716"/>
</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-06-06T03:23:30.088338" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:30.088066" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:30.088040" elapsed="0.000382"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:30.088882" level="INFO"> "s "[C "E "X "P "E "C "T "E "D "[C "i "n "[C "t "h "i "s "[C "t "e "s "t "[C "c "a "s "e ", "[C "a "n "d "[C "s "h "o "u "l "d "[C "b "e "[C "t "h "r "o "w "n "[C "w "h "e "n "[C "m "i "s "s "i "n "g "[C "m "a "n "d "a "t "o "r "y "[C "a "t "t "r "[78Ci "[A[78Cb
 "u "t "e "s ". "[K"
[?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-06-06T03:23:30.088575" elapsed="0.000389"/>
</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-06-06T03:23:30.089256" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:30.089031" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:30.089012" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:30.089368" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:30.091188" elapsed="0.000215"/>
</kw>
<msg time="2026-06-06T03:23:30.091555" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:30.090632" elapsed="0.000992"/>
</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="NOT RUN" start="2026-06-06T03:23:30.091826" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:30.091997" elapsed="0.000020"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:30.090249" elapsed="0.001830"/>
</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-06-06T03:23:30.089712" elapsed="0.002413"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:29.959570" elapsed="0.132652"/>
</kw>
<msg time="2026-06-06T03:23:30.092316" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:30.092361" level="INFO">${message} =  "s "[C "E "X "P "E "C "T "E "D "[C "i "n "[C "t "h "i "s "[C "t "e "s "t "[C "c "a "s "e ", "[C "a "n "d "[C "s "h "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.959049" elapsed="0.133349"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:30.092583" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:30.092475" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:30.092456" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:30.093095" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:30.093443" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:30.093573" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:29.958357" elapsed="0.135357"/>
</kw>
<msg time="2026-06-06T03:23:30.093811" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:30.093856" level="INFO">${output} =  "s "[C "E "X "P "E "C "T "E "D "[C "i "n "[C "t "h "i "s "[C "t "e "s "t "[C "c "a "s "e ", "[C "a "n "d "[C "s "h "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:29.953510" elapsed="0.140385"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:30.094232" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:30.093971" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:30.093954" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:29.953350" elapsed="0.140990"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:29.953183" elapsed="0.141188"/>
</for>
<arg>Error = WELL_KNOWN_ATTR_MISSING is EXPECTED in this test case, and should be thrown when missing mandatory attributes.</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:29.948996" elapsed="0.145430"/>
</kw>
<arg>KarafKeywords.Log_Message_To_Controller_Karaf</arg>
<arg>Error = WELL_KNOWN_ATTR_MISSING is EXPECTED in this test case, and should be thrown when missing mandatory attributes.</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:29.944114" elapsed="0.150361"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:30.103267" level="INFO">${start_cmd} = python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True --skipattr &amp;&gt;bgp_peer.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:30.102937" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:30.103731" level="INFO">python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True --skipattr &amp;&gt;bgp_peer.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:30.103467" elapsed="0.000312"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:30.107557" level="INFO">python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True --skipattr &amp;&gt;bgp_peer.log</msg>
<msg time="2026-06-06T03:23:30.107663" level="INFO">${output} =  python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True --skipattr &amp;&gt;bgp_peer.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:30.103941" elapsed="0.003751"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:30.108108" level="INFO"> python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True --skipattr &amp;&gt;bgp_peer.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:30.107860" elapsed="0.000296"/>
</kw>
<arg>${BGP_PEER_COMMAND} ${SKIP_PARAMS}</arg>
<arg>${BGP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:23:30.102497" elapsed="0.005714"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:23:40.110430" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:23:30.109865" elapsed="10.001383">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.111591" elapsed="0.000032"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:23:30.109561" elapsed="10.002213">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:23:30.109148" elapsed="10.002754"/>
</kw>
<msg time="2026-06-06T03:23:40.112028" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:30.108782" elapsed="10.003272"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:23:40.112241" elapsed="0.000371"/>
</return>
<status status="PASS" start="2026-06-06T03:23:40.112148" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.112122" elapsed="0.000574"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.112942" elapsed="0.000027"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.113126" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:23:30.108478" elapsed="10.004727"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.114736" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:40.114307" elapsed="0.000492"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.114288" elapsed="0.000537"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:40.114983" elapsed="0.000375"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.120626" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:40.120164" elapsed="0.000512"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:40.120902" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:40.120754" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.120734" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.121140" elapsed="0.000023"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.121323" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.121504" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.121696" elapsed="0.000027"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.121879" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.122057" elapsed="0.000021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.122229" elapsed="0.000021"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:40.119845" elapsed="0.002461"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:40.113959" elapsed="0.008398"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:40.113496" elapsed="0.008904"/>
</kw>
<doc>Connect BGP peer with advertising the routes without mandatory params like LOC_PREF.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:29.863783" elapsed="10.258655"/>
</test>
<test id="s1-s11-t4" name="TC1_Check_Example_Bgp_Rib" line="87">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:40.126004" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:40.125723" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:40.127300" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:40.127190" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.127170" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:40.132796" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:40.132685" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.132665" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.133894" 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-06-06T03:23:40.133487" elapsed="0.000434"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.134389" 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-06-06T03:23:40.134092" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:40.134460" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:40.134613" 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-06-06T03:23:40.133099" elapsed="0.001538"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:40.140308" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:40.140201" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.140181" elapsed="0.000238"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:40.141614" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:40.141507" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.141488" elapsed="0.000218"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:40.142175" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:40.141860" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:40.142598" level="INFO">${current_connection_index} = 7</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-06-06T03:23:40.142370" elapsed="0.000254"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:40.176186" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:40.143169" elapsed="0.033200"/>
</kw>
<msg time="2026-06-06T03:23:40.176573" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:40.176620" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:40.142825" elapsed="0.034001"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:40.203710" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "[K"
[?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-06-06T03:23:40.178495" elapsed="0.025376"/>
</kw>
<msg time="2026-06-06T03:23:40.204080" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:40.204127" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</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-06-06T03:23:40.177465" elapsed="0.026699"/>
</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-06-06T03:23:40.204580" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:40.204275" elapsed="0.000364"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.204242" elapsed="0.000457"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.205216" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "[K"
[?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-06-06T03:23:40.204861" elapsed="0.000423"/>
</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-06-06T03:23:40.205578" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:40.205352" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.205334" elapsed="0.000345"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:40.205718" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:40.208474" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:23:40.208816" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:40.207344" elapsed="0.001611"/>
</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="NOT RUN" start="2026-06-06T03:23:40.209261" elapsed="0.000279"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.209833" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:40.206657" elapsed="0.003369"/>
</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-06-06T03:23:40.206057" elapsed="0.004035"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:40.141204" elapsed="0.068985"/>
</kw>
<msg time="2026-06-06T03:23:40.210450" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:40.210504" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:40.140581" elapsed="0.069962"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:40.210750" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:40.210624" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.210604" elapsed="0.000287"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.211340" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.211745" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:40.211821" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:40.139831" elapsed="0.072100"/>
</kw>
<msg time="2026-06-06T03:23:40.212047" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:40.212093" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:40.135035" elapsed="0.077095"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:40.212468" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:40.212207" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.212189" elapsed="0.000356"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:40.134884" elapsed="0.077685"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:40.134709" elapsed="0.077895"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:40.132294" elapsed="0.080389"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:40.126900" elapsed="0.085842"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:40.126432" elapsed="0.086356"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:40.123290" elapsed="0.089552"/>
</kw>
<kw name="Verify_Keyword_Does_Not_Fail_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Confirm_Keyword_Fails_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:40.234941" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:40.235429" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:40.235763" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:40.217733" elapsed="0.018130"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.239175" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:40.236135" elapsed="0.003104"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.242581" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:40.239474" elapsed="0.003303"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:40.243013" elapsed="0.003572"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:40.217211" elapsed="0.029573"/>
</kw>
<msg time="2026-06-06T03:23:40.246885" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:40.246929" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:40.216564" elapsed="0.030388"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:40.247164" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:40.247045" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:40.247019" elapsed="0.000217"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.247755" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:40.247390" elapsed="0.000391"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:40.248253" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:40.247940" elapsed="0.000383">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:40.216224" elapsed="0.032209">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:41.265751" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:41.266256" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:41.266573" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:41.252513" elapsed="0.014154"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:41.270747" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:41.266972" elapsed="0.003927"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:41.276092" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:41.271345" elapsed="0.005010"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:41.276731" elapsed="0.004887"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:41.251550" elapsed="0.030337"/>
</kw>
<msg time="2026-06-06T03:23:41.282040" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:41.282103" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:41.250450" elapsed="0.031685"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:41.282439" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:41.282262" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:41.282223" elapsed="0.000318"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:41.283239" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:41.282799" elapsed="0.000476"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:41.283969" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:41.283497" elapsed="0.000568">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:41.249496" elapsed="0.034725">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:42.300378" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:42.301108" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:42.301581" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:42.286888" elapsed="0.014836"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:42.308710" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:42.302109" elapsed="0.006699"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:42.313849" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:42.309150" elapsed="0.004940"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:42.314423" elapsed="0.004253"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:42.286364" elapsed="0.032487"/>
</kw>
<msg time="2026-06-06T03:23:42.318953" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:42.318998" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:42.285718" elapsed="0.033302"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:42.319232" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:42.319105" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:42.319079" elapsed="0.000226"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:42.319818" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:42.319460" elapsed="0.000384"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:42.320318" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:42.320004" elapsed="0.000385">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:42.285089" elapsed="0.035434">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:43.337830" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:43.338793" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:43.339291" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:43.324961" elapsed="0.014454"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:43.344544" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:43.339895" elapsed="0.004769"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:43.349764" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:43.345028" elapsed="0.005083"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:43.350477" elapsed="0.003780"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:43.323909" elapsed="0.030528"/>
</kw>
<msg time="2026-06-06T03:23:43.354545" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:43.354592" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:43.322607" elapsed="0.032009"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:43.354914" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:43.354779" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:43.354748" elapsed="0.000242"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:43.355470" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:43.355150" elapsed="0.000347"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:43.356003" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:43.355675" elapsed="0.000403">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:43.321501" elapsed="0.034689">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:44.373884" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:44.374963" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:44.375621" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:44.360227" elapsed="0.015589"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:44.382514" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:44.376453" elapsed="0.006125"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:44.386084" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:44.382849" elapsed="0.003411"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:44.386497" elapsed="0.003589"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:44.359258" elapsed="0.031002"/>
</kw>
<msg time="2026-06-06T03:23:44.390364" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:44.390409" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:44.358142" elapsed="0.032290"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:44.390702" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:44.390522" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:44.390496" elapsed="0.000283"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:44.391254" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:44.390938" elapsed="0.000342"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:44.391779" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:44.391443" elapsed="0.000406">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:44.357166" elapsed="0.034794">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:45.402688" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:45.403170" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:45.403474" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:45.394069" elapsed="0.009477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:45.406698" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:45.403852" elapsed="0.002913"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:45.410131" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:45.407000" elapsed="0.003299"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:45.410535" elapsed="0.003657"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:45.393609" elapsed="0.020753"/>
</kw>
<msg time="2026-06-06T03:23:45.414462" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:45.414506" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:45.393092" elapsed="0.021437"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:45.414755" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:45.414614" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:45.414589" elapsed="0.000241"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:45.415296" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:45.414985" elapsed="0.000337"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:45.415850" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:45.415482" elapsed="0.000440">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:45.392570" elapsed="0.023464">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:46.432453" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:46.432956" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:46.433259" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:46.420871" elapsed="0.012474"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:46.436848" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:46.433623" elapsed="0.003292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:46.441514" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:46.437171" elapsed="0.004769"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:46.442316" elapsed="0.005149"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:46.419694" elapsed="0.028049"/>
</kw>
<msg time="2026-06-06T03:23:46.447883" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:46.447945" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:46.418113" elapsed="0.029863"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:46.448258" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:46.448091" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:46.448057" elapsed="0.000301"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:46.449032" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:46.448572" elapsed="0.000497"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:46.449810" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:46.449328" elapsed="0.000555">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:46.417041" elapsed="0.032951">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:47.467952" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:47.468473" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:47.468810" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:47.454262" elapsed="0.014624"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:47.472367" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:47.469187" elapsed="0.003277"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:47.477413" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:47.472827" elapsed="0.004886"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:47.478054" elapsed="0.005186"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:47.453253" elapsed="0.030234"/>
</kw>
<msg time="2026-06-06T03:23:47.483630" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:47.483720" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:47.451978" elapsed="0.031776"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:47.484030" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:47.483870" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:47.483836" elapsed="0.000276"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:47.484598" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:47.484271" elapsed="0.000355"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:47.485152" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:47.484811" elapsed="0.000415">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:47.450944" elapsed="0.034393">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:48.499292" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:48.500018" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:48.500609" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:48.489311" elapsed="0.011429"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:48.506283" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:48.501186" elapsed="0.005191"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:48.511028" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:48.506748" elapsed="0.004454"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:48.511436" elapsed="0.003585"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:48.488331" elapsed="0.026867"/>
</kw>
<msg time="2026-06-06T03:23:48.515299" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:48.515345" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:48.487243" elapsed="0.028126"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:48.515578" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:48.515455" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:48.515429" elapsed="0.000249"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:48.516152" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:48.515837" elapsed="0.000342"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:48.516686" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:48.516339" elapsed="0.000419">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:48.486304" elapsed="0.030564">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:49.530833" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:49.531318" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:49.531655" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:49.521081" elapsed="0.010651"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:49.534930" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:49.532026" elapsed="0.002971"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:49.539239" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:49.535233" elapsed="0.004308"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:49.539940" elapsed="0.005367"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:49.520039" elapsed="0.025587"/>
</kw>
<msg time="2026-06-06T03:23:49.545803" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:49.545878" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:49.518910" elapsed="0.027005"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:49.546241" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:49.546065" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:49.546025" elapsed="0.000318"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:49.547091" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:49.546562" elapsed="0.000566"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:49.547810" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:49.547351" elapsed="0.000554">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:49.517871" elapsed="0.030188">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:50.561903" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:50.562619" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:50.563139" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:50.551017" elapsed="0.012230"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.568397" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:50.563728" elapsed="0.004759"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.573203" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:50.568862" elapsed="0.004574"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:50.573864" elapsed="0.004603"/>
</kw>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:50.550219" elapsed="0.028445"/>
</kw>
<msg time="2026-06-06T03:23:50.578770" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:50.578816" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:50.549484" elapsed="0.029356"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:23:50.579066" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:50.578935" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.578905" elapsed="0.000237"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.579616" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:50.579300" elapsed="0.000357"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.580139" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:23:50.579821" elapsed="0.000390">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:23:50.548831" elapsed="0.031514">None</status>
</kw>
<msg time="2026-06-06T03:23:50.580437" level="FAIL">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</msg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Invert_Failure</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:23:40.215608" elapsed="10.364922">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</status>
</kw>
<msg time="2026-06-06T03:23:50.580584" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Invert_Failure</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="FAIL" start="2026-06-06T03:23:40.215235" elapsed="10.365400"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>BgpOperations.Check_Example_Bgp_Rib_Does_Not_Contain</arg>
<arg>config-session</arg>
<arg>"linkstate-route"</arg>
<doc>Some Keywords need several tries to finally fail, this keyword passes if and only if the failure ultimately happens.</doc>
<status status="FAIL" start="2026-06-06T03:23:40.214877" elapsed="10.365875">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</status>
</kw>
<msg time="2026-06-06T03:23:50.580867" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:23:50.580911" level="INFO">${output} = Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:40.214415" elapsed="10.366520"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:23:50.581123" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:23:50.581012" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.580993" elapsed="0.000211"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.581357" elapsed="0.000022"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.581530" elapsed="0.000020"/>
</kw>
<arg>Confirm_Keyword_Fails_Within_Timeout</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="PASS" start="2026-06-06T03:23:40.214019" elapsed="10.367655"/>
</kw>
<msg time="2026-06-06T03:23:50.581728" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Invert_Failure</arg>
<arg>Confirm_Keyword_Fails_Within_Timeout</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:40.213539" elapsed="10.368235"/>
</kw>
<arg>${DEFAULT_RIB_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_RIB_CHECK_PERIOD}</arg>
<arg>BgpOperations.Check_Example_Bgp_Rib_Does_Not_Contain</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${JSONKEYSTR}</arg>
<doc>Some positive checks report false success for a short time. This keyword verifies no failure does happen within timeout period.
This implementation needs more complicated logic than, Verify_Keyword_Never_Passes_Within_Timeout,
so use that keyword in case you have a negative check handy.</doc>
<status status="PASS" start="2026-06-06T03:23:40.213070" elapsed="10.368783"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.583214" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:50.582815" elapsed="0.000460"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.582797" elapsed="0.000502"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:50.583456" elapsed="0.000468"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.589395" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:50.588961" elapsed="0.000462"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:50.589726" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:23:50.589559" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.589537" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.589971" elapsed="0.000021"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.590152" elapsed="0.000020"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.590331" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.590504" elapsed="0.000019"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.590692" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.590867" elapsed="0.000019"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.591037" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:50.588616" elapsed="0.002498"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:50.582589" elapsed="0.008576"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:50.582173" elapsed="0.009035"/>
</kw>
<doc>Check RIB for not containig linkstate-route(s), because update messages were not good.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:40.122693" elapsed="10.468558"/>
</test>
<test id="s1-s11-t5" name="TC1_Disconnect_BGP_Peer" line="97">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:50.595363" elapsed="0.000221"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:50.594869" elapsed="0.000788"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:50.596709" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:50.596578" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.596558" elapsed="0.000220"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:50.601904" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:50.601796" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.601777" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.603019" 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-06-06T03:23:50.602604" elapsed="0.000441"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.603512" 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-06-06T03:23:50.603215" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:50.603582" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:50.603757" 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-06-06T03:23:50.602212" elapsed="0.001570"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:50.609446" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:50.609336" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.609317" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:50.610759" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:50.610619" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.610601" elapsed="0.000227"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:50.611283" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:50.610980" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:50.611719" level="INFO">${current_connection_index} = 7</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-06-06T03:23:50.611478" elapsed="0.000268"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:50.641772" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:50.612333" elapsed="0.029560"/>
</kw>
<msg time="2026-06-06T03:23:50.642066" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:50.642113" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:50.611912" elapsed="0.030238"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:50.663228" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:50.642726" elapsed="0.020609"/>
</kw>
<msg time="2026-06-06T03:23:50.663501" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:50.663547" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:23:50.642336" elapsed="0.021250"/>
</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-06-06T03:23:50.663943" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:50.663686" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.663661" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.664482" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:50.664177" elapsed="0.000372"/>
</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-06-06T03:23:50.664867" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:50.664617" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.664598" elapsed="0.000348"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:50.664982" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:50.667664" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:23:50.667875" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:50.666483" elapsed="0.001545"/>
</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="NOT RUN" start="2026-06-06T03:23:50.668375" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.668751" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:50.665845" elapsed="0.003096"/>
</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-06-06T03:23:50.665278" elapsed="0.003876"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:50.610316" elapsed="0.058946"/>
</kw>
<msg time="2026-06-06T03:23:50.669354" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:50.669398" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:50.609687" elapsed="0.059749"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:50.669624" elapsed="0.000052"/>
</return>
<status status="PASS" start="2026-06-06T03:23:50.669513" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.669494" elapsed="0.000244"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.670151" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.670501" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:50.670573" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:50.608997" elapsed="0.061703"/>
</kw>
<msg time="2026-06-06T03:23:50.670796" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:50.670840" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:50.604185" elapsed="0.066732"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:50.671261" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:50.670999" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:50.670980" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:50.604023" elapsed="0.067341"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:50.603843" elapsed="0.067554"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:50.601410" elapsed="0.070043"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:50.596283" elapsed="0.075227"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:50.595822" elapsed="0.075733"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:50.591985" elapsed="0.079625"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:50.672849" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:50.672510" elapsed="0.000367"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:50.673045" elapsed="0.000222"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:23:50.672230" elapsed="0.001095"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:23:52.674109" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:23:52.674472" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:23:50.673492" elapsed="2.001045"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.675816" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.675096" elapsed="0.000829"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:23:50.671852" elapsed="2.004213"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:23:52.691061" level="INFO">Executing command 'cat bgp_peer.log'.</msg>
<msg time="2026-06-06T03:23:52.704951" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:23:52.705140" level="INFO">${output_log} = 2026-06-06 03:23:30,197 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:23:30,198 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:23:30,198 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:23:52.690917" elapsed="0.014284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.706201" level="INFO">2026-06-06 03:23:30,197 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:23:30,198 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:23:30,198 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:23:30,198 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:23:30,198 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:23:30,199 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:23:30,203 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:23:30,203 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:23:30,203 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 1
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 1
2026-06-06 03:23:30,204 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 0]
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:23:30,204 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Length=53 (0x0035)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=24 (0x18)
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010440040047020641040000fbf0
2026-06-06 03:23:30,205 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010440040047020641040000fbf0'
2026-06-06 03:23:30,206 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010440040047020641040000fbf0
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:30,208 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:23:30,209 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 1
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.1.0')]
2026-06-06 03:23:30,209 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Length=60 (0x003c)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=37 (0x0025)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x800e2240044704c00002010000050015070000000000000001010203040001000105060708)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):     MP_REACH_NLRI: {'Identifier': 1, 'TunnelID': 1, 'LSPID': 1, 'IPv4TunnelSenderAddress': IPv4Address('1.2.3.4'), 'IPv4TunnelEndPointAddress': IPv4Address('5.6.7.8')}
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:23:30,210 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff003c0200000025800e2240044704c00002010000050015070000000000000001010203040001000105060708
2026-06-06 03:23:30,210 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:23:30,210 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Number of iterations: 1
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 1
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0012874603271484375s
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:30,211 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:23:30,211 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:23:30,211 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:30,212 DEBUG BGP-Thread-1 (job):   Length=23 (0x0017)
2026-06-06 03:23:30,212 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:23:30,212 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:23:30,212 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:23:30,212 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:23:30,212 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:23:30,212 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:23:30,212 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:23:30,212 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:23:30,228 INFO BGP-Thread-1 (job): ... idle for 0.016s
2026-06-06 03:23:30,228 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.016s
2026-06-06 03:23:30,228 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:23:30,228 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:23:30,228 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:23:30,229 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:23:30,230 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0006' (6)
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'800f03400447'
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job): Attribute value=0xb'400447'
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'4004'
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'47'
2026-06-06 03:23:30,231 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb''
2026-06-06 03:23:30,232 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: []
2026-06-06 03:23:30,232 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:23:30,232 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:23:30,232 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:23:30,425 INFO BGP-Thread-1 (job): NOTIFICATION message received: 0xffffffffffffffffffffffffffffffff0015030301
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.705582" elapsed="0.001202"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:52.708019" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc1_bgp_peer.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc1_bgp_peer.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:23:52.707241" elapsed="0.000906"/>
</kw>
<arg>${BGP_PEER_LOG_FILE}</arg>
<arg>tc1_${BGP_PEER_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:52.690471" elapsed="0.017815"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.711864" elapsed="0.000059"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.710337" elapsed="0.001672"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.710291" elapsed="0.001777"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:52.712426" elapsed="0.000819"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.718885" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:52.718445" elapsed="0.000468"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:52.719142" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:23:52.718989" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.718970" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.719390" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.719571" elapsed="0.000020"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.719769" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.719945" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.720118" elapsed="0.000020"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.720293" elapsed="0.000020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.720463" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:52.718126" elapsed="0.002414"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.709851" elapsed="0.010740"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:52.708969" elapsed="0.011664"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:50.591490" elapsed="2.129200"/>
</test>
<test id="s1-s11-t6" name="TC1_Deconfigure_iBGP_Peer" line="103">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:52.724663" elapsed="0.000296"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:52.724377" elapsed="0.000643"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.726057" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.725938" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.725918" elapsed="0.000209"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.731315" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.731192" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.731174" elapsed="0.000209"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.732414" 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-06-06T03:23:52.732027" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.732929" 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-06-06T03:23:52.732607" elapsed="0.000348"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:52.733043" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:23:52.733202" 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-06-06T03:23:52.731617" elapsed="0.001610"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:52.740119" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.739991" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.739968" elapsed="0.000224"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:52.741493" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.741385" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.741367" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:52.742132" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:52.741810" elapsed="0.000350"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:52.742565" level="INFO">${current_connection_index} = 7</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-06-06T03:23:52.742346" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:52.774444" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:52.743125" elapsed="0.031594"/>
</kw>
<msg time="2026-06-06T03:23:52.775098" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:52.775203" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:52.742776" elapsed="0.032510"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:52.797585" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:52.776543" elapsed="0.021159"/>
</kw>
<msg time="2026-06-06T03:23:52.797864" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:52.797910" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "...</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-06-06T03:23:52.775731" elapsed="0.022216"/>
</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-06-06T03:23:52.798259" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.798027" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.798004" elapsed="0.000335"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.798810" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:52.798489" elapsed="0.000388"/>
</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-06-06T03:23:52.799169" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.798945" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.798925" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:52.799281" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:52.802127" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:23:52.802333" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:52.800838" elapsed="0.001629"/>
</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="NOT RUN" start="2026-06-06T03:23:52.802768" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.803338" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:52.800145" elapsed="0.003381"/>
</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-06-06T03:23:52.799579" elapsed="0.004013"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:52.741080" elapsed="0.062695"/>
</kw>
<msg time="2026-06-06T03:23:52.803870" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:52.803915" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:52.740382" elapsed="0.063572"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:52.804140" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:52.804032" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.804012" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.804671" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.805017" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.805089" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:52.739557" elapsed="0.065640"/>
</kw>
<msg time="2026-06-06T03:23:52.805291" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:52.805335" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "1 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:52.733608" elapsed="0.071764"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.805724" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.805448" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.805431" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:52.733457" elapsed="0.072373"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:52.733282" elapsed="0.072581"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:52.730820" elapsed="0.075099"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:52.725626" elapsed="0.080349"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:52.725187" elapsed="0.080833"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:52.721791" elapsed="0.084280"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.806859" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.806261" elapsed="0.000627"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.851252" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:52.850870" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:52.852120" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:52.851810" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:52.852294" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:52.851451" elapsed="0.000868"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.852909" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:52.852509" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:52.853243" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:52.853475" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:52.853104" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.853932" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.853681" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.854963" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.854703" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.855431" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.855171" elapsed="0.000285"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.856140" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:52.855844" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:52.857011" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.856758" elapsed="0.000279"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:52.857090" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:23:52.857246" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:52.856358" elapsed="0.000913"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.857434" elapsed="0.000270"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:23:52.855702" elapsed="0.002044"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.858310" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:52.857998" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:52.859259" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.858875" elapsed="0.000412"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:52.859339" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:52.859493" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:52.858526" elapsed="0.000993"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.859696" elapsed="0.000227"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:23:52.857859" elapsed="0.002106"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.860541" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:52.860219" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:52.861311" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.861101" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:52.861387" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:52.861536" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:52.860777" elapsed="0.000784"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.861735" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:23:52.860080" elapsed="0.001920"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.862549" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:52.862252" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:52.863337" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.863125" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:52.863413" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:52.863563" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:52.862782" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:52.863769" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:52.862111" elapsed="0.001971"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:52.855508" elapsed="0.008611"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:52.864162" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:52.864323" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:52.854357" elapsed="0.009993"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.854052" elapsed="0.010330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.864607" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.864446" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.854032" elapsed="0.010671"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.865474" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:52.864854" elapsed="0.000649"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:52.865553" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:52.850228" elapsed="0.015470"/>
</kw>
<msg time="2026-06-06T03:23:52.865754" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:52.837228" elapsed="0.028574"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.878576" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.891220" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.903946" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.904148" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.904355" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.904741" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.904576" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:52.904561" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.904966" elapsed="0.000019"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.905136" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.905305" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:52.904532" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.904432" elapsed="0.001012"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.905605" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.905703" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:23:52.905828" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:52.832774" elapsed="0.073081"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.906976" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.906726" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:52.920172" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:52.920234" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:52.920328" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:52.909404" elapsed="0.010950"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.907089" elapsed="0.013307"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.920582" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.920422" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.907071" elapsed="0.013616"/>
</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-06-06T03:23:52.925374" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.921979" elapsed="0.003456"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.921661" elapsed="0.003823"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.921616" elapsed="0.003903"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.931212" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:52.925935" elapsed="0.005385"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.925597" elapsed="0.005801"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.925573" elapsed="0.005881"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.932862" 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-06-06T03:23:52.931918" elapsed="0.001005"/>
</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-06-06T03:23:52.933636" elapsed="0.000077"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.933085" elapsed="0.000707"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.934923" 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-06-06T03:23:52.934225" elapsed="0.000754"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.933847" elapsed="0.001210"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.933043" elapsed="0.002059"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.936321" 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-06-06T03:23:52.935463" elapsed="0.000916"/>
</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-06-06T03:23:52.937098" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.936532" elapsed="0.000690"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.938316" 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-06-06T03:23:52.937667" elapsed="0.000803"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.937274" elapsed="0.001282"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.936492" elapsed="0.002111"/>
</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-06-06T03:23:52.938985" elapsed="0.000802"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:52.940871" 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-06-06T03:23:52.940219" elapsed="0.000711"/>
</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-06-06T03:23:52.941144" elapsed="0.002369"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:23:52.921073" elapsed="0.022504"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:52.943624" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:23:52.946004" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:23:52.906125" elapsed="0.039910"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:52.946092" elapsed="0.000029"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:23:52.807130" elapsed="0.139088"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.947556" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:52.947162" elapsed="0.000456"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.947143" elapsed="0.000514"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:52.947814" elapsed="0.000317"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.954914" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:52.954480" elapsed="0.000462"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:52.955161" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:52.955018" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.955000" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.955400" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.955579" elapsed="0.000020"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.955774" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.955947" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.956132" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.956306" elapsed="0.000019"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:52.956475" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:52.954160" elapsed="0.002391"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:52.946937" elapsed="0.009664"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:52.946524" elapsed="0.010133"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:23:52.721218" elapsed="0.235478"/>
</test>
<test id="s1-s11-t7" name="TC2_Configure_iBGP_Peer" line="115">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:52.960138" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:52.959808" elapsed="0.000600"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.961428" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.961317" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.961297" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:52.966572" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.966466" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.966447" elapsed="0.000207"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.967666" 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-06-06T03:23:52.967268" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:52.968169" 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-06-06T03:23:52.967860" elapsed="0.000336"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:52.968240" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:52.968395" 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-06-06T03:23:52.966888" elapsed="0.001532"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:52.974206" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.974096" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.974077" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:52.975472" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:52.975364" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:52.975346" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:52.976017" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:52.975716" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:52.976465" level="INFO">${current_connection_index} = 7</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-06-06T03:23:52.976237" elapsed="0.000254"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.007544" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:52.977016" elapsed="0.030657"/>
</kw>
<msg time="2026-06-06T03:23:53.007840" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:53.007886" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:52.976673" elapsed="0.031249"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.028927" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:53.008480" elapsed="0.020569"/>
</kw>
<msg time="2026-06-06T03:23:53.029222" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:53.029267" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "...</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-06-06T03:23:53.008130" elapsed="0.021174"/>
</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-06-06T03:23:53.029675" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.029396" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.029368" elapsed="0.000392"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.030241" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:53.029916" elapsed="0.000392"/>
</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-06-06T03:23:53.030600" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.030375" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.030356" elapsed="0.000397"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:53.030792" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:53.033466" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:23:53.033707" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.032364" elapsed="0.001479"/>
</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="NOT RUN" start="2026-06-06T03:23:53.034124" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.034467" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:53.031690" elapsed="0.002983"/>
</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-06-06T03:23:53.031110" elapsed="0.003631"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:52.975061" elapsed="0.059779"/>
</kw>
<msg time="2026-06-06T03:23:53.034936" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:53.034981" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:52.974438" elapsed="0.060582"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:53.035206" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:53.035097" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.035078" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.035714" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.036090" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.036162" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:52.973754" elapsed="0.062518"/>
</kw>
<msg time="2026-06-06T03:23:53.036366" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:53.036411" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:52.968817" elapsed="0.067633"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.036799" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.036527" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.036509" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:52.968667" elapsed="0.068234"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:52.968476" elapsed="0.068457"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:52.966103" elapsed="0.070886"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:52.961025" elapsed="0.076020"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:52.960572" elapsed="0.076518"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:52.957575" elapsed="0.079569"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.038100" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | RIB_INSTANCE_NAME=example-bgp-rib | PASSIVE_MODE=true | BGP_RIB_OPENC...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.037323" elapsed="0.000807"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.072992" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:53.072598" elapsed="0.000465"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:53.073840" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:53.073583" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:53.074012" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:53.073238" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.074596" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:53.074210" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:53.074949" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:53.075103" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:53.074811" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.075538" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.075292" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.076592" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.076332" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.077085" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.076823" elapsed="0.000288"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.077798" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.077484" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.078685" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.078446" elapsed="0.000267"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.078763" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:53.078914" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.078018" elapsed="0.000920"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.079098" elapsed="0.000242"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:23:53.077344" elapsed="0.002036"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.079967" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.079632" elapsed="0.000362"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.080893" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.080679" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.080969" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:53.081119" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.080189" elapsed="0.000955"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.081303" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:23:53.079492" elapsed="0.002078"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.082139" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.081841" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.082907" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.082695" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.083022" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:53.083175" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.082355" elapsed="0.000844"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.083358" elapsed="0.000221"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:23:53.081700" elapsed="0.001920"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.084215" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.083917" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.084980" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.084768" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.085055" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:53.085203" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.084432" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.085383" elapsed="0.000219"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:23:53.083776" elapsed="0.001884"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.086212" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.085912" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.086972" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.086762" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.087047" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:53.087194" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.086426" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.087373" elapsed="0.000225"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:23:53.085774" elapsed="0.001878"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.088213" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.087918" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.088976" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.088766" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.089052" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:53.089199" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.088427" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.089378" elapsed="0.000219"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:23:53.087780" elapsed="0.001872"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.090197" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.089902" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.090958" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.090748" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.091033" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:53.091180" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.090411" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.091359" elapsed="0.000219"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:53.089765" elapsed="0.001854"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.092396" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.092091" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.093161" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.092951" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.093273" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:53.093427" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.092613" elapsed="0.000839"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.093609" elapsed="0.000238"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:23:53.091762" elapsed="0.002126"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.094430" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:23:53.094136" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:23:53.095194" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.094981" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:23:53.095268" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:23:53.095416" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:23:53.094657" elapsed="0.000783"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:23:53.095595" elapsed="0.000260"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:23:53.093999" elapsed="0.001898"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:23:53.077161" elapsed="0.018770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:23:53.095974" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:23:53.096132" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'PASSI...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:23:53.075996" elapsed="0.020162"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.075664" elapsed="0.020525"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.096369" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.096214" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.075630" elapsed="0.020813"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.097313" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:53.096591" elapsed="0.000751"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:53.097391" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:53.071972" elapsed="0.025541"/>
</kw>
<msg time="2026-06-06T03:23:53.097567" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.058881" elapsed="0.038733"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.110503" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.123258" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.136031" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.136270" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.136456" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.136846" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.136693" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:53.136678" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.137072" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.137244" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.137415" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:53.136634" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.136533" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.137661" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.137740" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:23:53.137864" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:53.054472" elapsed="0.083418"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.165378" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:53.164989" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:53.166186" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:53.165947" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:53.166355" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:53.165583" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.166953" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:53.166551" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:23:53.167296" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:23:53.167456" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:23:53.167147" elapsed="0.000368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.167985" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.167703" elapsed="0.000414"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:23:53.168533" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.168200" elapsed="0.000407"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.169112" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'PASSI...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:53.168811" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.168635" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.168177" elapsed="0.001021"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.170152" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:53.169353" elapsed="0.000830"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:23:53.170237" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:23:53.164332" elapsed="0.006036"/>
</kw>
<msg time="2026-06-06T03:23:53.170429" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.151223" elapsed="0.019255"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.183230" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.196034" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.209011" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.209217" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.209402" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.209799" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.209632" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:23:53.209617" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.210027" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.210201" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.210372" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:23:53.209588" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.209480" elapsed="0.000970"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.210654" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.210734" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:53.210868" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:23:53.148500" elapsed="0.062396"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:23:53.212246" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:23:53.211962" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:23:53.212405" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:53.211588" elapsed="0.000841"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.212769" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.212500" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.213330" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:53.213039" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.212851" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.212481" elapsed="0.000930"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.215873" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:23:53.213568" elapsed="0.002332"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:23:53.215951" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:23:53.216105" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:23:53.211235" elapsed="0.004894"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.217514" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.217268" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.217972" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.217733" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.218435" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.218193" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.218887" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.218632" elapsed="0.000298"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:53.219792" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:23:53.219567" elapsed="0.000251"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:23:53.220154" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:23:53.219980" elapsed="0.000199"/>
</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-06-06T03:23:53.220369" elapsed="0.000211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.221007" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.220757" elapsed="0.000294"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:23:53.221093" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:53.221248" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:23:53.219137" elapsed="0.002135"/>
</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-06-06T03:23:53.240475" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Content-Length': '1079', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
            &lt;connect-retry&gt;5&lt;/connect-retry&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:23:53.240561" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:53.240713" 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-06-06T03:23:53.223866" elapsed="0.016875"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.221342" elapsed="0.019448"/>
</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-06-06T03:23:53.240981" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.240818" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.221324" elapsed="0.019745"/>
</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-06-06T03:23:53.245218" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.242069" elapsed="0.003245"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.241835" elapsed="0.003559"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.241814" elapsed="0.003635"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.251700" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.246120" elapsed="0.005728"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.245574" elapsed="0.006407"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.245536" elapsed="0.006529"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.253543" 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-06-06T03:23:53.252472" elapsed="0.001133"/>
</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-06-06T03:23:53.254357" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.253800" elapsed="0.000687"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.255736" 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-06-06T03:23:53.254950" elapsed="0.000847"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.254540" elapsed="0.001338"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.253756" elapsed="0.002169"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.256583" 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-06-06T03:23:53.256192" elapsed="0.000419"/>
</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-06-06T03:23:53.256958" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.256700" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.257601" 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-06-06T03:23:53.257289" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.257092" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.256680" elapsed="0.001022"/>
</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-06-06T03:23:53.257864" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:23:53.258752" 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-06-06T03:23:53.258406" elapsed="0.000378"/>
</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-06-06T03:23:53.258978" elapsed="0.002500"/>
</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-06-06T03:23:53.241452" elapsed="0.020091"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:23:53.261738" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:23:53.261612" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.261592" elapsed="0.000238"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:23:53.261986" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.262060" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:23:53.264538" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:23:53.216464" elapsed="0.048102"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:53.264632" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:23:53.264811" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:23:53.043257" elapsed="0.221579"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.265185" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.264937" elapsed="0.000340"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.264919" elapsed="0.000393"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:23:53.265357" elapsed="0.000030"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:23:53.038408" elapsed="0.227084"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.266789" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.266387" elapsed="0.000465"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.266369" elapsed="0.000508"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.267031" elapsed="0.000396"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.272759" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:53.272327" elapsed="0.000460"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:53.273005" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:23:53.272862" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.272843" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.273243" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.273423" elapsed="0.000020"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.273602" elapsed="0.000068"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.273832" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.274006" elapsed="0.000020"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.274180" elapsed="0.000021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.274351" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:53.272010" elapsed="0.002416"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.266179" elapsed="0.008297"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:53.265803" elapsed="0.008714"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:23:52.957030" elapsed="0.317525"/>
</test>
<test id="s1-s11-t8" name="TC2_Check_Example_Bgp_Rib_Is_Empty" line="132">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:53.277955" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:53.277683" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.279251" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.279120" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.279101" elapsed="0.000219"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.284413" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.284306" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.284288" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.285491" 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-06-06T03:23:53.285111" elapsed="0.000407"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.285994" 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-06-06T03:23:53.285700" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:53.286064" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:53.286217" 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-06-06T03:23:53.284728" elapsed="0.001513"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:53.292104" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.291995" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.291975" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:53.293361" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.293230" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.293211" elapsed="0.000220"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:53.293902" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:53.293582" elapsed="0.000347"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.294321" level="INFO">${current_connection_index} = 7</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-06-06T03:23:53.294102" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.324880" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:53.294873" elapsed="0.030162"/>
</kw>
<msg time="2026-06-06T03:23:53.325234" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:53.325281" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:53.294512" elapsed="0.030806"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.350344" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:23:53.326064" elapsed="0.024389"/>
</kw>
<msg time="2026-06-06T03:23:53.350614" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:53.350682" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</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-06-06T03:23:53.325629" elapsed="0.025092"/>
</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-06-06T03:23:53.351086" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.350812" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.350787" elapsed="0.000381"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.351628" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "_ "I "s "_ "E "m "p "t "y "[K"
[?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-06-06T03:23:53.351323" elapsed="0.000393"/>
</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-06-06T03:23:53.352008" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.351784" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.351766" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:53.352124" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:53.355012" elapsed="0.000159"/>
</kw>
<msg time="2026-06-06T03:23:53.355239" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.353842" elapsed="0.001533"/>
</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="NOT RUN" start="2026-06-06T03:23:53.355685" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.356031" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:53.353033" elapsed="0.003184"/>
</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-06-06T03:23:53.352451" elapsed="0.003830"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:53.292924" elapsed="0.063455"/>
</kw>
<msg time="2026-06-06T03:23:53.356473" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:53.356518" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:53.292329" elapsed="0.064228"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:53.356762" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:23:53.356634" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.356615" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.357275" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.357622" elapsed="0.000040"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.357711" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:53.291649" elapsed="0.066173"/>
</kw>
<msg time="2026-06-06T03:23:53.357916" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:53.357960" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:53.286622" elapsed="0.071376"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.358338" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.358073" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.358056" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:53.286473" elapsed="0.072003"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:53.286299" elapsed="0.072213"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:53.283941" elapsed="0.074635"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:53.278829" elapsed="0.079806"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:53.278378" elapsed="0.080320"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:53.275477" elapsed="0.083275"/>
</kw>
<kw name="Check_Example_Bgp_Rib_Does_Not_Contain" owner="BgpOperations">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:23:53.366328" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:23:53.366843" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:23:53.367090" level="INFO">${response} = &lt;Response [200]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>url=${REST_API}/${BGP_RIB_URI}?content=nonconfig</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:23:53.359508" elapsed="0.007610"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.370067" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.367299" elapsed="0.002815"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.373473" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":true}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.370282" elapsed="0.003452"/>
</kw>
<kw name="Should Not Contain" owner="BuiltIn">
<arg>${response.text}</arg>
<arg>${substr}</arg>
<arg>${error_message}</arg>
<arg>values=False</arg>
<doc>Fails if ``container`` contains ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:23:53.373965" elapsed="0.004136"/>
</kw>
<arg>${CONFIG_SESSION}</arg>
<arg>${JSONKEYSTR}</arg>
<doc>Check the example-bgp-rib does not contain the string</doc>
<status status="PASS" start="2026-06-06T03:23:53.359024" elapsed="0.019172"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.380046" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.379477" elapsed="0.000658"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.379447" elapsed="0.000724"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.380390" elapsed="0.000477"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.386990" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:23:53.386534" elapsed="0.000484"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:23:53.387240" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:23:53.387095" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.387075" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.387487" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.387685" elapsed="0.000023"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.387868" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.388038" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.388209" elapsed="0.000020"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.388380" elapsed="0.000019"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.388553" elapsed="0.000020"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:23:53.386217" elapsed="0.002413"/>
</kw>
<status status="PASS" start="2026-06-06T03:23:53.379174" elapsed="0.009523"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:23:53.378594" elapsed="0.010143"/>
</kw>
<doc>Check RIB for none linkstate-routes</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:53.274910" elapsed="0.113866"/>
</test>
<test id="s1-s11-t9" name="TC2_Connect_BGP_Peer" line="137">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:23:53.392139" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:23:53.391866" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.393415" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.393304" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.393284" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.398778" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.398669" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.398638" elapsed="0.000238"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.399892" 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-06-06T03:23:53.399494" elapsed="0.000425"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.400380" 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-06-06T03:23:53.400086" elapsed="0.000319"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:23:53.400449" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:23:53.400602" 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-06-06T03:23:53.399111" elapsed="0.001569"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:23:53.406298" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.406189" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.406170" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:23:53.407572" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:23:53.407466" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.407448" elapsed="0.000215"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:23:53.408126" level="INFO">${karaf_connection_index} = 9</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-06-06T03:23:53.407820" elapsed="0.000333"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.408542" level="INFO">${current_connection_index} = 7</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-06-06T03:23:53.408325" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.440753" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:53.409094" elapsed="0.031876"/>
</kw>
<msg time="2026-06-06T03:23:53.441200" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:23:53.441247" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:23:53.408751" elapsed="0.032534"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.462851" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:53.442037" elapsed="0.020930"/>
</kw>
<msg time="2026-06-06T03:23:53.463134" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:23:53.463180" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "...</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-06-06T03:23:53.441544" elapsed="0.021673"/>
</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-06-06T03:23:53.463594" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.463319" elapsed="0.000361"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.463289" elapsed="0.000422"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.464189" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:23:53.463866" elapsed="0.000389"/>
</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-06-06T03:23:53.464548" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.464323" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.464303" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:23:53.464680" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:23:53.467414" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:23:53.467625" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:23:53.466271" elapsed="0.001510"/>
</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="NOT RUN" start="2026-06-06T03:23:53.468071" elapsed="0.001701"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.470061" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:23:53.465597" elapsed="0.004655"/>
</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-06-06T03:23:53.465019" elapsed="0.005300"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:23:53.407164" elapsed="0.063254"/>
</kw>
<msg time="2026-06-06T03:23:53.470576" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:53.470657" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:53.406524" elapsed="0.064175"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:23:53.470893" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:23:53.470782" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.470760" elapsed="0.000245"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.471434" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.471798" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:23:53.471872" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:23:53.405851" elapsed="0.066128"/>
</kw>
<msg time="2026-06-06T03:23:53.472072" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:23:53.472125" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:23:53.401072" elapsed="0.071102"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:23:53.472525" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:23:53.472263" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:23:53.472245" elapsed="0.000358"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:23:53.400921" elapsed="0.071705"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:23:53.400742" elapsed="0.071932"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:23:53.398292" elapsed="0.074439"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:23:53.393014" elapsed="0.079771"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:23:53.392559" elapsed="0.080270"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:23:53.389612" elapsed="0.083268"/>
</kw>
<kw name="Start_Console_Tool" owner="BGPcliKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.481945" level="INFO">${start_cmd} = python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True &amp;&gt;bgp_peer.log</msg>
<var>${start_cmd}</var>
<arg>${command} ${tool_opt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:23:53.481476" elapsed="0.000498"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.482392" level="INFO">python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True &amp;&gt;bgp_peer.log</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.482142" elapsed="0.000296"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:23:53.486616" level="INFO">python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True &amp;&gt;bgp_peer.log</msg>
<msg time="2026-06-06T03:23:53.486733" level="INFO">${output} = python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True &amp;&gt;bgp_peer.log
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:23:53.482619" elapsed="0.004143"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:23:53.487184" level="INFO">python3 play.py --amount 1 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --logfile bgp_peer.log --bgpls True &amp;&gt;bgp_peer.log
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:23:53.486932" elapsed="0.000299"/>
</kw>
<arg>${BGP_PEER_COMMAND}</arg>
<arg>${BGP_PEER_OPTIONS}</arg>
<doc>Start the tool ${command} ${tool_opt}</doc>
<status status="PASS" start="2026-06-06T03:23:53.481049" elapsed="0.006237"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:03.489436" level="FAIL">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:23:53.488929" elapsed="10.001299">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.490575" elapsed="0.000033"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:23:53.488638" elapsed="10.002101">No match found for '&gt;' in 10 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:23:53.488229" elapsed="10.002734"/>
</kw>
<msg time="2026-06-06T03:24:03.491088" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:23:53.487859" elapsed="10.003256"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:24:03.491306" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:24:03.491209" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.491182" elapsed="0.000211"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.491632" elapsed="0.000042"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.491832" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:23:53.487559" elapsed="10.004355"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.493324" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.492890" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.492872" elapsed="0.000543"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:03.493578" elapsed="0.000392"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.499504" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:03.499076" elapsed="0.000456"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:24:03.499773" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:03.499609" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.499590" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.500013" elapsed="0.000023"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.500205" elapsed="0.000021"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.500389" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.500565" elapsed="0.000020"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.500756" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.500949" elapsed="0.000021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.501122" elapsed="0.000026"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:24:03.498753" elapsed="0.002463"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:03.492676" elapsed="0.008593"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:24:03.492211" elapsed="0.009101"/>
</kw>
<doc>Connect BGP peer</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:23:53.389116" elapsed="10.112234"/>
</test>
<test id="s1-s11-t10" name="TC2_Check_Example_Bgp_Rib" line="143">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:03.505108" elapsed="0.000221"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:03.504806" elapsed="0.000587"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.506479" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:03.506359" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.506333" elapsed="0.000216"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.511853" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:03.511677" elapsed="0.000260"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.511655" elapsed="0.000310"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.513076" 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-06-06T03:24:03.512629" elapsed="0.000476"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.513596" 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-06-06T03:24:03.513289" elapsed="0.000334"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:03.513689" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:03.513851" 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-06-06T03:24:03.512228" elapsed="0.001649"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:03.519855" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:03.519744" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.519724" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:03.521205" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:03.521088" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.521069" elapsed="0.000206"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:03.521777" level="INFO">${karaf_connection_index} = 9</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-06-06T03:24:03.521436" elapsed="0.000368"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:03.522201" level="INFO">${current_connection_index} = 7</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-06-06T03:24:03.521975" elapsed="0.000253"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:03.553149" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:03.522792" elapsed="0.030503"/>
</kw>
<msg time="2026-06-06T03:24:03.553491" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:03.553540" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:03.522398" elapsed="0.031179"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:03.575390" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "[K"
[?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-06-06T03:24:03.554241" elapsed="0.021263"/>
</kw>
<msg time="2026-06-06T03:24:03.575694" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:03.575741" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</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-06-06T03:24:03.553828" elapsed="0.021949"/>
</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-06-06T03:24:03.576124" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.575868" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.575843" elapsed="0.000381"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.576709" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "p "_ "R "i "b "[K"
[?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-06-06T03:24:03.576382" elapsed="0.000398"/>
</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-06-06T03:24:03.577170" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.576900" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.576877" elapsed="0.000382"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:03.577295" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:03.579951" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:24:03.580162" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:03.578847" elapsed="0.001447"/>
</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="NOT RUN" start="2026-06-06T03:24:03.580631" elapsed="0.000104"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.581023" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:03.578183" elapsed="0.003027"/>
</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-06-06T03:24:03.577608" elapsed="0.003667"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:03.520748" elapsed="0.060627"/>
</kw>
<msg time="2026-06-06T03:24:03.581475" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:03.581521" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:03.520094" elapsed="0.061465"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:03.581768" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:03.581656" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.581619" elapsed="0.000235"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.582266" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.582616" elapsed="0.000049"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.582717" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:03.519354" elapsed="0.063474"/>
</kw>
<msg time="2026-06-06T03:24:03.582925" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:03.582970" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "C "h "e "c "k "_ "E "x "a "m "p "l "e "_ "B "g "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:03.514278" elapsed="0.068730"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.583347" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.583086" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.583068" elapsed="0.000362"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:03.514114" elapsed="0.069341"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:03.513935" elapsed="0.069553"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:03.511286" elapsed="0.072258"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:03.506035" elapsed="0.077566"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:03.505560" elapsed="0.078105"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:03.502368" elapsed="0.081353"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.584360" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | ROUTE_KEY=AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA== }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>ROUTE_KEY=${ROUTE_KEY}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:03.583900" elapsed="0.000489"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.636194" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:03.635817" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:03.637086" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:03.636798" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:03.637259" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:03.636393" elapsed="0.000891"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.637902" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:03.637496" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:03.638239" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:03.638404" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:03.638101" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.638864" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:03.638597" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.639889" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:03.639611" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.640369" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:03.640101" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.641156" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:03.640823" elapsed="0.000363"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:03.642101" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:03.641761" elapsed="0.000366"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:03.642178" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:03.642329" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:03.641382" elapsed="0.000972"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:03.642513" elapsed="0.000309"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:03.640634" elapsed="0.002229"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.643432" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:03.643113" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:03.644500" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:03.644165" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:03.644579" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:03.644758" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:03.643816" elapsed="0.000970"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:03.644964" elapsed="0.000273"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:03.642975" elapsed="0.002305"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:03.640459" elapsed="0.004856"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:03.645356" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:24:03.645511" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:03.639279" elapsed="0.006257"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:03.638979" elapsed="0.006590"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.645765" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.645593" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.638960" elapsed="0.006882"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.646576" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:03.645993" elapsed="0.000612"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:03.646680" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:03.635176" elapsed="0.011632"/>
</kw>
<msg time="2026-06-06T03:24:03.646899" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:03.622161" elapsed="0.024786"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.659765" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.672493" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.685348" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.685552" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.685749" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.686120" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.685969" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:03.685953" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.686351" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.686526" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.686714" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:03.685925" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.685825" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.686947" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.687023" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:03.687143" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:03.617753" elapsed="0.069416"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:03.688428" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:03.688187" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:03.688585" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:03.687842" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.689019" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.688759" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.689576" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:03.689281" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:03.689101" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.688738" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.692234" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:03.689838" elapsed="0.002422"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:03.692312" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:03.692465" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:03.687494" elapsed="0.004995"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:03.693760" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:03.693504" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:03.693916" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:03.693162" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:03.694146" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:03.694010" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:03.693991" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.694380" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.694559" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.694624" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:03.696609" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:03.692830" elapsed="0.003806"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.698060" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:03.697811" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:03.698514" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:03.698266" elapsed="0.000290"/>
</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-06-06T03:24:03.707508" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:03.707671" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:03.707783" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:03.700819" elapsed="0.007345">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:03.698621" elapsed="0.009625">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:03.708481" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.708310" elapsed="0.000237"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:03.698603" elapsed="0.009968">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:03.708980" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.709113" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:03.709075" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:03.709057" elapsed="0.000120"/>
</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-06-06T03:24:03.709328" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.709398" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:03.696977" elapsed="0.012524">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.709576" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:03.593971" elapsed="0.115715">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:03.709969" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:03.709782" elapsed="0.000260"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:03.709765" elapsed="0.000301"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:03.710100" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:03.589389" elapsed="0.120806">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.767343" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:04.766921" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:04.768321" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:04.768056" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:04.768494" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:04.767567" elapsed="0.000953"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.769103" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:04.768709" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:04.769443" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:04.769705" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:04.769300" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.770154" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:04.769902" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.771262" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:04.771005" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.771805" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:04.771473" elapsed="0.000358"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.772562" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:04.772210" elapsed="0.000378"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:04.773518" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:04.773168" elapsed="0.000376"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:04.773599" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:24:04.773796" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:04.772816" elapsed="0.001005"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:04.773983" elapsed="0.000289"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:04.772064" elapsed="0.002250"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.774907" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:04.774567" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:04.776036" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:04.775697" elapsed="0.000367"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:04.776114" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:04.776267" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:04.775311" elapsed="0.000981"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:04.776451" elapsed="0.000286"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:04.774427" elapsed="0.002351"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:04.771888" elapsed="0.004925"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:04.776857" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:24:04.777011" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:04.770664" elapsed="0.006373"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:04.770282" elapsed="0.006786"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.777250" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:04.777094" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:04.770257" elapsed="0.007068"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.778099" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:04.777475" elapsed="0.000653"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:04.778177" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:04.766194" elapsed="0.012106"/>
</kw>
<msg time="2026-06-06T03:24:04.778356" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:04.753068" elapsed="0.025385"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.791532" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.804596" elapsed="0.000068"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.817458" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.817739" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.817937" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.818370" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:04.818210" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:04.818191" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.818603" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.818803" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.818976" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:04.818151" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.818022" elapsed="0.001032"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.819209" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.819288" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:04.819453" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:04.748485" elapsed="0.070997"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:04.821035" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:04.820740" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:04.821204" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:04.820273" elapsed="0.000956"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.821660" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:04.821301" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.822239" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:04.821940" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:04.821746" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:04.821282" elapsed="0.001041"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.824986" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:04.822484" elapsed="0.002530"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:04.825067" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:04.825226" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:04.819899" elapsed="0.005352"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:04.826517" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:04.826262" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:04.826691" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:04.825915" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:04.826926" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:04.826790" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:04.826771" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.827163" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.827343" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.827409" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:04.829399" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:04.825562" elapsed="0.003864"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.830864" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:04.830592" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:04.831316" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:04.831072" elapsed="0.000288"/>
</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-06-06T03:24:04.840006" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:04.840144" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:04.840241" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:04.833751" elapsed="0.006856">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:04.831425" elapsed="0.009292">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:04.840959" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:04.840793" elapsed="0.000232"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:04.831407" elapsed="0.009641">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:04.841439" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.841572" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:04.841535" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:04.841517" elapsed="0.000118"/>
</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-06-06T03:24:04.841803" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.841874" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:04.829761" elapsed="0.012216">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.842053" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:04.725196" elapsed="0.116954">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:04.842434" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:04.842245" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:04.842227" elapsed="0.000304"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:04.842564" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:04.720431" elapsed="0.122245">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.901799" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:05.901271" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:05.902818" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:05.902452" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:05.902994" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:05.902062" elapsed="0.000957"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.903594" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:05.903204" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:05.903951" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:05.904185" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:05.903806" elapsed="0.000406"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.904627" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:05.904376" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.905736" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:05.905450" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.906219" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:05.905947" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.907035" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:05.906682" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:05.907999" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:05.907615" elapsed="0.000410"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:05.908080" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:05.908241" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:05.907257" elapsed="0.001008"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:05.908427" elapsed="0.000309"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:05.906481" elapsed="0.002296"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.909537" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:05.909027" elapsed="0.000537"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:05.910456" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:05.910119" elapsed="0.000363"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:05.910548" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:05.910716" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:05.909775" elapsed="0.000966"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:05.910899" elapsed="0.000269"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:05.908890" elapsed="0.002321"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:05.906302" elapsed="0.004944"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:05.911289" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:24:05.911443" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:05.905121" elapsed="0.006348"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:05.904773" elapsed="0.006728"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.911702" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:05.911526" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:05.904747" elapsed="0.007033"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.912544" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:05.911933" elapsed="0.000640"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:05.912623" elapsed="0.000050"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:05.900591" elapsed="0.012179"/>
</kw>
<msg time="2026-06-06T03:24:05.912826" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:05.887296" elapsed="0.025620"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.925729" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.938540" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.951419" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.951669" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.951869" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.952303" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:05.952141" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:05.952122" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.952541" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.952729" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.952903" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:05.952079" elapsed="0.000877"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.951955" elapsed="0.001029"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.953138" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.953216" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:24:05.953377" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:05.882535" elapsed="0.070871"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:05.954966" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:05.954626" elapsed="0.000419">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:05.955141" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:05.954149" elapsed="0.001016"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.955584" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:05.955236" elapsed="0.000424"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.956180" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:05.955882" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:05.955687" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:05.955217" elapsed="0.001046"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.958908" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:05.956423" elapsed="0.002513"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:05.958990" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:05.959149" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:05.953768" elapsed="0.005406"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:05.960406" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:05.960175" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:05.960562" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:05.959832" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:05.960811" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:05.960674" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:05.960653" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.961046" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.961224" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.961288" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:24:05.963304" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:05.959484" elapsed="0.003846"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.964772" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:05.964500" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:05.965226" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:05.964983" elapsed="0.000286"/>
</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-06-06T03:24:05.973446" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:05.973589" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:05.973712" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:05.967493" elapsed="0.006596">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:05.965334" elapsed="0.008838">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:05.974422" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:05.974254" elapsed="0.000266"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:05.965316" elapsed="0.009228">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:05.974942" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.975075" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:05.975037" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:05.975020" elapsed="0.000119"/>
</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-06-06T03:24:05.975289" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.975365" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:05.963658" elapsed="0.011810">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.975542" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:05.858244" elapsed="0.117392">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:05.975933" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:05.975746" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:05.975729" elapsed="0.000298"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:05.976060" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:05.851196" elapsed="0.124960">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.034446" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:07.034033" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:07.035295" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:07.035039" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:07.035465" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:07.034683" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.036075" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:07.035683" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:07.036414" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:07.036656" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:07.036272" elapsed="0.000414"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.037104" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:07.036853" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.038198" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:07.037938" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.038733" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:07.038432" elapsed="0.000328"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.039498" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:07.039146" elapsed="0.000380"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:07.040463" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:07.040119" elapsed="0.000371"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:07.040544" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:07.040724" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:07.039768" elapsed="0.000981"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:07.040911" elapsed="0.000290"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:07.038992" elapsed="0.002249"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.041861" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:07.041509" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:07.094808" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:07.094390" elapsed="0.000454"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:07.094911" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:24:07.095085" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:07.093821" elapsed="0.001289"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:07.095273" elapsed="0.000293"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:07.041358" elapsed="0.054251"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:07.038815" elapsed="0.056852"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:07.095715" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:07.095877" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:07.037584" elapsed="0.058320"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:07.037230" elapsed="0.058707"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.096127" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:07.095965" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:07.037206" elapsed="0.058999"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.097047" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:07.096356" elapsed="0.000721"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:07.097126" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:07.033316" elapsed="0.063938"/>
</kw>
<msg time="2026-06-06T03:24:07.097316" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:07.020167" elapsed="0.077265"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.110540" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.123429" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.136385" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.136658" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.136860" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.137288" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:07.137128" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:07.137109" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.137550" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.137745" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.137921" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:07.137070" elapsed="0.000906"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.136945" elapsed="0.001058"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.138158" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.138239" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:07.138395" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:07.015680" elapsed="0.122744"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:07.139870" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:07.139564" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:07.140038" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:07.139157" elapsed="0.000906"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.140483" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:07.140136" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.141079" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:07.140777" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:07.140571" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:07.140117" elapsed="0.001048"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.143816" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:07.141327" elapsed="0.002517"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:07.143898" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:07.144058" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:07.138793" elapsed="0.005290"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:07.145346" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:07.145107" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:07.145521" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:07.144756" elapsed="0.000790"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:07.145771" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:07.145618" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:07.145599" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.146008" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.146186" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.146251" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:07.148256" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:07.144399" elapsed="0.003884"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.149909" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:07.149477" elapsed="0.000479"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:07.150360" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:07.150117" elapsed="0.000286"/>
</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-06-06T03:24:07.159400" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:07.159564" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:07.159764" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:07.152616" elapsed="0.007678">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:07.150470" elapsed="0.009945">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:07.160810" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:07.160541" elapsed="0.000369"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:07.150451" elapsed="0.010495">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:07.161547" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.161768" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:07.161710" elapsed="0.000122"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:07.161682" elapsed="0.000184"/>
</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-06-06T03:24:07.162094" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.162201" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:07.148602" elapsed="0.013754">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.162468" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:06.992099" elapsed="0.170509">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:07.163044" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:07.162768" elapsed="0.000383"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:07.162743" elapsed="0.000445"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:07.163236" elapsed="0.000022"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:06.987465" elapsed="0.175911">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.239930" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:08.239471" elapsed="0.000493"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:08.240809" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:08.240534" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:08.240982" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:08.240156" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.241573" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:08.241181" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:08.241935" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:08.242182" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:08.241790" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.242632" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:08.242380" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.243773" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:08.243491" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.244257" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:08.243988" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.245069" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:08.244714" elapsed="0.000382"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:08.246027" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:08.245675" elapsed="0.000379"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:08.246110" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:24:08.246274" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:08.245293" elapsed="0.001006"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:08.246461" elapsed="0.000309"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:08.244553" elapsed="0.002260"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.247572" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:08.247066" elapsed="0.000532"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:08.248507" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:08.248157" elapsed="0.000378"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:08.248586" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:08.248756" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:08.247811" elapsed="0.000970"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:08.248940" elapsed="0.000269"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:08.246927" elapsed="0.002325"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:08.244339" elapsed="0.004948"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:08.249329" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:08.249485" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:08.243152" elapsed="0.006359"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:08.242780" elapsed="0.006763"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.249746" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:08.249571" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:08.242755" elapsed="0.007069"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.250567" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:08.249976" elapsed="0.000620"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:08.250668" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:08.238708" elapsed="0.012088"/>
</kw>
<msg time="2026-06-06T03:24:08.250852" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:08.221533" elapsed="0.029408"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.263822" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.276658" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.289452" elapsed="0.000046"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.289761" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.289966" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.290425" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:08.290261" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:08.290242" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.290684" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.290863" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.291037" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:08.290198" elapsed="0.000891"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.290055" elapsed="0.001063"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.291271" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.291353" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:24:08.291522" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:08.211662" elapsed="0.079889"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:08.293058" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:08.292756" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:08.293229" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:08.292309" elapsed="0.000945"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.293701" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:08.293327" elapsed="0.000434"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.294277" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:08.293978" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:08.293786" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:08.293308" elapsed="0.001053"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.297022" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:08.294522" elapsed="0.002527"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:08.297104" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:08.297263" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:08.291935" elapsed="0.005353"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:08.298548" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:08.298299" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:08.298729" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:08.297956" elapsed="0.000797"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:08.298961" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:08.298825" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:08.298806" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.299198" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.299378" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.299442" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:08.301459" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:08.297602" elapsed="0.003884"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.302929" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:08.302669" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:08.303383" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:08.303138" elapsed="0.000289"/>
</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-06-06T03:24:08.312343" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:08.312634" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:08.312947" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:08.305755" elapsed="0.008058">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:08.303493" elapsed="0.010531">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:08.314735" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:08.314232" elapsed="0.000658"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:08.303474" elapsed="0.011469">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:08.315919" elapsed="0.000060"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.316234" elapsed="0.000033"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:08.316145" elapsed="0.000185"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:08.316102" elapsed="0.000277"/>
</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-06-06T03:24:08.316882" elapsed="0.000050"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.317045" elapsed="0.000035"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:08.301824" elapsed="0.015464">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.317460" elapsed="0.000034"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:08.179788" elapsed="0.137913">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:08.318397" elapsed="0.000074"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:08.317920" elapsed="0.000703"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:08.317879" elapsed="0.000867"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:08.318852" elapsed="0.000043"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:08.174193" elapsed="0.144934">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.385288" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:09.384673" elapsed="0.000664"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:09.386489" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:09.386139" elapsed="0.000450">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:09.386748" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:09.385607" elapsed="0.001175"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.387563" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:09.387042" elapsed="0.000561"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:09.388046" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:09.388358" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:09.387857" elapsed="0.000539"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.388991" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:09.388622" elapsed="0.000432"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.390285" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:09.389999" elapsed="0.000337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.390819" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:09.390513" elapsed="0.000333"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.391678" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:09.391265" elapsed="0.000443"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:09.392731" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:09.392340" elapsed="0.000419"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:09.392817" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:24:09.392989" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:09.391933" elapsed="0.001080"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:09.393209" elapsed="0.000316"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:09.391112" elapsed="0.002458"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.394478" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:09.393881" elapsed="0.000624"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:09.395599" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:09.395225" elapsed="0.000402"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:09.395700" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:24:09.395869" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:09.394758" elapsed="0.001137"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:09.396060" elapsed="0.000296"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:09.393717" elapsed="0.002684"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:09.390905" elapsed="0.005534"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:09.396485" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:09.396677" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:09.389598" elapsed="0.007109"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:09.389158" elapsed="0.007583"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.396938" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:09.396770" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:09.389125" elapsed="0.007892"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.397849" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:09.397173" elapsed="0.000707"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:09.397933" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:09.383518" elapsed="0.014546"/>
</kw>
<msg time="2026-06-06T03:24:09.398126" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:09.368144" elapsed="0.030100"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.413352" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.426388" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.439300" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.439538" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.439746" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.440174" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:09.440014" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:09.439995" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.440410" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.440585" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.440773" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:09.439953" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.439833" elapsed="0.001023"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.441011" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.441090" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:09.441248" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:09.362027" elapsed="0.079250"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:09.442708" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:09.442405" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:09.442902" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:09.442002" elapsed="0.000926"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.443343" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:09.443000" elapsed="0.000401"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.443940" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:09.443624" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:09.443426" elapsed="0.000576"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:09.442981" elapsed="0.001042"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.446663" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:09.444185" elapsed="0.002506"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:09.446746" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:09.446919" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:09.441617" elapsed="0.005327"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:09.448190" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:09.447955" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:09.448349" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:09.447590" elapsed="0.000784"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:09.448586" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:09.448445" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:09.448427" elapsed="0.000262"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.448844" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.449024" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.449090" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:09.451079" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:09.447254" elapsed="0.003852"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.452518" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:09.452263" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:09.452990" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:09.452742" elapsed="0.000292"/>
</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-06-06T03:24:09.462255" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:09.462391" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:09.462488" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:09.455271" elapsed="0.007625">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:09.453101" elapsed="0.009879">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:09.463227" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:09.463057" elapsed="0.000237"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:09.453082" elapsed="0.010235">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:09.463723" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.463859" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:09.463821" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:09.463802" elapsed="0.000121"/>
</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-06-06T03:24:09.464075" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.464146" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:09.451418" elapsed="0.012832">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.464326" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:09.333416" elapsed="0.131007">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:09.464724" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:09.464517" elapsed="0.000281"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:09.464499" elapsed="0.000323"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:09.464855" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:09.326402" elapsed="0.138549">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.522827" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:10.522375" elapsed="0.000487"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:10.523684" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:10.523413" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:10.523858" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:10.523051" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.524448" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:10.524058" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:10.524805" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:10.525043" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:10.524660" elapsed="0.000412"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.525519" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:10.525237" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.526681" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:10.526401" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.527167" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:10.526895" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.527945" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:10.527575" elapsed="0.000396"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:10.528893" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:10.528517" elapsed="0.000403"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:10.528976" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:10.529141" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:10.528166" elapsed="0.000999"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:10.529389" elapsed="0.000316"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:10.527430" elapsed="0.002317"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.530506" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:10.530005" elapsed="0.000528"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:10.531561" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:10.531226" elapsed="0.000362"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:10.531657" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:10.531815" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:10.530878" elapsed="0.000962"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:10.531998" elapsed="0.000269"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:10.529864" elapsed="0.002446"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:10.527249" elapsed="0.005096"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:10.532388" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:10.532544" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:10.526067" elapsed="0.006503"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:10.525688" elapsed="0.006913"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.532800" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:10.532627" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:10.525655" elapsed="0.007221"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.533663" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:10.533026" elapsed="0.000668"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:10.533743" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:10.521588" elapsed="0.012280"/>
</kw>
<msg time="2026-06-06T03:24:10.533924" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:10.508129" elapsed="0.025888"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.546926" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.559854" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.572610" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.572865" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.573052" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.573478" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:10.573322" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:10.573306" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.573722" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.573896" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.574067" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:10.573271" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.573130" elapsed="0.001015"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.574296" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.574371" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:10.574499" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:10.503599" elapsed="0.070927"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:10.575968" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:10.575628" elapsed="0.000415">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:10.576140" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:10.575245" elapsed="0.000925"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.576677" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:10.576264" elapsed="0.000484"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.577326" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:10.576978" elapsed="0.000374"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:10.576774" elapsed="0.000615"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:10.576242" elapsed="0.001168"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.580107" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:10.577575" elapsed="0.002560"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:10.580190" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:10.580354" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:10.574874" elapsed="0.005505"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:10.581752" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:10.581480" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:10.581918" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:10.581105" elapsed="0.000838"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:10.582154" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:10.582014" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:10.581996" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.582414" elapsed="0.000026"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.582604" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.582688" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:24:10.584717" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:10.580724" elapsed="0.004020"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.586306" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:10.586037" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:10.586785" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:10.586518" elapsed="0.000311"/>
</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-06-06T03:24:10.596171" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:10.596311" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:10.596412" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:10.589101" elapsed="0.007802">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:10.586899" elapsed="0.010126">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:10.597419" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:10.597140" elapsed="0.000380"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:10.586879" elapsed="0.010677">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:10.598143" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.598343" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:10.598286" elapsed="0.000120"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:10.598260" elapsed="0.000179"/>
</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-06-06T03:24:10.598684" elapsed="0.000033"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.598792" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:10.585100" elapsed="0.013845">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.599057" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:10.479572" elapsed="0.119628">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:10.599614" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:10.599340" elapsed="0.000403"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:10.599315" elapsed="0.000463"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:10.599827" elapsed="0.000021"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:10.473111" elapsed="0.126857">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.658745" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:11.658331" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:11.659561" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:11.659305" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:11.659795" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:11.658962" elapsed="0.000860"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.660425" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:11.660000" elapsed="0.000461"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:11.660871" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:11.661125" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:11.660691" elapsed="0.000462"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.661664" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:11.661379" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.662769" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:11.662491" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.663436" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:11.663058" elapsed="0.000405"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.664268" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:11.663910" elapsed="0.000385"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:11.665248" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:11.664893" elapsed="0.000382"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:11.665331" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:24:11.665496" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:11.664497" elapsed="0.001024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:11.665703" elapsed="0.000292"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:11.663762" elapsed="0.002275"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.667962" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:11.666293" elapsed="0.001697"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:11.668898" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:11.668535" elapsed="0.000390"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:11.668976" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:11.669132" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:11.668187" elapsed="0.000970"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:11.669318" elapsed="0.000274"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:11.666153" elapsed="0.003483"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:11.663525" elapsed="0.006170"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:11.669741" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:11.669900" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:11.662147" elapsed="0.007780"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:11.661797" elapsed="0.008163"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.670148" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:11.669987" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:11.661772" elapsed="0.008455"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.671045" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:11.670379" elapsed="0.000704"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:11.671136" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:11.657704" elapsed="0.013559"/>
</kw>
<msg time="2026-06-06T03:24:11.671322" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:11.644376" elapsed="0.027048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.684438" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.697335" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.710233" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.710443" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.710627" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.711023" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:11.710869" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:11.710853" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.711252" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.711438" elapsed="0.000030"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.711636" elapsed="0.000049"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:11.710824" elapsed="0.000899"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.710721" elapsed="0.001028"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.711906" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.711981" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:11.712107" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:11.639804" elapsed="0.072329"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:11.713435" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:11.713169" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:11.713606" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:11.712810" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.714017" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:11.713723" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.714582" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:11.714286" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:11.714099" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:11.713704" elapsed="0.000992"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.717314" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:11.714872" elapsed="0.002469"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:11.717394" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:11.717548" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:11.712459" elapsed="0.005114"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:11.718835" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:11.718584" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:11.718993" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:11.718238" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:11.719224" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:24:11.719089" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:11.719070" elapsed="0.000276"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.719514" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.719750" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.719820" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:11.721855" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:11.717903" elapsed="0.003979"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.723286" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:11.723034" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:11.723771" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:11.723494" elapsed="0.000321"/>
</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-06-06T03:24:11.733028" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:11.733182" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:11.733307" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:11.726031" elapsed="0.007689">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:11.723882" elapsed="0.009932">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:11.734093" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:11.733900" elapsed="0.000262"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:11.723863" elapsed="0.010323">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:11.734604" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.734760" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:11.734721" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:11.734701" elapsed="0.000125"/>
</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-06-06T03:24:11.734980" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.735052" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:11.722197" elapsed="0.012961">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.735236" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:11.616326" elapsed="0.119005">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:11.735654" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:11.735426" elapsed="0.000305"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:11.735408" elapsed="0.000348"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:11.735789" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:11.610296" elapsed="0.125590">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.796058" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:12.795597" elapsed="0.000500"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:12.797012" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:12.796723" elapsed="0.000388">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:12.797227" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:12.796296" elapsed="0.000956"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.797847" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:12.797432" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:12.798195" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:12.798504" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:12.798048" elapsed="0.000487"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.799006" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:12.798737" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.800086" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:12.799820" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.800584" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:12.800308" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.801378" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:12.801017" elapsed="0.000389"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:12.802390" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:12.801993" elapsed="0.000424"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:12.802474" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:24:12.802657" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:12.801606" elapsed="0.001079"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:12.802852" elapsed="0.000302"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:12.800871" elapsed="0.002325"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.803984" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:12.803460" elapsed="0.000552"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:12.804945" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:12.804570" elapsed="0.000403"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:12.805024" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:12.805182" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:12.804212" elapsed="0.000996"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:12.805370" elapsed="0.000296"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:12.803317" elapsed="0.002394"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:12.800684" elapsed="0.005063"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:12.805793" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:12.805982" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:12.799463" elapsed="0.006562"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:12.799137" elapsed="0.006935"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.806319" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:12.806110" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:12.799112" elapsed="0.007289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.807210" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:12.806555" elapsed="0.000686"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:12.807293" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:12.794943" elapsed="0.012477"/>
</kw>
<msg time="2026-06-06T03:24:12.807478" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:12.780227" elapsed="0.027338"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.820521" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.833652" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.846509" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.846729" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.846914" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.847287" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:12.847135" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:12.847121" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.847515" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.847706" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.847881" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:12.847093" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.846990" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.848112" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.848187" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:24:12.848311" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:12.775611" elapsed="0.072728"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:12.849620" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:12.849379" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:12.849799" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:12.849024" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.850211" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:12.849895" elapsed="0.000377"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.850808" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:12.850488" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:12.850297" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:12.849877" elapsed="0.001015"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.853482" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:12.851054" elapsed="0.002456"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:12.853564" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:12.853735" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:12.848684" elapsed="0.005077"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:12.855073" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:12.854831" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:12.855234" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:12.854462" elapsed="0.000797"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:12.855468" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:12.855331" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:12.855312" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.855722" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.855907" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.855974" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:12.857963" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:12.854078" elapsed="0.003912"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.859551" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:12.859300" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:12.860020" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:12.859774" elapsed="0.000291"/>
</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-06-06T03:24:12.868526" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:12.868685" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:12.868790" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:12.862362" elapsed="0.006793">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:12.860177" elapsed="0.009062">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:12.869474" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:12.869310" elapsed="0.000230"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:12.860114" elapsed="0.009449">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:12.869971" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.870106" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:12.870068" elapsed="0.000103"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:12.870050" elapsed="0.000148"/>
</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-06-06T03:24:12.870350" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.870422" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:12.858322" elapsed="0.012204">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.870602" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:12.751273" elapsed="0.119448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:12.871004" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:12.870817" elapsed="0.000260"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:12.870800" elapsed="0.000301"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:12.871134" elapsed="0.000015"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:12.746181" elapsed="0.125048">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.928756" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:13.928340" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:13.929620" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:13.929360" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:13.929848" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:13.929011" elapsed="0.000863"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.930433" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:13.930048" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:13.930788" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:13.931030" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:l...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:13.930629" elapsed="0.000428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.931466" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:13.931220" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.932687" level="INFO">mapping: {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:13.932414" elapsed="0.000318"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.933200" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:13.932925" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.934008" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:13.933633" elapsed="0.000403"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:13.934960" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:13.934583" elapsed="0.000404"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:13.935042" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:13.935205" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:13.934231" elapsed="0.000999"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:13.935392" elapsed="0.000307"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:13.933461" elapsed="0.002280"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.936489" level="INFO">${value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:13.935995" elapsed="0.000522"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:13.937448" level="INFO">${encoded} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:13.937109" elapsed="0.000367"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:13.937526" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:13.937696" level="INFO">${encoded_value} = AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:13.936728" elapsed="0.000994"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:13.937886" elapsed="0.000271"/>
</kw>
<var name="${key}">ROUTE_KEY</var>
<var name="${value}">AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA==</var>
<status status="PASS" start="2026-06-06T03:24:13.935857" elapsed="0.002343"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:13.933283" elapsed="0.004951"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:13.938277" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:24:13.938432" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'ROUTE_KEY': 'AAUAFQcAAAAAAAAAAQECAwQAAQABBQYHCA=='}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:13.932081" elapsed="0.006378"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:13.931591" elapsed="0.006899"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.938686" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:13.938515" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:13.931567" elapsed="0.007196"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.939499" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:13.938914" elapsed="0.000614"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:13.939576" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:13.927701" elapsed="0.012020"/>
</kw>
<msg time="2026-06-06T03:24:13.939778" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:13.914489" elapsed="0.025381"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.952887" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.965767" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.978714" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.978938" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.979127" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.979541" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:13.979382" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:13.979364" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.979792" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.979968" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.980141" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:13.979326" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:13.979209" elapsed="0.001012"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.980375" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:13.980453" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:13.980601" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:13.910022" elapsed="0.070607"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:13.982038" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:13.981759" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:13.982209" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:13.981351" elapsed="0.000883"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.982625" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:13.982305" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.983219" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:13.982919" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:13.982727" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:13.982286" elapsed="0.001017"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.985943" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:13.983463" elapsed="0.002508"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:13.986025" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:13.986182" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:13.980994" elapsed="0.005214"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:13.987451" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:13.987216" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/lsp/effective_rib_in/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:13.987610" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:13.986868" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:13.987860" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:13.987723" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:13.987704" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.988096" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:13.988274" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:13.988339" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:13.990349" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//lsp/effective_rib_in/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:13.986518" elapsed="0.003857"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.991821" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:13.991519" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:13.992284" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:13.992039" elapsed="0.000289"/>
</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-06-06T03:24:14.185074" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:14.185415" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:14.185741" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</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="FAIL" start="2026-06-06T03:24:13.994567" elapsed="0.192032">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:13.992394" elapsed="0.194455">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</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-06-06T03:24:14.187508" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:14.187045" elapsed="0.000658"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:13.992376" elapsed="0.195387">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:24:14.188816" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.189018" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:14.188960" elapsed="0.000120"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:14.188933" elapsed="0.000177"/>
</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-06-06T03:24:14.189325" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.189423" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:24:13.990702" elapsed="0.198875">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.189705" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:24:13.886661" elapsed="0.303187">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:14.190249" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:14.189980" elapsed="0.000370"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:14.189956" elapsed="0.000428"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.190430" elapsed="0.000020"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:24:13.882050" elapsed="0.308515">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<msg time="2026-06-06T03:24:14.190729" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${DEFAULT_RIB_CHECK_TIMEOUT}</arg>
<arg>${DEFAULT_RIB_CHECK_PERIOD}</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${BGP_VARIABLES_FOLDER}/lsp/effective_rib_in</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:24:03.584569" elapsed="10.606296">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:14.192812" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:14.192217" elapsed="0.000682"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.192190" elapsed="0.000742"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:14.193150" elapsed="0.000846"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.201443" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:14.201005" elapsed="0.000466"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="NOT RUN" start="2026-06-06T03:24:14.201709" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:14.201547" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.201528" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.202225" level="INFO">${newline} = 
</msg>
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:14.201926" elapsed="0.000325"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:14.202782" level="INFO">${reference} = bgpcep_userfeatures_txt_Ibgp_Peer_Lsp_TC2_Check_Example_Bgp_Rib</msg>
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:14.202415" elapsed="0.000395"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<msg time="2026-06-06T03:24:14.203153" level="INFO">${reference} = bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib</msg>
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="PASS" start="2026-06-06T03:24:14.202979" elapsed="0.000201"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.203698" level="INFO">${msg} = ... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib"
reference somewhere inside)</msg>
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:14.203339" elapsed="0.000386"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.204195" level="INFO">${bugs} = "https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib&amp;order=bug_status"</msg>
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:14.203886" elapsed="0.000336"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.204885" level="INFO">Set test message to:
... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib&amp;order=bug_status"

Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</msg>
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="PASS" start="2026-06-06T03:24:14.204380" elapsed="0.000559"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.205397" level="INFO">... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib&amp;order=bug_status"</msg>
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:14.205104" elapsed="0.000340"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:24:14.200592" elapsed="0.004908"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:14.191919" elapsed="0.013632"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:24:14.191342" elapsed="0.014251"/>
</kw>
<doc>Check RIB for linkstate-route(s) and check all of their attributes.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:24:03.501774" elapsed="10.703861">... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_ibgp_peer_lsp_tc2_check_example_bgp_rib&amp;order=bug_status"

Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-linkstate%3Alinkstate-address-family,bgp-linkstate%3Alinkstate-subsequent-address-family/bgp-linkstate:linkstate-routes?content=nonconfig</status>
</test>
<test id="s1-s11-t11" name="TC2_Disconnect_BGP_Peer" line="156">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:14.209512" elapsed="0.000235"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:14.209139" elapsed="0.000666"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.210825" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:14.210712" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.210691" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.216009" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:14.215903" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.215885" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.217202" 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-06-06T03:24:14.216815" elapsed="0.000414"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.217713" 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-06-06T03:24:14.217398" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:14.217786" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:24:14.217948" 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-06-06T03:24:14.216374" elapsed="0.001599"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:14.223947" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:14.223840" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.223820" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:14.225239" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:14.225132" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.225114" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:14.225802" level="INFO">${karaf_connection_index} = 9</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-06-06T03:24:14.225459" elapsed="0.000371"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:14.226221" level="INFO">${current_connection_index} = 7</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-06-06T03:24:14.226000" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:14.258078" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:14.226774" elapsed="0.031413"/>
</kw>
<msg time="2026-06-06T03:24:14.258372" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:14.258419" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:14.226414" elapsed="0.032040"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:14.279246" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:24:14.259030" elapsed="0.020324"/>
</kw>
<msg time="2026-06-06T03:24:14.279517" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:14.279563" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "...</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-06-06T03:24:14.258664" elapsed="0.020935"/>
</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-06-06T03:24:14.279955" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:14.279708" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.279679" elapsed="0.000357"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.280524" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:24:14.280188" elapsed="0.000419"/>
</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-06-06T03:24:14.280925" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:14.280696" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.280677" elapsed="0.000350"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:14.281074" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:14.284010" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:24:14.284222" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:14.282851" elapsed="0.001508"/>
</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="NOT RUN" start="2026-06-06T03:24:14.284718" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:14.285115" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:14.282054" elapsed="0.003251"/>
</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-06-06T03:24:14.281424" elapsed="0.003950"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:14.224829" elapsed="0.060643"/>
</kw>
<msg time="2026-06-06T03:24:14.285567" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:14.285611" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:14.224174" elapsed="0.061490"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:14.285854" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:14.285745" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.285725" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:14.286365" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:14.286740" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:14.286815" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:14.223488" elapsed="0.063437"/>
</kw>
<msg time="2026-06-06T03:24:14.287034" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:14.287078" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "i "s "c "o "n "n "e "c "t "_ "B "G "P "_ "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:14.218363" elapsed="0.068750"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:14.287457" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:14.287191" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:14.287173" elapsed="0.000364"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:14.218212" elapsed="0.069349"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:14.218033" elapsed="0.069560"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:14.215525" elapsed="0.072139"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:14.210403" elapsed="0.077322"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:14.209965" elapsed="0.077807"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:14.206696" elapsed="0.081130"/>
</kw>
<kw name="Stop_Console_Tool" owner="BGPcliKeywords">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:14.289013" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:14.288698" elapsed="0.000342"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:14.289199" elapsed="0.000423"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:24:14.288402" elapsed="0.001308"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.290528" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:24:16.290907" level="INFO">${output} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<var>${output}</var>
<arg>delay=1s</arg>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:24:14.289868" elapsed="2.001103"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.292131" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.291447" elapsed="0.000792"/>
</kw>
<doc>Stop the tool if still running.</doc>
<status status="PASS" start="2026-06-06T03:24:14.288054" elapsed="2.004321"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.309804" level="INFO">Executing command 'cat bgp_peer.log'.</msg>
<msg time="2026-06-06T03:24:16.323556" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:16.323721" level="INFO">${output_log} = 2026-06-06 03:23:53,576 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:23:53,576 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:23:53,576 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:16.309658" elapsed="0.014102"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.324455" level="INFO">2026-06-06 03:23:53,576 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:23:53,576 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:23:53,576 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:23:53,576 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:23:53,576 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:23:53,577 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:23:53,580 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400020001010440040047400200b44700
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 1
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 1
2026-06-06 03:23:53,581 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, 0]
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:23:53,581 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:23:53,581 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:23:53,581 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:53,581 DEBUG BGP-Thread-1 (job):   Length=53 (0x0035)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=24 (0x18)
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010440040047020641040000fbf0
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010440040047020641040000fbf0'
2026-06-06 03:23:53,582 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010440040047020641040000fbf0
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:53,584 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:23:53,585 INFO BGP-Thread-1 (job): Iteration: 0 - total remaining prefixes: 1
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): ########## Iteration: 0 ##########
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): Remaining prefixes: 1
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): --- COMBINED SCENARIO ---
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): Prefixes to be inserted in this iteration:
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix count: 1
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix indexes: [0]
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix list: [IPv4Address('8.0.1.0')]
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job): Prefixes to be withdrawn in this iteration:
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix slot index: 0
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix slot size: 1
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix count: 0
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix indexes: []
2026-06-06 03:23:53,585 DEBUG BGP-Thread-1 (job):   Prefix list: []
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Length=80 (0x0050)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=57 (0x0039)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064800e2240044704c00002010000050015070000000000000001010203040001000105060708)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):     MP_REACH_NLRI: {'Identifier': 1, 'TunnelID': 1, 'LSPID': 1, 'IPv4TunnelSenderAddress': IPv4Address('1.2.3.4'), 'IPv4TunnelEndPointAddress': IPv4Address('5.6.7.8')}
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:23:53,586 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff005002000000394001010040020602010000fbf040050400000064800e2240044704c00002010000050015070000000000000001010203040001000105060708
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): All update messages generated.
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): Storing performance results.
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): ########## Final results ##########
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): Number of iterations: 1
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the pre-fill phase: 0
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): The pre-fill phase duration: 0s
2026-06-06 03:23:53,586 INFO BGP-Thread-1 (job): Number of UPDATE messages sent in the 2nd test phase: 1
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job): The 2nd test phase duration: 0.0012733936309814453s
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job): Threshold for performance reporting: 1000
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job): Message generator performance results stored in totals-bgp.csv:
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job): Message generator performance results stored in performance-bgp.csv:
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job):   
2026-06-06 03:23:53,587 INFO BGP-Thread-1 (job): Finally an END-OF-RIB is sent.
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job): UPDATE message encoding
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job):   Length=43 (0x002b)
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job):   Type=2 (0x02)
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job):   withdrawn_routes_length=0 (0x0000)
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job):   Withdrawn_Routes=[]/28 (0x)
2026-06-06 03:23:53,587 DEBUG BGP-Thread-1 (job):   Total Path Attributes Length=20 (0x0014)
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job):   Path Attributes=(0x4001010040020602010000fbf040050400000064)
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job):     Origin=IGP
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job):     AS path=64496
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job):     Next hop=192.0.2.1
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job):     MP_REACH_NLRI: {'Identifier': 1, 'TunnelID': 1, 'LSPID': 1, 'IPv4TunnelSenderAddress': IPv4Address('1.2.3.4'), 'IPv4TunnelEndPointAddress': IPv4Address('5.6.7.8')}
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job):   Network Layer Reachability Information=[]/28 (0x)
2026-06-06 03:23:53,588 DEBUG BGP-Thread-1 (job): UPDATE message encoded: 0xffffffffffffffffffffffffffffffff002b02000000144001010040020602010000fbf040050400000064
2026-06-06 03:23:53,588 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:23:53,588 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:23:53,588 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:23:53,594 INFO BGP-Thread-1 (job): ... idle for 0.005s
2026-06-06 03:23:53,594 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.005s
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:23:53,594 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0006' (6)
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Path attributes: 0xb'800f03400447'
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Attribute type=15 (MP_UNREACH_NLRI, flags:0xb'80')
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Attribute value=0xb'400447'
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job):   Address Family Identifier=0xb'4004'
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job):   Subsequent Address Family Identifier=0xb'47'
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job):   Withdrawn Routes=0xb''
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job):   Withdrawn routes prefix list: []
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:23:53,595 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Allf False
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Message type: 0xb'02' (update)
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Withdrawn routes lenght: 0xb'0000' (0)
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Withdrawn routes: 0xb''
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Withdrawn routes prefix list: []
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Total path attribute lenght: 0xb'0000' (0)
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Path attributes: 0xb''
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): Calculated NLRI length: 0
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): NLRI: 0xb''
2026-06-06 03:23:53,596 DEBUG BGP-Thread-1 (job): NLRI prefix list: []
2026-06-06 03:23:53,599 INFO BGP-Thread-1 (job): NOTIFICATION message received: 0xffffffffffffffffffffffffffffffff0015030301
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.324090" elapsed="0.000655"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:16.325553" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc2_bgp_peer.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/tc2_bgp_peer.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:24:16.325038" elapsed="0.000594"/>
</kw>
<arg>${BGP_PEER_LOG_FILE}</arg>
<arg>tc2_${BGP_PEER_LOG_FILE}</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:16.309212" elapsed="0.016530"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.327597" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.327032" elapsed="0.000673"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.327001" elapsed="0.000741"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.327972" elapsed="0.000452"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.335629" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:16.335054" elapsed="0.000637"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:24:16.336008" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:24:16.335800" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.335772" elapsed="0.000363"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.336355" elapsed="0.000031"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.336605" elapsed="0.000029"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.336887" elapsed="0.000029"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.337131" elapsed="0.000028"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.337371" elapsed="0.000029"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.337612" elapsed="0.000045"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.337875" elapsed="0.000028"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:24:16.334601" elapsed="0.003422"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.326720" elapsed="0.011389"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:24:16.326164" elapsed="0.012005"/>
</kw>
<doc>Stop BGP peer &amp; store logs</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:24:14.206081" elapsed="2.132141"/>
</test>
<test id="s1-s11-t12" name="TC2_Deconfigure_iBGP_Peer" line="162">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:16.343157" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:16.342887" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:16.344440" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:16.344328" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.344308" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:16.349598" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:16.349491" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.349472" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.350721" 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-06-06T03:24:16.350319" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.351211" 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-06-06T03:24:16.350917" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:16.351322" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:16.351479" 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-06-06T03:24:16.349920" elapsed="0.001584"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:16.357286" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:16.357161" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.357137" elapsed="0.000225"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:16.358690" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:16.358550" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.358531" elapsed="0.000229"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:16.359229" level="INFO">${karaf_connection_index} = 9</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-06-06T03:24:16.358913" elapsed="0.000343"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.359659" level="INFO">${current_connection_index} = 7</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-06-06T03:24:16.359423" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.391022" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:16.360196" elapsed="0.030998"/>
</kw>
<msg time="2026-06-06T03:24:16.391404" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:16.391451" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:16.359853" elapsed="0.031633"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.413017" level="INFO">". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:24:16.392172" elapsed="0.021026"/>
</kw>
<msg time="2026-06-06T03:24:16.413430" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:16.413479" level="INFO">${message_wait} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "...</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-06-06T03:24:16.391751" elapsed="0.021765"/>
</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-06-06T03:24:16.414058" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.413631" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.413595" elapsed="0.000561"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.414695" level="INFO"> ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "_ "P "e "e "r "[K"
[?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-06-06T03:24:16.414314" elapsed="0.000451"/>
</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-06-06T03:24:16.415058" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.414833" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.414814" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:16.415177" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:16.418241" elapsed="0.000157"/>
</kw>
<msg time="2026-06-06T03:24:16.418461" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.416850" elapsed="0.001748"/>
</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="NOT RUN" start="2026-06-06T03:24:16.418914" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.419261" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:16.416097" elapsed="0.003352"/>
</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-06-06T03:24:16.415504" elapsed="0.004011"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:16.358250" elapsed="0.061456"/>
</kw>
<msg time="2026-06-06T03:24:16.419844" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:16.419920" level="INFO">${message} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:16.357546" elapsed="0.062428"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:16.420212" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:24:16.420059" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.420038" elapsed="0.000294"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.420811" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.421169" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:16.421243" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:16.356756" elapsed="0.064598"/>
</kw>
<msg time="2026-06-06T03:24:16.421454" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:16.421497" level="INFO">${output} =  ". "t "x "t ". "I "b "g "p "[C "P "e "e "r "[C "L "s "p ". "T "C "2 "_ "D "e "c "o "n "f "i "g "u "r "e "_ "i "B "G "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:16.351908" elapsed="0.069624"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.421935" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.421611" elapsed="0.000382"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.421593" elapsed="0.000426"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:16.351753" elapsed="0.070292"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:16.351561" elapsed="0.070518"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:16.349129" elapsed="0.073008"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:16.344036" elapsed="0.078161"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:16.343583" elapsed="0.078662"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:16.339477" elapsed="0.082823"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.423138" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.422485" elapsed="0.000686"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.468571" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:16.468180" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:16.469401" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:16.469139" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:16.469573" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:16.468792" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.470195" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:16.469787" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:16.470534" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpuser/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:16.470775" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:16.470393" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.471220" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.470969" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.472256" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.471997" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.472754" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.472468" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.473476" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:16.473170" elapsed="0.000333"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:16.474307" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.474081" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:16.474386" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:16.474543" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:16.473715" elapsed="0.000853"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.474746" elapsed="0.000243"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:24:16.473015" elapsed="0.002015"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.475578" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:16.475281" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:16.476343" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.476131" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:16.476419" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:16.476569" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:16.475808" elapsed="0.000785"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.476765" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:24:16.475144" elapsed="0.001886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.477579" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:16.477280" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:16.478414" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.478197" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:16.478493" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:16.478660" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:16.477844" elapsed="0.000844"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.478852" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:16.477142" elapsed="0.001975"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.479878" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:16.479369" elapsed="0.000535"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:16.480652" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.480425" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:16.480731" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:16.480886" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:16.480098" elapsed="0.000812"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:16.481070" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:16.479230" elapsed="0.002140"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:16.472833" elapsed="0.008574"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:16.481452" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:24:16.481612" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:16.471665" elapsed="0.009987"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.471340" elapsed="0.010348"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.481904" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.481713" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.471317" elapsed="0.010668"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.482775" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:16.482137" elapsed="0.000667"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:16.482854" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:16.467535" elapsed="0.015443"/>
</kw>
<msg time="2026-06-06T03:24:16.483033" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.453999" elapsed="0.029081"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.496012" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.508879" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpuser/../../../variables/bgpuser//bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.523704" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.523930" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.524119" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.524537" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.524378" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:16.524359" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.524788" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.524970" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.525143" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:16.524320" elapsed="0.000876"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:16.524203" elapsed="0.001085"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.525449" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:16.525528" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:24:16.525700" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:16.449434" elapsed="0.076296"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.526977" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.526681" elapsed="0.000494"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:16.538995" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01kdax787yyt1c4nccdu5a862j20.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:16.539066" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:16.539199" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:16.529387" elapsed="0.009850"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.527241" elapsed="0.012057"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.539575" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.539338" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.527223" elapsed="0.012500"/>
</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-06-06T03:24:16.545229" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.541231" elapsed="0.004062"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.540890" elapsed="0.004455"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.540862" elapsed="0.004521"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.549550" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.545951" elapsed="0.003668"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.545491" elapsed="0.004200"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.545455" elapsed="0.004274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.550667" 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-06-06T03:24:16.550032" elapsed="0.000678"/>
</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-06-06T03:24:16.551065" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.550811" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.551616" 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-06-06T03:24:16.551316" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.551146" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.550790" elapsed="0.000925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.552246" 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-06-06T03:24:16.551882" elapsed="0.000391"/>
</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-06-06T03:24:16.552594" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.552344" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.553196" 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-06-06T03:24:16.552890" elapsed="0.000388"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.552692" elapsed="0.000626"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.552325" elapsed="0.001014"/>
</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-06-06T03:24:16.553516" elapsed="0.000403"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:16.554406" 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-06-06T03:24:16.554100" elapsed="0.000332"/>
</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-06-06T03:24:16.554599" elapsed="0.002590"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:24:16.540257" elapsed="0.017019"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:16.557340" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:24:16.560197" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:24:16.526033" elapsed="0.034193"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:16.560283" elapsed="0.000028"/>
</return>
<arg>${BGP_VARIABLES_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:24:16.423414" elapsed="0.136998"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils" type="TEARDOWN">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.561947" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.561427" elapsed="0.000593"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.561406" elapsed="0.000640"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.562254" elapsed="0.000381"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.567949" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:16.567489" elapsed="0.000489"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="PASS" start="2026-06-06T03:24:16.568230" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:24:16.568055" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.568035" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.568478" elapsed="0.000022"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.568677" elapsed="0.000022"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.568865" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.569043" elapsed="0.000021"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.569221" elapsed="0.000021"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.569399" elapsed="0.000021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.569574" elapsed="0.000021"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:24:16.567160" elapsed="0.002511"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:16.561211" elapsed="0.008531"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:24:16.560782" elapsed="0.009007"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:24:16.338682" elapsed="0.231149"/>
</test>
<kw name="Teardown_Everything" owner="BgpOperations" type="TEARDOWN">
<kw name="Search_And_Kill_Remote_Python" owner="KillPythonTool">
<kw name="Search_For_Remote_Python_Processes" owner="KillPythonTool">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.571623" level="INFO">Executing command 'ps -elf | egrep python | egrep 'play.py' | egrep -v grep'.</msg>
<msg time="2026-06-06T03:24:16.595085" level="INFO">Command exited with return code 1.</msg>
<msg time="2026-06-06T03:24:16.595398" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>ps -elf | egrep python | egrep ${filter} | egrep -v grep</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:16.571467" elapsed="0.023990"/>
</kw>
<return>
<value>${processes}</value>
<status status="PASS" start="2026-06-06T03:24:16.595598" elapsed="0.000131"/>
</return>
<msg time="2026-06-06T03:24:16.596042" level="INFO">${processes} = </msg>
<var>${processes}</var>
<arg>${filter}</arg>
<doc>Only searches for the list of processes, in case something else than kill has to be done with them.</doc>
<status status="PASS" start="2026-06-06T03:24:16.571105" elapsed="0.024993"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.597181" level="INFO"/>
<arg>${processes}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.596519" elapsed="0.000757"/>
</kw>
<kw name="Kill_Remote_Processes" owner="KillPythonTool">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.599900" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:24:16.600072" level="INFO">${arg_length} = 0</msg>
<var>${arg_length}</var>
<arg>${pself_lines}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:16.599259" elapsed="0.000866"/>
</kw>
<if>
<branch type="IF" condition="${arg_length} == 0">
<return>
<status status="PASS" start="2026-06-06T03:24:16.600555" elapsed="0.000062"/>
</return>
<status status="PASS" start="2026-06-06T03:24:16.600290" elapsed="0.000424"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.600245" elapsed="0.000527"/>
</if>
<kw name="Execute Command" owner="SSHLibrary">
<var>${commands}</var>
<arg>echo '${pself_lines}' | awk '{print "kill -${signal}",$4}'</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.601128" elapsed="0.000047"/>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${commands}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.601528" elapsed="0.000045"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<var>${stdout}</var>
<var>${stderr}</var>
<arg>echo 'set -exu; ${commands}' | sudo sh</arg>
<arg>return_stderr=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:16.601988" elapsed="0.000050"/>
</kw>
<arg>${processes}</arg>
<doc>Kill processes by PIDs from given list (no-op if the list is empty), using specified signal. Log the kill commands used.</doc>
<status status="PASS" start="2026-06-06T03:24:16.598520" elapsed="0.003669"/>
</kw>
<arg>'play\.py'</arg>
<doc>The main keyword. Search for processes, Log the list of them, kill them.</doc>
<status status="PASS" start="2026-06-06T03:24:16.570794" elapsed="0.031512"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:16.602898" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:24:16.602725" elapsed="0.000334"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:24:16.603399" elapsed="0.000806"/>
</kw>
<doc>Create and Log the diff between expected and actual responses, make sure Python tool was killed.
Tear down imported Resources.</doc>
<status status="PASS" start="2026-06-06T03:24:16.570388" elapsed="0.033952"/>
</kw>
<doc>Basic tests for iBGP peers.

Copyright (c) 2015-2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

Test suite performs basic iBGP functional test case for
carrying LSP State Information in BGP as described in
http://tools.ietf.org/html/draft-ietf-idr-te-lsp-distribution-03</doc>
<status status="FAIL" start="2026-06-06T03:23:27.182110" elapsed="49.422304"/>
</suite>
<suite id="s1-s12" name="010 Bgp Functional L3Vpn" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/010_bgp_functional_l3vpn.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.700783" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:16.695963" elapsed="0.004887"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:24:16.695712" elapsed="0.005222"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.706038" 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-06-06T03:24:16.702186" elapsed="0.003881"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:24:16.706295" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:16.706162" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.706134" elapsed="0.000235"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.706915" 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-06-06T03:24:16.706537" elapsed="0.000421"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.707439" 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-06-06T03:24:16.707128" elapsed="0.000337"/>
</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-06-06T03:24:16.708011" elapsed="0.000290"/>
</kw>
<msg time="2026-06-06T03:24:16.708400" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:16.708448" 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-06-06T03:24:16.707638" elapsed="0.000833"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.709036" 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-06-06T03:24:16.708663" elapsed="0.000400"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.710226" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:24:16.709869" elapsed="0.000385"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.710694" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:24:16.710413" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.711192" 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-06-06T03:24:16.710891" elapsed="0.000328"/>
</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-06-06T03:24:16.714610" elapsed="0.000233"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.715339" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:24:16.715015" elapsed="0.000350"/>
</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-06-06T03:24:16.715525" elapsed="0.000246"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.716568" 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-06-06T03:24:16.716273" elapsed="0.000322"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:24:16.716659" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:24:16.716825" 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-06-06T03:24:16.715974" elapsed="0.000876"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:16.717453" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e591a910&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-06-06T03:24:16.717015" elapsed="0.000682"/>
</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-06-06T03:24:16.717873" elapsed="0.000193"/>
</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-06-06T03:24:16.714039" elapsed="0.004086"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:16.713839" elapsed="0.004332"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:24:16.711278" elapsed="0.006923"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.718874" 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-06-06T03:24:16.718398" elapsed="0.000521"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.719492" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:24:16.719092" elapsed="0.000444"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.720102" 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-06-06T03:24:16.719719" elapsed="0.000425"/>
</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-06-06T03:24:16.709338" elapsed="0.010862"/>
</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-06-06T03:24:16.701825" elapsed="0.018431"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:16.720447" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:16.720327" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.720306" elapsed="0.000207"/>
</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-06-06T03:24:16.723952" 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-06-06T03:24:16.723540" elapsed="0.000439"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.724443" 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-06-06T03:24:16.724148" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:16.724515" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:16.724689" 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-06-06T03:24:16.723201" elapsed="0.001514"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:16.725841" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:24:16.725527" elapsed="0.000341"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.726637" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:24:16.726759" 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-06-06T03:24:16.726468" elapsed="0.000318"/>
</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-06-06T03:24:16.730450" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:16.729859" elapsed="0.000678"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:16.729838" elapsed="0.000738"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.731241" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:24:16.730800" elapsed="0.000744"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.732604" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:16.731911" elapsed="0.000815"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.734102" 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-06-06T03:24:16.733144" elapsed="0.001035"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:16.735906" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:24:16.736083" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:16.735530" elapsed="0.000598"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.736474" elapsed="0.000471"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:24:16.738214" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:24:17.088790" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:23:27 UTC 2026

  System load:  0.03               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:23:29 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:24:16.737876" elapsed="0.351065"/>
</kw>
<msg time="2026-06-06T03:24:17.089025" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.737302" elapsed="0.351909"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:24:16.734628" elapsed="0.354731"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:17.090237" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:24:17.103064" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:24:17.103232" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:24:17.103332" 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-06-06T03:24:17.089759" elapsed="0.013621"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:17.103713" elapsed="0.000487"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:17.105448" 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-06-06T03:24:17.104846" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:24:17.106223" elapsed="0.000052"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:17.105808" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:17.105781" elapsed="0.000612"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:17.106709" elapsed="0.000062"/>
</return>
<status status="PASS" start="2026-06-06T03:24:17.106473" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:17.106455" elapsed="0.000441"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:24:17.106955" elapsed="0.000016"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:17.110468" elapsed="0.000479"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:17.111234" elapsed="0.000286"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:17.111810" elapsed="0.000224"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:17.107443" elapsed="0.004660"/>
</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-06-06T03:24:16.728874" elapsed="0.383407"/>
</kw>
<msg time="2026-06-06T03:24:17.112338" 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-06-06T03:24:16.727981" elapsed="0.384410"/>
</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-06-06T03:24:16.727473" elapsed="0.384999"/>
</kw>
<msg time="2026-06-06T03:24:17.112513" 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-06-06T03:24:16.726951" elapsed="0.385608"/>
</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-06-06T03:24:17.115380" elapsed="0.000329"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:17.115882" elapsed="0.000146"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:17.116185" elapsed="0.000097"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:17.112889" elapsed="0.003444"/>
</kw>
<msg time="2026-06-06T03:24:17.116424" 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-06-06T03:24:16.726096" elapsed="0.390353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:17.116921" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:17.116661" elapsed="0.000302"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:24:17.117006" elapsed="0.000030"/>
</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-06-06T03:24:16.725164" elapsed="0.391992"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:16.724980" elapsed="0.392216"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:16.724839" elapsed="0.392392"/>
</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-06-06T03:24:16.720760" elapsed="0.396526"/>
</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-06-06T03:24:17.117450" elapsed="0.000290"/>
</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-06-06T03:24:17.131852" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:17.131733" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:17.131712" elapsed="0.000212"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:17.132226" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:24:17.132331" 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-06-06T03:24:17.132088" elapsed="0.000269"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:17.132795" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:17.132519" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:17.133319" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:17.133054" elapsed="0.000312"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:17.134157" 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-06-06T03:24:17.133933" elapsed="0.000331">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:24:17.134371" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:24:17.134416" 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-06-06T03:24:17.133535" elapsed="0.000904"/>
</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-06-06T03:24:17.134763" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:17.134516" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:17.134497" elapsed="0.000368"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:17.135624" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:24:17.135358" elapsed="0.000307"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:24:17.135715" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:17.135872" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:24:17.135077" elapsed="0.000820"/>
</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-06-06T03:24:17.136059" elapsed="0.000402"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:17.136757" level="INFO">index=4
host=10.30.170.38
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-06-06T03:24:17.136860" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:24:17.136637" elapsed="0.000251"/>
</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-06-06T03:24:17.137044" elapsed="0.002418"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:24:17.139964" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:24:18.084285" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:24:17.139657" elapsed="0.944787"/>
</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-06-06T03:24:18.087945" elapsed="0.000388"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:18.088510" elapsed="0.000188"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:18.088858" elapsed="0.000102"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:18.085576" elapsed="0.003439"/>
</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-06-06T03:24:18.084888" elapsed="0.004174"/>
</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-06-06T03:24:17.131435" elapsed="0.957679"/>
</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-06-06T03:24:17.118467" elapsed="0.970696"/>
</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-06-06T03:24:17.118093" elapsed="0.971123"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:17.117946" elapsed="0.971376"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:24:17.117799" elapsed="0.971560"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:24:16.701292" elapsed="1.388129"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:18.092224" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:18.092095" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.092049" elapsed="0.000250"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:18.097252" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:18.097145" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.097127" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:18.098305" 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-06-06T03:24:18.097912" elapsed="0.000421"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:18.098820" 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-06-06T03:24:18.098504" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:18.098893" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:18.099054" 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-06-06T03:24:18.097554" elapsed="0.001526"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:18.105978" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:18.105867" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.105844" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:18.107280" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:18.107152" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.107133" elapsed="0.000218"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:18.107848" 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-06-06T03:24:18.107505" elapsed="0.000370"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:18.108301" 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-06-06T03:24:18.108044" elapsed="0.000284"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:18.142415" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:18.109025" elapsed="0.033537"/>
</kw>
<msg time="2026-06-06T03:24:18.142723" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:18.142771" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:24:18.108497" elapsed="0.034310"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:18.214074" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "1 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "l "3 "v "p "n ". "r "o "b "o "t "[K"
[?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-06-06T03:24:18.143544" elapsed="0.070686"/>
</kw>
<msg time="2026-06-06T03:24:18.214360" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:18.214407" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:24:18.143005" elapsed="0.071438"/>
</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-06-06T03:24:18.214818" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:18.214530" elapsed="0.000439"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.214505" elapsed="0.000493"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:18.215517" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "1 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "l "3 "v "p "n ". "r "o "b "o "t "[K"
[?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-06-06T03:24:18.215156" elapsed="0.000527"/>
</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-06-06T03:24:18.216030" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:18.215752" elapsed="0.000430"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.215733" elapsed="0.000476"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:18.216246" elapsed="0.000036"/>
</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-06-06T03:24:18.218341" elapsed="0.002006"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:18.220720" elapsed="0.000310"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:18.221367" elapsed="0.000236"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:18.217488" elapsed="0.004568"/>
</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-06-06T03:24:18.216550" elapsed="0.005644"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:18.106857" elapsed="0.115443"/>
</kw>
<msg time="2026-06-06T03:24:18.222619" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:18.222682" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:18.106206" elapsed="0.116514"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:18.222916" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:24:18.222803" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.222782" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:18.223430" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:18.225226" elapsed="0.000045"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:18.225353" elapsed="0.000025"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:18.105555" elapsed="0.119972"/>
</kw>
<msg time="2026-06-06T03:24:18.225713" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:18.225784" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:18.099455" elapsed="0.126384"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:18.226374" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:18.225955" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:18.225928" elapsed="0.000567"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:18.099306" elapsed="0.127225"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:18.099135" elapsed="0.127441"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:18.096852" elapsed="0.129828"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:24:18.090071" elapsed="0.136696"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:18.089590" elapsed="0.137240"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:24:16.695363" elapsed="1.531545"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:18.227708" level="INFO">${tools_system_conn_id} = 7</msg>
<var>${tools_system_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:18.227153" elapsed="0.000596"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:18.228524" level="INFO">${tools_system_conn_id} = 7</msg>
<arg>${tools_system_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:18.228027" elapsed="0.000560"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:24:18.231181" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:24:18.231296" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:18.230770" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:18.231662" elapsed="0.000822"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:24:18.233850" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:24:18.830817" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:24:18 UTC 2026

  System load:  0.46               Processes:             106
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:23:28 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:24:18.233335" elapsed="0.597606"/>
</kw>
<msg time="2026-06-06T03:24:18.831018" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:18.232774" elapsed="0.598314"/>
</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-06-06T03:24:18.230093" elapsed="0.601097"/>
</kw>
<msg time="2026-06-06T03:24:18.831244" 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-06-06T03:24:18.229468" elapsed="0.601820"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:24:18.228916" elapsed="0.602470"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:24:18.837493" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:24:18.837153" 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-06-06T03:24:18.839019" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:24:19.175674" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:19.175975" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 195ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:24:19.176081" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:24:19.176173" 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-06-06T03:24:18.838831" elapsed="0.337394"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:19.178191" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:24:19.177544" elapsed="0.000754"/>
</kw>
<msg time="2026-06-06T03:24:19.178514" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:24:19.178615" 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-06-06T03:24:19.176705" elapsed="0.001994"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:19.180156" 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-06-06T03:24:19.179155" elapsed="0.001062"/>
</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-06-06T03:24:19.183140" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 195ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:19.182472" elapsed="0.000783"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:19.184048" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:19.183621" elapsed="0.000470"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:19.184491" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:19.184252" elapsed="0.000285"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:24:19.181233" elapsed="0.003359"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:19.180404" elapsed="0.004226"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:19.180354" elapsed="0.004318"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:24:19.184837" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:19.184731" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:19.184714" elapsed="0.000252"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:19.185111" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:24:19.185020" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:19.185004" elapsed="0.000196"/>
</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-06-06T03:24:19.185357" 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-06-06T03:24:18.838253" elapsed="0.347225"/>
</kw>
<msg time="2026-06-06T03:24:19.185536" 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-06-06T03:24:18.837706" elapsed="0.347880"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:24:18.836512" elapsed="0.349199"/>
</kw>
<msg time="2026-06-06T03:24:19.185768" 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-06-06T03:24:18.832435" elapsed="0.353376"/>
</kw>
<arg>virtualenv ${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-06-06T03:24:18.832049" elapsed="0.353872"/>
</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-06-06T03:24:19.192788" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/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-06-06T03:24:19.192443" elapsed="0.000373"/>
</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-06-06T03:24:19.194763" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-06-06T03:24:21.430402" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:21.431205" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
Installing collected packages: pip
  Att...</msg>
<msg time="2026-06-06T03:24:21.431417" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:24:21.431634" 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-06-06T03:24:19.194388" elapsed="2.237428"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:21.438843" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:24:21.437635" elapsed="0.001518"/>
</kw>
<msg time="2026-06-06T03:24:21.439626" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:24:21.439875" 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-06-06T03:24:21.434026" elapsed="0.005940"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:21.443375" 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-06-06T03:24:21.440634" elapsed="0.002839"/>
</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-06-06T03:24:21.449620" level="INFO">Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
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.1.2</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:21.449013" elapsed="0.000763"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:21.450605" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:21.450204" elapsed="0.000515"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:21.451469" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:21.451094" elapsed="0.000471"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:24:21.446484" elapsed="0.005251"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:21.444147" elapsed="0.007697"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:21.444074" elapsed="0.007809"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:24:21.452242" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:21.451949" elapsed="0.000421"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:21.451928" elapsed="0.000470"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:21.452622" elapsed="0.000055"/>
</return>
<status status="PASS" start="2026-06-06T03:24:21.452456" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:21.452438" elapsed="0.000395"/>
</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-06-06T03:24:21.453000" 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-06-06T03:24:19.193736" elapsed="2.259457"/>
</kw>
<msg time="2026-06-06T03:24:21.453254" 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-06-06T03:24:19.192988" elapsed="2.260326"/>
</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/defaultvenv/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-06-06T03:24:19.191824" elapsed="2.261578"/>
</kw>
<msg time="2026-06-06T03:24:21.453458" 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-06-06T03:24:19.187880" elapsed="2.265627"/>
</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-06-06T03:24:19.187304" elapsed="2.266678"/>
</kw>
<msg time="2026-06-06T03:24:21.454039" 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-06-06T03:24:19.186902" elapsed="2.267183"/>
</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-06-06T03:24:19.186536" elapsed="2.267626"/>
</kw>
<msg time="2026-06-06T03:24:21.454205" 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-06-06T03:24:19.186084" elapsed="2.268163"/>
</kw>
<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-06-06T03:24:18.831695" elapsed="2.622627"/>
</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-06-06T03:24:21.462738" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:24:21.462239" elapsed="0.000540"/>
</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-06-06T03:24:21.464894" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; deactivate'.</msg>
<msg time="2026-06-06T03:24:22.324778" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:22.325166" level="INFO">${stdout} = Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setupt...</msg>
<msg time="2026-06-06T03:24:22.325217" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:24:22.325259" 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-06-06T03:24:21.464476" elapsed="0.860811"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:22.327672" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:24:22.327104" elapsed="0.000683"/>
</kw>
<msg time="2026-06-06T03:24:22.327952" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:24:22.327999" 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-06-06T03:24:22.325694" elapsed="0.002328"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:22.329135" 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-06-06T03:24:22.328252" elapsed="0.000910"/>
</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-06-06T03:24:22.331490" level="INFO">Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setuptools
  Attempting uninstall: setuptools
    Found existing installation: setuptools 59.6.0
    Uninstalling setuptools-59.6.0:
      Successfully uninstalled setuptools-59.6.0
Successfully installed setuptools-44.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:22.331157" elapsed="0.000404"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:22.332275" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:22.331953" elapsed="0.000387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:22.332976" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:22.332656" elapsed="0.000387"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:24:22.330237" elapsed="0.002879"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:22.329395" elapsed="0.003817"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:22.329364" elapsed="0.003878"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:24:22.333447" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:22.333302" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:22.333283" elapsed="0.000287"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:22.333773" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:24:22.333626" elapsed="0.000263"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:22.333609" elapsed="0.000309"/>
</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-06-06T03:24:22.334076" elapsed="0.000021"/>
</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-06-06T03:24:21.463821" elapsed="0.870394"/>
</kw>
<msg time="2026-06-06T03:24:22.334275" 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-06-06T03:24:21.462982" elapsed="0.871348"/>
</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/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:24:21.461288" elapsed="0.873141"/>
</kw>
<msg time="2026-06-06T03:24:22.334486" 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-06-06T03:24:21.456699" elapsed="0.877833"/>
</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-06-06T03:24:21.456122" elapsed="0.878504"/>
</kw>
<msg time="2026-06-06T03:24:22.334708" 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-06-06T03:24:21.455628" elapsed="0.879126"/>
</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-06-06T03:24:21.455244" elapsed="0.879601"/>
</kw>
<msg time="2026-06-06T03:24:22.334889" 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-06-06T03:24:21.454837" elapsed="0.880095"/>
</kw>
<arg>setuptools==44.0.0</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-06-06T03:24:21.454541" elapsed="0.880479"/>
</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-06-06T03:24:22.342682" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:24:22.342338" 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-06-06T03:24:22.344517" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; deactivate'.</msg>
<msg time="2026-06-06T03:24:23.934459" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:23.934849" level="INFO">${stdout} = Collecting exabgp==3.4.16
  Using cached exabgp-3.4.16.tar.gz (240 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to b...</msg>
<msg time="2026-06-06T03:24:23.935022" level="INFO">${stderr} =   error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        ...</msg>
<msg time="2026-06-06T03:24:23.935089" 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-06-06T03:24:22.344163" elapsed="1.590949"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:23.937204" level="INFO">Length is 1821.</msg>
<msg time="2026-06-06T03:24:23.937639" level="FAIL">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:24:23.936682" elapsed="0.001223">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</status>
</kw>
<msg time="2026-06-06T03:24:23.938077" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:24:23.938127" level="INFO">${result} = '  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
       ...</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-06-06T03:24:23.935381" elapsed="0.002773"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:23.939234" 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-06-06T03:24:23.938385" elapsed="0.000876"/>
</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-06-06T03:24:23.941365" level="INFO">Collecting exabgp==3.4.16
  Using cached exabgp-3.4.16.tar.gz (240 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 'error'</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:23.941043" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:23.942067" level="INFO">  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-vha4755l/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:23.941748" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:23.942851" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:23.942517" elapsed="0.000403"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:24:23.940175" elapsed="0.002815"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:23.939393" elapsed="0.003694"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:23.939372" elapsed="0.003743"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:24:23.943314" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:23.943173" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:23.943155" elapsed="0.000277"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:23.943617" elapsed="0.000113"/>
</return>
<status status="PASS" start="2026-06-06T03:24:23.943487" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:23.943471" elapsed="0.000372"/>
</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-06-06T03:24:23.943996" 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-06-06T03:24:22.343489" elapsed="1.600647"/>
</kw>
<msg time="2026-06-06T03:24:23.944190" 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-06-06T03:24:22.342881" elapsed="1.601357"/>
</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/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:24:22.341727" elapsed="1.602601"/>
</kw>
<msg time="2026-06-06T03:24:23.944381" 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-06-06T03:24:22.337673" elapsed="1.606754"/>
</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-06-06T03:24:22.337101" elapsed="1.607411"/>
</kw>
<msg time="2026-06-06T03:24:23.944560" 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-06-06T03:24:22.336712" elapsed="1.607891"/>
</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-06-06T03:24:22.336317" elapsed="1.608386"/>
</kw>
<msg time="2026-06-06T03:24:23.944746" 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-06-06T03:24:22.335893" elapsed="1.608895"/>
</kw>
<arg>exabgp==3.4.16</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-06-06T03:24:22.335228" elapsed="1.609637"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:23.945311" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59b9190&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:24:23.945030" elapsed="0.000677"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:24:23.984880" level="INFO">[chan 5] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:24:23.992463" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/exa.cfg' -&gt; '/home/jenkins//exa.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${DEFAULT_EXA_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:24:23.946155" elapsed="0.046370"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:24:23.999937" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp-l3vpn-ipv4.cfg' -&gt; '/home/jenkins//bgp-l3vpn-ipv4.cfg'</msg>
<arg>${BGP_L3VPN_DIR}/${L3VPN_EXA_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:24:23.992728" elapsed="0.007269"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.007414" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/exabgp_files/exarpc.py' -&gt; '/home/jenkins//exarpc.py'</msg>
<arg>${EXARPCSCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:24:24.000168" elapsed="0.007306"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.017091" level="INFO">6 files:
bgp-flowspec-redirect.cfg
bgp-flowspec.cfg
bgp-l3vpn-ipv4.cfg
exa-md5.cfg
exa.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:24:24.017207" level="INFO">@{cfgfiles} = [ bgp-flowspec-redirect.cfg | bgp-flowspec.cfg | bgp-l3vpn-ipv4.cfg | exa-md5.cfg | exa.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:24:24.007664" elapsed="0.009570"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.017806" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:24:24.030243" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.017614" elapsed="0.012689"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.030680" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:24:24.082742" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.030489" elapsed="0.052314"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.083122" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:24:24.134333" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.082980" elapsed="0.051413"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.134733" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:24:24.186725" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.134571" elapsed="0.052277"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.187280" level="INFO">Executing command 'cat bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:24:24.238815" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:24.239008" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.187132" elapsed="0.051926"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:24.239540" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;

        }
        then {
            redirect 65500:12345;
        }
    }
    route flow2 {
        match {
            source 10.0.0.2/32;
            destination 192.168.0.2/32;

        }
        then {
                redirect 1.2.3.4;
        }
    }
    route flow4 {
        match {
            source 10.0.0.4/32;
            destination 192.168.0.4/32;

        }
        next-hop 127.0.0.1;
        then {
                redirect-to-nexthop;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:24.239271" elapsed="0.000320"/>
</kw>
<var name="${cfgfile}">bgp-flowspec-redirect.cfg</var>
<status status="PASS" start="2026-06-06T03:24:24.017466" elapsed="0.222160"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.240090" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:24:24.290856" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.239915" elapsed="0.051006"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.291293" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:24:24.342419" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.291105" elapsed="0.051441"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.343160" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:24:24.394549" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.342935" elapsed="0.051763"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.395211" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:24:24.446578" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.395034" elapsed="0.051627"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.447002" level="INFO">Executing command 'cat bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:24:24.499017" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:24.499129" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.446850" elapsed="0.052307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:24.499701" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;
            port =80;
            destination-port &gt;8080&amp;&lt;8088;
            source-port &gt;1024;
            protocol tcp;
            packet-length &gt;400&amp;&lt;500;
            fragment =first-fragment;
            icmp-type echo-reply;
            icmp-code network-unreachable;
            tcp-flags =urgent;
            dscp 20;
        }
        then {
            action sample-terminal;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:24.499384" elapsed="0.000371"/>
</kw>
<var name="${cfgfile}">bgp-flowspec.cfg</var>
<status status="PASS" start="2026-06-06T03:24:24.239765" elapsed="0.260026"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.500304" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:24:24.550436" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.500135" elapsed="0.050364"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.550877" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:24:24.602536" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.550700" elapsed="0.052041"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.603608" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:24:24.654414" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.603153" elapsed="0.051400"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.655361" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:24:24.706449" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.655029" elapsed="0.051561"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.707380" level="INFO">Executing command 'cat bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:24:24.755340" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:24.755733" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.707050" elapsed="0.048752"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:24.757051" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255.254;
      rd 1.2.3.4:1;
      label 24005;
    }
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:24.756353" elapsed="0.000802"/>
</kw>
<var name="${cfgfile}">bgp-l3vpn-ipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:24:24.499983" elapsed="0.257251"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.758763" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:24:24.806846" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.758250" elapsed="0.048808"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.808165" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:24:24.859367" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.807619" elapsed="0.051934"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.860449" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:24:24.911417" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.860080" elapsed="0.051618"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.912569" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:24:24.962370" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.912196" elapsed="0.050334"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:24.963340" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:24:25.014474" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:25.014805" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:24.962984" elapsed="0.051888"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.016210" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.015431" elapsed="0.000892"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:24:24.757503" elapsed="0.258905"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.017517" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:24:25.062294" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.017112" elapsed="0.045321"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.063269" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:24:25.111298" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.062878" elapsed="0.048582"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.112290" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:24:25.162448" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.111940" elapsed="0.050640"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.163484" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:24:25.214556" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.163014" elapsed="0.051732"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.215527" level="INFO">Executing command 'cat exa.cfg'.</msg>
<msg time="2026-06-06T03:24:25.262879" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:25.263162" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 un...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.215185" elapsed="0.048039"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.264444" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
    ipv4 mpls-vpn;
  }

  process exarpcserver {
    run exarpc.py --host 10.30.171.194;
    encoder json;
    receive-routes;
    neighbor-changes;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.263773" elapsed="0.000780"/>
</kw>
<var name="${cfgfile}">exa.cfg</var>
<status status="PASS" start="2026-06-06T03:24:25.016735" elapsed="0.247939"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.265827" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:24:25.310738" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.265379" elapsed="0.045686"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.312415" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:24:25.363675" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.311809" elapsed="0.052097"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.365020" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:24:25.414905" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.364501" elapsed="0.050564"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.415957" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:24:25.477029" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.415532" elapsed="0.061675"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.478049" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:24:25.526544" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:25.526850" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:25.477702" elapsed="0.049210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.528225" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.527464" elapsed="0.000872"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:24:25.264963" elapsed="0.263454"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:24:24.017298" elapsed="1.511210"/>
</for>
<doc>Uploads exabgp config files and needed scripts</doc>
<status status="PASS" start="2026-06-06T03:24:23.945930" elapsed="1.582789"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:16.694990" elapsed="8.833867"/>
</kw>
<test id="s1-s12-t1" name="Configure_App_Peer" line="57">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:25.538394" elapsed="0.000506"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:25.537876" elapsed="0.001143"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.540783" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.540542" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.540499" elapsed="0.000404"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.549232" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.548977" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.548950" elapsed="0.000396"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.550731" 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-06-06T03:24:25.550253" elapsed="0.000508"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.551256" 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-06-06T03:24:25.550939" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:25.551329" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:24:25.551606" 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-06-06T03:24:25.549734" elapsed="0.001898"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:25.557522" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.557375" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.557340" elapsed="0.000259"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:25.560423" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.560158" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.560110" elapsed="0.000478"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:25.561879" 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-06-06T03:24:25.561009" elapsed="0.000937"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.562452" level="INFO">${current_connection_index} = 7</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-06-06T03:24:25.562223" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.594659" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:25.563025" elapsed="0.031916"/>
</kw>
<msg time="2026-06-06T03:24:25.595279" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:25.595351" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:25.562663" elapsed="0.032740"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.624713" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:25.596492" elapsed="0.028345"/>
</kw>
<msg time="2026-06-06T03:24:25.625012" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:25.625072" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "C "o "n "f "i "g "u "r "e...</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-06-06T03:24:25.595817" elapsed="0.029292"/>
</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-06-06T03:24:25.625538" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.625230" elapsed="0.000365"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.625188" elapsed="0.000441"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.626151" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:25.625811" elapsed="0.000409"/>
</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-06-06T03:24:25.626518" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.626290" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.626270" elapsed="0.000325"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:25.626637" elapsed="0.000071"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:25.629520" elapsed="0.000175"/>
</kw>
<msg time="2026-06-06T03:24:25.629759" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:25.628405" elapsed="0.001498"/>
</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="NOT RUN" start="2026-06-06T03:24:25.630453" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.630821" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:25.627702" elapsed="0.003314"/>
</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-06-06T03:24:25.627062" elapsed="0.004022"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:25.559193" elapsed="0.071994"/>
</kw>
<msg time="2026-06-06T03:24:25.631358" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:25.631404" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "C "o "n "f "i "g "u "r "e...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:25.557802" elapsed="0.073638"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:25.631630" elapsed="0.000052"/>
</return>
<status status="PASS" start="2026-06-06T03:24:25.631519" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.631499" elapsed="0.000245"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.632177" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.632529" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.632601" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:25.556939" elapsed="0.075790"/>
</kw>
<msg time="2026-06-06T03:24:25.632825" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:25.632869" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "C "o "n "f "i "g "u "r "e...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:25.552084" elapsed="0.080820"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.633260" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.632981" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.632963" elapsed="0.000376"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:25.551925" elapsed="0.081438"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:25.551723" elapsed="0.081678"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:25.548423" elapsed="0.085040"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:25.540064" elapsed="0.093458"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:25.539262" elapsed="0.094309"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:25.531712" elapsed="0.101918"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.634331" level="INFO">&amp;{mapping} = { BGP_RIB=example-bgp-rib | IP=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:25.633842" elapsed="0.000517"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.669059" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:25.668624" elapsed="0.000468"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:25.669945" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:25.669617" elapsed="0.000413">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:25.670127" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:25.669272" elapsed="0.000879"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.670754" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:25.670346" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:25.671094" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:25.671289" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:25.670953" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.671818" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.671544" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.672877" level="INFO">mapping: {'BGP_RIB': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.672586" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.673693" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:25.673122" elapsed="0.000600"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.674443" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:25.674140" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:25.675273" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:25.675042" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:25.675357" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:24:25.675534" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:25.674701" elapsed="0.000858"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:25.675739" elapsed="0.000256"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:25.673990" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.676592" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:25.676295" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:25.677441" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:25.677185" elapsed="0.000283"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:25.677520" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:25.677691" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:25.676824" elapsed="0.000894"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:25.677889" elapsed="0.000230"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:24:25.676156" elapsed="0.002005"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:25.673788" elapsed="0.004408"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:25.678242" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:25.678398" level="INFO">${mapping_to_use} = {'BGP_RIB': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:25.672254" elapsed="0.006170"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.671943" elapsed="0.006514"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.678663" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.678487" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.671919" elapsed="0.006823"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.679533" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:25.678896" elapsed="0.000667"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:25.679613" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:25.667998" elapsed="0.011758"/>
</kw>
<msg time="2026-06-06T03:24:25.679812" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:25.654929" elapsed="0.024936"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.693273" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.706344" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.719196" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.719408" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.719597" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.720002" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.719846" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:25.719828" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.720234" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.720409" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.720591" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:25.719795" elapsed="0.000863"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.719688" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.720849" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.720926" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:25.721083" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:25.650514" elapsed="0.070598"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.749458" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:25.748882" elapsed="0.000605"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:25.750294" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:25.750029" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:25.750475" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:25.749677" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.751133" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:25.750733" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:25.751478" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:25.751669" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:25.751331" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.752117" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.751868" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:25.752548" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.752237" elapsed="0.000371"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.753126" level="INFO">${mapping_to_use} = {'BGP_RIB': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:25.752803" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.752633" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.752216" elapsed="0.000994"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.753953" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:25.753365" elapsed="0.000618"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:25.754034" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:25.748237" elapsed="0.005953"/>
</kw>
<msg time="2026-06-06T03:24:25.754250" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:25.734873" elapsed="0.019425"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.767377" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.780373" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.793714" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.793998" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.794276" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.794746" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.794570" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:25.794548" elapsed="0.000287"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.794985" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.795163" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.795332" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:25.794502" elapsed="0.000882"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.794369" elapsed="0.001045"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.795568" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.795660" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:24:25.795855" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:25.731992" elapsed="0.063897"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:25.797499" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:25.797163" elapsed="0.000421">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:25.797698" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:25.796663" elapsed="0.001060"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.798082" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.797796" elapsed="0.000346"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.798683" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:25.798366" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.798168" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.797777" elapsed="0.000989"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.801206" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:25.798928" elapsed="0.002304"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:25.801286" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:25.801446" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:25.796242" elapsed="0.005228"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.802937" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.802672" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.803390" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.803150" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.803862" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.803597" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.804309" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.804064" elapsed="0.000336"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:25.805357" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:24:25.805125" elapsed="0.000259"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:24:25.805744" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:24:25.805547" elapsed="0.000224"/>
</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-06-06T03:24:25.805930" elapsed="0.000218"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.806562" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.806312" elapsed="0.000294"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:24:25.806670" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:25.806831" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:24:25.804613" elapsed="0.002244"/>
</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-06-06T03:24:25.827232" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:24:25.827379" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:24:25 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:25.827674" 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-06-06T03:24:25.810954" elapsed="0.016789"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.806928" elapsed="0.020934"/>
</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-06-06T03:24:25.828351" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.827930" elapsed="0.000585"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.806909" elapsed="0.021659"/>
</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-06-06T03:24:25.834178" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.830475" elapsed="0.003767"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.830134" elapsed="0.004157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.830105" elapsed="0.004221"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.838119" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:25.834747" elapsed="0.003437"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.834405" elapsed="0.003829"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.834381" elapsed="0.003887"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.839138" 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-06-06T03:24:25.838533" elapsed="0.000643"/>
</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-06-06T03:24:25.839628" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.839276" elapsed="0.000457"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.840437" 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-06-06T03:24:25.840009" elapsed="0.000466"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.839767" elapsed="0.000759"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.839250" elapsed="0.001306"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.841309" 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-06-06T03:24:25.840819" elapsed="0.000518"/>
</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-06-06T03:24:25.841670" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.841408" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.842290" 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-06-06T03:24:25.841983" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:25.841809" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.841389" elapsed="0.000983"/>
</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-06-06T03:24:25.842535" elapsed="0.000378"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:25.843399" 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-06-06T03:24:25.843088" elapsed="0.000337"/>
</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-06-06T03:24:25.843592" elapsed="0.002438"/>
</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-06-06T03:24:25.829558" elapsed="0.016540"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:25.846282" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:24:25.846168" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.846148" elapsed="0.000234"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:24:25.846543" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.846612" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:25.848989" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:24:25.801832" elapsed="0.047185"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:25.849084" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:25.849240" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:25.639237" elapsed="0.210028"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:25.849616" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:25.849364" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.849346" elapsed="0.000379"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:25.849758" elapsed="0.000025"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:24:25.634628" elapsed="0.215253"/>
</kw>
<doc>Configures bgp application peer. Openconfig is used for carbon and above.</doc>
<status status="PASS" start="2026-06-06T03:24:25.529027" elapsed="0.321000"/>
</test>
<test id="s1-s12-t2" name="Reconfigure_ODL_To_Accept_Connection" line="65">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:25.853728" elapsed="0.000217"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:25.853438" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.855042" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.854931" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.854912" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:25.860242" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.860135" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.860117" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.861427" 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-06-06T03:24:25.861035" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:25.861940" 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-06-06T03:24:25.861624" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:25.862011" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:25.862164" 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-06-06T03:24:25.860572" elapsed="0.001617"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:25.868032" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.867921" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.867900" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:25.869338" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:25.869229" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:25.869210" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:25.869900" 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-06-06T03:24:25.869561" elapsed="0.000366"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:25.870321" level="INFO">${current_connection_index} = 7</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-06-06T03:24:25.870097" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.198011" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:25.870884" elapsed="1.327379"/>
</kw>
<msg time="2026-06-06T03:24:27.198518" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:27.198569" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:25.870516" elapsed="1.328089"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.207832" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:24:27.199375" elapsed="0.008664"/>
</kw>
<msg time="2026-06-06T03:24:27.208256" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:27.208304" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "R "e "c "o "n "f "i "g "u...</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-06-06T03:24:27.198908" elapsed="0.009434"/>
</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-06-06T03:24:27.208820" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.208451" elapsed="0.000432"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.208417" elapsed="0.000494"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.209449" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:24:27.209067" elapsed="0.000456"/>
</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-06-06T03:24:27.209844" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.209592" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.209573" elapsed="0.000351"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:27.209962" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:27.213175" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:24:27.213392" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.211591" elapsed="0.001941"/>
</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="NOT RUN" start="2026-06-06T03:24:27.213840" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.214194" elapsed="0.000259"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:27.210929" elapsed="0.003646"/>
</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-06-06T03:24:27.210301" elapsed="0.004368"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:25.868920" elapsed="1.345854"/>
</kw>
<msg time="2026-06-06T03:24:27.214977" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:27.215024" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "R "e "c "o "n "f "i "g "u...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:25.868261" elapsed="1.346800"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:27.215262" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:27.215144" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.215123" elapsed="0.000226"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.215843" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.216199" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.216270" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:25.867558" elapsed="1.348822"/>
</kw>
<msg time="2026-06-06T03:24:27.216477" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:27.216523" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "R "e "c "o "n "f "i "g "u...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:25.862669" elapsed="1.353889"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.216913" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.216635" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.216618" elapsed="0.000373"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:25.862501" elapsed="1.354515"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:25.862308" elapsed="1.354742"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:25.859773" elapsed="1.357336"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:25.854614" elapsed="1.362553"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:25.854163" elapsed="1.363053"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:25.850963" elapsed="1.366306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.218138" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB=example-bgp-rib | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB_OPENCONFIG=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.217455" elapsed="0.000712"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.255679" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.255032" elapsed="0.000713"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.256680" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.256356" elapsed="0.000403">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:27.256857" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.255964" elapsed="0.000919"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.257480" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.257064" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.257849" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:27.258103" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:27.257700" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.258579" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.258317" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.259790" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB': 'example-bgp-rib', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.259483" elapsed="0.000355"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.260303" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.260012" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.261042" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.260739" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.261870" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.261622" elapsed="0.000274"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.261953" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:27.262120" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.261286" elapsed="0.000865"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.262330" elapsed="0.000248"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:27.260577" elapsed="0.002043"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.263231" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.262910" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.264078" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.263858" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.264168" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:24:27.264370" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.263454" elapsed="0.000950"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.264568" elapsed="0.000269"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:27.262767" elapsed="0.002113"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.265656" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.265132" elapsed="0.000553"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.266423" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.266212" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.266500" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:27.266666" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.265882" elapsed="0.000809"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.266852" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:24:27.264993" elapsed="0.002123"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.267685" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.267364" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.268516" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.268302" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.268592" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:27.268763" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.267967" elapsed="0.000821"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.268947" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:24:27.267227" elapsed="0.002038"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.269846" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.269523" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.270656" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.270428" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.270736" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:27.270891" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.270065" elapsed="0.000851"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.271075" elapsed="0.000224"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:24:27.269383" elapsed="0.001958"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.271939" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.271593" elapsed="0.000373"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.272716" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.272486" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.272794" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:27.272945" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.272162" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.273127" elapsed="0.000262"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:27.271453" elapsed="0.001980"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.274019" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.273703" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:27.274860" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.274590" elapsed="0.000302"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:27.274949" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:27.275110" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:27.274260" elapsed="0.000877"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.275305" elapsed="0.000234"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:24:27.273547" elapsed="0.002037"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:27.260388" elapsed="0.015233"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:27.275685" elapsed="0.000062"/>
</return>
<msg time="2026-06-06T03:24:27.275896" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB': 'example-bgp-rib', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:27.259126" elapsed="0.016797"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.258732" elapsed="0.017228"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.276158" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.275988" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.258705" elapsed="0.017536"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.277166" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:27.276404" elapsed="0.000793"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.277252" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:27.254066" elapsed="0.023319"/>
</kw>
<msg time="2026-06-06T03:24:27.277443" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.240292" elapsed="0.037207"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.290861" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.303941" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.316901" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.317146" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.317342" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.317782" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.317609" elapsed="0.000232"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:27.317590" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.318021" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.318202" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.318377" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:27.317550" elapsed="0.000881"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.317428" elapsed="0.001030"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.318614" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.318710" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:27.318866" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:27.235602" elapsed="0.083294"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.346892" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.346467" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.347750" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.347464" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:27.348036" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.347111" elapsed="0.000951"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.348634" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.348240" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.348991" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:27.349156" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:27.348848" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.349605" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.349354" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:27.350082" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.349750" elapsed="0.000391"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.350621" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB': 'example-bgp-rib', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.350321" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.350168" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.349727" elapsed="0.000996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.351555" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:27.350879" elapsed="0.000706"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.351676" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:27.345796" elapsed="0.006019"/>
</kw>
<msg time="2026-06-06T03:24:27.351870" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.332280" elapsed="0.019637"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.364988" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.377832" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.390692" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.390961" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.391152" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.391550" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.391398" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:27.391381" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.391814" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.391991" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.392162" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:27.391347" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.391235" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.392396" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.392474" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:27.392614" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:27.329433" elapsed="0.063224"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.394061" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.393772" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:27.394236" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.393363" elapsed="0.000897"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.394601" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.394331" elapsed="0.000354"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.395198" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.394898" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.394710" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.394312" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.397744" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.395438" elapsed="0.002332"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:27.397823" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:27.397982" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:27.393004" elapsed="0.005003"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.399588" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.399331" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.400077" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.399835" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.400527" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.400284" elapsed="0.000452"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.401145" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.400900" elapsed="0.000289"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:27.402037" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:24:27.401837" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:24:27.402398" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:24:27.402224" elapsed="0.000199"/>
</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-06-06T03:24:27.402579" elapsed="0.000225"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.403216" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.402967" elapsed="0.000294"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:24:27.403304" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:27.403461" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:24:27.401397" elapsed="0.002090"/>
</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-06-06T03:24:27.417487" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Content-Length': '295', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:24:27.417557" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:27.417693" 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-06-06T03:24:27.406071" elapsed="0.011652"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.403560" elapsed="0.014221"/>
</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-06-06T03:24:27.418007" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.417813" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.403541" elapsed="0.014559"/>
</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-06-06T03:24:27.421817" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.419178" elapsed="0.002686"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.418926" elapsed="0.002974"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.418906" elapsed="0.003020"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.424626" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.422223" elapsed="0.002469"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.421984" elapsed="0.002745"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.421967" elapsed="0.002787"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.425379" 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-06-06T03:24:27.424957" elapsed="0.000450"/>
</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-06-06T03:24:27.425749" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.425479" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.426388" 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-06-06T03:24:27.426034" elapsed="0.000383"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.425833" elapsed="0.000620"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.425460" elapsed="0.001016"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.427036" 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-06-06T03:24:27.426664" elapsed="0.000400"/>
</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-06-06T03:24:27.427383" elapsed="0.000101"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.427136" elapsed="0.000388"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.428096" 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-06-06T03:24:27.427789" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.427550" elapsed="0.000608"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.427116" elapsed="0.001065"/>
</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-06-06T03:24:27.428353" elapsed="0.000376"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:27.429207" 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-06-06T03:24:27.428906" elapsed="0.000328"/>
</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-06-06T03:24:27.429402" elapsed="0.002435"/>
</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-06-06T03:24:27.418519" elapsed="0.013389"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:27.432095" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:24:27.431982" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.431961" elapsed="0.000235"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:24:27.432358" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.432428" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:27.435423" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:24:27.398341" elapsed="0.037124"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.435555" elapsed="0.000114"/>
</return>
<msg time="2026-06-06T03:24:27.435822" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:27.223154" elapsed="0.212694"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.436309" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.435967" elapsed="0.000416"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.435944" elapsed="0.000465"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.436443" elapsed="0.000026"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:24:27.218445" elapsed="0.218127"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:24:25.850378" elapsed="1.586340"/>
</test>
<test id="s1-s12-t3" name="L3vpn_Ipv4_To_Odl" line="80">
<kw name="Setup_Testcase" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:27.441586" elapsed="0.000276"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:27.441298" elapsed="0.000621"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.443003" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:27.442881" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.442860" elapsed="0.000213"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.448438" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:27.448290" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.448264" elapsed="0.000259"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.449725" 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-06-06T03:24:27.449248" elapsed="0.000507"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.450252" 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-06-06T03:24:27.449937" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:27.450424" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:24:27.450600" 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-06-06T03:24:27.448839" elapsed="0.001788"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:27.456440" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:27.456320" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.456299" elapsed="0.000211"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:27.457916" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:27.457767" elapsed="0.000263"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.457748" elapsed="0.000310"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:27.458626" 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-06-06T03:24:27.458219" elapsed="0.000450"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.459121" level="INFO">${current_connection_index} = 7</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-06-06T03:24:27.458879" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.492044" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:27.460651" elapsed="0.031623"/>
</kw>
<msg time="2026-06-06T03:24:27.492486" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:27.492535" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:27.459341" elapsed="0.033232"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.516051" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "L "3 "v "p "n "_ "I "p "v "4 "_ "T "o "_ "O "d "l "[K"
[?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-06-06T03:24:27.494321" elapsed="0.021902"/>
</kw>
<msg time="2026-06-06T03:24:27.516392" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:27.516439" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "L "3 "v "p "n "_ "I "p "v...</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-06-06T03:24:27.492915" elapsed="0.023562"/>
</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-06-06T03:24:27.517030" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.516631" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.516599" elapsed="0.000636"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.518010" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "L "3 "v "p "n "_ "I "p "v "4 "_ "T "o "_ "O "d "l "[K"
[?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-06-06T03:24:27.517391" elapsed="0.000735"/>
</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-06-06T03:24:27.518529" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.518227" elapsed="0.000485"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.518205" elapsed="0.000535"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:27.518781" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:27.521675" elapsed="0.000161"/>
</kw>
<msg time="2026-06-06T03:24:27.521880" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.520955" elapsed="0.000997"/>
</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="NOT RUN" start="2026-06-06T03:24:27.522179" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.522404" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:27.520045" elapsed="0.002509"/>
</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-06-06T03:24:27.519119" elapsed="0.003548"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:27.457334" elapsed="0.065493"/>
</kw>
<msg time="2026-06-06T03:24:27.522925" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:27.522970" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "L "3 "v "p "n "_ "I "p "v...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:27.456688" elapsed="0.066320"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:27.523248" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:27.523131" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.523110" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.523822" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.524213" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.524288" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:27.455964" elapsed="0.068434"/>
</kw>
<msg time="2026-06-06T03:24:27.524495" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:27.524539" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "L "3 "v "p "n "_ "I "p "v...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:27.451056" elapsed="0.073521"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.524951" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.524687" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.524637" elapsed="0.000392"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:27.450903" elapsed="0.074151"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:27.450709" elapsed="0.074378"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:27.447795" elapsed="0.077351"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:27.442561" elapsed="0.082644"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:27.442086" elapsed="0.083165"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:27.438405" elapsed="0.086899"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Empty_Reported_Data">
<kw name="Verify_Empty_Data_Neon">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.580199" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.579462" elapsed="0.000772"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.581239" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.580793" elapsed="0.000558">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:27.581523" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.580418" elapsed="0.001131"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.582216" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.581744" elapsed="0.000500"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.582634" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:27.582847" level="INFO">${template} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:27.582413" elapsed="0.000461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.583452" level="INFO">/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.583094" elapsed="0.000431"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.585157" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.584498" elapsed="0.000806"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.586343" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:27.585577" elapsed="0.000846"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.587143" elapsed="0.000072"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.587532" elapsed="0.000145"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.587942" elapsed="0.000069"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:24:27.586869" elapsed="0.001190"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.586513" elapsed="0.001622"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:27.588231" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:27.588531" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:27.583993" elapsed="0.004565"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.583605" elapsed="0.004986"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.588801" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.588617" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.583581" elapsed="0.005299"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.589620" level="INFO">${final_text} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:27.589032" elapsed="0.000679"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.589764" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:27.578823" elapsed="0.011067"/>
</kw>
<msg time="2026-06-06T03:24:27.589945" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.565334" elapsed="0.024661"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.603726" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.616969" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.630060" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.630355" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.630547" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.630980" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.630822" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:27.630805" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.631212" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.631388" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.631577" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:27.630765" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.630631" elapsed="0.001040"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.631828" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.631906" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:27.632047" level="INFO">${uri} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:27.560775" elapsed="0.071301"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.633478" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.633180" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:27.633664" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.632789" elapsed="0.000902"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.634039" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.633762" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.634610" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.634312" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.634122" elapsed="0.000570"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.633743" elapsed="0.000970"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.637163" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.634874" elapsed="0.002320"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:27.637246" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:27.637402" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:27.632416" elapsed="0.005011"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.638631" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:24:27.638435" elapsed="0.000265"/>
</kw>
<msg time="2026-06-06T03:24:27.638785" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.638091" elapsed="0.000718"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.639016" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:27.638879" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.638859" elapsed="0.000265"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.639482" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:27.639658" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:27.639280" elapsed="0.000405"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:24:27.640091" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.639850" elapsed="0.000267"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:24:27.640167" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:27.640326" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:27.637757" elapsed="0.002594"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.641780" level="INFO">/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.641512" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.642232" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.641989" elapsed="0.000286"/>
</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-06-06T03:24:27.653236" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:27.653588" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '154'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:27.653799" 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-06-06T03:24:27.646239" elapsed="0.007592"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.642348" elapsed="0.011550"/>
</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-06-06T03:24:27.654191" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.653939" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.642322" elapsed="0.011962"/>
</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-06-06T03:24:27.658501" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.655575" elapsed="0.002976"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.655271" elapsed="0.003316"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.655249" elapsed="0.003362"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.661358" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.658920" elapsed="0.002485"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.658686" elapsed="0.002754"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.658667" elapsed="0.002798"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.662113" 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-06-06T03:24:27.661689" elapsed="0.000450"/>
</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-06-06T03:24:27.662464" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.662215" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.663043" 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-06-06T03:24:27.662739" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.662546" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.662196" elapsed="0.000930"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.663689" 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-06-06T03:24:27.663296" elapsed="0.000421"/>
</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-06-06T03:24:27.664033" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.663788" elapsed="0.000367"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.664673" 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-06-06T03:24:27.664356" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.664183" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.663769" elapsed="0.000989"/>
</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-06-06T03:24:27.664922" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:27.665780" 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-06-06T03:24:27.665446" elapsed="0.000360"/>
</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-06-06T03:24:27.665971" elapsed="0.002437"/>
</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-06-06T03:24:27.654756" elapsed="0.013719"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.668674" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:27.668545" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.668527" elapsed="0.000220"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:27.671694" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:24:27.668899" elapsed="0.002825"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:24:27.671778" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:24:27.671947" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:24:27.640683" elapsed="0.031291"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.672038" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:24:27.672188" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:27.537027" elapsed="0.135187"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.747188" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.746276" elapsed="0.001003"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.748691" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.748387" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:27.748958" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:27.747656" elapsed="0.001383"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.750405" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.749323" elapsed="0.001164"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:27.751128" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:27.751454" level="INFO">${template} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:27.750761" elapsed="0.000777"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.752500" level="INFO">{
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
                "uptodate": "*"
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.751879" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:27.753818" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.752816" elapsed="0.001106"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.754985" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.754304" elapsed="0.000717"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.753984" elapsed="0.001089"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.752775" elapsed="0.002355"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.756325" level="INFO">${final_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:27.755362" elapsed="0.001044"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.756496" elapsed="0.000040"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:27.744541" elapsed="0.012256"/>
</kw>
<msg time="2026-06-06T03:24:27.756857" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.687521" elapsed="0.069396"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.770281" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.783180" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.796493" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.796729" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.796942" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.797400" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.797240" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:27.797224" elapsed="0.000405"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.797811" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.797986" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.798180" elapsed="0.000076"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:27.797183" elapsed="0.001110"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.797031" elapsed="0.001291"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.798480" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:27.798559" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:27.798711" level="INFO">${expected_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:27.684726" elapsed="0.114013"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.798926" elapsed="0.002387"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:27.802519" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.802118" elapsed="0.000430"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:27.803112" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:27.802753" elapsed="0.000393"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:27.803327" elapsed="0.000536"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:27.801672" elapsed="0.002255"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.801396" elapsed="0.002566"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:27.804147" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:27.803988" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.801376" elapsed="0.002875"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:24:27.673385" elapsed="0.130920"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:24:27.672555" elapsed="0.131830"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.672298" elapsed="0.132134"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.672280" elapsed="0.132178"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:27.804492" elapsed="0.000030"/>
</return>
<arg>${BGP_L3VPN_DIR}${/}empty_route</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:24:27.530506" elapsed="0.274119"/>
</kw>
<doc>Verify empty data on neon</doc>
<status status="PASS" start="2026-06-06T03:24:27.526276" elapsed="0.278435"/>
</kw>
<doc>Verfiy empty data response</doc>
<status status="PASS" start="2026-06-06T03:24:27.526026" elapsed="0.278735"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Empty_Reported_Data</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:27.525470" elapsed="0.279334"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.808308" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug bgp-l3vpn-ipv4.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.807957" elapsed="0.000379"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.808776" level="INFO">env exabgp.tcp.port=1790 exabgp --debug bgp-l3vpn-ipv4.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.808506" elapsed="0.000316"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.812250" level="INFO">source /tmp/defaultvenv/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-06-06T03:24:27.809459" elapsed="0.002882"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.818020" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:24:27.818164" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:24:27.812715" elapsed="0.005489"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.819097" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.818721" elapsed="0.000445"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:27.818309" elapsed="0.000907"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:27.818280" elapsed="0.000974"/>
</if>
<arg>log_output=${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-06-06T03:24:27.809072" elapsed="0.010303"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:27.821632" level="INFO">env exabgp.tcp.port=1790 exabgp --debug bgp-l3vpn-ipv4.cfg</msg>
<msg time="2026-06-06T03:24:27.821739" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug bgp-l3vpn-ipv4.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:27.819613" elapsed="0.002153"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.822182" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug bgp-l3vpn-ipv4.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.821935" elapsed="0.000292"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:27.807596" elapsed="0.014686"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.824298" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:27.823933" elapsed="0.000391"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.826732" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:27.824497" elapsed="0.002263"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:27.832193" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:27.832354" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:27.832457" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:27.826935" elapsed="0.005549"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.835262" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:27.832696" elapsed="0.002641"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:24:27.838212" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:24:27.835511" elapsed="0.002786">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:24:27.823400" elapsed="0.015019">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.842038" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:30.840981" elapsed="0.001135"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.847952" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:30.842741" elapsed="0.005281"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:30.857080" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:30.858228" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '1671'} 
 body={"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":true},"bgp-vpn-ipv4:vpn-ipv4-routes":{"vpn-route":[{"path-id":0,"route-key":"WAABAQIDBAABAQEB","route-distinguisher":"1.2.3.4:1","prefix":"1.1.1.0/24","attributes":{"origin":{"value":"igp"},"ipv4-next-hop":{"global":"10.0.255.254"},"local-pref":{"pref":100}},"label-stack":[{"label-value":24005}]}]}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":true},"bgp-vpn-ipv4:vpn-ipv4-routes":{"vpn-route":[{"path-id":0,"route-key":"WAABAQIDBAABAQEB","route-distinguisher":"1.2.3.4:1","prefix":"1.1.1.0/24","attributes":{"origin":{"value":"igp"},"ipv4-next-hop":{"global":"10.0.255.254"},"local-pref":{"pref":100}},"label-stack":[{"label-value":24005}]}]}}]},"peer-role":"ibgp"}]} 
 </msg>
<msg time="2026-06-06T03:24:30.858423" level="INFO">${rsp} = &lt;Response [200]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:30.848538" elapsed="0.009916"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.861521" level="INFO">{"bgp-rib:peer":[{"peer-id":"bgp://10.30.171.194","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":true},"bgp-vpn-ipv4:vpn-ipv4-routes":{"vpn-route":[{"path-id":0,"route-key":"WAABAQIDBAABAQEB","route-distinguisher":"1.2.3.4:1","prefix":"1.1.1.0/24","attributes":{"origin":{"value":"igp"},"ipv4-next-hop":{"global":"10.0.255.254"},"local-pref":{"pref":100}},"label-stack":[{"label-value":24005}]}]}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":true},"bgp-vpn-ipv4:vpn-ipv4-routes":{"vpn-route":[{"path-id":0,"route-key":"WAABAQIDBAABAQEB","route-distinguisher":"1.2.3.4:1","prefix":"1.1.1.0/24","attributes":{"origin":{"value":"igp"},"ipv4-next-hop":{"global":"10.0.255.254"},"local-pref":{"pref":100}},"label-stack":[{"label-value":24005}]}]}}]},"peer-role":"ibgp"}]}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.858672" elapsed="0.002934"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="PASS" start="2026-06-06T03:24:30.861892" elapsed="0.003682"/>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="PASS" start="2026-06-06T03:24:30.839534" elapsed="0.026158"/>
</kw>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:27.822863" elapsed="3.042908"/>
</kw>
<msg time="2026-06-06T03:24:30.865923" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:30.865986" level="INFO">${value} = None</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:27.822450" elapsed="3.043569"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.866582" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:30.866161" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.866124" elapsed="0.000600"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="PASS" start="2026-06-06T03:24:30.866964" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:24:30.866804" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.866782" elapsed="0.000310"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:24:27.807392" elapsed="3.059740"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:24:27.807122" elapsed="3.060059"/>
</for>
<kw name="Fail" owner="BuiltIn">
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.867445" elapsed="0.000034"/>
</kw>
<arg>${cfg_file}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>connection_retries=${3}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="PASS" start="2026-06-06T03:24:27.805124" elapsed="3.062444"/>
</kw>
<arg>${L3VPN_EXA_CFG}</arg>
<doc>Verifies initial test condition and starts the exabgp</doc>
<status status="PASS" start="2026-06-06T03:24:27.437978" elapsed="3.429706"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Reported_Data">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.924806" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:30.924363" elapsed="0.000477"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:30.925733" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:30.925435" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:30.925906" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:30.925068" elapsed="0.000862"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.926503" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:30.926106" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:30.926864" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:30.927107" level="INFO">${template} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:30.926718" elapsed="0.000417"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.927563" level="INFO">/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.927305" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.928755" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.928426" elapsed="0.000375"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.929261" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:30.928985" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.929631" elapsed="0.000046"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.929871" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.930053" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:24:30.929488" elapsed="0.000621"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:24:30.929343" elapsed="0.000797"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:30.930189" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:30.930355" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:30.928085" elapsed="0.002296"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:30.927710" elapsed="0.002703"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.930591" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:30.930438" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.927685" elapsed="0.003021"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.931312" level="INFO">${final_text} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:30.930860" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:30.931392" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:30.923637" elapsed="0.007878"/>
</kw>
<msg time="2026-06-06T03:24:30.931570" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:30.910299" elapsed="0.021320"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.945123" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.957999" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.970920" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.971173" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.971363" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.971756" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:30.971588" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:30.971572" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.971983" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.972156" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.972329" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:30.971541" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:30.971440" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.972562" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:30.972652" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:30.972782" level="INFO">${uri} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:30.905710" elapsed="0.067099"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:30.974139" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:30.973876" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:30.974303" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:30.973499" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.974673" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:30.974399" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.975234" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:30.974943" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:30.974757" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.974380" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.977738" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:30.975475" elapsed="0.002291"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:30.977818" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:30.977971" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:30.973156" elapsed="0.004840"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:30.979269" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:30.979030" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:30.979426" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:30.978682" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:30.979673" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:24:30.979521" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.979502" elapsed="0.000295"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.979954" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:30.980134" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:30.980200" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:30.982365" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:30.978306" elapsed="0.004086"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.983817" level="INFO">/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.983547" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.984267" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.984025" elapsed="0.000285"/>
</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-06-06T03:24:30.992724" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:30.993077" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '295'} 
 body={"bgp-vpn-ipv4:vpn-ipv4-routes":{"vpn-route":[{"path-id":0,"route-key":"WAABAQIDBAABAQEB","route-distinguisher":"1.2.3.4:1","prefix":"1.1.1.0/24","attributes":{"origin":{"value":"igp"},"ipv4-next-hop":{"global":"10.0.255.254"},"local-pref":{"pref":100}},"label-stack":[{"label-value":24005}]}]}} 
 </msg>
<msg time="2026-06-06T03:24:30.993196" 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-06-06T03:24:30.986521" elapsed="0.006703"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:30.984376" elapsed="0.008893"/>
</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-06-06T03:24:30.993460" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:30.993296" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.984357" elapsed="0.009189"/>
</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-06-06T03:24:30.997136" level="INFO">{"bgp-vpn-ipv4:vpn-ipv4-routes":{"vpn-route":[{"path-id":0,"route-key":"WAABAQIDBAABAQEB","route-distinguisher":"1.2.3.4:1","prefix":"1.1.1.0/24","attributes":{"origin":{"value":"igp"},"ipv4-next-hop":{"global":"10.0.255.254"},"local-pref":{"pref":100}},"label-stack":[{"label-value":24005}]}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.994598" elapsed="0.002587"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:30.994366" elapsed="0.002855"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.994347" elapsed="0.002899"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:30.999937" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:30.997533" elapsed="0.002451"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:30.997304" elapsed="0.002715"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:30.997286" elapsed="0.002758"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.000609" 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-06-06T03:24:31.000221" elapsed="0.000430"/>
</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-06-06T03:24:31.001005" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.000727" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.001702" 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-06-06T03:24:31.001258" elapsed="0.000484"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.001088" elapsed="0.000704"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.000708" elapsed="0.001114"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.002559" 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-06-06T03:24:31.002056" elapsed="0.000540"/>
</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-06-06T03:24:31.003060" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.002720" elapsed="0.000420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.003907" 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-06-06T03:24:31.003465" elapsed="0.000481"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.003224" elapsed="0.000773"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.002693" elapsed="0.001334"/>
</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-06-06T03:24:31.004248" elapsed="0.000512"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:31.005429" 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-06-06T03:24:31.005018" elapsed="0.000448"/>
</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-06-06T03:24:31.005715" elapsed="0.003362"/>
</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-06-06T03:24:30.993931" elapsed="0.015236"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.009416" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.009266" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.009239" elapsed="0.000272"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:31.013775" level="INFO">${text_normalized} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<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="PASS" start="2026-06-06T03:24:31.009748" elapsed="0.004057"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:24:31.013857" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:31.014018" level="INFO">${response_text} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:24:30.982725" elapsed="0.031319"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.014107" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:24:31.014261" level="INFO">${response_text} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:30.881929" elapsed="0.132358"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.043576" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.042936" elapsed="0.000668"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.044622" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:31.044148" elapsed="0.000615">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:31.044954" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:31.043806" elapsed="0.001174"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.045594" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:31.045153" elapsed="0.000468"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.045966" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:31.046137" level="INFO">${template} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:31.045805" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.046668" level="INFO">{
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origin": {
      "value": "igp"
     }
    },
    "label-stack": [
     {
      "label-value": 24005
     }
    ],
    "path-id": 0,
    "prefix": "1.1.1.0/24",
    "route-distinguisher": "1.2.3.4:1",
    "route-key": "WAABAQIDBAABAQEB"
   }
  ]
 }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.046379" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:31.047197" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.046787" elapsed="0.000471"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.047976" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.047435" elapsed="0.000567"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.047283" elapsed="0.000756"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.046767" elapsed="0.001293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.048712" level="INFO">${final_text} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:31.048215" elapsed="0.000526"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.048791" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:31.042297" elapsed="0.006647"/>
</kw>
<msg time="2026-06-06T03:24:31.049000" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:31.029164" elapsed="0.019885"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.062406" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.075376" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/bgp_l3vpn_ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.088587" elapsed="0.000071"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.088936" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.089138" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.089613" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.089430" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:31.089411" elapsed="0.000310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.089875" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.090049" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.090307" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:31.089371" elapsed="0.000992"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.089229" elapsed="0.001163"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.090549" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.090631" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:31.090801" level="INFO">${expected_text} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:31.026419" elapsed="0.064411"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:31.091019" elapsed="0.002402"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:31.094778" level="INFO">${expected_normalized} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:31.094243" elapsed="0.000565"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:31.095394" level="INFO">${actual_normalized} = {
 "bgp-vpn-ipv4:vpn-ipv4-routes": {
  "vpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "10.0.255.254"
     },
     "local-pref": {
      "pref": 100
     },
     "origi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:31.094971" elapsed="0.000451"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:31.095587" elapsed="0.000356"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:31.093801" elapsed="0.002203"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.093503" elapsed="0.002535"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.096220" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.096064" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.093483" elapsed="0.002820"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:24:31.015447" elapsed="0.080905"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:24:31.014619" elapsed="0.081813"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.014371" elapsed="0.082108"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.014354" elapsed="0.082150"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.096540" elapsed="0.000033"/>
</return>
<arg>${BGP_L3VPN_DIR}${/}${exprspdir}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:24:30.874836" elapsed="0.221854"/>
</kw>
<arg>${L3VPN_RSP}</arg>
<doc>Verifies expected response</doc>
<status status="PASS" start="2026-06-06T03:24:30.868583" elapsed="0.228173"/>
</kw>
<arg>15s</arg>
<arg>1s</arg>
<arg>Verify_Reported_Data</arg>
<arg>${L3VPN_RSP}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:30.867949" elapsed="0.228855"/>
</kw>
<kw name="Teardown_Simple" type="TEARDOWN">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.097887" level="INFO">[?2004l03:24:27 | 3251   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:24:27 | 3251   | [01;34mversion      [0m | [1m4.2.17  [0m
03:24:27 | 3251   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:24:27 | 3251   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:24:27 | 3251   | [01;34minstallation [0m | [1m        [0m
03:24:27 | 3251   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:24:27 | 3251   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:24:27 | 3251   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:24:27 | 3251   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:24:27 | 3251   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:24:27 | 3251   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:24:27 | 3251   | configuration[0m | . local-as         | '64496'[0m
03:24:27 | 3251   | configuration[0m | . peer-as          | '64496'[0m
03:24:27 | 3251   | configuration[0m | &gt; family           | [0m
03:24:27 | 3251   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:24:27 | 3251   | configuration[0m | &lt; family           | [0m
03:24:27 | 3251   | configuration[0m | &gt; static           | [0m
03:24:27 | 3251   | configuration[0m | &gt; route            | '1.1.1.0/24'[0m
03:24:27 | 3251   | configuration[0m | . next-hop         | '10.0.255.254'[0m
03:24:27 | 3251   | configuration[0m | . rd               | '1.2.3.4:1'[0m
03:24:27 | 3251   | configuration[0m | . label            | '24005'[0m
03:24:27 | 3251   | configuration[0m | &lt; route            | [0m
03:24:27 | 3251   | configuration[0m | &lt; static           | [0m
03:24:27 | 3251   | configuration[0m | &lt; neighbor         | [0m
03:24:27 | 3251   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:24:27 | 3251   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:24:27 | 3251   | reactor      [0m | initialising connection to peer-1[0m
03:24:27 | 3251   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:24:27 | 3251   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 8002 0641 0400 00FB F002 0206 00[0m
03:24:27 | 3251   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 mpls-vpn), Extended Message(65535), ASN4(64496)][0m
03:24:27 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 00D9 01[0m
03:24:27 | 3251   | outgoing-1   [0m | received complete TCP payload ( 198) 04FB F000 B4C0 0002 02BC 02BA 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0001 0004 0104 0001 0085 0104 0002 0004 0104 0001 0081 0104 0001 0084 0104 0002 0081 0104 0002 0080 0104 0001 0086 0104 0002 0086 0104 0002 0085 0104 0002 0005 0104 0001 0080 0104 0001 0005 0104 4004 0047 0104 0019 0046 0104 0002 0001 4046 003C 0002 8500 0002 0500 0001 8000 4004 4700 0002 8100 0001 0400 0001 0100 0001 8600 0002 8000 0001 8500 0019 4600 0002 0400 0002 0100 0001 0500 0001 8400 0002 8600 0001 8100 4700[0m
03:24:27 | 3251   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:24:27 | 3251   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv4 nlri-mpls,ipv4 flow,ipv6 nlri-mpls,ipv4 unknown safi 129,ipv4 rtc,ipv6 unknown safi 129,ipv6 mpls-vpn,ipv4 flow-vpn,ipv6 flow-vpn,ipv6 flow,ipv6 unknown safi 5,ipv4 mpls-vpn,ipv4 unknown safi 5,bgp-ls bgp-ls,l2vpn evpn,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 60 ipv6/flow=0x0 ipv6/unknown safi 5=0x0 ipv4/mpls-vpn=0x0 bgp-ls/bgp-ls=0x0 ipv6/unknown safi 129=0x0 ipv4/nlri-mpls=0x0 ipv4/unicast=0x0 ipv4/flow-vpn=0x0 ipv6/mpls-vpn=0x0 ipv4/flow=0x0 l2vpn/evpn=0x0 ipv6/nlri-mpls=0x0 ipv6/unicast=0x0 ipv4/unknown safi 5=0x0 ipv4/rtc=0x0 ipv6/flow-vpn=0x0 ipv4/unknown safi 129=0x0, ASN4(64496), Unassigned 71][0m
03:24:27 | 3251   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1mthe connection can not carry the following family/families[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/nlri-mpls[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/unicast[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unknown safi 5[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/unknown safi 129[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for l2vpn/evpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/flow[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/unknown safi 5[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/flow-vpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unicast[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/nlri-mpls[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unknown safi 129[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/mpls-vpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/rtc[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow-vpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for bgp-ls/bgp-ls[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1mtherefore no routes of this kind can be announced on the connection[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:24:27 | 3251   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:24:27 | 3251   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:24:27 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:24:27 | 3251   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:24:27 | 3251   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:24:27 | 3251   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:24:27 | 3251   | outgoing-1   [0m | sending TCP payload (  79) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004F 0200 0000 3840 0101 0040 0200 4003 040A 00FF FE40 0504 0000 0064 800E 2000 0180 0C00 0000 0000 0000 000A 00FF FE00 7005 DC51 0001 0102 0304 0001 0101 01[0m
03:24:27 | 3251   | outgoing-1   [0m | &gt;&gt; 1 UPDATE(s)[0m
03:24:28 | 3251   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:24:28 | 3251   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:24:28 | 3251   | outgoing-1   [0m | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0180[0m
03:24:28 | 3251   | outgoing-1   [0m | &gt;&gt; EOR ipv4 mpls-vpn[0m
03:24:28 | 3251   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:24:28 | 3251   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:24:28 | 3251   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:24:28 | 3251   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:24:28 | 3251   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  10) 0000 0006 800F 0300 0180[0m
03:24:28 | 3251   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:24:28 | 3251   | parser       [0m | parsing UPDATE (  10) 0000 0006 800F 0300 0180[0m
03:24:28 | 3251   | routes       [0m | withdrawn NLRI none[0m
03:24:28 | 3251   | parser       [0m | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0001 80[0m
03:24:28 | 3251   | routes       [0m | announced NLRI none[0m
03:24:28 | 3251   | peer-1       [0m | &lt;&lt; UPDATE #2[0m
03:24:28 | 3251   | peer-1       [0m |    UPDATE #2 nlri  (  11) eor 1/128 (ipv4 mpls-vpn)[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:24:28 | 3251   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:24:28 | 3251   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:24:28 | 3251   | peer-1       [0m | &lt;&lt; UPDATE #3[0m
03:24:28 | 3251   | peer-1       [0m |    UPDATE #3 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:24:29 | 3251   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:24:29 | 3251   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
03:24:29 | 3251   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:24:29 | 3251   | ka-outgoing-1[0m | send-timer 57 second(s) left[0m
03:24:31 | 3251   | ka-outgoing-1[0m | receive-timer 177 second(s) left[0m
03:24:31 | 3251   | ka-outgoing-1[0m | send-timer 56 second(s) left[0m</msg>
<msg time="2026-06-06T03:24:31.098371" level="INFO">${output} = [?2004l03:24:27 | 3251   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:24:27 | 3251   | [01;34mversion      [0m | [1m4.2.17  [0m
03:24:27 | 3251   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:24:31.097743" elapsed="0.000661"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.098858" level="INFO">[?2004l03:24:27 | 3251   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:24:27 | 3251   | [01;34mversion      [0m | [1m4.2.17  [0m
03:24:27 | 3251   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:24:27 | 3251   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:24:27 | 3251   | [01;34minstallation [0m | [1m        [0m
03:24:27 | 3251   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:24:27 | 3251   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:24:27 | 3251   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:24:27 | 3251   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:24:27 | 3251   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:24:27 | 3251   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:24:27 | 3251   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:24:27 | 3251   | configuration[0m | . local-as         | '64496'[0m
03:24:27 | 3251   | configuration[0m | . peer-as          | '64496'[0m
03:24:27 | 3251   | configuration[0m | &gt; family           | [0m
03:24:27 | 3251   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:24:27 | 3251   | configuration[0m | &lt; family           | [0m
03:24:27 | 3251   | configuration[0m | &gt; static           | [0m
03:24:27 | 3251   | configuration[0m | &gt; route            | '1.1.1.0/24'[0m
03:24:27 | 3251   | configuration[0m | . next-hop         | '10.0.255.254'[0m
03:24:27 | 3251   | configuration[0m | . rd               | '1.2.3.4:1'[0m
03:24:27 | 3251   | configuration[0m | . label            | '24005'[0m
03:24:27 | 3251   | configuration[0m | &lt; route            | [0m
03:24:27 | 3251   | configuration[0m | &lt; static           | [0m
03:24:27 | 3251   | configuration[0m | &lt; neighbor         | [0m
03:24:27 | 3251   | reactor      [0m | new peer: neighbor 10.30.170.38 local-ip 10.30.171.194 local-as 64496 peer-as 64496 router-id 10.30.171.194 family-allowed in-open[0m
03:24:27 | 3251   | [01;34mreactor      [0m | [1mloaded new configuration successfully[0m
03:24:27 | 3251   | reactor      [0m | initialising connection to peer-1[0m
03:24:27 | 3251   | outgoing-1   [0m | attempting connection to 10.30.170.38:1790[0m
03:24:27 | 3251   | outgoing-1   [0m | sending TCP payload (  49) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0031 0104 FBF0 00B4 0A1E ABC2 1402 0601 0400 0100 8002 0641 0400 00FB F002 0206 00[0m
03:24:27 | 3251   | outgoing-1   [0m | &gt;&gt; OPEN version=4 asn=64496 hold_time=180 router_id=10.30.171.194 capabilities=[Multiprotocol(ipv4 mpls-vpn), Extended Message(65535), ASN4(64496)][0m
03:24:27 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 00D9 01[0m
03:24:27 | 3251   | outgoing-1   [0m | received complete TCP payload ( 198) 04FB F000 B4C0 0002 02BC 02BA 4104 0000 FBF0 0600 0200 0104 0001 0001 0104 0001 0004 0104 0001 0085 0104 0002 0004 0104 0001 0081 0104 0001 0084 0104 0002 0081 0104 0002 0080 0104 0001 0086 0104 0002 0086 0104 0002 0085 0104 0002 0005 0104 0001 0080 0104 0001 0005 0104 4004 0047 0104 0019 0046 0104 0002 0001 4046 003C 0002 8500 0002 0500 0001 8000 4004 4700 0002 8100 0001 0400 0001 0100 0001 8600 0002 8000 0001 8500 0019 4600 0002 0400 0002 0100 0001 0500 0001 8400 0002 8600 0001 8100 4700[0m
03:24:27 | 3251   | outgoing-1   [0m | &lt;&lt; message of type OPEN[0m
03:24:27 | 3251   | outgoing-1   [0m | &lt;&lt; OPEN version=4 asn=64496 hold_time=180 router_id=192.0.2.2 capabilities=[Multiprotocol(ipv4 unicast,ipv4 nlri-mpls,ipv4 flow,ipv6 nlri-mpls,ipv4 unknown safi 129,ipv4 rtc,ipv6 unknown safi 129,ipv6 mpls-vpn,ipv4 flow-vpn,ipv6 flow-vpn,ipv6 flow,ipv6 unknown safi 5,ipv4 mpls-vpn,ipv4 unknown safi 5,bgp-ls bgp-ls,l2vpn evpn,ipv6 unicast), Route Refresh, Extended Message(65535), Graceful Restart Flags 0x0 Time 60 ipv6/flow=0x0 ipv6/unknown safi 5=0x0 ipv4/mpls-vpn=0x0 bgp-ls/bgp-ls=0x0 ipv6/unknown safi 129=0x0 ipv4/nlri-mpls=0x0 ipv4/unicast=0x0 ipv4/flow-vpn=0x0 ipv6/mpls-vpn=0x0 ipv4/flow=0x0 l2vpn/evpn=0x0 ipv6/nlri-mpls=0x0 ipv6/unicast=0x0 ipv4/unknown safi 5=0x0 ipv4/rtc=0x0 ipv6/flow-vpn=0x0 ipv4/unknown safi 129=0x0, ASN4(64496), Unassigned 71][0m
03:24:27 | 3251   | ka-outgoing-1[0m | receive-timer 60 second(s) left[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1mthe connection can not carry the following family/families[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/nlri-mpls[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/unicast[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unknown safi 5[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/unknown safi 129[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for l2vpn/evpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/flow[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/unknown safi 5[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/flow-vpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unicast[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/nlri-mpls[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/unknown safi 129[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/mpls-vpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv4/rtc[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for ipv6/flow-vpn[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m - exabgp is not configured for bgp-ls/bgp-ls[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1mtherefore no routes of this kind can be announced on the connection[0m
03:24:27 | 3251   | [01;33moutgoing-1   [0m | [1m--------------------------------------------------------------------[0m
03:24:27 | 3251   | outgoing-1   [0m | sending TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:24:27 | 3251   | outgoing-1   [0m | &gt;&gt; KEEPALIVE (OPENCONFIRM)[0m
03:24:27 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0013 04[0m
03:24:27 | 3251   | outgoing-1   [0m | &lt;&lt; message of type KEEPALIVE[0m
03:24:27 | 3251   | ka-outgoing-1[0m | receive-timer 180 second(s) left[0m
03:24:27 | 3251   | [01;34mreactor      [0m | [1mconnected to peer-1 with outgoing-1 10.30.171.194-10.30.170.38[0m
03:24:27 | 3251   | outgoing-1   [0m | sending TCP payload (  79) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 004F 0200 0000 3840 0101 0040 0200 4003 040A 00FF FE40 0504 0000 0064 800E 2000 0180 0C00 0000 0000 0000 000A 00FF FE00 7005 DC51 0001 0102 0304 0001 0101 01[0m
03:24:27 | 3251   | outgoing-1   [0m | &gt;&gt; 1 UPDATE(s)[0m
03:24:28 | 3251   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:24:28 | 3251   | ka-outgoing-1[0m | send-timer 59 second(s) left[0m
03:24:28 | 3251   | outgoing-1   [0m | sending TCP payload (  30) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001E 0200 0000 0790 0F00 0300 0180[0m
03:24:28 | 3251   | outgoing-1   [0m | &gt;&gt; EOR ipv4 mpls-vpn[0m
03:24:28 | 3251   | peer-1       [0m | &gt;&gt; EOR(s)[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:24:28 | 3251   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:24:28 | 3251   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:24:28 | 3251   | peer-1       [0m | &lt;&lt; UPDATE #1[0m
03:24:28 | 3251   | peer-1       [0m |    UPDATE #1 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 001D 02[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  10) 0000 0006 800F 0300 0180[0m
03:24:28 | 3251   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:24:28 | 3251   | parser       [0m | parsing UPDATE (  10) 0000 0006 800F 0300 0180[0m
03:24:28 | 3251   | routes       [0m | withdrawn NLRI none[0m
03:24:28 | 3251   | parser       [0m | attribute mp-unreach-nlri    flag 0x80 type 0x0f len 0x03 payload 0001 80[0m
03:24:28 | 3251   | routes       [0m | announced NLRI none[0m
03:24:28 | 3251   | peer-1       [0m | &lt;&lt; UPDATE #2[0m
03:24:28 | 3251   | peer-1       [0m |    UPDATE #2 nlri  (  11) eor 1/128 (ipv4 mpls-vpn)[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (  19) FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF 0017 02[0m
03:24:28 | 3251   | outgoing-1   [0m | received complete TCP payload (   4) 0000 0000[0m
03:24:28 | 3251   | outgoing-1   [0m | &lt;&lt; message of type UPDATE[0m
03:24:28 | 3251   | parser       [0m | parsing UPDATE (   4) 0000 0000[0m
03:24:28 | 3251   | peer-1       [0m | &lt;&lt; UPDATE #3[0m
03:24:28 | 3251   | peer-1       [0m |    UPDATE #3 nlri  (   4) eor 1/1 (ipv4 unicast)[0m
03:24:29 | 3251   | ka-outgoing-1[0m | receive-timer 179 second(s) left[0m
03:24:29 | 3251   | ka-outgoing-1[0m | send-timer 58 second(s) left[0m
03:24:29 | 3251   | ka-outgoing-1[0m | receive-timer 178 second(s) left[0m
03:24:29 | 3251   | ka-outgoing-1[0m | send-timer 57 second(s) left[0m
03:24:31 | 3251   | ka-outgoing-1[0m | receive-timer 177 second(s) left[0m
03:24:31 | 3251   | ka-outgoing-1[0m | send-timer 56 second(s) left[0m
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.098569" elapsed="0.000533"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.099986" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:31.099656" elapsed="0.000358"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:31.100176" elapsed="0.000290"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:24:31.099319" elapsed="0.001208"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.230993" level="INFO">^C03:24:31 | 3251   | [00;31mreactor      [0m | [1m^C received[0m
03:24:31 | 3251   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:24:31 | 3251   | outgoing-1   [0m | stop, message [shutting down][0m
03:24:31 | 3251   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:24:31.231225" level="INFO">${output} = ^C03:24:31 | 3251   | [00;31mreactor      [0m | [1m^C received[0m
03:24:31 | 3251   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:24:31 | 3251   | outgoing-1   [0m | stop, messag...</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:24:31.100713" elapsed="0.130547"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.231912" level="INFO">^C03:24:31 | 3251   | [00;31mreactor      [0m | [1m^C received[0m
03:24:31 | 3251   | [00;31mreactor      [0m | [1mperforming shutdown[0m
03:24:31 | 3251   | outgoing-1   [0m | stop, message [shutting down][0m
03:24:31 | 3251   | [01;33moutgoing-1   [0m | [1moutgoing-1 10.30.171.194-10.30.170.38, closing connection[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.231534" elapsed="0.000438"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.234021" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:31.232747" elapsed="0.001332"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.235195" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:24:31.235283" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:24:31.234249" elapsed="0.001060"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.236238" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.235978" elapsed="0.000310"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.235393" elapsed="0.000930"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.235368" elapsed="0.000983"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:24:31.232271" elapsed="0.004131"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:24:31.097426" elapsed="0.139031"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Empty_Reported_Data">
<kw name="Verify_Empty_Data_Neon">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.290559" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.289882" elapsed="0.000708"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.291552" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:31.291152" elapsed="0.000513">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:31.291837" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:31.290796" elapsed="0.001067"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.292525" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:31.292041" elapsed="0.000512"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.292986" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:31.293159" level="INFO">${template} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:31.292761" elapsed="0.000425"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.293698" level="INFO">/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.293351" elapsed="0.000395"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.295747" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.294943" elapsed="0.000952"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.297153" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:31.296176" elapsed="0.001061"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.297976" elapsed="0.000071"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.298350" elapsed="0.000131"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.298774" elapsed="0.000071"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:24:31.297692" elapsed="0.001203"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.297332" elapsed="0.001640"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:31.299070" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:24:31.299380" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:31.294241" elapsed="0.005165"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.293827" elapsed="0.005611"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.299620" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.299465" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.293801" elapsed="0.005958"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.300500" level="INFO">${final_text} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:31.299910" elapsed="0.000618"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.300577" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:31.289185" elapsed="0.011560"/>
</kw>
<msg time="2026-06-06T03:24:31.300801" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:31.275810" elapsed="0.025054"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.313892" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.326683" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.339500" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.339715" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.339900" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.340390" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.340171" elapsed="0.000278"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:31.340156" elapsed="0.000318"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.340625" elapsed="0.000053"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.340842" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.341018" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:31.340125" elapsed="0.000946"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.339975" elapsed="0.001121"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.341249" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.341324" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:24:31.341446" level="INFO">${uri} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:31.271375" elapsed="0.070098"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.342805" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:31.342535" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:31.342961" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:31.342180" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.343310" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.343056" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.343893" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.343580" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.343392" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.343037" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.346543" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:31.344135" elapsed="0.002435"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:31.346622" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:24:31.346793" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:31.341820" elapsed="0.004997"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.348030" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:24:31.347845" elapsed="0.000238"/>
</kw>
<msg time="2026-06-06T03:24:31.348167" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:31.347484" elapsed="0.000707"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.348403" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.348262" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.348243" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.348822" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:31.348947" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:31.348619" elapsed="0.000353"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:24:31.349407" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:24:31.349171" elapsed="0.000264"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:24:31.349482" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:31.349635" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:31.347127" elapsed="0.002549"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.351104" level="INFO">/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.350856" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.351550" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.351309" elapsed="0.000285"/>
</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-06-06T03:24:31.360219" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:31.360474" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '153'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":true}}]} 
 </msg>
<msg time="2026-06-06T03:24:31.360571" 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-06-06T03:24:31.353992" elapsed="0.006605"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.351831" elapsed="0.008850"/>
</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-06-06T03:24:31.360871" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.360709" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.351807" elapsed="0.009151"/>
</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-06-06T03:24:31.364781" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":true}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.362020" elapsed="0.002812"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.361793" elapsed="0.003075"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.361773" elapsed="0.003121"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.370554" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.365189" elapsed="0.005432"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.364952" elapsed="0.005741"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.364934" elapsed="0.005795"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.371547" 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-06-06T03:24:31.370990" elapsed="0.000595"/>
</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-06-06T03:24:31.372073" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.371724" elapsed="0.000431"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.372904" 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-06-06T03:24:31.372427" elapsed="0.000513"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.372188" elapsed="0.000805"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.371696" elapsed="0.001326"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.373786" 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-06-06T03:24:31.373258" elapsed="0.000566"/>
</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-06-06T03:24:31.374260" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.373923" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.375040" 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-06-06T03:24:31.374608" elapsed="0.000468"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.374374" elapsed="0.000753"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.373897" elapsed="0.001259"/>
</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-06-06T03:24:31.375436" elapsed="0.000526"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:31.376602" 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-06-06T03:24:31.376200" elapsed="0.000495"/>
</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-06-06T03:24:31.376926" elapsed="0.002517"/>
</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-06-06T03:24:31.361325" elapsed="0.018187"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.379710" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.379585" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.379565" elapsed="0.000215"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:31.382730" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:24:31.379933" elapsed="0.002827"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:24:31.382814" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:24:31.382980" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:24:31.349991" elapsed="0.033019"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.383104" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:31.383268" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:31.247927" elapsed="0.135370"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.456177" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.455067" elapsed="0.001194"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.457661" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:31.457310" elapsed="0.000452">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:31.457959" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:31.456573" elapsed="0.001468"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.459353" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:31.458325" elapsed="0.001110"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:31.460156" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_ipv4/empty_route/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:31.460470" level="INFO">${template} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
        ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:31.459792" elapsed="0.000779"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.461495" level="INFO">{
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
                "uptodate": "*"
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.460847" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:31.462707" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.461788" elapsed="0.001024"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.463835" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.463198" elapsed="0.000675"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.462876" elapsed="0.001049"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.461750" elapsed="0.002232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.465189" level="INFO">${final_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
        ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:31.464202" elapsed="0.001072"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.465364" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:31.453799" elapsed="0.011831"/>
</kw>
<msg time="2026-06-06T03:24:31.465705" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:31.398400" elapsed="0.067372"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.479230" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.492222" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_ipv4/empty_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.505419" elapsed="0.000055"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.505733" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.505935" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.506464" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.506294" elapsed="0.000404"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:31.506275" elapsed="0.000457"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.506889" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.507068" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.507242" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:31.506231" elapsed="0.001066"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.506028" elapsed="0.001297"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.507480" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.507630" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:24:31.507800" level="INFO">${expected_text} = {
    "bgp-rib:tables": [
        {
            "afi": "bgp-types:ipv4-address-family",
            "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family",
            "attributes": {
        ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:31.395626" elapsed="0.112204"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:31.508020" elapsed="0.002604"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:31.511920" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:31.511488" elapsed="0.000461"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:31.512463" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:31.512111" elapsed="0.000380"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:31.512687" elapsed="0.000499"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:31.511018" elapsed="0.002231"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.510736" elapsed="0.002547"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.513471" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.513309" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.510715" elapsed="0.002834"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:24:31.384504" elapsed="0.129094"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:24:31.383660" elapsed="0.130033"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:31.383383" elapsed="0.130359"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.383365" elapsed="0.130401"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:31.513801" elapsed="0.000035"/>
</return>
<arg>${BGP_L3VPN_DIR}${/}empty_route</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:24:31.241595" elapsed="0.272343"/>
</kw>
<doc>Verify empty data on neon</doc>
<status status="PASS" start="2026-06-06T03:24:31.237356" elapsed="0.276645"/>
</kw>
<doc>Verfiy empty data response</doc>
<status status="PASS" start="2026-06-06T03:24:31.237091" elapsed="0.276958"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Empty_Reported_Data</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:31.236624" elapsed="0.277468"/>
</kw>
<doc>Testcse teardown with data verification</doc>
<status status="PASS" start="2026-06-06T03:24:31.097052" elapsed="0.417098"/>
</kw>
<doc>Testing mpls vpn ipv4 routes reported to odl from exabgp</doc>
<status status="PASS" start="2026-06-06T03:24:27.437239" elapsed="4.076960"/>
</test>
<test id="s1-s12-t4" name="Start_Play" line="86">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:31.517843" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:31.517557" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.519132" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.519020" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.519000" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.524329" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.524221" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.524202" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.525427" 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-06-06T03:24:31.525047" elapsed="0.000444"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.525977" 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-06-06T03:24:31.525678" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:31.526048" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:31.526203" 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-06-06T03:24:31.524661" elapsed="0.001566"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:31.532063" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.531954" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.531934" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:31.533316" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.533209" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.533190" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:31.533865" 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-06-06T03:24:31.533537" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.534279" level="INFO">${current_connection_index} = 7</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-06-06T03:24:31.534061" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.564741" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:31.534837" elapsed="0.030014"/>
</kw>
<msg time="2026-06-06T03:24:31.565020" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:31.565066" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:31.534474" elapsed="0.030629"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.587574" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "S "t "a "r "t "_ "P "l "a "y "[K"
[?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-06-06T03:24:31.565670" elapsed="0.022022"/>
</kw>
<msg time="2026-06-06T03:24:31.587852" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:31.587898" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "S "t "a "r "t "_ "P "l "a...</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-06-06T03:24:31.565292" elapsed="0.022643"/>
</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-06-06T03:24:31.588261" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.588018" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.587995" elapsed="0.000346"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.588849" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "S "t "a "r "t "_ "P "l "a "y "[K"
[?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-06-06T03:24:31.588524" elapsed="0.000391"/>
</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-06-06T03:24:31.589208" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.588983" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.588964" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:31.589321" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:31.591913" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:24:31.592120" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:31.590821" elapsed="0.001433"/>
</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="NOT RUN" start="2026-06-06T03:24:31.592756" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.593095" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:31.590178" elapsed="0.003150"/>
</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-06-06T03:24:31.589617" elapsed="0.003778"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:31.532906" elapsed="0.060589"/>
</kw>
<msg time="2026-06-06T03:24:31.593589" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:31.593634" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "S "t "a "r "t "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:31.532295" elapsed="0.061398"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:31.593883" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:31.593773" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.593754" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.594383" elapsed="0.000031"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.594792" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.594869" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:31.531601" elapsed="0.063378"/>
</kw>
<msg time="2026-06-06T03:24:31.595076" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:31.595121" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "S "t "a "r "t "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:31.526603" elapsed="0.068556"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.595495" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.595235" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.595218" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:31.526454" elapsed="0.069144"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:31.526279" elapsed="0.069350"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:31.523857" elapsed="0.071846"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:31.518728" elapsed="0.077033"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:31.518266" elapsed="0.077541"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:31.515318" elapsed="0.080542"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.605811" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>${PLAY_SCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:24:31.596030" elapsed="0.009841"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.607966" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:24:31.640809" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:31.641080" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:24:31.641187" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:24:31.641288" 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-06-06T03:24:31.607390" elapsed="0.033959"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.643385" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:24:31.642726" elapsed="0.000770"/>
</kw>
<msg time="2026-06-06T03:24:31.643758" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:24:31.643866" 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-06-06T03:24:31.641843" elapsed="0.002080"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.645465" 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-06-06T03:24:31.644347" elapsed="0.001184"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.646718" elapsed="0.000062"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:31.645758" elapsed="0.001120"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.645709" elapsed="0.001230"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:24:31.647313" elapsed="0.000069"/>
</return>
<status status="PASS" start="2026-06-06T03:24:31.647074" elapsed="0.000389"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.647035" elapsed="0.000493"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:24:31.647782" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:31.647693" elapsed="0.000189"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:31.647624" elapsed="0.000312"/>
</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-06-06T03:24:31.648301" elapsed="0.000052"/>
</kw>
<msg time="2026-06-06T03:24:31.648726" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:24:31.606804" elapsed="0.041985"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:24:31.649178" elapsed="0.000059"/>
</return>
<status status="PASS" start="2026-06-06T03:24:31.648961" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:31.648920" elapsed="0.000445"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:31.649770" elapsed="0.000053"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:24:31.606140" elapsed="0.043826"/>
</kw>
<kw name="Read" owner="SSHLibrary">
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:24:31.650333" elapsed="0.000289"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Start_Bgp_Peer">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.653961" level="INFO">${command} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --allf --wfr 1 &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:31.653619" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:31.654397" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --allf --wfr 1 &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:31.654155" elapsed="0.000288"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:31.680344" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --allf --wfr 1 &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:24:31.680455" level="INFO">${output} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --allf --wfr 1 &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:31.654599" elapsed="0.025884"/>
</kw>
<arg>--amount 0 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug --allf --wfr 1</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:24:31.652911" elapsed="0.027636"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:37.682507" level="FAIL">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:24:31.682163" elapsed="6.001034">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.683497" elapsed="0.000032"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:24:31.681886" elapsed="6.001773">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:24:31.681469" elapsed="6.002314"/>
</kw>
<msg time="2026-06-06T03:24:37.683892" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:31.681109" elapsed="6.002809"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:24:37.684106" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:24:37.684014" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.683987" elapsed="0.000205"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.684461" elapsed="0.000026"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.684661" elapsed="0.000022"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:24:31.680827" elapsed="6.003918"/>
</kw>
<doc>Starts bgp peer and verifies that the peer runs.</doc>
<status status="PASS" start="2026-06-06T03:24:31.652025" elapsed="6.032858"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>Start_Bgp_Peer</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:31.651054" elapsed="6.033875"/>
</kw>
<doc>Start Python speaker to connect to ODL. We need to do WUKS until odl really starts to accept incomming bgp connection. The failure happens if the incomming connection comes too quickly after configuring the peer in the previous test case.</doc>
<status status="PASS" start="2026-06-06T03:24:31.514429" elapsed="6.170626"/>
</test>
<test id="s1-s12-t5" name="Play_To_Odl_rt_constrain_type_0" line="94">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:37.689074" elapsed="0.000249"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:37.688795" elapsed="0.000585"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.690451" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:37.690318" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.690298" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.695673" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:37.695548" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.695530" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.696974" 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-06-06T03:24:37.696554" elapsed="0.000447"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.697475" 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-06-06T03:24:37.697172" elapsed="0.000330"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:37.697547" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:37.697722" 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-06-06T03:24:37.695977" elapsed="0.001771"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:37.703401" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:37.703293" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.703273" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:37.704697" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:37.704566" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.704547" elapsed="0.000219"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:37.705224" 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-06-06T03:24:37.704920" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:37.705634" level="INFO">${current_connection_index} = 7</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-06-06T03:24:37.705418" elapsed="0.000259"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:37.739290" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:37.706191" elapsed="0.033211"/>
</kw>
<msg time="2026-06-06T03:24:37.739589" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:37.739636" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:37.705846" elapsed="0.033852"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:37.769122" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "0 "[K"
[?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-06-06T03:24:37.740256" elapsed="0.028977"/>
</kw>
<msg time="2026-06-06T03:24:37.769396" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:37.769442" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "P "l "a "y "_ "T "o "_ "O...</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-06-06T03:24:37.739890" elapsed="0.029590"/>
</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-06-06T03:24:37.769826" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.769562" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.769539" elapsed="0.000421"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.770414" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "0 "[K"
[?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-06-06T03:24:37.770112" elapsed="0.000376"/>
</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-06-06T03:24:37.770800" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.770555" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.770537" elapsed="0.000341"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:37.770913" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:37.773523" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:24:37.773753" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:37.772426" elapsed="0.001458"/>
</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="NOT RUN" start="2026-06-06T03:24:37.774168" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.774512" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:37.771773" elapsed="0.002952"/>
</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-06-06T03:24:37.771205" elapsed="0.003585"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:37.704246" elapsed="0.070643"/>
</kw>
<msg time="2026-06-06T03:24:37.774983" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:37.775029" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "P "l "a "y "_ "T "o "_ "O...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:37.703627" elapsed="0.071440"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:37.775261" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:37.775144" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.775125" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.775774" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.776125" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.776198" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:37.702955" elapsed="0.073366"/>
</kw>
<msg time="2026-06-06T03:24:37.776421" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:37.776467" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "P "l "a "y "_ "T "o "_ "O...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:37.698132" elapsed="0.078374"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.776862" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.776586" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.776568" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:37.697981" elapsed="0.078985"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:37.697806" elapsed="0.079191"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:37.695185" elapsed="0.081865"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:37.690019" elapsed="0.087087"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:37.689544" elapsed="0.087609"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:37.686140" elapsed="0.091066"/>
</kw>
<kw name="Play_To_Odl_Non_Removal_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.778084" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:37.778251" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:37.777839" elapsed="0.000440"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:37.778438" elapsed="0.003427"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:24:37.782030" elapsed="0.002001"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.784811" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:37.784211" elapsed="0.000629"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.839909" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:37.839510" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.840742" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:37.840474" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:37.840910" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:37.840108" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.841501" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:37.841109" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.841852" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:37.841986" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:37.841713" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.842423" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.842176" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.843476" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.843190" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.843981" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:37.843714" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.844812" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:37.844386" elapsed="0.000453"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:37.846054" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:37.845496" elapsed="0.000657"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:37.846232" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:37.846526" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:37.845034" elapsed="0.001518"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:37.846732" elapsed="0.000380"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:24:37.844228" elapsed="0.002926"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.848002" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:37.847419" elapsed="0.000611"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:37.849324" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:37.848780" elapsed="0.000644"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:37.849501" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:37.849812" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:37.848286" elapsed="0.001553"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:37.850002" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:37.847277" elapsed="0.003135"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:37.844057" elapsed="0.006391"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:37.850491" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:37.850670" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:37.842857" elapsed="0.007840"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.842537" elapsed="0.008194"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.850913" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.850756" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.842518" elapsed="0.008471"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.851733" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:37.851139" elapsed="0.000623"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:37.851811" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:37.838881" elapsed="0.013053"/>
</kw>
<msg time="2026-06-06T03:24:37.851989" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:37.825765" elapsed="0.026273"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.864990" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.877887" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.890667" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.890868" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.891051" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.891458" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.891305" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:37.891289" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.891701" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.891879" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.892051" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:37.891261" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.891158" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.892297" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.892373" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:37.892492" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:37.821314" elapsed="0.071204"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.893796" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:37.893538" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:37.893952" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:37.893191" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.894297" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.894046" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.894870" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:37.894560" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.894379" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.894028" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.897526" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:37.895108" elapsed="0.002447"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:37.897607" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:37.897776" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:37.892860" elapsed="0.004941"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.899045" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:37.898805" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:37.899201" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:37.898439" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:24:37.899431" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:24:37.899296" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.899277" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.899682" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.899861" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.899961" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:37.901959" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:37.898108" elapsed="0.003878"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.903378" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.903129" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.903846" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.903586" elapsed="0.000304"/>
</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-06-06T03:24:37.913224" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:37.913688" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '361'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:24:37.913789" 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-06-06T03:24:37.906109" elapsed="0.007706"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.903956" elapsed="0.009903"/>
</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-06-06T03:24:37.914047" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.913886" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.903938" elapsed="0.010195"/>
</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-06-06T03:24:37.918467" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.915175" elapsed="0.003369"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.914948" elapsed="0.003654"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.914928" elapsed="0.003921"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.922932" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.919329" elapsed="0.003670"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.918956" elapsed="0.004093"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.918925" elapsed="0.004159"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.923955" 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-06-06T03:24:37.923381" elapsed="0.000612"/>
</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-06-06T03:24:37.924482" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.924093" elapsed="0.000479"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.925321" 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-06-06T03:24:37.924868" elapsed="0.000492"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.924606" elapsed="0.000805"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.924066" elapsed="0.001375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.926297" 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-06-06T03:24:37.925726" elapsed="0.000611"/>
</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-06-06T03:24:37.926838" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.926440" elapsed="0.000486"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.927672" 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-06-06T03:24:37.927217" elapsed="0.000542"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.926960" elapsed="0.000853"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.926413" elapsed="0.001430"/>
</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-06-06T03:24:37.928065" elapsed="0.000571"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:37.929124" 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-06-06T03:24:37.928838" elapsed="0.000312"/>
</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-06-06T03:24:37.929314" elapsed="0.002363"/>
</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-06-06T03:24:37.914499" elapsed="0.017243"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:37.931921" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:37.931813" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.931794" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:37.934994" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:24:37.932142" elapsed="0.002882"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:24:37.935076" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:37.935233" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:24:37.902298" elapsed="0.032961"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:37.935322" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:24:37.935471" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:37.796530" elapsed="0.138968"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.964724" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:37.964222" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.965556" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:37.965275" elapsed="0.000419">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:37.965872" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:37.964929" elapsed="0.000970"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.966512" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:37.966073" elapsed="0.000467"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:37.966889" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:37.967051" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:37.966727" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.967555" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-extended-community": {
                    "global-administrator": 64496,
                    "local-administrator": "AAAAZQ=="
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:37.967280" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:37.968102" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:37.967694" elapsed="0.000483"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.968888" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:37.968363" elapsed="0.000552"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.968204" elapsed="0.000747"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.967673" elapsed="0.001299"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:37.969619" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:37.969127" elapsed="0.000547"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:37.969726" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:37.963571" elapsed="0.006284"/>
</kw>
<msg time="2026-06-06T03:24:37.969913" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:37.950276" elapsed="0.019686"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.982997" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:37.995908" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.008933" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.009137" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.009321" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.009717" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.009551" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:38.009536" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.009991" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.010171" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.010348" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:38.009506" elapsed="0.000896"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.009400" elapsed="0.001028"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.010583" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.010675" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:24:38.010813" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:37.947526" elapsed="0.063314"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:38.011024" elapsed="0.003531"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:38.015862" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:38.015416" elapsed="0.000476"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:38.016485" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:38.016054" elapsed="0.000460"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:38.016696" elapsed="0.000330"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:38.014916" elapsed="0.002171"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.014637" elapsed="0.002483"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.017300" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.017145" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.014618" elapsed="0.002758"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:24:37.936688" elapsed="0.080735"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:24:37.935846" elapsed="0.081651"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:37.935585" elapsed="0.081957"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:37.935568" elapsed="0.081998"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:38.017598" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:24:37.790180" elapsed="0.227560"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:37.785018" elapsed="0.232780"/>
</kw>
<arg>rt_constrain_type_0</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:24:37.777442" elapsed="0.240421"/>
</kw>
<doc>This keyword sends route-target route containg route-target argument so odl
can identify this peer as appropriate for advertizement when it recieves such route.</doc>
<status status="PASS" start="2026-06-06T03:24:37.685390" elapsed="0.332583"/>
</test>
<test id="s1-s12-t6" name="Odl_To_Play_l3vpn_rt_arg" line="99">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:38.021580" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:38.021274" elapsed="0.000592"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.022871" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:38.022761" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.022741" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.028009" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:38.027903" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.027884" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.029115" 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-06-06T03:24:38.028734" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.029608" 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-06-06T03:24:38.029311" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:38.029696" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:38.029852" 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-06-06T03:24:38.028336" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:38.035691" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:38.035568" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.035548" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:38.036947" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:38.036839" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.036820" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:38.037466" 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-06-06T03:24:38.037168" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:38.037899" level="INFO">${current_connection_index} = 7</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-06-06T03:24:38.037678" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:38.069445" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:38.038439" elapsed="0.031113"/>
</kw>
<msg time="2026-06-06T03:24:38.069740" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:38.069787" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:38.038093" elapsed="0.031732"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:38.098666" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "3 "v "p "n "_ "r "t "_ "a "r "g "[K"
[?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-06-06T03:24:38.070352" elapsed="0.028426"/>
</kw>
<msg time="2026-06-06T03:24:38.098940" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:38.098986" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "O "d "l "_ "T "o "_ "P "l...</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-06-06T03:24:38.070003" elapsed="0.029020"/>
</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-06-06T03:24:38.099332" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.099102" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.099082" elapsed="0.000329"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.099888" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "3 "v "p "n "_ "r "t "_ "a "r "g "[K"
[?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-06-06T03:24:38.099563" elapsed="0.000395"/>
</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-06-06T03:24:38.100263" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.100024" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.100006" elapsed="0.000371"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:38.100411" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:38.102950" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:24:38.103153" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:38.101877" elapsed="0.001403"/>
</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="NOT RUN" start="2026-06-06T03:24:38.103557" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.103914" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:38.101241" elapsed="0.002869"/>
</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-06-06T03:24:38.100702" elapsed="0.003473"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:38.036510" elapsed="0.067762"/>
</kw>
<msg time="2026-06-06T03:24:38.104363" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:38.104407" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "O "d "l "_ "T "o "_ "P "l...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:38.035920" elapsed="0.068524"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:38.104626" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:24:38.104520" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.104501" elapsed="0.000234"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.105136" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.105478" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.105550" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:38.035224" elapsed="0.070448"/>
</kw>
<msg time="2026-06-06T03:24:38.105766" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:38.105809" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "O "d "l "_ "T "o "_ "P "l...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:38.030245" elapsed="0.075601"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.106177" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.105921" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.105903" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:38.030096" elapsed="0.076180"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:38.029928" elapsed="0.076376"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:38.027521" elapsed="0.078836"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:38.022456" elapsed="0.083955"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:38.022026" elapsed="0.084429"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:38.019042" elapsed="0.087464"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.107407" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/announce_l3vpn_rt_arg.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/announce_l3vpn_rt_arg.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:38.107567" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0053020000003c4001010040020040050400000064800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:38.107211" elapsed="0.000383"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:24:38.107984" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0053020000003c4001010040020040050400000064800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.107774" elapsed="0.000269"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.108436" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/withdraw_l3vpn_rt_arg.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/withdraw_l3vpn_rt_arg.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:38.108565" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:38.108246" elapsed="0.000345"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:24:38.108988" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.108783" elapsed="0.000231"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.109307" elapsed="0.000216"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.109086" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.109068" elapsed="0.000513"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.144793" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:38.144395" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.145564" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:38.145340" elapsed="0.000291">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:38.145743" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:38.144995" elapsed="0.000773"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.146331" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:38.145944" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.146677" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:38.146817" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:38.146527" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.147253" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.147006" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.148295" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.148014" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.148797" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.148510" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.149485" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:38.149183" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:38.150708" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.150252" elapsed="0.000484"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:38.150789" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:24:38.150946" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:38.149904" elapsed="0.001067"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.151132" elapsed="0.000239"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:24:38.149041" elapsed="0.002370"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.152188" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:38.151683" elapsed="0.000574"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:38.153209" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.152798" elapsed="0.000438"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:38.153287" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:38.153439" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:38.152453" elapsed="0.001012"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:38.153631" elapsed="0.000241"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:38.151525" elapsed="0.002389"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:38.148872" elapsed="0.005078"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:38.153993" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:38.154150" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:38.147681" elapsed="0.006494"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.147368" elapsed="0.006839"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.154391" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.154232" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.147349" elapsed="0.007119"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.155217" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:38.154619" elapsed="0.000627"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:38.155295" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:38.143738" elapsed="0.011680"/>
</kw>
<msg time="2026-06-06T03:24:38.155474" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:38.130515" elapsed="0.025008"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.168637" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.181438" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.194262" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.194464" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.194673" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.195175" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.195020" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:38.195003" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.195405" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.195579" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.195770" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:38.194967" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.194784" elapsed="0.001067"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.196003" elapsed="0.000046"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.196106" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:38.196225" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:38.126082" elapsed="0.070169"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.222140" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:38.221761" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.222934" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:38.222702" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:38.223098" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:38.222341" elapsed="0.000781"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.223698" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:38.223295" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.224043" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:38.224210" level="INFO">${template} = &lt;vpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-vpn-ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;WAABAQIDBAABAQEB&lt;/route-key&gt;
    &lt;label-stack&gt;
        &lt;label-value&gt;24005&lt;/label-value&gt;
   ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:38.223894" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.224670" level="INFO">&lt;vpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-vpn-ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;WAABAQIDBAABAQEB&lt;/route-key&gt;
    &lt;label-stack&gt;
        &lt;label-value&gt;24005&lt;/label-value&gt;
    &lt;/label-stack&gt;
    &lt;attributes&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;route-target-extended-community&gt;
                &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
                &lt;local-administrator&gt;AAAAZQ==&lt;/local-administrator&gt;
            &lt;/route-target-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;10.0.255.254&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
    &lt;route-distinguisher&gt;1.2.3.4:1&lt;/route-distinguisher&gt;
    &lt;prefix&gt;1.1.1.0/24&lt;/prefix&gt;
&lt;/vpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.224404" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:38.225101" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.224800" elapsed="0.000398"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.225701" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:38.225384" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.225227" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.224781" elapsed="0.001006"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.226386" level="INFO">${final_text} = &lt;vpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-vpn-ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;WAABAQIDBAABAQEB&lt;/route-key&gt;
    &lt;label-stack&gt;
        &lt;label-value&gt;24005&lt;/label-value&gt;
   ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:38.225942" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:38.226467" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:38.221124" elapsed="0.005469"/>
</kw>
<msg time="2026-06-06T03:24:38.226667" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:38.207749" elapsed="0.018968"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.239662" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.252569" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.265671" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.265874" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.266057" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.266427" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.266275" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:38.266260" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.266677" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.266855" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.267028" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:38.266231" elapsed="0.000850"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.266130" elapsed="0.000978"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.267261" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.267370" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:38.267503" level="INFO">${data} = &lt;vpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-vpn-ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;WAABAQIDBAABAQEB&lt;/route-key&gt;
    &lt;label-stack&gt;
        &lt;label-value&gt;24005&lt;/label-value&gt;
   ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:38.206870" elapsed="0.060662"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:38.268855" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:38.268592" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:38.269011" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:38.268238" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.269358" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.269106" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.269927" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:38.269617" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.269438" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.269087" elapsed="0.000922"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.272608" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:38.270168" elapsed="0.002467"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:38.272702" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:38.272858" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:38.267887" elapsed="0.004995"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.274421" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.274172" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.274885" level="INFO">&lt;vpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-vpn-ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;WAABAQIDBAABAQEB&lt;/route-key&gt;
    &lt;label-stack&gt;
        &lt;label-value&gt;24005&lt;/label-value&gt;
    &lt;/label-stack&gt;
    &lt;attributes&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;route-target-extended-community&gt;
                &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
                &lt;local-administrator&gt;AAAAZQ==&lt;/local-administrator&gt;
            &lt;/route-target-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;10.0.255.254&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
    &lt;route-distinguisher&gt;1.2.3.4:1&lt;/route-distinguisher&gt;
    &lt;prefix&gt;1.1.1.0/24&lt;/prefix&gt;
&lt;/vpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.274628" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.275347" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.275101" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.275812" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.275551" elapsed="0.000305"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:38.276714" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:24:38.276504" elapsed="0.000236"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:24:38.277074" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:24:38.276899" elapsed="0.000201"/>
</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-06-06T03:24:38.277254" elapsed="0.000198"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.277914" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.277615" elapsed="0.000343"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:24:38.278001" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:38.278156" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:24:38.276092" elapsed="0.002089"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:38.294871" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Content-Length': '933', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;vpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-vpn-ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;WAABAQIDBAABAQEB&lt;/route-key&gt;
    &lt;label-stack&gt;
        &lt;label-value&gt;24005&lt;/label-value&gt;
    &lt;/label-stack&gt;
    &lt;attributes&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;route-target-extended-community&gt;
                &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
                &lt;local-administrator&gt;AAAAZQ==&lt;/local-administrator&gt;
            &lt;/route-target-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;10.0.255.254&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
    &lt;route-distinguisher&gt;1.2.3.4:1&lt;/route-distinguisher&gt;
    &lt;prefix&gt;1.1.1.0/24&lt;/prefix&gt;
&lt;/vpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:24:38.294936" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes/vpn-route=WAABAQIDBAABAQEB,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:38.295044" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:38.280412" elapsed="0.014658"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.278250" elapsed="0.016866"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.295305" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.295143" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.278232" elapsed="0.017161"/>
</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-06-06T03:24:38.299058" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.296462" elapsed="0.002640"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.296235" elapsed="0.002903"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.296215" elapsed="0.002948"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.301827" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:38.299450" elapsed="0.002424"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.299220" elapsed="0.002689"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.299203" elapsed="0.002731"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.302485" 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-06-06T03:24:38.302107" elapsed="0.000405"/>
</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-06-06T03:24:38.302847" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.302583" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.303403" 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-06-06T03:24:38.303101" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.302931" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.302564" elapsed="0.000923"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.304055" 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-06-06T03:24:38.303671" 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-06-06T03:24:38.304402" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.304158" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.304971" 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-06-06T03:24:38.304672" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:38.304483" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.304138" elapsed="0.000973"/>
</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-06-06T03:24:38.305272" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:38.306095" 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-06-06T03:24:38.305813" elapsed="0.000308"/>
</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-06-06T03:24:38.306283" elapsed="0.002378"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:24:38.295778" elapsed="0.012947"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:38.308907" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:38.308799" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.308780" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:24:38.309149" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.309217" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:38.311734" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:24:38.273214" elapsed="0.038547"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:38.311832" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:38.312006" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:38.114503" elapsed="0.197528"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:38.312378" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:38.312135" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:38.312118" elapsed="0.000354"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:38.312506" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:24:38.109847" elapsed="0.202784"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:38.316133" level="INFO">${update} = </msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:38.313575" elapsed="0.002587"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:24:38.318572" level="FAIL"> == </msg>
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="FAIL" start="2026-06-06T03:24:38.316323" elapsed="0.002313"> == </status>
</kw>
<return>
<value>${update}</value>
<status status="NOT RUN" start="2026-06-06T03:24:38.318713" elapsed="0.000018"/>
</return>
<doc>Returns hex update message.</doc>
<status status="FAIL" start="2026-06-06T03:24:38.313299" elapsed="0.005524"> == </status>
</kw>
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:40.324520" level="INFO">${update} = ffffffffffffffffffffffffffffffff0053020000003c4001010040020040050400000064800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.320592" elapsed="0.004044"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:24:40.325111" elapsed="0.004588"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:24:40.329777" elapsed="0.000051"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:24:40.319734" elapsed="0.010240"/>
</kw>
<msg time="2026-06-06T03:24:40.330083" level="INFO">${update} = ffffffffffffffffffffffffffffffff0053020000003c4001010040020040050400000064800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:38.312829" elapsed="2.017290"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.331411" level="INFO">Length is 166.</msg>
<msg time="2026-06-06T03:24:40.331517" level="INFO">${len_1} = 166</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:40.331019" elapsed="0.000532"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.332258" level="INFO">Length is 166.</msg>
<msg time="2026-06-06T03:24:40.332364" level="INFO">${len_2} = 166</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:40.331893" elapsed="0.000505"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:40.332629" elapsed="0.000465"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:40.333742" level="INFO">${sum_1} = 2527</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:40.333328" elapsed="0.000451"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:40.334270" level="INFO">${sum_2} = 2527</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:40.334006" elapsed="0.000301"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:40.334538" elapsed="0.000485"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:24:40.330435" elapsed="0.004674"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:40.335331" elapsed="0.002230"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.382332" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:40.381951" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.383194" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.382935" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:40.383365" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:40.382532" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.383968" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:40.383562" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.384302" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:40.384451" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:40.384163" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.384902" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.384655" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.386151" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.385833" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.386691" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.386371" elapsed="0.000348"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.387523" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.387103" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:40.388687" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.388189" elapsed="0.000578"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:40.388904" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:24:40.389128" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:40.387764" elapsed="0.001390"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.389316" elapsed="0.000419"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:24:40.386958" elapsed="0.002857"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.390487" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.390072" elapsed="0.000442"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:40.391618" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.391154" elapsed="0.000566"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:40.391856" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:40.392078" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:40.390731" elapsed="0.001373"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.392263" elapsed="0.000412"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:40.389932" elapsed="0.002786"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:40.386776" elapsed="0.005978"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:40.392798" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:40.392955" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:40.385327" elapsed="0.007652"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.385020" elapsed="0.007991"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.393191" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.393036" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.384998" elapsed="0.008268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.394013" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:40.393418" elapsed="0.000623"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:40.394090" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:40.381313" elapsed="0.012903"/>
</kw>
<msg time="2026-06-06T03:24:40.394275" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:40.368177" elapsed="0.026151"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.407303" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.420332" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.433371" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.433582" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.433850" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.434244" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.434089" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:40.434072" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.434475" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.434687" elapsed="0.000027"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.434876" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:40.434037" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.433931" elapsed="0.001027"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.435114" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.435192" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:40.435322" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:40.363750" elapsed="0.071600"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.436536" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.436260" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:40.450016" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:40.450065" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:40.450158" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:40.439098" elapsed="0.011087"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.436678" elapsed="0.013548"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.450418" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.450253" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.436636" elapsed="0.013869"/>
</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-06-06T03:24:40.458538" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.452976" elapsed="0.005752"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.452428" elapsed="0.006390"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.452385" elapsed="0.006492"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.461976" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.459543" elapsed="0.002480"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.459009" elapsed="0.003050"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.458969" elapsed="0.003115"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.462716" 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-06-06T03:24:40.462277" elapsed="0.000467"/>
</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-06-06T03:24:40.463088" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.462828" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.463729" 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-06-06T03:24:40.463395" elapsed="0.000361"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.463215" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.462805" elapsed="0.001009"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.464375" 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-06-06T03:24:40.464005" elapsed="0.000397"/>
</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-06-06T03:24:40.464732" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.464472" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.465294" 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-06-06T03:24:40.464992" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.464815" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.464453" elapsed="0.000925"/>
</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-06-06T03:24:40.465539" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:40.466371" 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-06-06T03:24:40.466079" elapsed="0.000318"/>
</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-06-06T03:24:40.466559" elapsed="0.002404"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:24:40.451432" elapsed="0.017595"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:40.469076" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:24:40.471484" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:24:40.435626" elapsed="0.035887"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:40.471574" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:24:40.338622" elapsed="0.133102"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.338185" elapsed="0.133597"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:24:40.337783" elapsed="0.134059"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:40.475139" level="INFO">${update} = ffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.472822" elapsed="0.002347"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:24:40.475355" elapsed="0.002343"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:24:40.477751" elapsed="0.000030"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:24:40.472502" elapsed="0.005375"/>
</kw>
<msg time="2026-06-06T03:24:40.477953" level="INFO">${update} = ffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:40.472021" elapsed="0.005957"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.478926" level="INFO">Length is 138.</msg>
<msg time="2026-06-06T03:24:40.479003" level="INFO">${len_1} = 138</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:40.478633" elapsed="0.000394"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.479451" level="INFO">Length is 138.</msg>
<msg time="2026-06-06T03:24:40.479528" level="INFO">${len_2} = 138</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:40.479193" elapsed="0.000358"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:40.479792" elapsed="0.000449"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:40.480769" level="INFO">${sum_1} = 1777</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:40.480477" elapsed="0.000328"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:40.481294" level="INFO">${sum_2} = 1777</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:40.481029" elapsed="0.000303"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:40.481620" elapsed="0.000467"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:24:40.478219" elapsed="0.003955"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.531075" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:40.530671" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.531911" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.531625" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:40.532098" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:40.531282" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.532712" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:40.532300" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.533060" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:40.533234" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:40.532915" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.533698" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.533430" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.535016" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.534743" elapsed="0.000320"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.535528" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.535243" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.536527" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.535960" elapsed="0.000593"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:40.537768" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.537278" elapsed="0.000534"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:40.537935" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:24:40.538164" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:40.536783" elapsed="0.001408"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.538356" elapsed="0.000556"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:24:40.535813" elapsed="0.003142"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.539753" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.539211" elapsed="0.000569"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:40.540950" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.540465" elapsed="0.000528"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:40.541131" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:40.541355" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:40.539974" elapsed="0.001408"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.541544" elapsed="0.000533"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:40.539071" elapsed="0.003101"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:40.535612" elapsed="0.006599"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:40.542257" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:40.542421" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:40.534141" elapsed="0.008305"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.533821" elapsed="0.008659"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.542705" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.542506" elapsed="0.000260"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.533800" elapsed="0.008987"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.543541" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:40.542948" elapsed="0.000622"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:40.543621" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:40.529962" elapsed="0.013805"/>
</kw>
<msg time="2026-06-06T03:24:40.543822" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:40.516376" elapsed="0.027506"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.557084" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.570093" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/l3vpn_rt_arg/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.583185" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.583392" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.583578" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.583993" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.583834" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:40.583814" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.584220" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.584393" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.584565" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:40.583779" elapsed="0.000892"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.583675" elapsed="0.001027"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.584861" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.584949" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:40.585078" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:40.511846" elapsed="0.073259"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.586286" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.586030" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:40.597764" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:40.598147" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '379'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-types:mpls-labeled-vpn-subsequent-address-family']/bgp-vpn-ipv4:vpn-ipv4-routes",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:40.598300" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:24:40.598342" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.590025" elapsed="0.008764">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:40.586401" elapsed="0.012470">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.599080" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.598912" elapsed="0.000230"/>
</branch>
<status status="FAIL" start="2026-06-06T03:24:40.586382" elapsed="0.012784">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:24:40.602770" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.600249" elapsed="0.002558">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:40.600011" elapsed="0.002861">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:24:40.599991" elapsed="0.002914">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.606414" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.603213" elapsed="0.003249">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:40.602978" elapsed="0.003599">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:24:40.602960" elapsed="0.003664">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.607474" 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-06-06T03:24:40.606919" elapsed="0.000654"/>
</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-06-06T03:24:40.608079" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.607719" elapsed="0.000443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.608914" 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-06-06T03:24:40.608435" elapsed="0.000518"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.608196" elapsed="0.000810"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.607689" elapsed="0.001349"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.609835" 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-06-06T03:24:40.609280" elapsed="0.000602"/>
</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-06-06T03:24:40.610362" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.609999" elapsed="0.000446"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.611230" 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-06-06T03:24:40.610799" elapsed="0.000469"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.610479" elapsed="0.000838"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.609967" elapsed="0.001381"/>
</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-06-06T03:24:40.611572" elapsed="0.000400"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:40.612441" 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-06-06T03:24:40.612149" elapsed="0.000318"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:24:40.615118" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.612632" elapsed="0.002520">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:24:40.599543" elapsed="0.015758">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:40.615369" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:40.617861" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:24:40.617892" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:24:40.585381" elapsed="0.032540">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:40.617990" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.483780" elapsed="0.134382">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.483136" elapsed="0.135090"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:24:40.482521" elapsed="0.135764"/>
</kw>
<arg>l3vpn_rt_arg</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<arg>False</arg>
<status status="PASS" start="2026-06-06T03:24:38.106823" elapsed="2.511512"/>
</kw>
<doc>Same as TC before but fluorine and further this l3vpn route also needs to contain route-target argument.</doc>
<status status="PASS" start="2026-06-06T03:24:38.018184" elapsed="2.600285"/>
</test>
<test id="s1-s12-t7" name="Kill_Talking_BGP_Speaker" line="103">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:40.621969" elapsed="0.000220"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:40.621627" elapsed="0.000619"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.623342" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.623230" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.623210" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.628736" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.628611" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.628593" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.629827" 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-06-06T03:24:40.629427" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.630319" 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-06-06T03:24:40.630022" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:40.630395" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:40.630593" 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-06-06T03:24:40.629040" elapsed="0.001590"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:40.636784" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.636673" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.636651" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:40.638089" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.637970" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.637950" elapsed="0.000208"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:40.638659" 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-06-06T03:24:40.638311" elapsed="0.000378"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.639089" level="INFO">${current_connection_index} = 7</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-06-06T03:24:40.638858" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.669506" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:40.639659" elapsed="0.030054"/>
</kw>
<msg time="2026-06-06T03:24:40.669935" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:40.669985" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:40.639293" elapsed="0.030731"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.700141" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:24:40.670766" elapsed="0.029520"/>
</kw>
<msg time="2026-06-06T03:24:40.700468" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:40.700516" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "K "i "l "l "_ "T "a "l "k...</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-06-06T03:24:40.670262" elapsed="0.030293"/>
</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-06-06T03:24:40.701007" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.700693" elapsed="0.000372"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.700631" elapsed="0.000464"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.701623" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:24:40.701250" elapsed="0.000474"/>
</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-06-06T03:24:40.702032" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.701798" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.701778" elapsed="0.000332"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:40.702150" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:40.705050" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:24:40.705271" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:40.703869" elapsed="0.001613"/>
</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="NOT RUN" start="2026-06-06T03:24:40.705797" elapsed="0.000086"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.706160" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:40.703168" elapsed="0.003179"/>
</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-06-06T03:24:40.702530" elapsed="0.003884"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:40.637664" elapsed="0.068869"/>
</kw>
<msg time="2026-06-06T03:24:40.706656" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:40.706705" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "K "i "l "l "_ "T "a "l "k...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.637026" elapsed="0.069719"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:40.706945" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:24:40.706826" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.706806" elapsed="0.000228"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.707462" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.707845" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.707919" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:40.636315" elapsed="0.071726"/>
</kw>
<msg time="2026-06-06T03:24:40.708148" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:40.708195" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "K "i "l "l "_ "T "a "l "k...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:40.631182" elapsed="0.077051"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.708579" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.708313" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.708295" elapsed="0.000381"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:40.631010" elapsed="0.077692"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:40.630813" elapsed="0.077924"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:40.628242" elapsed="0.080555"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:40.622931" elapsed="0.085929"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.622407" elapsed="0.086503"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:40.619369" elapsed="0.089598"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.710251" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:40.709918" elapsed="0.000365"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:40.710489" elapsed="0.000648"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:24:40.709604" elapsed="0.001614"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.737282" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:24:40.711749" elapsed="0.025777"/>
</kw>
<msg time="2026-06-06T03:24:40.737859" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:40.737963" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.711389" elapsed="0.026631"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.739866" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:24:40.753353" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:40.753611" level="INFO">${output_log} = 2026-06-06 03:24:31,773 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:31,774 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:40.739468" elapsed="0.014240"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.754967" level="INFO">2026-06-06 03:24:31,773 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:24:31,775 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:24:31,779 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:24:31,779 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Length=125 (0x007d)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=96 (0x60)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff007d0104fbf000b40a1eabc26002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0'
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff007d0104fbf000b40a1eabc26002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:24:31,782 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:31,784 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:31,784 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:31,784 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:31,794 INFO BGP-Thread-1 (job): ... idle for 0.010s
2026-06-06 03:24:31,794 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.010s
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000180
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000280
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000201
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,804 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:31,804 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:31,804 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:32,805 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.011s
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:33,807 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:33,807 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.012s
2026-06-06 03:24:33,807 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:33,808 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:33,808 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:34,808 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:24:34,808 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.013s
2026-06-06 03:24:34,809 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:34,809 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:34,809 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.014s
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.015s
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:37,813 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:37,813 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.016s
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:38] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:38,328 INFO BGP-Thread-1 (job): ... idle for 0.514s
2026-06-06 03:24:38,328 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.529s
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0053020000003c4001010040020040050400000064800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0053' (83)
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:38,330 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:38,330 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:38,330 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:39,331 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:39,331 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.530s
2026-06-06 03:24:39,332 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:39,332 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:39,332 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:40,333 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:40,333 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.532s
2026-06-06 03:24:40,334 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:40,334 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:40,334 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:40] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:40] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:40,468 INFO BGP-Thread-1 (job): ... idle for 0.134s
2026-06-06 03:24:40,468 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.665s
2026-06-06 03:24:40,468 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065
2026-06-06 03:24:40,468 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:40,470 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:40,470 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:40,470 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:40] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.754235" elapsed="0.001362"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:24:40.738666" elapsed="0.017099"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:24:40.756250" elapsed="0.000078"/>
</return>
<status status="PASS" start="2026-06-06T03:24:40.755939" elapsed="0.000461"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.755885" elapsed="0.000573"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.756843" elapsed="0.000051"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.757237" elapsed="0.000045"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:24:40.709264" elapsed="0.048149"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.770433" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:24:40.802808" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:40.803049" level="INFO">${output_log} = 2026-06-06 03:24:31,773 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:31,774 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:24:40.770253" elapsed="0.032858"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.804363" level="INFO">2026-06-06 03:24:31,773 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:24:31,774 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:24:31,775 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:24:31,778 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:24:31,779 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:24:31,779 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:24:31,779 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Length=125 (0x007d)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=96 (0x60)
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff007d0104fbf000b40a1eabc26002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0'
2026-06-06 03:24:31,780 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff007d0104fbf000b40a1eabc26002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:24:31,782 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:31,783 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:31,784 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:31,784 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:31,784 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:31,794 INFO BGP-Thread-1 (job): ... idle for 0.010s
2026-06-06 03:24:31,794 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.010s
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,794 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000180
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,795 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,796 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,797 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:24:31,798 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000280
2026-06-06 03:24:31,799 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:24:31,800 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000201
2026-06-06 03:24:31,801 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,802 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,803 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:31,804 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:31,804 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:31,804 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:31,804 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:32,805 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.011s
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:32,806 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:33,807 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:33,807 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.012s
2026-06-06 03:24:33,807 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:33,808 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:33,808 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:34,808 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:24:34,808 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.013s
2026-06-06 03:24:34,809 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:34,809 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:34,809 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.014s
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:35,810 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.015s
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:36,812 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:37,813 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:37,813 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.016s
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:37,814 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:38] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:38,328 INFO BGP-Thread-1 (job): ... idle for 0.514s
2026-06-06 03:24:38,328 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.529s
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0053020000003c4001010040020040050400000064800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0053' (83)
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:38,329 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:38,330 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:38,330 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:38,330 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:38,330 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:39,331 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:39,331 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.530s
2026-06-06 03:24:39,332 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:39,332 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:39,332 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:40,333 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:40,333 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.532s
2026-06-06 03:24:40,334 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:40,334 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:40,334 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:40] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:40] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:40,468 INFO BGP-Thread-1 (job): ... idle for 0.134s
2026-06-06 03:24:40,468 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.665s
2026-06-06 03:24:40,468 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065
2026-06-06 03:24:40,468 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0045' (69)
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:24:40,469 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:24:40,470 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:40,470 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:40,470 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:40] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.803607" elapsed="0.001465"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.806519" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/010_l3vpn_play.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/010_l3vpn_play.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:24:40.805578" elapsed="0.001139"/>
</kw>
<arg>play.py.out</arg>
<arg>010_l3vpn_play.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:40.769814" elapsed="0.037067"/>
</kw>
<doc>Abort the Python speaker</doc>
<status status="PASS" start="2026-06-06T03:24:40.618865" elapsed="0.188326"/>
</test>
<test id="s1-s12-t8" name="Delete_Bgp_Peer_Configuration" line="109">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:40.815525" elapsed="0.000316"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:40.815166" elapsed="0.000745"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.817138" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.816983" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.816956" elapsed="0.000264"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.822728" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.822600" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.822580" elapsed="0.000219"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.823893" 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-06-06T03:24:40.823471" elapsed="0.000451"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.824416" 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-06-06T03:24:40.824096" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:40.824489" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:24:40.824676" 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-06-06T03:24:40.823066" elapsed="0.001637"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:40.830623" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.830492" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.830466" elapsed="0.000247"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:40.831968" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:40.831856" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.831836" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:40.832524" 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-06-06T03:24:40.832195" elapsed="0.000362"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.832991" level="INFO">${current_connection_index} = 7</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-06-06T03:24:40.832762" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.864212" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:40.833547" elapsed="0.030784"/>
</kw>
<msg time="2026-06-06T03:24:40.864506" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:40.864553" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:40.833189" elapsed="0.031402"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:40.893393" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:24:40.865169" elapsed="0.028341"/>
</kw>
<msg time="2026-06-06T03:24:40.893700" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:40.893748" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "l "e "t "e "_ "B "g...</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-06-06T03:24:40.864811" elapsed="0.028974"/>
</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-06-06T03:24:40.894152" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.893864" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.893844" elapsed="0.000398"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.894786" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:24:40.894440" elapsed="0.000420"/>
</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-06-06T03:24:40.895161" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.894931" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.894911" elapsed="0.000339"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:40.895291" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:40.898005" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:24:40.898241" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:40.896859" elapsed="0.001556"/>
</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="NOT RUN" start="2026-06-06T03:24:40.898918" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.899293" elapsed="0.000095"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:40.896174" elapsed="0.003357"/>
</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-06-06T03:24:40.895600" elapsed="0.004003"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:40.831513" elapsed="0.068247"/>
</kw>
<msg time="2026-06-06T03:24:40.900053" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:40.900099" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "l "e "t "e "_ "B "g...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.830877" elapsed="0.069260"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:40.900336" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:24:40.900217" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.900197" elapsed="0.000227"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.900857" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.901203" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:40.901285" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:40.830094" elapsed="0.071303"/>
</kw>
<msg time="2026-06-06T03:24:40.901492" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:40.901538" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "l "e "t "e "_ "B "g...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:40.825113" elapsed="0.076463"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.901935" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.901668" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.901634" elapsed="0.000380"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:40.824957" elapsed="0.077080"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:40.824766" elapsed="0.077304"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:40.822184" elapsed="0.079942"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:40.816660" elapsed="0.085523"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:40.816123" elapsed="0.086109"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:40.809355" elapsed="0.092938"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.903113" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.902587" elapsed="0.000557"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.950781" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:40.950341" elapsed="0.000477"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.951698" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:40.951383" elapsed="0.000405">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:40.951888" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:40.951013" elapsed="0.000900"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.952494" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:40.952090" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:40.952879" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:40.953068" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:40.952725" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.953529" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.953274" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.954873" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:40.954573" elapsed="0.000346"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.955390" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.955090" elapsed="0.000328"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.956141" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.955837" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:40.957246" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.957005" elapsed="0.000270"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:40.957333" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:24:40.957507" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:40.956389" elapsed="0.001143"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.957715" elapsed="0.000262"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:40.955686" elapsed="0.002333"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.958618" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:40.958310" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:40.959414" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.959190" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:40.959492" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:40.959663" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:40.958862" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:40.959852" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:40.958136" elapsed="0.001982"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:40.955478" elapsed="0.004747"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:40.960280" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:40.960443" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:40.954198" elapsed="0.006271"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:40.953862" elapsed="0.006640"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.960704" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:40.960528" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:40.953634" elapsed="0.007150"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:40.961564" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:40.960939" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:40.961662" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:40.949636" elapsed="0.012154"/>
</kw>
<msg time="2026-06-06T03:24:40.961847" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:40.936070" elapsed="0.025824"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.976446" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:40.995081" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.015766" elapsed="0.000045"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.016086" elapsed="0.000033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.016363" elapsed="0.000030"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.016947" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.016720" elapsed="0.000309"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:41.016695" elapsed="0.000369"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.017282" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.017537" elapsed="0.000029"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.017809" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:41.016630" elapsed="0.001257"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.016476" elapsed="0.001504"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.018213" elapsed="0.000030"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.018376" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:24:41.018573" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:40.930925" elapsed="0.087682"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.019866" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.019518" elapsed="0.000397"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:41.030534" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:41.030588" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:41.030757" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:41.022274" elapsed="0.008522"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.019983" elapsed="0.010877"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.031159" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.030903" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.019964" elapsed="0.011320"/>
</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-06-06T03:24:41.036636" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.032892" elapsed="0.003830"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.032513" elapsed="0.004261"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.032484" elapsed="0.004327"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.040085" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.037235" elapsed="0.002897"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.036894" elapsed="0.003273"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.036869" elapsed="0.003323"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.040817" 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-06-06T03:24:41.040390" elapsed="0.000454"/>
</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-06-06T03:24:41.041165" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.040916" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.041750" 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-06-06T03:24:41.041422" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.041248" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.040898" elapsed="0.000936"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.042382" 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-06-06T03:24:41.042003" elapsed="0.000406"/>
</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-06-06T03:24:41.042740" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.042480" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.043286" 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-06-06T03:24:41.042990" elapsed="0.000395"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.042822" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.042461" elapsed="0.000983"/>
</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-06-06T03:24:41.043609" elapsed="0.000371"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:41.044455" 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-06-06T03:24:41.044153" elapsed="0.000328"/>
</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-06-06T03:24:41.044658" elapsed="0.002377"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:24:41.031872" elapsed="0.015232"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:41.047156" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:24:41.049489" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:24:41.018905" elapsed="0.030611"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:41.049572" elapsed="0.000027"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:24:40.903395" elapsed="0.146320"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:24:40.807965" elapsed="0.241878"/>
</test>
<test id="s1-s12-t9" name="Deconfigure_App_Peer" line="117">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:41.053771" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:41.053472" elapsed="0.000744"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.055279" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.055165" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.055145" elapsed="0.000205"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.060766" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.060653" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.060620" elapsed="0.000217"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.062105" 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-06-06T03:24:41.061468" elapsed="0.000665"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.062695" 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-06-06T03:24:41.062359" elapsed="0.000363"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:41.062769" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:24:41.062930" 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-06-06T03:24:41.061078" elapsed="0.001877"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:41.068813" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.068701" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.068680" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:41.070127" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.070016" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.069997" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:41.070716" 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-06-06T03:24:41.070383" elapsed="0.000362"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.071142" level="INFO">${current_connection_index} = 7</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-06-06T03:24:41.070919" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.102024" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:41.071703" elapsed="0.030431"/>
</kw>
<msg time="2026-06-06T03:24:41.102529" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:41.102576" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:41.071337" elapsed="0.031276"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.130075" level="INFO">". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:41.103179" elapsed="0.027185"/>
</kw>
<msg time="2026-06-06T03:24:41.130635" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:41.130720" level="INFO">${message_wait} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "c "o "n "f "i "g "u...</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-06-06T03:24:41.102822" elapsed="0.027942"/>
</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-06-06T03:24:41.131279" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.130897" elapsed="0.000446"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.130853" elapsed="0.000519"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.131987" level="INFO"> ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:41.131531" elapsed="0.000532"/>
</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-06-06T03:24:41.132366" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.132134" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.132114" elapsed="0.000332"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:41.132486" elapsed="0.000048"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:41.135395" elapsed="0.000411"/>
</kw>
<msg time="2026-06-06T03:24:41.135872" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:41.134216" elapsed="0.001793"/>
</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="NOT RUN" start="2026-06-06T03:24:41.136299" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.136659" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:41.133501" elapsed="0.003349"/>
</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-06-06T03:24:41.132881" elapsed="0.004034"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:41.069708" elapsed="0.067306"/>
</kw>
<msg time="2026-06-06T03:24:41.137106" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:41.137151" level="INFO">${message} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "c "o "n "f "i "g "u...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:41.069043" elapsed="0.068145"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:41.137374" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:41.137265" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.137246" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.137905" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.138290" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.138363" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:41.068342" elapsed="0.070130"/>
</kw>
<msg time="2026-06-06T03:24:41.138566" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:41.138610" level="INFO">${output} =  ". "t "x "t ". "0 "1 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n ". "D "e "c "o "n "f "i "g "u...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:41.063397" elapsed="0.075267"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.139063" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.138800" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.138781" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:41.063206" elapsed="0.075958"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:41.063017" elapsed="0.076180"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:41.060268" elapsed="0.078988"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:41.054868" elapsed="0.084447"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:41.054397" elapsed="0.084966"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:41.050860" elapsed="0.088559"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.140103" level="INFO">&amp;{mapping} = { IP=10.30.170.38 | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:41.139605" elapsed="0.000526"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.183984" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:41.183587" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:41.184790" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:41.184524" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:41.184965" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:41.184181" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.185546" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:41.185161" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:41.185898" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:41.186060" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:41.185760" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.186533" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.186284" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.187570" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.187313" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.188060" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:41.187798" elapsed="0.000288"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.188765" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:41.188453" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:41.189743" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:41.189499" elapsed="0.000270"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:41.189819" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:41.189969" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:41.188984" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:41.190214" elapsed="0.000247"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:24:41.188310" elapsed="0.002193"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.191069" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:41.190772" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:41.191838" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:41.191609" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:41.191914" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:41.192063" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:41.191286" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:41.192246" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:41.190615" elapsed="0.001890"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:41.188138" elapsed="0.004402"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:41.192582" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:24:41.192756" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:41.186983" elapsed="0.005798"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.186661" elapsed="0.006152"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.192992" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.192838" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.186626" elapsed="0.006441"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.193814" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:41.193217" elapsed="0.000625"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:41.193891" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:41.182967" elapsed="0.011046"/>
</kw>
<msg time="2026-06-06T03:24:41.194068" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:41.169937" elapsed="0.024192"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.207040" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.220054" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.232802" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.233048" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.233234" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.233604" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.233452" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:41.233437" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.233854" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.234027" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.234231" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:41.233409" elapsed="0.000879"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.233308" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.234469" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.234545" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:41.234682" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:41.165509" elapsed="0.069201"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.235837" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.235567" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:41.246048" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node014mk4vnkblagjsb2jw6aqxv6n21.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:41.246097" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:41.246234" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:41.238372" elapsed="0.007888"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.235950" elapsed="0.010351"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:41.246487" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.246327" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.235932" elapsed="0.010638"/>
</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-06-06T03:24:41.251405" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.247988" elapsed="0.003477"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.247669" elapsed="0.003846"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.247618" elapsed="0.003931"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.255258" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.251962" elapsed="0.003361"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.251625" elapsed="0.003747"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.251602" elapsed="0.003804"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.256196" 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-06-06T03:24:41.255665" elapsed="0.000569"/>
</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-06-06T03:24:41.256776" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.256334" elapsed="0.000527"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.257560" 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-06-06T03:24:41.257136" elapsed="0.000460"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.256895" elapsed="0.000771"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.256308" elapsed="0.001389"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.258476" 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-06-06T03:24:41.257932" elapsed="0.000582"/>
</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-06-06T03:24:41.258885" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.258615" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.259434" 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-06-06T03:24:41.259139" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.258968" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.258588" elapsed="0.000929"/>
</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-06-06T03:24:41.259686" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:41.260482" 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-06-06T03:24:41.260204" elapsed="0.000304"/>
</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-06-06T03:24:41.260685" elapsed="0.002424"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:24:41.247080" elapsed="0.016092"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:41.263218" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:41.265530" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:24:41.234986" elapsed="0.030571"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:41.265610" elapsed="0.000027"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:24:41.140361" elapsed="0.125389"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:24:41.050195" elapsed="0.215666"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Virtual_Env_Delete" 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-06-06T03:24:41.274033" level="INFO">${cd_and_command} = cd '.' &amp;&amp; rm -rf /tmp/defaultvenv</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-06-06T03:24:41.273705" elapsed="0.000356"/>
</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-06-06T03:24:41.275523" level="INFO">Executing command 'cd '.' &amp;&amp; rm -rf /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:24:41.309248" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:41.309516" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:24:41.309621" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:24:41.309766" 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-06-06T03:24:41.275336" elapsed="0.034484"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.311791" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:24:41.311136" elapsed="0.000762"/>
</kw>
<msg time="2026-06-06T03:24:41.312112" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:24:41.312225" 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-06-06T03:24:41.310288" elapsed="0.001994"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.313669" 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-06-06T03:24:41.312707" elapsed="0.001030"/>
</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-06-06T03:24:41.316192" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.315596" elapsed="0.000692"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.317288" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.316723" elapsed="0.000658"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.318505" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.317864" elapsed="0.000742"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:24:41.314760" elapsed="0.003941"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:41.313913" elapsed="0.004833"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.313868" elapsed="0.004911"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.318977" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.318851" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.318828" elapsed="0.000234"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:41.319238" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:24:41.319128" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.319108" elapsed="0.000236"/>
</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-06-06T03:24:41.319542" elapsed="0.000027"/>
</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-06-06T03:24:41.274785" elapsed="0.044906"/>
</kw>
<msg time="2026-06-06T03:24:41.319745" 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-06-06T03:24:41.274241" elapsed="0.045564"/>
</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 rm -rf /tmp/defaultvenv.
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-06-06T03:24:41.273076" elapsed="0.046806"/>
</kw>
<msg time="2026-06-06T03:24:41.319932" 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-06-06T03:24:41.267288" elapsed="0.052698"/>
</kw>
<arg>rm -rf ${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-06-06T03:24:41.266936" elapsed="0.053124"/>
</kw>
<doc>Deletes a directory with virtual env.</doc>
<status status="PASS" start="2026-06-06T03:24:41.266703" elapsed="0.053407"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:24:41.320262" elapsed="0.000405"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:41.320909" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:24:41.320835" elapsed="0.000152"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:24:41.266422" elapsed="0.054616"/>
</kw>
<doc>Functional test suite for bgp - l3vpn-ipv4

Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests advertising and receiveing routes with l3vpn content.
It uses odl and exabgp as bgp peers. Routes advertized from odl
are configured via application peer. Routes advertised from exabgp is
statically configured in exabgp config file.

For fluorine and further, instead of exabgp, play.py is used. When sending
routes from odl to peer, first route containg route-target argument have to
be send from peer to odl, so odl can identify this peer. Than it sends l3vpn
route containg this argument to odl app peer, and we check that app peer
advertizes this route back to the peer.</doc>
<status status="PASS" start="2026-06-06T03:24:16.606166" elapsed="24.714902"/>
</suite>
<suite id="s1-s13" name="030 Bgp Functional Evpn" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/030_bgp_functional_evpn.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.410204" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:41.405862" elapsed="0.004397"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:24:41.405605" elapsed="0.004729"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.415219" 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-06-06T03:24:41.411463" elapsed="0.003784"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:24:41.415478" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.415337" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.415311" elapsed="0.000243"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.416089" 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-06-06T03:24:41.415730" elapsed="0.000402"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.416616" 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-06-06T03:24:41.416301" elapsed="0.000356"/>
</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-06-06T03:24:41.417247" elapsed="0.000282"/>
</kw>
<msg time="2026-06-06T03:24:41.417629" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:41.417694" 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-06-06T03:24:41.416894" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.418282" 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-06-06T03:24:41.417893" elapsed="0.000415"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.419311" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:24:41.419042" elapsed="0.000295"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.419770" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:24:41.419492" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.420250" 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-06-06T03:24:41.419960" elapsed="0.000316"/>
</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-06-06T03:24:41.423528" elapsed="0.000236"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.424259" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:24:41.423932" elapsed="0.000353"/>
</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-06-06T03:24:41.424443" elapsed="0.000243"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.425476" 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-06-06T03:24:41.425180" elapsed="0.000322"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:24:41.425548" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:24:41.425728" 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-06-06T03:24:41.424884" elapsed="0.000870"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:41.426449" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5a27050&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-06-06T03:24:41.425918" elapsed="0.000688"/>
</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-06-06T03:24:41.426829" elapsed="0.000206"/>
</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-06-06T03:24:41.422966" elapsed="0.004129"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:41.422772" elapsed="0.004367"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:24:41.420332" elapsed="0.006839"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.427757" 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-06-06T03:24:41.427341" elapsed="0.000460"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.428366" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:24:41.427970" elapsed="0.000439"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.428987" 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-06-06T03:24:41.428576" elapsed="0.000453"/>
</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-06-06T03:24:41.418569" elapsed="0.010516"/>
</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-06-06T03:24:41.411103" elapsed="0.018039"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:41.429321" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:41.429208" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.429189" elapsed="0.000199"/>
</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-06-06T03:24:41.432584" 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-06-06T03:24:41.432205" elapsed="0.000406"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.433098" 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-06-06T03:24:41.432800" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:41.433169" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:41.433324" 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-06-06T03:24:41.431833" elapsed="0.001516"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:41.434362" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:24:41.434098" elapsed="0.000290"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.435162" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:24:41.435263" 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-06-06T03:24:41.434989" elapsed="0.000301"/>
</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-06-06T03:24:41.438921" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:41.438306" elapsed="0.000703"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:41.438284" elapsed="0.000763"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.439711" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:24:41.439252" elapsed="0.000741"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.440934" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:41.440260" elapsed="0.000780"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.442250" 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-06-06T03:24:41.441326" elapsed="0.000976"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:41.444018" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:24:41.444193" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:41.443662" elapsed="0.000574"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:41.444583" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:24:41.446239" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:24:42.062423" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:24:41 UTC 2026

  System load:  0.07               Processes:             124
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:24:17 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:24:41.445877" elapsed="0.616724"/>
</kw>
<msg time="2026-06-06T03:24:42.062717" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:41.445414" elapsed="0.617478"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:24:41.442772" elapsed="0.620276"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.064061" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:24:42.077239" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:24:42.077713" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:24:42.077970" 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-06-06T03:24:42.063519" elapsed="0.014567"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:42.078856" elapsed="0.001122"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.082608" 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-06-06T03:24:42.081311" elapsed="0.001585"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.083850" elapsed="0.000111"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.083259" elapsed="0.000868"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.083200" elapsed="0.001013"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:24:42.084918" elapsed="0.000134"/>
</return>
<status status="PASS" start="2026-06-06T03:24:42.084393" elapsed="0.000832"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.084353" elapsed="0.000959"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.085442" elapsed="0.000036"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:42.090891" elapsed="0.000642"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:42.091949" elapsed="0.000398"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:42.092739" elapsed="0.000308"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:42.086575" elapsed="0.006567"/>
</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-06-06T03:24:41.437305" elapsed="0.656079"/>
</kw>
<msg time="2026-06-06T03:24:42.093462" 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-06-06T03:24:41.436477" elapsed="0.657057"/>
</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-06-06T03:24:41.435992" elapsed="0.657687"/>
</kw>
<msg time="2026-06-06T03:24:42.093740" 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-06-06T03:24:41.435452" elapsed="0.658353"/>
</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-06-06T03:24:42.097596" elapsed="0.000500"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:42.098336" elapsed="0.000204"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:42.098763" elapsed="0.000099"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:42.094220" elapsed="0.004695"/>
</kw>
<msg time="2026-06-06T03:24:42.099009" 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-06-06T03:24:41.434607" elapsed="0.664426"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.099466" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:42.099218" elapsed="0.000289"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:24:42.099551" elapsed="0.000029"/>
</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-06-06T03:24:41.433722" elapsed="0.665970"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:41.433527" elapsed="0.666204"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:41.433401" elapsed="0.666366"/>
</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-06-06T03:24:41.429615" elapsed="0.670210"/>
</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-06-06T03:24:42.099986" elapsed="0.000212"/>
</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-06-06T03:24:42.114070" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.113957" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.113937" elapsed="0.000203"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.114435" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:24:42.114539" 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-06-06T03:24:42.114299" elapsed="0.000267"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.115002" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:42.114742" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.115446" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:42.115203" elapsed="0.000287"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:42.116265" 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-06-06T03:24:42.116040" elapsed="0.000332">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:24:42.116478" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:24:42.116524" 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-06-06T03:24:42.115669" elapsed="0.000878"/>
</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-06-06T03:24:42.116866" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:42.116623" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.116604" elapsed="0.000361"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:42.117744" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:24:42.117444" elapsed="0.000326"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:24:42.117817" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:42.117965" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:24:42.117171" elapsed="0.000818"/>
</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-06-06T03:24:42.118148" elapsed="0.000403"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.118855" level="INFO">index=4
host=10.30.170.38
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-06-06T03:24:42.118954" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:24:42.118747" elapsed="0.000234"/>
</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-06-06T03:24:42.119134" elapsed="0.002389"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.122002" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:24:42.331761" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:24:42.121736" elapsed="0.210221"/>
</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-06-06T03:24:42.337002" elapsed="0.000543"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:42.337835" elapsed="0.000241"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:42.338309" elapsed="0.000264"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:42.333564" elapsed="0.005117"/>
</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-06-06T03:24:42.332525" elapsed="0.006230"/>
</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-06-06T03:24:42.113673" elapsed="0.225158"/>
</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-06-06T03:24:42.100983" elapsed="0.237916"/>
</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-06-06T03:24:42.100589" elapsed="0.238386"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:42.100444" elapsed="0.238590"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:24:42.100291" elapsed="0.238792"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:24:41.410651" elapsed="0.928514"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.342612" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.342491" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.342469" elapsed="0.000241"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.347522" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.347414" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.347396" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.348612" 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-06-06T03:24:42.348205" elapsed="0.000450"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.349129" 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-06-06T03:24:42.348827" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:42.349199" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:42.349360" 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-06-06T03:24:42.347858" elapsed="0.001528"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:42.355126" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.355016" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.354997" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:42.356429" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.356302" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.356283" elapsed="0.000215"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:42.356998" 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-06-06T03:24:42.356674" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.357417" 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-06-06T03:24:42.357188" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.391796" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:42.358145" elapsed="0.033794"/>
</kw>
<msg time="2026-06-06T03:24:42.392083" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:42.392130" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:24:42.357623" elapsed="0.034545"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.465013" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "3 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "e "v "p "n ". "r "o "b "o "t "[K"
[?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-06-06T03:24:42.392948" elapsed="0.072243"/>
</kw>
<msg time="2026-06-06T03:24:42.465431" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:42.465479" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:24:42.392363" elapsed="0.073154"/>
</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-06-06T03:24:42.465938" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:42.465616" elapsed="0.000472"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.465588" elapsed="0.000531"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.466876" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "3 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "e "v "p "n ". "r "o "b "o "t "[K"
[?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-06-06T03:24:42.466271" elapsed="0.000693"/>
</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-06-06T03:24:42.467278" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:42.467032" elapsed="0.000391"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.467013" elapsed="0.000437"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:42.467488" elapsed="0.000040"/>
</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-06-06T03:24:42.469544" elapsed="0.000473"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:42.470365" elapsed="0.000478"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:24:42.471179" elapsed="0.000238"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:42.468732" elapsed="0.002774"/>
</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-06-06T03:24:42.467832" elapsed="0.003822"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:42.356015" elapsed="0.115743"/>
</kw>
<msg time="2026-06-06T03:24:42.471855" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:42.471901" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:42.355352" elapsed="0.116586"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:42.472121" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:42.472014" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.471995" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:42.472618" elapsed="0.000041"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:42.472983" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.473055" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:42.354720" elapsed="0.118445"/>
</kw>
<msg time="2026-06-06T03:24:42.473261" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:42.473306" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:42.349817" elapsed="0.123527"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:42.473717" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:42.473441" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.473422" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:42.349667" elapsed="0.124154"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:42.349443" elapsed="0.124411"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:42.347123" elapsed="0.126789"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:24:42.340034" elapsed="0.133972"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:42.339395" elapsed="0.134657"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:24:41.405289" elapsed="1.068817"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.474624" level="INFO">${mininet_conn_id} = 7</msg>
<var>${mininet_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:24:42.474265" elapsed="0.000541"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.475304" level="INFO">${mininet_conn_id} = 7</msg>
<arg>${mininet_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:42.474983" elapsed="0.000363"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:24:42.477050" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:24:42.477127" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:42.476769" elapsed="0.000382"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:42.477312" elapsed="0.000573"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.478859" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:24:42.831787" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:24:18 UTC 2026

  System load:  0.46               Processes:             106
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:24:18 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:24:42.478431" elapsed="0.353555"/>
</kw>
<msg time="2026-06-06T03:24:42.832084" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:42.478065" elapsed="0.354106"/>
</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-06-06T03:24:42.476317" elapsed="0.355985"/>
</kw>
<msg time="2026-06-06T03:24:42.832360" 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-06-06T03:24:42.475930" elapsed="0.356478"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:24:42.475545" elapsed="0.356942"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:42.833198" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5b02a10&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:24:42.832771" elapsed="0.000610"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.842031" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:24:42.857499" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>${PLAY_SCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:24:42.833569" elapsed="0.024014"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.859538" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:24:42.892298" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:24:42.892547" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:24:42.892678" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:24:42.892780" 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-06-06T03:24:42.859280" elapsed="0.033551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.894860" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:24:42.894186" elapsed="0.000776"/>
</kw>
<msg time="2026-06-06T03:24:42.895172" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:24:42.895271" 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-06-06T03:24:42.893292" elapsed="0.002030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.896714" 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-06-06T03:24:42.895731" elapsed="0.001044"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:24:42.897899" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:42.897062" elapsed="0.000980"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.897011" elapsed="0.001090"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:24:42.898450" elapsed="0.000065"/>
</return>
<status status="PASS" start="2026-06-06T03:24:42.898228" elapsed="0.000363"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.898190" elapsed="0.000487"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.898888" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.898808" elapsed="0.000169"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:42.898772" elapsed="0.000254"/>
</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-06-06T03:24:42.899356" elapsed="0.000047"/>
</kw>
<msg time="2026-06-06T03:24:42.899710" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:24:42.858751" elapsed="0.041017"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:24:42.900124" elapsed="0.000057"/>
</return>
<status status="PASS" start="2026-06-06T03:24:42.899921" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.899882" elapsed="0.000418"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:42.900666" elapsed="0.000050"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:24:42.858044" elapsed="0.042808"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.906174" level="INFO">${EVPN_CONF_URL} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes</msg>
<arg>${EVPN_CONF_URL}</arg>
<arg>/rests/data/bgp-rib:application-rib=${ODL_SYSTEM_IP}/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:42.901253" elapsed="0.004969"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.910855" level="INFO">${EVPN_LOC_RIB} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<arg>${EVPN_LOC_RIB}</arg>
<arg>/rests/data/bgp-rib:bgp-rib/rib=${RIB_NAME}/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:42.906395" elapsed="0.004508"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.915633" level="INFO">${EVPN_FAMILY_LOC_RIB} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig</msg>
<arg>${EVPN_FAMILY_LOC_RIB}</arg>
<arg>/rests/data/bgp-rib:bgp-rib/rib=${RIB_NAME}/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:42.911077" elapsed="0.004616"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.941013" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/empty_routes.vanadium/empty_routes.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:42.940465" elapsed="0.000576"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:42.941884" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/empty_routes.vanadium/empty_routes.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:42.941589" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/empty_routes.vanadium/empty_routes.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:42.942063" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:42.941245" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.942653" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/empty_routes/empty_routes.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:42.942254" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:42.942986" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/empty_routes/empty_routes.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/empty_routes/empty_routes.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:42.943149" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "odl-bgp-evpn:l2vpn-address-family",
      "safi": "odl-bgp-evpn:evpn-subsequent-address-family",
      "attributes": {
        "uptodate": false
      }
   ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:42.942849" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.943628" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "odl-bgp-evpn:l2vpn-address-family",
      "safi": "odl-bgp-evpn:evpn-subsequent-address-family",
      "attributes": {
        "uptodate": false
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:42.943379" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:42.944067" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:42.943759" elapsed="0.000368"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.944596" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:42.944302" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:42.944152" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.943741" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.945305" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "odl-bgp-evpn:l2vpn-address-family",
      "safi": "odl-bgp-evpn:evpn-subsequent-address-family",
      "attributes": {
        "uptodate": false
      }
   ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:42.944855" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:42.945383" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:42.945537" level="INFO">${EMPTY_ROUTES} = {
  "bgp-rib:tables": [
    {
      "afi": "odl-bgp-evpn:l2vpn-address-family",
      "safi": "odl-bgp-evpn:evpn-subsequent-address-family",
      "attributes": {
        "uptodate": false
      }
   ...</msg>
<var>${EMPTY_ROUTES}</var>
<arg>${EVPN_DIR}/empty_routes</arg>
<arg>empty_routes.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:42.938286" elapsed="0.007278"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.946065" level="INFO">${EMPTY_ROUTES} = {
  "bgp-rib:tables": [
    {
      "afi": "odl-bgp-evpn:l2vpn-address-family",
      "safi": "odl-bgp-evpn:evpn-subsequent-address-family",
      "attributes": {
        "uptodate": false
      }
   ...</msg>
<arg>${EMPTY_ROUTES}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:24:42.945755" elapsed="0.000353"/>
</kw>
<doc>Initialize SetupUtils. Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:41.404966" elapsed="1.541199"/>
</kw>
<test id="s1-s13-t1" name="Configure_App_Peer" line="48">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:42.949462" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:42.949186" elapsed="0.000563"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.950752" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.950620" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.950600" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:42.956039" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.955931" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.955913" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.957141" 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-06-06T03:24:42.956735" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:42.957665" 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-06-06T03:24:42.957347" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:42.957739" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:42.957897" 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-06-06T03:24:42.956339" elapsed="0.001584"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:42.963493" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.963384" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.963364" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:42.964780" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:42.964667" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:42.964624" elapsed="0.000226"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:42.965323" 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-06-06T03:24:42.965002" elapsed="0.000349"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:42.965751" level="INFO">${current_connection_index} = 7</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-06-06T03:24:42.965518" elapsed="0.000259"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.000205" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:42.966328" elapsed="0.034161"/>
</kw>
<msg time="2026-06-06T03:24:43.000855" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:43.000926" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:42.965980" elapsed="0.035000"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.027018" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:43.002037" elapsed="0.025106"/>
</kw>
<msg time="2026-06-06T03:24:43.027312" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:43.027358" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "C "o "n "f "i "g "u "r "e "_...</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-06-06T03:24:43.001366" elapsed="0.026030"/>
</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-06-06T03:24:43.027833" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.027508" elapsed="0.000384"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.027473" elapsed="0.000452"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.028414" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:43.028085" elapsed="0.000407"/>
</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-06-06T03:24:43.028818" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.028564" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.028542" elapsed="0.000357"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:43.028940" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:43.031767" elapsed="0.000158"/>
</kw>
<msg time="2026-06-06T03:24:43.031991" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.030688" elapsed="0.001447"/>
</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="NOT RUN" start="2026-06-06T03:24:43.032421" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.032787" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:43.029976" elapsed="0.003001"/>
</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-06-06T03:24:43.029319" elapsed="0.003726"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:42.964338" elapsed="0.068843"/>
</kw>
<msg time="2026-06-06T03:24:43.033281" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:43.033334" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "C "o "n "f "i "g "u "r "e "_...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:42.963733" elapsed="0.069640"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:43.035494" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:24:43.033454" elapsed="0.002112"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.033434" elapsed="0.002158"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.036035" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.036385" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.036457" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:42.963043" elapsed="0.073526"/>
</kw>
<msg time="2026-06-06T03:24:43.036753" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:43.036799" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "C "o "n "f "i "g "u "r "e "_...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:42.958305" elapsed="0.078532"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.037200" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.036918" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.036900" elapsed="0.000380"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:42.958156" elapsed="0.079150"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:42.957979" elapsed="0.079363"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:42.955553" elapsed="0.081848"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:42.950332" elapsed="0.087126"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:42.949903" elapsed="0.087602"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:42.946963" elapsed="0.090594"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.038282" level="INFO">&amp;{mapping} = { BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.037758" elapsed="0.000555"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.075054" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.074620" elapsed="0.000470"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.076066" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.075722" elapsed="0.000429">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:43.076252" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.075280" elapsed="0.000998"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.076871" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:43.076455" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.077246" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:43.077440" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:43.077093" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.077915" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.077653" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.079029" level="INFO">mapping: {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.078763" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.079523" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.079246" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.080284" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.079976" elapsed="0.000335"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.081415" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.081174" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.081558" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:24:43.081784" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.080800" elapsed="0.001011"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.081979" elapsed="0.000255"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:43.079830" elapsed="0.002446"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.082858" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.082532" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.083717" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.083420" elapsed="0.000340"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.083834" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:24:43.084013" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.083080" elapsed="0.000959"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.084200" elapsed="0.000230"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:24:43.082392" elapsed="0.002081"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:43.079611" elapsed="0.004897"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:43.084554" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:43.084733" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:43.078410" elapsed="0.006350"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.078049" elapsed="0.006744"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.084979" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.084821" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.078021" elapsed="0.007053"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.085878" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:43.085232" elapsed="0.000677"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.085960" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:43.073960" elapsed="0.012128"/>
</kw>
<msg time="2026-06-06T03:24:43.086145" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.060051" elapsed="0.026144"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.099080" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.111689" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.124359" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.124632" elapsed="0.000037"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.124838" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.125310" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.125120" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:43.125098" elapsed="0.000296"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.125546" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.125734" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.125907" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:43.125054" elapsed="0.000906"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.124920" elapsed="0.001067"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.126140" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.126216" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:43.126356" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:43.055482" elapsed="0.070902"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.154652" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.154188" elapsed="0.000501"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.155533" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.155245" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:43.155736" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.154884" elapsed="0.000877"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.156324" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:43.155934" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.156679" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:43.156875" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:43.156518" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.157337" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.157085" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:43.157871" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.157473" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.158416" level="INFO">${mapping_to_use} = {'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.158117" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.157965" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.157445" elapsed="0.001121"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.159346" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:43.158738" elapsed="0.000638"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.159432" elapsed="0.000038"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:43.153438" elapsed="0.006136"/>
</kw>
<msg time="2026-06-06T03:24:43.159632" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.139861" elapsed="0.019843"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.172581" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.185387" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.198182" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.198396" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.198583" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.199038" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.198883" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:43.198865" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.199266" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.199438" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.199607" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:43.198829" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.198707" elapsed="0.001004"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.199866" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.199986" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:24:43.200132" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:43.136821" elapsed="0.063342"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.201703" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.201392" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:43.201880" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.200984" elapsed="0.000921"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.202246" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.201977" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.202838" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.202522" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.202328" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.201958" elapsed="0.000965"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.205597" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:43.203081" elapsed="0.002543"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:43.205695" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:43.205855" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:43.200575" elapsed="0.005304"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.207307" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.207054" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.207931" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.207512" elapsed="0.000469"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.208410" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.208161" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.208869" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.208610" elapsed="0.000302"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:43.209774" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:24:43.209551" elapsed="0.000250"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:24:43.210137" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:24:43.209960" elapsed="0.000202"/>
</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-06-06T03:24:43.210316" elapsed="0.000216"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.210954" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.210706" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:24:43.211041" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:43.211196" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:24:43.209141" elapsed="0.002080"/>
</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-06-06T03:24:43.228855" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:24:43.229103" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:24:43 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:43.229318" 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-06-06T03:24:43.213463" elapsed="0.015895"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.211291" elapsed="0.018150"/>
</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-06-06T03:24:43.229817" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.229492" elapsed="0.000425"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.211273" elapsed="0.018676"/>
</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-06-06T03:24:43.235799" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.231575" elapsed="0.004290"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.231193" elapsed="0.004723"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.231163" elapsed="0.004789"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.239230" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.236427" elapsed="0.002851"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.236033" elapsed="0.003282"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.236009" elapsed="0.003332"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.240012" 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-06-06T03:24:43.239555" elapsed="0.000485"/>
</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-06-06T03:24:43.240386" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.240113" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.240998" 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-06-06T03:24:43.240668" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.240477" elapsed="0.000589"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.240094" elapsed="0.000992"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.241631" 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-06-06T03:24:43.241256" elapsed="0.000418"/>
</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-06-06T03:24:43.241997" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.241747" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.242567" 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-06-06T03:24:43.242254" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.242080" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.241728" elapsed="0.000939"/>
</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-06-06T03:24:43.242834" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:43.243722" 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-06-06T03:24:43.243375" elapsed="0.000388"/>
</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-06-06T03:24:43.243968" elapsed="0.002435"/>
</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-06-06T03:24:43.230576" elapsed="0.015895"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:43.246667" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:24:43.246540" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.246521" elapsed="0.000252"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:24:43.246931" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.246999" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:43.249355" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:24:43.206216" elapsed="0.043167"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.249503" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.249685" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:43.043247" elapsed="0.206465"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.250071" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.249814" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.249796" elapsed="0.000370"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.250202" elapsed="0.000026"/>
</return>
<arg>${BGP_DIR}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:24:43.038595" elapsed="0.211736"/>
</kw>
<doc>Configures bgp application peer. Openconfig is used for carbon and above.</doc>
<status status="PASS" start="2026-06-06T03:24:42.946229" elapsed="0.304236"/>
</test>
<test id="s1-s13-t2" name="Reconfigure_ODL_To_Accept_Connection" line="54">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:43.253926" elapsed="0.000222"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:43.253629" elapsed="0.000575"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.255278" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.255152" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.255132" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.260697" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.260569" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.260550" elapsed="0.000218"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.261872" 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-06-06T03:24:43.261460" elapsed="0.000440"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.262371" 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-06-06T03:24:43.262069" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:43.262443" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:43.262599" 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-06-06T03:24:43.261060" elapsed="0.001564"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:43.268840" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.268721" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.268700" elapsed="0.000229"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:43.270271" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.270147" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.270127" elapsed="0.000218"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:43.270831" 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-06-06T03:24:43.270500" elapsed="0.000358"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.271265" level="INFO">${current_connection_index} = 7</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-06-06T03:24:43.271028" elapsed="0.000267"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.302504" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:43.271842" elapsed="0.030787"/>
</kw>
<msg time="2026-06-06T03:24:43.302834" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:43.302881" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:43.271465" elapsed="0.031454"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.351321" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:24:43.303615" elapsed="0.047911"/>
</kw>
<msg time="2026-06-06T03:24:43.351776" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:43.351825" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "R "e "c "o "n "f "i "g "u "r...</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-06-06T03:24:43.303118" elapsed="0.048746"/>
</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-06-06T03:24:43.352325" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.351985" elapsed="0.000402"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.351946" elapsed="0.000471"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.353031" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:24:43.352573" elapsed="0.000543"/>
</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-06-06T03:24:43.353412" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.353186" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.353167" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:43.353532" elapsed="0.000046"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:43.356314" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:24:43.356533" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.355244" elapsed="0.001458"/>
</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="NOT RUN" start="2026-06-06T03:24:43.357251" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.357626" elapsed="0.000197"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:43.354520" elapsed="0.003424"/>
</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-06-06T03:24:43.353913" elapsed="0.004098"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:43.269781" elapsed="0.088329"/>
</kw>
<msg time="2026-06-06T03:24:43.358202" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:43.358247" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "R "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:43.269092" elapsed="0.089193"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:43.358471" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:43.358362" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.358342" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.358995" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.359346" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.359418" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:43.268348" elapsed="0.091178"/>
</kw>
<msg time="2026-06-06T03:24:43.359621" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:43.359684" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "R "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:43.263044" elapsed="0.096680"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.360060" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.359804" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.359786" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:43.262894" elapsed="0.097315"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:43.262706" elapsed="0.097541"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:43.260196" elapsed="0.100111"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:43.254852" elapsed="0.105515"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:43.254364" elapsed="0.106050"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:43.251403" elapsed="0.109066"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.361326" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB_OPENCONFIG=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.360676" elapsed="0.000680"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.396005" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.395596" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.396862" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.396547" elapsed="0.000403">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:43.397046" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.396208" elapsed="0.000863"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.397627" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:43.397242" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.397979" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:43.398193" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:43.397839" elapsed="0.000381"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.398624" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.398380" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.399672" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.399396" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.400344" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.399883" elapsed="0.000487"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.401122" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.400784" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.401915" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.401683" elapsed="0.000258"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.401994" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:24:43.402153" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.401342" elapsed="0.000835"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.402336" elapsed="0.000247"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:24:43.400616" elapsed="0.002010"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.403276" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.402974" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.404042" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.403831" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.404119" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:43.404267" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.403491" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.404447" elapsed="0.000237"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:24:43.402833" elapsed="0.001898"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.405289" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.404991" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.406044" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.405835" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.406119" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.406267" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.405500" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.406444" elapsed="0.000236"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:24:43.404854" elapsed="0.001867"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.407263" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.406966" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.408019" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.407808" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.408095" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.408244" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.407474" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.408420" elapsed="0.000233"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:24:43.406831" elapsed="0.001864"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.409284" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.408986" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.410054" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.409842" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.410131" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:43.410280" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.409497" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.410459" elapsed="0.000239"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:24:43.408807" elapsed="0.001934"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.411460" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:24:43.410990" elapsed="0.000496"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:24:43.412216" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.412008" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:24:43.412291" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:43.412438" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:24:43.411689" elapsed="0.000773"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:24:43.412616" elapsed="0.000259"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:24:43.410853" elapsed="0.002063"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:24:43.400427" elapsed="0.012525"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:24:43.413032" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.413193" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:24:43.399070" elapsed="0.014149"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.398763" elapsed="0.014487"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.413427" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.413275" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.398737" elapsed="0.014765"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.414342" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:43.413662" elapsed="0.000709"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.414420" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:43.394973" elapsed="0.019570"/>
</kw>
<msg time="2026-06-06T03:24:43.414597" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.382111" elapsed="0.032696"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.427433" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.440000" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.452579" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.452791" elapsed="0.000037"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.452989" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.453370" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.453207" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:43.453193" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.453597" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.453793" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.453965" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:43.453165" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.453064" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.454191" elapsed="0.000099"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.454354" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:24:43.454479" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:43.377687" elapsed="0.076819"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.481295" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.480912" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.482076" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.481845" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:43.482244" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.481491" elapsed="0.000777"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.482836" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:43.482435" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.483164" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:43.483317" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:43.483029" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.483777" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.483508" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:43.484203" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.483903" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.484964" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.484434" elapsed="0.000557"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.484286" elapsed="0.000741"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.483884" elapsed="0.001165"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.485932" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:43.485199" elapsed="0.000763"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.486011" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:43.480235" elapsed="0.005900"/>
</kw>
<msg time="2026-06-06T03:24:43.486227" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.467369" elapsed="0.018905"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.498912" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.511583" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.524180" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.524377" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.524554" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.524953" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.524803" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:24:43.524788" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.525176" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.525345" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.525512" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:24:43.524745" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.524627" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.525750" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.525826" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:43.525958" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:24:43.464668" elapsed="0.061319"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:43.527258" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.527011" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:43.527450" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.526666" elapsed="0.000809"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.527811" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.527546" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.528370" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.528079" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.527892" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.527527" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.530886" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:43.528607" elapsed="0.002305"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:24:43.530964" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.531117" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:24:43.526322" elapsed="0.004820"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.532532" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.532285" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.533003" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.532751" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.533465" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.533223" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.533919" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.533678" elapsed="0.000284"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:43.534791" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:24:43.534571" elapsed="0.000247"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:24:43.535148" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:24:43.534974" elapsed="0.000199"/>
</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-06-06T03:24:43.535325" elapsed="0.000203"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.536117" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.535702" elapsed="0.000460"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:24:43.536204" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:43.536359" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:24:43.534165" elapsed="0.002219"/>
</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-06-06T03:24:43.552428" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1090', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:24:43.552535" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:43.552629" 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-06-06T03:24:43.538581" elapsed="0.014094"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.536453" elapsed="0.016268"/>
</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-06-06T03:24:43.552922" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.552761" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.536435" elapsed="0.016574"/>
</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-06-06T03:24:43.556343" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.553964" elapsed="0.002422"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.553741" elapsed="0.002679"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.553722" elapsed="0.002723"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.559094" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.556754" elapsed="0.002388"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.556502" elapsed="0.002676"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.556484" elapsed="0.002721"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.559902" 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-06-06T03:24:43.559406" elapsed="0.000523"/>
</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-06-06T03:24:43.560248" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.560002" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.560851" 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-06-06T03:24:43.560497" elapsed="0.000381"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.560329" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.559982" elapsed="0.000953"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.561464" 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-06-06T03:24:43.561101" elapsed="0.000389"/>
</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-06-06T03:24:43.561816" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.561559" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.562353" 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-06-06T03:24:43.562060" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:43.561896" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.561541" elapsed="0.000892"/>
</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-06-06T03:24:43.562594" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:24:43.563427" 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-06-06T03:24:43.563134" elapsed="0.000318"/>
</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-06-06T03:24:43.563612" elapsed="0.002356"/>
</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-06-06T03:24:43.553369" elapsed="0.012665"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:24:43.566213" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:24:43.566102" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.566084" elapsed="0.000222"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:24:43.566461" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.566528" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:24:43.568839" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:24:43.531474" elapsed="0.037392"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.568979" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.569139" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:24:43.366328" elapsed="0.202837"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.569518" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.569264" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.569247" elapsed="0.000364"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:24:43.569659" elapsed="0.000027"/>
</return>
<arg>${BGP_DIR}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:24:43.361630" elapsed="0.208157"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:24:43.250826" elapsed="0.319091"/>
</test>
<test id="s1-s13-t3" name="Start_Bgp_Peer" line="66">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:43.573749" elapsed="0.000212"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:43.573465" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.575037" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.574926" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.574907" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.580124" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.580018" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.580000" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.581216" 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-06-06T03:24:43.580833" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.581719" 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-06-06T03:24:43.581407" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:43.581790" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:43.581944" 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-06-06T03:24:43.580424" elapsed="0.001545"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:43.587530" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.587422" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.587403" elapsed="0.000194"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:43.588828" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:43.588701" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.588681" elapsed="0.000214"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:43.589342" 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-06-06T03:24:43.589043" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.589769" level="INFO">${current_connection_index} = 7</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-06-06T03:24:43.589531" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.620658" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:43.590297" elapsed="0.030599"/>
</kw>
<msg time="2026-06-06T03:24:43.621142" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:43.621190" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:43.589958" elapsed="0.031269"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.646191" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:43.622037" elapsed="0.024366"/>
</kw>
<msg time="2026-06-06T03:24:43.646593" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:43.646664" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "S "t "a "r "t "_ "B "g "p "_...</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-06-06T03:24:43.621510" elapsed="0.025195"/>
</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-06-06T03:24:43.647132" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.646822" elapsed="0.000367"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.646788" elapsed="0.000432"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.647728" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:24:43.647373" elapsed="0.000423"/>
</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-06-06T03:24:43.648088" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.647864" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.647845" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:43.648205" elapsed="0.000045"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:43.650935" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:24:43.651149" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:43.649880" elapsed="0.001404"/>
</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="NOT RUN" start="2026-06-06T03:24:43.651562" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.651932" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:43.649196" elapsed="0.002924"/>
</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-06-06T03:24:43.648553" elapsed="0.003633"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:43.588375" elapsed="0.063909"/>
</kw>
<msg time="2026-06-06T03:24:43.652381" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:43.652424" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "S "t "a "r "t "_ "B "g "p "_...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:43.587768" elapsed="0.064694"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:43.652663" elapsed="0.000040"/>
</return>
<status status="PASS" start="2026-06-06T03:24:43.652539" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.652520" elapsed="0.000242"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.653186" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.653535" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:43.653605" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:43.587086" elapsed="0.066643"/>
</kw>
<msg time="2026-06-06T03:24:43.653824" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:43.653867" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "S "t "a "r "t "_ "B "g "p "_...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:43.582362" elapsed="0.071541"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:43.654235" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:43.653978" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:43.653961" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:43.582213" elapsed="0.072122"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:43.582029" elapsed="0.072341"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:43.579657" elapsed="0.074770"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:43.574619" elapsed="0.079903"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:43.574175" elapsed="0.080393"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:43.571097" elapsed="0.083524"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Start_Bgp_Peer">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.656444" level="INFO">${command} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --evpn --wfr 1 &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:43.656114" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:43.656919" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --evpn --wfr 1 &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:43.656634" elapsed="0.000331"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:43.660249" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --evpn --wfr 1 &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:24:43.660338" level="INFO">${output} =  python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --evpn --wfr 1 &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:43.657122" elapsed="0.003243"/>
</kw>
<arg>--amount 0 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --${BGP_TOOL_LOG_LEVEL} --evpn --wfr 1</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:24:43.655620" elapsed="0.004804"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:24:49.662681" level="FAIL">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.662083" elapsed="6.001414">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.663869" elapsed="0.000037"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:24:43.661807" elapsed="6.002223">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:24:43.661378" elapsed="6.002781"/>
</kw>
<msg time="2026-06-06T03:24:49.664286" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:43.661014" elapsed="6.003298"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:24:49.664500" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:24:49.664409" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.664381" elapsed="0.000206"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.664830" elapsed="0.000027"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.665011" elapsed="0.049887"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:24:43.660730" elapsed="6.054312"/>
</kw>
<doc>Starts bgp peer and verifies that the peer runs.</doc>
<status status="PASS" start="2026-06-06T03:24:43.655277" elapsed="6.059829"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>Start Bgp Peer</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:43.654828" elapsed="6.060325"/>
</kw>
<doc>Start Python speaker to connect to ODL. We need to do WUKS until odl really starts to accept incomming bgp connection. The failure happens if the incomming connection comes too quickly after configuring the peer in the previous test case.</doc>
<status status="PASS" start="2026-06-06T03:24:43.570274" elapsed="6.145026"/>
</test>
<test id="s1-s13-t4" name="Odl_To_Play_route_es_arb" line="71">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:49.719250" elapsed="0.000220"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:49.718972" elapsed="0.000557"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:49.720606" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:49.720464" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.720441" elapsed="0.000256"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:49.725779" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:49.725668" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.725635" elapsed="0.000296"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.726973" 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-06-06T03:24:49.726559" elapsed="0.000444"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.727471" 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-06-06T03:24:49.727170" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:49.727543" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:49.727722" 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-06-06T03:24:49.726173" elapsed="0.001575"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:49.733447" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:49.733336" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.733316" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:49.734988" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:49.734806" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.734786" elapsed="0.000365"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:49.735732" 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-06-06T03:24:49.735306" elapsed="0.000487"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:49.736419" level="INFO">${current_connection_index} = 7</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-06-06T03:24:49.736156" elapsed="0.000323"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:49.767564" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:49.738358" elapsed="0.029367"/>
</kw>
<msg time="2026-06-06T03:24:49.767860" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:49.767953" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:49.736808" elapsed="0.031215"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:49.793335" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "a "r "b "[K"
[?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-06-06T03:24:49.769957" elapsed="0.023514"/>
</kw>
<msg time="2026-06-06T03:24:49.793603" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:49.793716" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:24:49.768419" elapsed="0.025370"/>
</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-06-06T03:24:49.794452" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:49.794092" elapsed="0.000482"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.794068" elapsed="0.000566"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.795373" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "a "r "b "[K"
[?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-06-06T03:24:49.794806" elapsed="0.000682"/>
</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-06-06T03:24:49.796029" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:49.795676" elapsed="0.000467"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.795654" elapsed="0.000545"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:49.796236" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:49.799725" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:24:49.799911" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:49.799234" elapsed="0.000745"/>
</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="NOT RUN" start="2026-06-06T03:24:49.800239" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.800463" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:49.798470" elapsed="0.002288"/>
</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-06-06T03:24:49.796524" elapsed="0.004328"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:49.734342" elapsed="0.066692"/>
</kw>
<msg time="2026-06-06T03:24:49.801129" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:49.801174" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:49.733702" elapsed="0.067532"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:49.801424" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:24:49.801315" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.801295" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.801983" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.802538" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:49.802611" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:49.732978" elapsed="0.069830"/>
</kw>
<msg time="2026-06-06T03:24:49.802903" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:49.802947" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:49.728130" elapsed="0.074853"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:49.803316" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:49.803058" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:49.803040" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:49.727981" elapsed="0.075435"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:49.727805" elapsed="0.075642"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:49.725281" elapsed="0.078223"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:49.720159" elapsed="0.083401"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:49.719710" elapsed="0.083895"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:49.716632" elapsed="0.087043"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:49.811956" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:49.812097" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:49.812213" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:49.804106" elapsed="0.008133"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:49.812411" elapsed="0.002599"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:49.820366" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:49.820761" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:49.820909" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:49.815180" elapsed="0.005760"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:49.824064" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:49.823758" elapsed="0.000335"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:49.824532" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:49.824255" elapsed="0.000304"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:49.824737" elapsed="0.000331"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:49.821174" elapsed="0.003956"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:49.803827" elapsed="0.021370"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:24:49.716020" elapsed="0.109219"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:49.826027" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:49.826210" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:49.825826" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:49.826589" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:49.826730" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
         ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:49.826400" elapsed="0.000358"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:49.827104" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/announce_route_es_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/announce_route_es_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:49.827228" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:49.826915" elapsed="0.000339"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:24:49.827619" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:24:49.827412" elapsed="0.000249"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:49.828013" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/withdraw_route_es_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/withdraw_route_es_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:49.828138" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:49.827825" elapsed="0.000339"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:24:49.828521" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:24:49.828323" elapsed="0.000224"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.828970" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.828723" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.829492" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.829245" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.829956" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.829713" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.830394" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.830155" elapsed="0.000283"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:49.830590" elapsed="0.003284"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:49.846889" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '706', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:24:49.846950" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:49.847042" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:49.834041" elapsed="0.013026"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.849913" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.847245" elapsed="0.002711"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:49.855453" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:49.855787" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '339'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:49.855901" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:49.850119" elapsed="0.005810"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.858665" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.856114" elapsed="0.002602"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:49.866028" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:49.866454" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '339'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:49.866557" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:49.859732" elapsed="0.006852"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.869251" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:49.866789" elapsed="0.002512"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:49.869462" elapsed="0.002529"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:49.874447" level="INFO">${update} = </msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:49.872159" elapsed="0.002317"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:24:49.876870" level="FAIL"> == </msg>
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="FAIL" start="2026-06-06T03:24:49.874636" elapsed="0.002310"> == </status>
</kw>
<return>
<value>${update}</value>
<status status="NOT RUN" start="2026-06-06T03:24:49.877008" elapsed="0.000023"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="FAIL" start="2026-06-06T03:24:49.859371" elapsed="0.017758"> == </status>
</kw>
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.886596" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.886860" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '339'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:51.887024" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.879016" elapsed="0.008049"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.891102" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.887344" elapsed="0.003834"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:51.891420" elapsed="0.004217"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:51.898458" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:51.895919" elapsed="0.002583"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:24:51.898845" elapsed="0.003540"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:24:51.902466" elapsed="0.000057"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:24:51.877878" elapsed="0.024856"/>
</kw>
<msg time="2026-06-06T03:24:51.902875" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:49.858893" elapsed="2.044021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.903720" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.903171" elapsed="0.000633"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.905165" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:24:51.905272" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:51.904780" elapsed="0.000524"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.906057" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:24:51.906249" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:51.905605" elapsed="0.000681"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:51.906517" elapsed="0.000479"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:51.907533" level="INFO">${sum_1} = 1851</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:51.907228" elapsed="0.000351"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:51.908200" level="INFO">${sum_2} = 1851</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:51.907889" elapsed="0.000350"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:51.908468" elapsed="0.000513"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:24:51.904201" elapsed="0.004891"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:51.909362" elapsed="0.001586"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.917894" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.918023" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '339'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:51.918120" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.911520" elapsed="0.006626"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.920881" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.918326" elapsed="0.002627"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:51.921208" elapsed="0.003640"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.931304" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.931465" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '339'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:51.931610" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.925087" elapsed="0.006604"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.935627" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.932065" elapsed="0.003655"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:51.935946" elapsed="0.003716"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:24:51.942515" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:51.939784" elapsed="0.002775"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:51.939752" elapsed="0.002832"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.949536" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.949598" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.949760" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.942786" elapsed="0.007005"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:24:51.911201" elapsed="0.038661"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.956719" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.956880" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:51.957010" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.951304" elapsed="0.005742"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.961132" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.957297" elapsed="0.003905"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:51.961431" elapsed="0.003680"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:51.967893" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:51.965377" elapsed="0.002576"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:24:51.968259" elapsed="0.003132"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:24:51.971467" elapsed="0.000045"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:24:51.950729" elapsed="0.020946"/>
</kw>
<msg time="2026-06-06T03:24:51.971794" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:51.950049" elapsed="0.021780"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.972565" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.972104" elapsed="0.000569"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.974026" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:24:51.974146" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:51.973532" elapsed="0.000649"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.974792" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:24:51.974899" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:51.974406" elapsed="0.000526"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:51.975160" elapsed="0.000580"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:51.976268" level="INFO">${sum_1} = 1404</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:51.975972" elapsed="0.000333"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:51.976863" level="INFO">${sum_2} = 1404</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:51.976522" elapsed="0.000397"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:51.977149" elapsed="0.000437"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:24:51.973017" elapsed="0.004676"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.983904" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.984040" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:51.984141" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.978822" elapsed="0.005345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.986863" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.984342" elapsed="0.002572"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:51.987082" elapsed="0.002680"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:51.994365" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:51.994571" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:51.994749" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:51.989933" elapsed="0.004862"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:51.998555" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:51.995038" elapsed="0.003584"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:51.998868" elapsed="0.003714"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:24:52.005995" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:24:52.002722" elapsed="0.003358"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.002691" elapsed="0.003426"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.006333" elapsed="0.000030"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:24:51.978133" elapsed="0.028323"/>
</kw>
<arg>route_es_arb</arg>
<status status="PASS" start="2026-06-06T03:24:49.825509" elapsed="2.181013"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:49.715544" elapsed="2.291154"/>
</test>
<test id="s1-s13-t5" name="Play_To_Odl_route_es_arb" line="73">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:52.012244" elapsed="0.000297"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:52.011826" elapsed="0.000795"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:52.013780" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:52.013636" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.013615" elapsed="0.000236"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:52.018971" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:52.018850" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.018829" elapsed="0.000213"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.020154" 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-06-06T03:24:52.019725" elapsed="0.000458"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.020666" 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-06-06T03:24:52.020349" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:52.020741" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:24:52.020901" 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-06-06T03:24:52.019316" elapsed="0.001611"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:52.026509" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:52.026399" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.026380" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:52.028057" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:52.027856" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.027836" elapsed="0.000387"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:52.028807" 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-06-06T03:24:52.028379" elapsed="0.000495"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:52.029497" level="INFO">${current_connection_index} = 7</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-06-06T03:24:52.029228" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:52.058826" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:52.031455" elapsed="0.027498"/>
</kw>
<msg time="2026-06-06T03:24:52.059090" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:52.059186" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:52.029897" elapsed="0.029359"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:52.089801" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "a "r "b "[K"
[?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-06-06T03:24:52.061260" elapsed="0.028680"/>
</kw>
<msg time="2026-06-06T03:24:52.090126" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:52.090240" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:24:52.059681" elapsed="0.030633"/>
</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-06-06T03:24:52.091017" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:52.090620" elapsed="0.000516"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.090595" elapsed="0.000602"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.092094" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "a "r "b "[K"
[?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-06-06T03:24:52.091353" elapsed="0.000860"/>
</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-06-06T03:24:52.092771" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:52.092394" elapsed="0.000495"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.092372" elapsed="0.000576"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:52.092987" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:52.096817" elapsed="0.000157"/>
</kw>
<msg time="2026-06-06T03:24:52.097018" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:52.096257" elapsed="0.000827"/>
</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="NOT RUN" start="2026-06-06T03:24:52.097303" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.097569" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:52.095377" elapsed="0.002485"/>
</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-06-06T03:24:52.093281" elapsed="0.004674"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:52.027393" elapsed="0.070740"/>
</kw>
<msg time="2026-06-06T03:24:52.098227" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:52.098271" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:52.026751" elapsed="0.071555"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:52.098494" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:52.098384" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.098364" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.099076" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.099503" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:52.099578" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:52.026050" elapsed="0.073716"/>
</kw>
<msg time="2026-06-06T03:24:52.099865" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:52.099910" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:52.021312" elapsed="0.078662"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.100396" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:52.100065" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.100046" elapsed="0.000436"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:52.021163" elapsed="0.079343"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:52.020985" elapsed="0.079554"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:52.018374" elapsed="0.082221"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:52.013343" elapsed="0.087336"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:52.012862" elapsed="0.087870"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:52.008465" elapsed="0.092322"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:52.106319" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:52.106486" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:52.106636" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:52.101220" elapsed="0.005464"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:52.106859" elapsed="0.002722"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:52.114952" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:52.115148" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:52.115292" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:52.109768" elapsed="0.005561"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:52.120080" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:52.119615" elapsed="0.000506"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:52.120752" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:52.120348" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:52.121015" elapsed="0.000454"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:52.115679" elapsed="0.005877"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:52.100937" elapsed="0.020695"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:24:52.007768" elapsed="0.113943"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:52.122898" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:52.123188" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:52.122568" elapsed="0.000663"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.150319" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_arb.vanadium/route_es_arb.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:52.149935" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:52.151143" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb.vanadium/route_es_arb.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:52.150891" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb.vanadium/route_es_arb.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:52.151315" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:52.150521" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.151930" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:52.151509" elapsed="0.000450"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:52.152258" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/route_es_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:52.152388" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
         ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:52.152123" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.152837" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:52.152574" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:52.153286" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:52.152966" elapsed="0.000379"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.153875" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:52.153521" elapsed="0.000380"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:52.153370" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:52.152937" elapsed="0.001022"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.154559" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
         ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:52.154112" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:52.154654" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:24:52.154816" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
         ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:52.147471" elapsed="0.007372"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:52.155202" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/announce_route_es_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/announce_route_es_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:52.155327" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:52.155009" elapsed="0.000345"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:52.155736" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/withdraw_route_es_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_arb/withdraw_route_es_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:52.155866" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:52.155513" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.156329" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:52.156084" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.156803" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:52.156539" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.157245" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:52.157008" elapsed="0.000281"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:52.157696" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:52.157444" elapsed="0.000297"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:52.157894" elapsed="0.002210"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:24:52.160265" elapsed="0.001872"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:52.167595" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:52.167780" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:52.167974" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:24:52.163301" elapsed="0.005219">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.168816" elapsed="0.000034"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:52.169155" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:24:52.162968" elapsed="0.006361">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:54.179177" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:54.179379" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '339'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:54.179526" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:54.171047" elapsed="0.008516"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:24:54.180308" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:24:54.183610" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:24:54.179870" elapsed="0.003830"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:54.188318" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:54.187681" elapsed="0.000677"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:54.189149" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:54.188585" elapsed="0.000603"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:54.189413" elapsed="0.000501"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:54.184043" elapsed="0.005963"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:24:54.170051" elapsed="0.020032"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:52.162331" elapsed="2.027820"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:24:54.190378" elapsed="0.002806"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:54.200325" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:54.200578" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:54.200764" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:54.194492" elapsed="0.006311"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:54.201049" elapsed="0.003933"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:54.211330" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:54.211927" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:24:54.212078" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:54.205221" elapsed="0.006896"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:54.216574" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:54.216172" elapsed="0.000442"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:54.217479" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:54.216861" elapsed="0.000659"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:24:54.218210" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:24:54.218486" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:24:54.217767" elapsed="0.000821">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:24:54.212447" elapsed="0.006370">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:54.194105" elapsed="0.024939">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.227949" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.228150" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.228296" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.220558" elapsed="0.007774"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.228580" elapsed="0.003698"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.238294" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.238441" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:56.238583" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.232516" elapsed="0.006103"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.243018" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.242574" elapsed="0.000483"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.243679" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.243278" elapsed="0.000442"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.243947" elapsed="0.000480"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.238984" elapsed="0.005533"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.219737" elapsed="0.024861"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:54.193462" elapsed="2.051220"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:24:56.245461" elapsed="0.002693"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.254769" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.254946" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.255159" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.249813" elapsed="0.005383"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.255431" elapsed="0.003698"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.263949" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.264094" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:56.264235" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.259362" elapsed="0.004910"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.268675" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.268255" elapsed="0.000462"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.269313" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.268938" elapsed="0.000413"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.269570" elapsed="0.000488"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.264592" elapsed="0.005552"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.249335" elapsed="0.020883"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:56.248428" elapsed="0.021842"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:24:56.244959" elapsed="0.025386"/>
</kw>
<arg>route_es_arb</arg>
<status status="PASS" start="2026-06-06T03:24:52.122062" elapsed="4.148349"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:52.007114" elapsed="4.263446"/>
</test>
<test id="s1-s13-t6" name="Odl_To_Play_route_es_as" line="76">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:56.275427" elapsed="0.000244"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:56.275145" elapsed="0.000587"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:56.276794" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.276660" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.276621" elapsed="0.000247"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:56.283490" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.283380" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.283361" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.284589" 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-06-06T03:24:56.284195" elapsed="0.000422"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.285101" 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-06-06T03:24:56.284800" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:56.285172" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:24:56.285336" 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-06-06T03:24:56.283809" elapsed="0.001552"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:56.290959" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.290849" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.290830" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:56.292704" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.292496" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.292476" elapsed="0.000391"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:56.293434" 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-06-06T03:24:56.293021" elapsed="0.000475"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:56.294139" level="INFO">${current_connection_index} = 7</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-06-06T03:24:56.293876" elapsed="0.000322"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:56.326414" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:56.296043" elapsed="0.030508"/>
</kw>
<msg time="2026-06-06T03:24:56.326719" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:56.326817" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:56.294508" elapsed="0.032379"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:56.354312" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "a "s "[K"
[?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-06-06T03:24:56.328873" elapsed="0.025574"/>
</kw>
<msg time="2026-06-06T03:24:56.354580" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:56.354697" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:24:56.327299" elapsed="0.027470"/>
</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-06-06T03:24:56.355436" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.355071" elapsed="0.000481"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.355048" elapsed="0.000565"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.356375" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "a "s "[K"
[?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-06-06T03:24:56.355792" elapsed="0.000697"/>
</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-06-06T03:24:56.357039" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.356681" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.356659" elapsed="0.000556"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:56.357253" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:56.360930" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:24:56.361117" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:56.360320" elapsed="0.000865"/>
</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="NOT RUN" start="2026-06-06T03:24:56.361403" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.361620" elapsed="0.000038"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:56.359523" elapsed="0.002346"/>
</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-06-06T03:24:56.357535" elapsed="0.004419"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:56.292054" elapsed="0.070076"/>
</kw>
<msg time="2026-06-06T03:24:56.362225" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:56.362270" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:56.291188" elapsed="0.071119"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:56.362686" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:24:56.362386" elapsed="0.000364"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.362366" elapsed="0.000409"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.363239" elapsed="0.000063"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.363734" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:56.363809" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:56.290491" elapsed="0.073428"/>
</kw>
<msg time="2026-06-06T03:24:56.364014" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:56.364058" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:56.285784" elapsed="0.078310"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.364427" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.364169" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.364151" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:56.285597" elapsed="0.078933"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:56.285417" elapsed="0.079143"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:56.283008" elapsed="0.081605"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:56.276343" elapsed="0.088484"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:56.275890" elapsed="0.088984"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:56.272328" elapsed="0.092599"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.370662" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.370798" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.370904" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.365357" elapsed="0.005574"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.371099" elapsed="0.002597"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.378823" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.378970" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:56.379109" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.373865" elapsed="0.005282"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.383468" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.383058" elapsed="0.000449"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.384132" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.383753" elapsed="0.000462"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.384444" elapsed="0.000477"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.379464" elapsed="0.005543"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.365074" elapsed="0.020008"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:24:56.271679" elapsed="0.113457"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.386239" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.386489" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.385961" elapsed="0.000569"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.387043" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.387218" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
       ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.386776" elapsed="0.000480"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.387765" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/announce_route_es_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/announce_route_es_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.387938" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.387479" elapsed="0.000496"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:24:56.388490" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:24:56.388200" elapsed="0.000327"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.389040" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/withdraw_route_es_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/withdraw_route_es_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.389216" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.388774" elapsed="0.000479"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:24:56.389802" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:24:56.389477" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.390415" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.390069" elapsed="0.000423"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.391068" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.390732" elapsed="0.000404"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.391710" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.391356" elapsed="0.000418"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.392375" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.392037" elapsed="0.000400"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:56.392671" elapsed="0.002466"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.405739" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '754', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:24:56.405801" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.405905" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.395302" elapsed="0.010629"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.411825" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.406106" elapsed="0.005815"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.417363" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.417773" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:56.417901" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.412281" elapsed="0.005648"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.420653" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.418129" elapsed="0.002575"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.427614" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.428134" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:56.428286" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.421728" elapsed="0.006598"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.432248" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.428697" elapsed="0.003619"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.432543" elapsed="0.003625"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:56.438917" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.436406" elapsed="0.002552"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.439182" elapsed="0.003323"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:24:56.442587" elapsed="0.000076"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:24:56.421354" elapsed="0.021466"/>
</kw>
<msg time="2026-06-06T03:24:56.442933" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:56.420881" elapsed="0.022088"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.443560" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.443206" elapsed="0.000418"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.445154" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:24:56.445259" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:56.444779" elapsed="0.000514"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.445936" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:24:56.446039" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:56.445536" elapsed="0.000535"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.446299" elapsed="0.000642"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:56.447591" level="INFO">${sum_1} = 2075</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:56.447166" elapsed="0.000460"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:56.448117" level="INFO">${sum_2} = 2075</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:56.447871" elapsed="0.000280"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.448368" elapsed="0.000445"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:24:56.443993" elapsed="0.004903"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:56.449111" elapsed="0.002041"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.456603" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.456767" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:56.456867" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.451835" elapsed="0.005058"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.459872" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.457081" elapsed="0.002842"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.460143" elapsed="0.002809"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.468950" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.469111" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:56.469253" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.463192" elapsed="0.006100"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.472985" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.469544" elapsed="0.003509"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.473276" elapsed="0.003585"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:24:56.480339" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.477019" elapsed="0.003385"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.476975" elapsed="0.003461"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.487055" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.487100" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.487198" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.480672" elapsed="0.006553"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:24:56.451423" elapsed="0.035871"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.492636" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.492815" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.492945" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.488312" elapsed="0.004670"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.496668" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.493225" elapsed="0.003512"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.496959" elapsed="0.003528"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:56.503884" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.500745" elapsed="0.003179"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.504216" elapsed="0.003054"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:24:56.507341" elapsed="0.000048"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:24:56.487962" elapsed="0.019563"/>
</kw>
<msg time="2026-06-06T03:24:56.507635" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:56.487466" elapsed="0.020225"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.508271" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.507927" elapsed="0.000406"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.509547" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:24:56.509720" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:56.509188" elapsed="0.000568"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.510381" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:24:56.510485" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:24:56.510019" elapsed="0.000499"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.510783" elapsed="0.000426"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:56.511700" level="INFO">${sum_1} = 1628</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:56.511431" elapsed="0.000306"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:24:56.512195" level="INFO">${sum_2} = 1628</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:24:56.511954" elapsed="0.000276"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.512446" elapsed="0.000442"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:24:56.508676" elapsed="0.004294"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.518737" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.518888" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.519018" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.513779" elapsed="0.005275"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.523108" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.519296" elapsed="0.003879"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.523447" elapsed="0.003539"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.532017" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.532124" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.532225" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.527223" elapsed="0.005029"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.534919" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.532462" elapsed="0.002504"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.535123" elapsed="0.002535"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:24:56.540839" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:24:56.537738" elapsed="0.003184"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.537717" elapsed="0.003241"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.541174" elapsed="0.000030"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:24:56.513325" elapsed="0.027972"/>
</kw>
<arg>route_es_as</arg>
<status status="PASS" start="2026-06-06T03:24:56.385491" elapsed="0.155868"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.271020" elapsed="0.270490"/>
</test>
<test id="s1-s13-t7" name="Play_To_Odl_route_es_as" line="78">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:24:56.546720" elapsed="0.000308"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:24:56.546333" elapsed="0.000774"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:56.548805" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.548627" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.548599" elapsed="0.000302"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:24:56.554387" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.554278" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.554259" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.555468" 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-06-06T03:24:56.555081" elapsed="0.000414"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.555975" 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-06-06T03:24:56.555675" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:24:56.556047" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:24:56.556200" 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-06-06T03:24:56.554700" elapsed="0.001525"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:24:56.562085" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.561975" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.561956" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:24:56.563594" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:24:56.563413" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.563393" elapsed="0.000398"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:24:56.564357" 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-06-06T03:24:56.563946" elapsed="0.000473"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:24:56.565052" level="INFO">${current_connection_index} = 7</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-06-06T03:24:56.564785" elapsed="0.000330"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:24:56.595676" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:24:56.567017" elapsed="0.028785"/>
</kw>
<msg time="2026-06-06T03:24:56.595937" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:24:56.596034" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:24:56.565428" elapsed="0.030678"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:24:56.621056" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "a "s "[K"
[?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-06-06T03:24:56.598093" elapsed="0.023130"/>
</kw>
<msg time="2026-06-06T03:24:56.621355" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:24:56.621450" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:24:56.596510" elapsed="0.025011"/>
</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-06-06T03:24:56.622223" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.621858" elapsed="0.000481"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.621836" elapsed="0.000562"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.623139" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "a "s "[K"
[?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-06-06T03:24:56.622550" elapsed="0.000704"/>
</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-06-06T03:24:56.623801" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.623431" elapsed="0.000486"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.623410" elapsed="0.000566"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:24:56.624014" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:24:56.627540" elapsed="0.000157"/>
</kw>
<msg time="2026-06-06T03:24:56.627741" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:24:56.627018" elapsed="0.000791"/>
</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="NOT RUN" start="2026-06-06T03:24:56.628032" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.628252" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:24:56.626249" elapsed="0.002235"/>
</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-06-06T03:24:56.624289" elapsed="0.004283"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:24:56.562962" elapsed="0.065811"/>
</kw>
<msg time="2026-06-06T03:24:56.628871" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:56.628916" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:56.562312" elapsed="0.066643"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:24:56.629153" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:24:56.629038" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.629017" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.629749" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.630182" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:24:56.630256" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:24:56.561616" elapsed="0.068748"/>
</kw>
<msg time="2026-06-06T03:24:56.630462" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:24:56.630507" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:24:56.556607" elapsed="0.073936"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.630897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.630620" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.630602" elapsed="0.000373"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:24:56.556461" elapsed="0.074538"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:24:56.556285" elapsed="0.074747"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:24:56.553916" elapsed="0.077172"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:24:56.548220" elapsed="0.082972"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:24:56.547503" elapsed="0.083738"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:24:56.543286" elapsed="0.088010"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.636450" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.636582" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.636695" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.631779" elapsed="0.004944"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:56.636894" elapsed="0.003106"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.643904" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.644008" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:24:56.644110" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:56.640180" elapsed="0.003961"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.647251" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.646947" elapsed="0.000333"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:56.647728" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:56.647439" elapsed="0.000317"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.647916" elapsed="0.000326"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:56.644373" elapsed="0.003931"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.631449" elapsed="0.016909"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:24:56.542611" elapsed="0.105787"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.649133" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.649291" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.648930" elapsed="0.000390"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.675280" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_as.vanadium/route_es_as.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:56.674902" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.676121" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as.vanadium/route_es_as.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:24:56.675844" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as.vanadium/route_es_as.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:24:56.676298" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:24:56.675479" elapsed="0.000843"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.676901" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:24:56.676493" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.677229" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/route_es_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.677357" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
       ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.677095" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.677823" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.677559" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:24:56.678247" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:24:56.677942" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.678787" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:24:56.678479" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.678330" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:24:56.677923" elapsed="0.000947"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.679462" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
       ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:24:56.679022" elapsed="0.000468"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:24:56.679540" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:24:56.679712" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
       ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:24:56.672568" elapsed="0.007171"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.680095" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/announce_route_es_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/announce_route_es_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.680220" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.679902" elapsed="0.000344"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:24:56.680591" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/withdraw_route_es_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_as/withdraw_route_es_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:24:56.680728" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:24:56.680402" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.681163" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.680914" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.681680" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.681407" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.682126" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.681886" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:24:56.682562" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:24:56.682325" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:24:56.682773" elapsed="0.003312"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:24:56.686255" elapsed="0.002178"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:56.693824" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:56.693932" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:56.694027" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:24:56.689392" elapsed="0.005005">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.694590" elapsed="0.000022"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:24:56.694844" elapsed="0.000024"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:24:56.689067" elapsed="0.005902">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:58.704474" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:58.704694" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:24:58.704841" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:58.696613" elapsed="0.008267"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:24:58.705534" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:24:58.708883" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:24:58.705136" elapsed="0.003816"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:58.713491" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:58.712869" elapsed="0.000662"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:58.714338" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:58.713774" elapsed="0.000603"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:24:58.714600" elapsed="0.000477"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:24:58.709274" elapsed="0.005892"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:24:58.695609" elapsed="0.019639"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:56.688625" elapsed="2.026687"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:24:58.715531" elapsed="0.003047"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:58.724792" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:58.724968" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:24:58.725107" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:58.719877" elapsed="0.005267"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:24:58.725396" elapsed="0.003993"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:24:58.734672" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:24:58.735244" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '504'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:24:58.735392" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:24:58.729625" elapsed="0.005804"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:58.739781" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:58.739349" elapsed="0.000476"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:24:58.740759" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:24:58.740051" elapsed="0.000751"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:24:58.741546" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "es-route": {
       "as-generated": {
        "as": 16843009,
        "local-discriminator": 2000
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:24:58.741847" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:24:58.741100" elapsed="0.000853">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:24:58.735783" elapsed="0.006364">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:24:58.719464" elapsed="0.022855">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQUBAQEBAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.751945" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.752133" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:00.752279" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.743990" elapsed="0.008326"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:00.752563" elapsed="0.003733"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.761914" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.762060" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:00.762305" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.756532" elapsed="0.005811"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:00.766729" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.766278" elapsed="0.000492"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:00.767371" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.766991" elapsed="0.000466"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.767716" elapsed="0.000465"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.762699" elapsed="0.005571"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:00.743060" elapsed="0.025288"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:24:58.718852" elapsed="2.049551"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:00.769180" elapsed="0.002765"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.778586" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.778763" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:00.778907" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.773552" elapsed="0.005392"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:00.779179" elapsed="0.003841"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.788015" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.788166" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:00.788310" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.783255" elapsed="0.005092"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:00.792745" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.792331" elapsed="0.000454"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:00.793386" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.793007" elapsed="0.000418"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.793669" elapsed="0.000454"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.788693" elapsed="0.005516"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:00.772835" elapsed="0.021449"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:00.772220" elapsed="0.022120"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:00.768687" elapsed="0.025779"/>
</kw>
<arg>route_es_as</arg>
<status status="PASS" start="2026-06-06T03:24:56.648614" elapsed="4.145922"/>
</kw>
<status status="PASS" start="2026-06-06T03:24:56.541983" elapsed="4.252737"/>
</test>
<test id="s1-s13-t8" name="Odl_To_Play_route_es_lacp" line="81">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:00.799995" elapsed="0.000294"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:00.799598" elapsed="0.000768"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:00.801852" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:00.801673" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.801618" elapsed="0.000340"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:00.808818" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:00.808707" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.808688" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.809905" 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-06-06T03:25:00.809502" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.810400" 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-06-06T03:25:00.810098" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:00.810470" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:25:00.810633" 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-06-06T03:25:00.809119" elapsed="0.001554"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:00.816509" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:00.816399" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.816379" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:00.818046" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:00.817863" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.817844" elapsed="0.000364"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:00.818791" 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-06-06T03:25:00.818363" elapsed="0.000489"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:00.819503" level="INFO">${current_connection_index} = 7</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-06-06T03:25:00.819200" elapsed="0.000364"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:00.850680" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:00.821446" elapsed="0.029370"/>
</kw>
<msg time="2026-06-06T03:25:00.850954" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:00.851048" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:00.819892" elapsed="0.031226"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:00.876901" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "l "a "c "p "[K"
[?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-06-06T03:25:00.853144" elapsed="0.023894"/>
</kw>
<msg time="2026-06-06T03:25:00.877172" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:00.877266" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:00.851562" elapsed="0.025775"/>
</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-06-06T03:25:00.878040" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:00.877662" elapsed="0.000496"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.877616" elapsed="0.000603"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.878969" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "l "a "c "p "[K"
[?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-06-06T03:25:00.878374" elapsed="0.000769"/>
</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-06-06T03:25:00.879732" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:00.879344" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.879304" elapsed="0.000606"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:00.879950" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:00.883943" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:25:00.884133" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:00.883367" elapsed="0.000834"/>
</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="NOT RUN" start="2026-06-06T03:25:00.884419" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:00.884636" elapsed="0.000040"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:00.882543" elapsed="0.002332"/>
</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-06-06T03:25:00.880251" elapsed="0.004709"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:00.817396" elapsed="0.067743"/>
</kw>
<msg time="2026-06-06T03:25:00.885234" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:00.885279" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:00.816755" elapsed="0.068560"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:00.885501" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:00.885393" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.885374" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:00.886065" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:00.886488" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:00.886560" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:00.816049" elapsed="0.070700"/>
</kw>
<msg time="2026-06-06T03:25:00.886846" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:00.886890" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:00.811067" elapsed="0.075860"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:00.887261" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:00.887004" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.886986" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:00.810918" elapsed="0.076463"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:00.810736" elapsed="0.076678"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:00.808330" elapsed="0.079140"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:00.801233" elapsed="0.086296"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:00.800584" elapsed="0.086991"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:00.796503" elapsed="0.091128"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.893371" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.893543" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:00.893678" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.888213" elapsed="0.005494"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:00.893881" elapsed="0.002617"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.900915" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.901020" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:00.901123" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.896687" elapsed="0.004464"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:00.905458" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.905040" elapsed="0.000457"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:00.906122" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.905743" elapsed="0.000418"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.906384" elapsed="0.000474"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.901443" elapsed="0.005501"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:00.887934" elapsed="0.019086"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:00.795849" elapsed="0.111228"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:00.908192" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:00.908440" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:00.907911" elapsed="0.000570"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:00.908994" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:00.909173" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
   ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:00.908726" elapsed="0.000484"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:00.909718" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/announce_route_es_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/announce_route_es_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:00.909895" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:00.909432" elapsed="0.000499"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:00.910446" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:00.910155" elapsed="0.000328"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:00.911050" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/withdraw_route_es_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/withdraw_route_es_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:00.911227" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:00.910778" elapsed="0.000489"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:00.911862" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:00.911551" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.912473" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.912126" elapsed="0.000426"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.913068" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.912792" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.913512" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.913274" elapsed="0.000282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.913963" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.913727" elapsed="0.000280"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:00.914159" elapsed="0.002139"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.925508" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '803', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:00.925598" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQHyDN2An%2FcAFgAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.925760" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.916503" elapsed="0.009295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.931590" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.926045" elapsed="0.005628"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.937083" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.937636" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:00.937817" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.931904" elapsed="0.005951"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.941583" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.938097" elapsed="0.003573"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.948756" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.949208" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:00.949388" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.943058" elapsed="0.006372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.953079" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.949698" elapsed="0.003450"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:00.953369" elapsed="0.003656"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:00.959671" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:00.957325" elapsed="0.002377"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.959891" elapsed="0.002186"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:00.962132" elapsed="0.000039"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:00.942564" elapsed="0.019714"/>
</kw>
<msg time="2026-06-06T03:25:00.962361" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:00.941917" elapsed="0.020469"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.962819" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.962554" elapsed="0.000311"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.963780" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:00.963855" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:00.963499" elapsed="0.000380"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.964295" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:00.964387" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:00.964040" elapsed="0.000376"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.964596" elapsed="0.000408"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:00.965451" level="INFO">${sum_1} = 2883</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:00.965211" elapsed="0.000273"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:00.965989" level="INFO">${sum_2} = 2883</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:00.965707" elapsed="0.000315"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:00.966228" elapsed="0.000397"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:00.963101" elapsed="0.003621"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:00.966930" elapsed="0.002278"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.975258" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.975534" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:00.975729" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.970007" elapsed="0.005762"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.979847" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.976071" elapsed="0.003839"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:00.980127" elapsed="0.003574"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:00.989271" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:00.989456" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:00.989594" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:00.983919" elapsed="0.005706"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:00.993100" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:00.989874" elapsed="0.003292"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:00.993390" elapsed="0.003507"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:01.000337" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:00.997030" elapsed="0.003567"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:00.996991" elapsed="0.003643"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.007771" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.007841" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.008115" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:01.000892" elapsed="0.007264"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:00.969562" elapsed="0.038708"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.015117" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.015340" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:01.015486" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:01.009821" elapsed="0.005706"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.019390" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.015823" elapsed="0.003641"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:01.019725" elapsed="0.003688"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:01.026025" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:01.023639" elapsed="0.002430"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:01.026343" elapsed="0.003223"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:01.029662" elapsed="0.000058"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:01.009297" elapsed="0.020579"/>
</kw>
<msg time="2026-06-06T03:25:01.030009" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:01.008541" elapsed="0.021510"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.030708" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.030314" elapsed="0.000461"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.032160" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:01.032278" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:01.031768" elapsed="0.000547"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.032944" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:01.033046" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:01.032558" elapsed="0.000522"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:01.033326" elapsed="0.000478"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:01.034346" level="INFO">${sum_1} = 2436</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:01.034058" elapsed="0.000329"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:01.034915" level="INFO">${sum_2} = 2436</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:01.034636" elapsed="0.000312"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:01.035148" elapsed="0.000843"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:01.031140" elapsed="0.004998"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.044538" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.044857" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:01.045013" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:01.037447" elapsed="0.007606"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.049459" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.045335" elapsed="0.004196"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:01.049793" elapsed="0.003742"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.059078" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.059276" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:01.059424" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:01.053793" elapsed="0.005669"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.063137" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.059737" elapsed="0.003466"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:01.063446" elapsed="0.003534"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:01.070382" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:25:01.067101" elapsed="0.003377"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.067067" elapsed="0.003448"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.070752" elapsed="0.000032"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:01.036754" elapsed="0.034131"/>
</kw>
<arg>route_es_lacp</arg>
<status status="PASS" start="2026-06-06T03:25:00.907468" elapsed="0.163483"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:00.795152" elapsed="0.275954"/>
</test>
<test id="s1-s13-t9" name="Play_To_Odl_route_es_lacp" line="83">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:01.075284" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:01.074999" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:01.076573" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:01.076459" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.076439" elapsed="0.000217"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:01.081672" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:01.081549" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.081531" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.082755" 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-06-06T03:25:01.082355" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.083270" 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-06-06T03:25:01.082948" elapsed="0.000349"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:01.083342" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:01.083496" 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-06-06T03:25:01.081973" elapsed="0.001548"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:01.089425" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:01.089315" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.089295" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:01.090963" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:01.090781" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.090761" elapsed="0.000367"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:01.091738" 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-06-06T03:25:01.091298" elapsed="0.000502"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:01.092421" level="INFO">${current_connection_index} = 7</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-06-06T03:25:01.092153" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:01.122682" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:01.094370" elapsed="0.028484"/>
</kw>
<msg time="2026-06-06T03:25:01.123014" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:01.123110" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:01.092817" elapsed="0.030366"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:01.148271" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "l "a "c "p "[K"
[?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-06-06T03:25:01.125277" elapsed="0.023307"/>
</kw>
<msg time="2026-06-06T03:25:01.148866" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:01.148999" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:01.123681" elapsed="0.025419"/>
</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-06-06T03:25:01.150133" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:01.149549" elapsed="0.000719"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.149502" elapsed="0.000842"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.151346" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "l "a "c "p "[K"
[?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-06-06T03:25:01.150537" elapsed="0.000960"/>
</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-06-06T03:25:01.152153" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:01.151725" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.151700" elapsed="0.000666"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:01.152416" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:01.156820" elapsed="0.000176"/>
</kw>
<msg time="2026-06-06T03:25:01.157050" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:01.156100" elapsed="0.001031"/>
</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="NOT RUN" start="2026-06-06T03:25:01.157391" elapsed="0.000028"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.157732" elapsed="0.000028"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:01.155156" elapsed="0.002830"/>
</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-06-06T03:25:01.152831" elapsed="0.005251"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:01.090312" elapsed="0.067973"/>
</kw>
<msg time="2026-06-06T03:25:01.158412" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:01.158467" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:01.089668" elapsed="0.068845"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:01.158819" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:25:01.158691" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.158665" elapsed="0.000252"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.159531" elapsed="0.000031"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.160222" elapsed="0.000032"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:01.160319" elapsed="0.000021"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:01.088971" elapsed="0.071486"/>
</kw>
<msg time="2026-06-06T03:25:01.160572" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:01.160625" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:01.084047" elapsed="0.076640"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.161099" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:01.160783" elapsed="0.000381"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.160761" elapsed="0.000431"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:01.083897" elapsed="0.077325"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:01.083706" elapsed="0.077558"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:01.081183" elapsed="0.080156"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:01.076169" elapsed="0.085247"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:01.075726" elapsed="0.085751"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:01.072801" elapsed="0.088746"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.167732" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.167925" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:01.168070" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:01.162098" elapsed="0.006012"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:01.168371" elapsed="0.004259"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.178764" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.178920" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:01.179071" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:01.172899" elapsed="0.006214"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:01.183702" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:01.183239" elapsed="0.000509"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:01.184373" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:01.183989" elapsed="0.000424"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:01.184661" elapsed="0.000515"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:01.179560" elapsed="0.005711"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:01.161754" elapsed="0.023608"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:01.072204" elapsed="0.113227"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:01.186502" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:01.186745" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:01.186207" elapsed="0.000581"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.224727" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_lacp.vanadium/route_es_lacp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:01.224267" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:01.225611" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp.vanadium/route_es_lacp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:01.225314" elapsed="0.000398">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp.vanadium/route_es_lacp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:01.225812" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:01.224946" elapsed="0.000891"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.226419" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:01.226011" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:01.226779" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/route_es_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:01.226937" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
   ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:01.226617" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.227403" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.227128" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:01.227932" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:01.227538" elapsed="0.000454"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.228488" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:01.228171" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:01.228019" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:01.227512" elapsed="0.001060"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.229208" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
   ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:01.228750" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:01.229384" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:25:01.229562" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
   ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:01.221779" elapsed="0.007811"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:01.229978" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/announce_route_es_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/announce_route_es_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:01.230123" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:01.229776" elapsed="0.000374"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:01.230505" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/withdraw_route_es_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lacp/withdraw_route_es_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:01.230628" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:01.230314" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.231085" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.230834" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.231613" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.231367" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.232093" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.231843" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:01.232589" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:01.232302" elapsed="0.000363"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:01.232869" elapsed="0.004141"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:01.237283" elapsed="0.002231"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:01.245071" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:01.245271" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:01.245436" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:01.240715" elapsed="0.005322">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.246431" elapsed="0.000037"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:01.246857" elapsed="0.000038"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:01.240312" elapsed="0.006741">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:03.257868" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:03.258207" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:03.258445" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:03.248788" elapsed="0.009717"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:03.259594" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:03.263927" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:03.258958" elapsed="0.005043"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:03.268675" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:03.268041" elapsed="0.000677"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:03.269504" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:03.268946" elapsed="0.000805"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:03.269980" elapsed="0.000483"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:03.264322" elapsed="0.006230"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:03.247799" elapsed="0.022829"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:01.239724" elapsed="2.030993"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:03.270944" elapsed="0.003100"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:03.281033" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:03.281189" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:03.281389" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:03.275387" elapsed="0.006039"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:03.281699" elapsed="0.003930"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:03.291360" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:03.291995" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '534'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:03.292148" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:03.285886" elapsed="0.006300"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:03.296600" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:03.296180" elapsed="0.000479"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:03.297571" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:03.296902" elapsed="0.000711"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:03.298337" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "es-route": {
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:03.298631" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:03.297861" elapsed="0.000894">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:03.292530" elapsed="0.006422">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:03.274995" elapsed="0.024129">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQHyDN2An/cAFgAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.309161" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.309360" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.309519" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.300577" elapsed="0.008982"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.309952" elapsed="0.003871"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.319115" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.319285" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:05.319400" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.314005" elapsed="0.005422"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.322700" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.322357" elapsed="0.000373"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.323171" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.322894" elapsed="0.000306"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.323365" elapsed="0.000383"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.319709" elapsed="0.004104"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.299787" elapsed="0.024084"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:03.274332" elapsed="2.049581"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:05.324472" elapsed="0.004555"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.334370" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.334505" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.334619" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.330355" elapsed="0.004308"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.334846" elapsed="0.002839"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.342060" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.342219" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:05.342328" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.337862" elapsed="0.004493"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.345538" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.345235" elapsed="0.000332"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.346031" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.345753" elapsed="0.000307"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.346224" elapsed="0.000342"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.342599" elapsed="0.004031"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.329774" elapsed="0.016931"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:05.329253" elapsed="0.017493"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:05.324111" elapsed="0.022693"/>
</kw>
<arg>route_es_lacp</arg>
<status status="PASS" start="2026-06-06T03:25:01.185770" elapsed="4.161084"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:01.071584" elapsed="4.275381"/>
</test>
<test id="s1-s13-t10" name="Odl_To_Play_route_es_lan" line="86">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:05.351325" elapsed="0.000214"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:05.351055" elapsed="0.000539"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:05.352675" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.352532" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.352508" elapsed="0.000243"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:05.357843" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.357732" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.357713" elapsed="0.000201"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.358943" 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-06-06T03:25:05.358535" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.359436" 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-06-06T03:25:05.359138" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:05.359508" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:25:05.359696" 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-06-06T03:25:05.358147" elapsed="0.001576"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:05.365658" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.365532" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.365512" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:05.367149" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.366968" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.366949" elapsed="0.000361"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:05.367907" 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-06-06T03:25:05.367465" elapsed="0.000504"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:05.368635" level="INFO">${current_connection_index} = 7</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-06-06T03:25:05.368360" elapsed="0.000352"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:05.400869" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:05.370577" elapsed="0.030545"/>
</kw>
<msg time="2026-06-06T03:25:05.401335" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:05.401457" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:05.369026" elapsed="0.032528"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:05.430003" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "l "a "n "[K"
[?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-06-06T03:25:05.404175" elapsed="0.026009"/>
</kw>
<msg time="2026-06-06T03:25:05.430369" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:05.430499" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:05.402128" elapsed="0.028471"/>
</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-06-06T03:25:05.431576" elapsed="0.000059"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.431043" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.431006" elapsed="0.000853"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.433603" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "l "a "n "[K"
[?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-06-06T03:25:05.432275" elapsed="0.001887"/>
</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-06-06T03:25:05.435612" elapsed="0.000175"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.434624" elapsed="0.001322"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.434558" elapsed="0.001523"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:05.436174" elapsed="0.000087"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:05.445541" elapsed="0.000397"/>
</kw>
<msg time="2026-06-06T03:25:05.446037" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:05.444004" elapsed="0.002182"/>
</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="NOT RUN" start="2026-06-06T03:25:05.447418" elapsed="0.000062"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.448352" elapsed="0.000058"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:05.441927" elapsed="0.006970"/>
</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-06-06T03:25:05.437204" elapsed="0.011945"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:05.366511" elapsed="0.082987"/>
</kw>
<msg time="2026-06-06T03:25:05.449602" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:05.449677" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:05.365888" elapsed="0.083829"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:05.449913" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:05.449800" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.449779" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.450486" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.450940" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:05.451065" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:05.365180" elapsed="0.086002"/>
</kw>
<msg time="2026-06-06T03:25:05.451279" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:05.451324" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:05.360107" elapsed="0.091254"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.451731" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.451438" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.451420" elapsed="0.000392"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:05.359959" elapsed="0.091877"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:05.359782" elapsed="0.092089"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:05.357348" elapsed="0.094582"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:05.352231" elapsed="0.099757"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:05.351779" elapsed="0.100256"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:05.348833" elapsed="0.103257"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.458121" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.458277" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.458418" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.452517" elapsed="0.005929"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.458675" elapsed="0.002729"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.466486" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.466692" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:05.466863" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.461581" elapsed="0.005325"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.472159" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.471703" elapsed="0.000498"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.472882" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.472443" elapsed="0.000481"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.473201" elapsed="0.000429"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.467291" elapsed="0.006434"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.452241" elapsed="0.021608"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:05.347926" elapsed="0.125968"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.474706" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.474858" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.474478" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.475241" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.475368" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.475048" elapsed="0.000347"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.475778" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/announce_route_es_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/announce_route_es_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.475936" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.475555" elapsed="0.000409"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:05.476343" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:05.476127" elapsed="0.000243"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.476751" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/withdraw_route_es_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/withdraw_route_es_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.476878" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.476539" elapsed="0.000366"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:05.477306" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:05.477100" elapsed="0.000233"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.477766" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.477498" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.478222" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.477979" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.478686" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.478427" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.479127" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.478889" elapsed="0.000282"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:05.479324" elapsed="0.002648"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.493476" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '817', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:05.493543" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQLyDN2An%2FcAFAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.493674" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.482312" elapsed="0.011391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.497312" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.493900" elapsed="0.003456"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.504997" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.505512" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '393'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:05.505688" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.497578" elapsed="0.008152"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.511175" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.505981" elapsed="0.005321"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.520904" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.521308" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '393'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:05.521431" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.513607" elapsed="0.007851"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.525097" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.521690" elapsed="0.003553"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.525514" elapsed="0.003986"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:05.533096" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.529787" elapsed="0.003353"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.533408" elapsed="0.003697"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:05.537189" elapsed="0.000056"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:05.512825" elapsed="0.024575"/>
</kw>
<msg time="2026-06-06T03:25:05.537522" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:05.511762" elapsed="0.025798"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.538211" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.537837" elapsed="0.000442"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.539601" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:05.539743" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:05.539211" elapsed="0.000570"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.540400" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:05.540515" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:05.540018" elapsed="0.000533"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.540814" elapsed="0.000523"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:05.541889" level="INFO">${sum_1} = 2882</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:05.541582" elapsed="0.000346"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:05.542430" level="INFO">${sum_2} = 2882</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:05.542165" elapsed="0.000304"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.542918" elapsed="0.000461"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:05.538632" elapsed="0.004838"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:05.543728" elapsed="0.002374"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.552433" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.552584" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '393'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:05.552703" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.546890" elapsed="0.005841"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.555579" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.552907" elapsed="0.002722"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.555806" elapsed="0.002520"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.563224" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.563447" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '393'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:05.563601" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.558498" elapsed="0.005170"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.567600" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.563933" elapsed="0.003760"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.567932" elapsed="0.003841"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:05.575451" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.571895" elapsed="0.003620"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.571864" elapsed="0.003687"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.582768" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.582814" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.582912" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.575801" elapsed="0.007138"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:05.546451" elapsed="0.036556"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.587867" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.587976" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.588069" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.583984" elapsed="0.004111"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.591704" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.588268" elapsed="0.003505"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.591998" elapsed="0.004543"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:05.607157" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.596796" elapsed="0.010427"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.607620" elapsed="0.004837"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:05.612570" elapsed="0.000068"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:05.583632" elapsed="0.029263"/>
</kw>
<msg time="2026-06-06T03:25:05.613097" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:05.583177" elapsed="0.029976"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.614191" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.613603" elapsed="0.000691"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.616285" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:05.616452" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:05.615701" elapsed="0.000805"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.617473" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:05.617546" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:05.616889" elapsed="0.000681"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.617743" elapsed="0.000305"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:05.618386" level="INFO">${sum_1} = 2435</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:05.618210" elapsed="0.000202"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:05.618760" level="INFO">${sum_2} = 2435</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:05.618569" elapsed="0.000216"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.618940" elapsed="0.000305"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:05.614849" elapsed="0.004456"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.623715" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.623824" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.623916" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.619878" elapsed="0.004063"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.629001" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.624113" elapsed="0.004956"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.629294" elapsed="0.003565"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.638573" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.638706" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.638812" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.633114" elapsed="0.005725"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.641482" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.639017" elapsed="0.002513"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.641705" elapsed="0.002491"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:05.646661" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:25:05.644276" elapsed="0.002453"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.644255" elapsed="0.002500"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.646911" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:05.619557" elapsed="0.027446"/>
</kw>
<arg>route_es_lan</arg>
<status status="PASS" start="2026-06-06T03:25:05.474171" elapsed="0.172878"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.347394" elapsed="0.299766"/>
</test>
<test id="s1-s13-t11" name="Play_To_Odl_route_es_lan" line="88">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:05.650952" elapsed="0.000207"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:05.650681" elapsed="0.000534"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:05.652222" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.652109" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.652088" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:05.657313" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.657205" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.657187" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.658389" 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-06-06T03:25:05.658007" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.658890" 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-06-06T03:25:05.658578" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:05.658961" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:25:05.659115" 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-06-06T03:25:05.657611" elapsed="0.001528"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:05.664903" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.664774" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.664754" elapsed="0.000221"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:05.666436" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:05.666255" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.666235" elapsed="0.000364"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:05.667181" 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-06-06T03:25:05.666771" elapsed="0.000471"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:05.667999" level="INFO">${current_connection_index} = 7</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-06-06T03:25:05.667734" elapsed="0.000327"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:05.699349" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:05.669955" elapsed="0.029542"/>
</kw>
<msg time="2026-06-06T03:25:05.699665" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:05.699766" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:05.668368" elapsed="0.031472"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:05.725498" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "l "a "n "[K"
[?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-06-06T03:25:05.701875" elapsed="0.023757"/>
</kw>
<msg time="2026-06-06T03:25:05.725788" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:05.725885" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:05.700256" elapsed="0.025700"/>
</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-06-06T03:25:05.726637" elapsed="0.000067"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.726263" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.726238" elapsed="0.000655"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.727625" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "l "a "n "[K"
[?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-06-06T03:25:05.727048" elapsed="0.000716"/>
</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-06-06T03:25:05.728299" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.727942" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.727921" elapsed="0.000553"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:05.728514" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:05.732137" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:25:05.732324" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:05.731563" elapsed="0.000830"/>
</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="NOT RUN" start="2026-06-06T03:25:05.732612" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.732926" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:05.730803" elapsed="0.002339"/>
</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-06-06T03:25:05.728835" elapsed="0.004393"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:05.665814" elapsed="0.067588"/>
</kw>
<msg time="2026-06-06T03:25:05.733499" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:05.733544" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:05.665132" elapsed="0.068449"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:05.733787" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:05.733677" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.733656" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.734337" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.734783" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:05.734857" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:05.664416" elapsed="0.070552"/>
</kw>
<msg time="2026-06-06T03:25:05.735062" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:05.735107" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:05.659522" elapsed="0.075622"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.735479" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.735219" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.735201" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:05.659375" elapsed="0.076205"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:05.659196" elapsed="0.076417"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:05.656810" elapsed="0.078878"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:05.651819" elapsed="0.083927"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:05.651372" elapsed="0.084421"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:05.648409" elapsed="0.087438"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.741483" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.741619" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.741735" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.736310" elapsed="0.005451"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:05.741932" elapsed="0.002873"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.749609" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.749734" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:05.749838" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:05.745009" elapsed="0.004855"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.753005" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.752669" elapsed="0.000364"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:05.753473" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:05.753195" elapsed="0.000306"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.753678" elapsed="0.000329"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:05.750097" elapsed="0.003972"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.736030" elapsed="0.018095"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:05.647928" elapsed="0.106238"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.754899" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.755054" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.754694" elapsed="0.000389"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.780969" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_lan.vanadium/route_es_lan.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:05.780546" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.781791" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan.vanadium/route_es_lan.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:05.781507" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan.vanadium/route_es_lan.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:05.781963" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:05.781166" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.782586" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:05.782192" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.782939" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/route_es_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.783066" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.782802" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.783499" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.783254" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:05.783939" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:05.783615" elapsed="0.000383"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.784470" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:05.784171" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.784023" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:05.783596" elapsed="0.000955"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.785182" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:05.784718" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:05.785261" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:05.785416" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:05.778240" elapsed="0.007202"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.785818" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/announce_route_es_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/announce_route_es_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.785943" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.785604" elapsed="0.000366"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:05.786315" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/withdraw_route_es_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_lan/withdraw_route_es_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:05.786436" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:05.786127" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.786884" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.786623" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.787334" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.787095" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.787835" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.787573" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:05.788277" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:05.788036" elapsed="0.000285"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:05.788474" elapsed="0.002384"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:05.791020" elapsed="0.001823"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:05.797946" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:05.798054" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:05.798148" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:05.793829" elapsed="0.004685">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.798725" elapsed="0.000023"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:05.798962" elapsed="0.000024"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:05.793462" elapsed="0.005626">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:07.809316" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:07.809559" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '393'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:07.809974" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:07.800718" elapsed="0.009298"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:07.810840" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:07.814343" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:07.810360" elapsed="0.004060"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:07.819572" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:07.818870" elapsed="0.000750"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:07.820516" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:07.819931" elapsed="0.000613"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:07.820726" elapsed="0.000381"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:07.814931" elapsed="0.006242"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:07.799763" elapsed="0.021468"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:05.793039" elapsed="2.028244"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:07.821446" elapsed="0.003263"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:07.830139" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:07.830341" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:07.830502" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:07.825763" elapsed="0.004781"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:07.830866" elapsed="0.004522"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:07.841196" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:07.841931" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '541'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:07.842161" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:07.835693" elapsed="0.006511"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:07.847392" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:07.846910" elapsed="0.000528"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:07.848443" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:07.847704" elapsed="0.000782"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:07.849271" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "es-route": {
       "lan-auto-generated": {
        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
        "root-bridge-priority": 20
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:07.849692" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:07.848756" elapsed="0.001052">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:07.842714" elapsed="0.007310">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:07.825435" elapsed="0.024778">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQLyDN2An/cAFAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:09.859743" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:09.859938" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:09.860092" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:09.851719" elapsed="0.008413"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:09.860401" elapsed="0.003942"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:09.870758" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:09.870960" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:09.871122" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:09.864597" elapsed="0.006565"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:09.876001" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:09.875525" elapsed="0.000519"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:09.876790" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:09.876359" elapsed="0.000473"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:09.877073" elapsed="0.000517"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:09.871539" elapsed="0.006171"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:09.850933" elapsed="0.026860"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:07.824917" elapsed="2.052937"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:09.878693" elapsed="0.003616"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:09.889734" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:09.889955" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:09.890141" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:09.884139" elapsed="0.006043"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:09.890480" elapsed="0.004063"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:09.900514" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:09.900714" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:09.900875" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:09.894832" elapsed="0.006084"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:09.905783" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:09.905310" elapsed="0.000515"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:09.906463" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:09.906062" elapsed="0.000442"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:09.906776" elapsed="0.000509"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:09.901306" elapsed="0.006073"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:09.883324" elapsed="0.024138"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:09.882601" elapsed="0.024921"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:09.878140" elapsed="0.029468"/>
</kw>
<arg>route_es_lan</arg>
<status status="PASS" start="2026-06-06T03:25:05.754380" elapsed="4.153326"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:05.647476" elapsed="4.260388"/>
</test>
<test id="s1-s13-t12" name="Odl_To_Play_route_es_mac" line="91">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:09.912822" elapsed="0.000206"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:09.912542" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:09.914207" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:09.914072" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.914048" elapsed="0.000235"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:09.919317" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:09.919208" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.919189" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:09.920416" 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-06-06T03:25:09.920023" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:09.920921" 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-06-06T03:25:09.920607" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:09.920991" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:25:09.921155" 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-06-06T03:25:09.919623" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:09.927063" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:09.926951" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.926931" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:09.928597" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:09.928412" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.928392" elapsed="0.000399"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:09.929364" 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-06-06T03:25:09.928947" elapsed="0.000479"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:09.930068" level="INFO">${current_connection_index} = 7</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-06-06T03:25:09.929799" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:09.962258" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:09.932009" elapsed="0.030557"/>
</kw>
<msg time="2026-06-06T03:25:09.962901" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:09.963048" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:09.930443" elapsed="0.032712"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:09.987079" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "m "a "c "[K"
[?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-06-06T03:25:09.965432" elapsed="0.021879"/>
</kw>
<msg time="2026-06-06T03:25:09.987502" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:09.987599" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:09.963785" elapsed="0.023916"/>
</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-06-06T03:25:09.988500" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:09.988044" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.988006" elapsed="0.000696"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:09.989498" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "m "a "c "[K"
[?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-06-06T03:25:09.988862" elapsed="0.000753"/>
</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-06-06T03:25:09.990165" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:09.989810" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.989788" elapsed="0.000556"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:09.990387" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:09.994197" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:25:09.994387" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:09.993609" elapsed="0.000848"/>
</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="NOT RUN" start="2026-06-06T03:25:09.994696" elapsed="0.000040"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:09.994936" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:09.992831" elapsed="0.002323"/>
</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-06-06T03:25:09.990825" elapsed="0.004416"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:09.927967" elapsed="0.067453"/>
</kw>
<msg time="2026-06-06T03:25:09.995520" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:09.995566" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:09.927290" elapsed="0.068315"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:09.995998" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:09.995888" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.995867" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:09.996557" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:09.997065" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:09.997142" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:09.926574" elapsed="0.070681"/>
</kw>
<msg time="2026-06-06T03:25:09.997352" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:09.997395" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:09.921572" elapsed="0.075859"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:09.997783" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:09.997508" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:09.997490" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:09.921422" elapsed="0.076463"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:09.921241" elapsed="0.076678"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:09.918844" elapsed="0.079131"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:09.913768" elapsed="0.084266"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:09.913307" elapsed="0.084775"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:09.909720" elapsed="0.088417"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.004351" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.004493" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:10.004612" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:09.998571" elapsed="0.006397"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.005159" elapsed="0.002772"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.014472" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.014674" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:10.014862" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.008185" elapsed="0.006717"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:10.019817" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:10.019346" elapsed="0.000514"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:10.020499" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:10.020098" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.020801" elapsed="0.000511"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.015269" elapsed="0.006136"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:09.998288" elapsed="0.023201"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:09.908982" elapsed="0.112569"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.022738" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.022987" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.022407" elapsed="0.000623"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.023551" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.023762" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discrimi...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.023268" elapsed="0.000534"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.024320" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/announce_route_es_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/announce_route_es_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.024505" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.024038" elapsed="0.000506"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:10.025109" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:10.024802" elapsed="0.000348"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.025694" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/withdraw_route_es_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/withdraw_route_es_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.025881" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.025387" elapsed="0.000533"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:10.026520" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:10.026221" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.027228" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.026854" elapsed="0.000455"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.027951" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.027541" elapsed="0.000481"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.028602" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.028253" elapsed="0.000438"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.029268" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.028922" elapsed="0.000411"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:10.029556" elapsed="0.002989"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.044468" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '807', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:10.044613" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQPyDN2An%2FcAB9AgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.044873" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.032737" elapsed="0.012195"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.050342" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.045350" elapsed="0.005062"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.057050" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.057613" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '389'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:10.057912" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.050719" elapsed="0.007237"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.062189" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.058271" elapsed="0.003994"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.068935" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.069326" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '389'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:10.069446" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.063992" elapsed="0.005482"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.072309" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.069705" elapsed="0.002655"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.072527" elapsed="0.002564"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:10.077758" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:10.075262" elapsed="0.002541"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.078070" elapsed="0.003307"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:10.081458" elapsed="0.000055"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:10.063291" elapsed="0.018397"/>
</kw>
<msg time="2026-06-06T03:25:10.081815" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:10.062540" elapsed="0.019314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.082489" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.082113" elapsed="0.000445"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.083960" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:10.084077" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:10.083535" elapsed="0.000579"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.084752" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:10.084866" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:10.084351" elapsed="0.000550"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.085138" elapsed="0.000462"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:10.086134" level="INFO">${sum_1} = 3078</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:10.085862" elapsed="0.000310"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:10.086746" level="INFO">${sum_2} = 3078</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:10.086402" elapsed="0.000384"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.087021" elapsed="0.000456"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:10.082973" elapsed="0.004589"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:10.087900" elapsed="0.002155"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.095150" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.095301" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '389'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:10.095413" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.090630" elapsed="0.004809"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.098519" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.095637" elapsed="0.002935"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.098807" elapsed="0.003401"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.109061" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.109264" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '389'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:10.109439" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.102457" elapsed="0.007023"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.113519" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.109786" elapsed="0.003807"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.113850" elapsed="0.003759"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:10.120780" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:10.117757" elapsed="0.003070"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.117722" elapsed="0.003128"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.127500" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.127574" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.127801" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.121009" elapsed="0.006835"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:10.090305" elapsed="0.037656"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.135136" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.135339" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:10.135500" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.129632" elapsed="0.005908"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.139735" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.135879" elapsed="0.003935"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.140075" elapsed="0.003839"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:10.146811" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:10.144176" elapsed="0.002683"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.147146" elapsed="0.003311"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:10.150538" elapsed="0.000057"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:10.129110" elapsed="0.021678"/>
</kw>
<msg time="2026-06-06T03:25:10.150913" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:10.128336" elapsed="0.022616"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.151577" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.151210" elapsed="0.000459"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.153027" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:10.153138" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:10.152602" elapsed="0.000572"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.153793" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:10.153901" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:10.153403" elapsed="0.000533"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.154167" elapsed="0.000451"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:10.155160" level="INFO">${sum_1} = 2631</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:10.154886" elapsed="0.000311"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:10.155709" level="INFO">${sum_2} = 2631</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:10.155423" elapsed="0.000325"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.155977" elapsed="0.000450"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:10.152039" elapsed="0.004477"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.162088" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.162239" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:10.162429" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.157407" elapsed="0.005050"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.165826" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.162720" elapsed="0.003158"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.166052" elapsed="0.002564"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.173557" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.173747" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:10.173897" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.168991" elapsed="0.004935"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.176902" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.174159" elapsed="0.002794"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.177127" elapsed="0.002590"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:10.182158" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:25:10.179816" elapsed="0.002423"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.179786" elapsed="0.002481"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.182460" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:10.156945" elapsed="0.025616"/>
</kw>
<arg>route_es_mac</arg>
<status status="PASS" start="2026-06-06T03:25:10.021962" elapsed="0.160651"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:09.908304" elapsed="0.274928"/>
</test>
<test id="s1-s13-t13" name="Play_To_Odl_route_es_mac" line="93">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:10.192673" elapsed="0.000731"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:10.192035" elapsed="0.001527"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:10.196081" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:10.195806" elapsed="0.000382"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.195757" elapsed="0.000482"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:10.204958" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:10.204798" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.204771" elapsed="0.000289"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.206570" 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-06-06T03:25:10.205996" elapsed="0.000630"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.207341" 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-06-06T03:25:10.206900" elapsed="0.000479"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:10.207444" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:25:10.207702" 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-06-06T03:25:10.205402" elapsed="0.002340"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:10.214865" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:10.214754" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.214734" elapsed="0.000276"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:10.216514" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:10.216328" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.216308" elapsed="0.000389"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:10.217273" 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-06-06T03:25:10.216855" elapsed="0.000481"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:10.217972" level="INFO">${current_connection_index} = 7</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-06-06T03:25:10.217703" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:10.248357" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:10.219981" elapsed="0.028634"/>
</kw>
<msg time="2026-06-06T03:25:10.248893" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:10.249070" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:10.218348" elapsed="0.030834"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:10.272120" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "m "a "c "[K"
[?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-06-06T03:25:10.252219" elapsed="0.020039"/>
</kw>
<msg time="2026-06-06T03:25:10.272391" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:10.272484" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:10.249864" elapsed="0.022693"/>
</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-06-06T03:25:10.273301" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:10.272901" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.272869" elapsed="0.000612"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.274235" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "m "a "c "[K"
[?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-06-06T03:25:10.273636" elapsed="0.000717"/>
</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-06-06T03:25:10.274941" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:10.274533" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.274512" elapsed="0.000605"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:10.275158" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:10.278892" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:25:10.279088" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:10.278269" elapsed="0.000890"/>
</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="NOT RUN" start="2026-06-06T03:25:10.279408" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.279634" elapsed="0.000041"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:10.277460" elapsed="0.002424"/>
</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-06-06T03:25:10.275483" elapsed="0.004490"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:10.215843" elapsed="0.064318"/>
</kw>
<msg time="2026-06-06T03:25:10.280263" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:10.280310" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:10.215169" elapsed="0.065183"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:10.280546" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:25:10.280434" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.280414" elapsed="0.000299"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.281193" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.281628" elapsed="0.000070"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:10.281749" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:10.214374" elapsed="0.067490"/>
</kw>
<msg time="2026-06-06T03:25:10.281964" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:10.282009" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:10.208296" elapsed="0.073752"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.282394" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:10.282128" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.282109" elapsed="0.000363"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:10.208081" elapsed="0.074417"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:10.207825" elapsed="0.074707"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:10.204238" elapsed="0.078369"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:10.195097" elapsed="0.087629"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:10.193992" elapsed="0.088784"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:10.186747" elapsed="0.096082"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.291252" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.291439" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:10.291590" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.283260" elapsed="0.008368"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:10.291900" elapsed="0.003668"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.302164" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.302402" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:10.302699" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:10.295829" elapsed="0.006933"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:10.309040" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:10.308565" elapsed="0.000518"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:10.309804" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:10.309378" elapsed="0.000467"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.310083" elapsed="0.000498"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:10.303280" elapsed="0.007416"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:10.282981" elapsed="0.027797"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:10.185171" elapsed="0.125665"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.311906" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.312238" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.311587" elapsed="0.000695"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.339019" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_mac.vanadium/route_es_mac.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:10.338626" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.339836" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac.vanadium/route_es_mac.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:10.339576" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac.vanadium/route_es_mac.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:10.340008" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:10.339218" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.340588" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:10.340203" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.340930" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/route_es_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.341056" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discrimi...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.340797" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.341485" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.341243" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:10.341970" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:10.341605" elapsed="0.000425"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.342496" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:10.342204" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:10.342055" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:10.341584" elapsed="0.001013"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.343207" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discrimi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:10.342763" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:10.343286" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:25:10.343443" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discrimi...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:10.336307" elapsed="0.007194"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.343879" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/announce_route_es_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/announce_route_es_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.344004" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.343684" elapsed="0.000346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:10.344378" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/withdraw_route_es_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_mac/withdraw_route_es_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:10.344498" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:10.344189" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.344946" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.344701" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.345393" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.345156" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.345850" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.345595" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:10.346301" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:10.346061" elapsed="0.000284"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:10.346497" elapsed="0.002864"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:10.349532" elapsed="0.002033"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:10.358238" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:10.358392" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:10.358523" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:10.352526" elapsed="0.006588">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.359384" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:10.359781" elapsed="0.000035"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:10.352200" elapsed="0.007757">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:12.370463" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:12.370776" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '389'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:12.370925" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:12.361686" elapsed="0.009277"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:12.371629" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:12.374884" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:12.371227" elapsed="0.003729"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:12.379517" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:12.378892" elapsed="0.000667"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:12.380379" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:12.379809" elapsed="0.000611"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:12.380720" elapsed="0.000479"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:12.375288" elapsed="0.005998"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:12.360629" elapsed="0.020735"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:10.351781" elapsed="2.029648"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:12.381712" elapsed="0.003724"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:12.390666" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:12.390778" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:12.390872" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:12.386409" elapsed="0.004488"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:12.391128" elapsed="0.002839"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:12.398940" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:12.399527" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '537'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:12.399697" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:12.394139" elapsed="0.005597"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:12.404183" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:12.403782" elapsed="0.000441"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:12.405112" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:12.404449" elapsed="0.000702"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:12.405865" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "es-route": {
       "mac-auto-generated": {
        "local-discriminator": 2000,
        "system-mac-address": "f2:0c:dd:80:9f:f7"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:12.406144" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:12.405375" elapsed="0.000875">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:12.400056" elapsed="0.006389">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:12.386123" elapsed="0.020494">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQPyDN2An/cAB9AgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.413826" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.414016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.414162" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.407994" elapsed="0.006206"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.414451" elapsed="0.003842"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.423596" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.423772" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:14.424060" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.418534" elapsed="0.005564"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.428458" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.428038" elapsed="0.000460"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.429151" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.428764" elapsed="0.000426"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.429416" elapsed="0.000478"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.424435" elapsed="0.005545"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.407324" elapsed="0.022735"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:12.385690" elapsed="2.044423"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:14.430890" elapsed="0.003285"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.440418" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.440599" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.440776" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.435805" elapsed="0.005009"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.441053" elapsed="0.003692"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.450002" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.450232" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:14.450380" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.444986" elapsed="0.005432"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.454846" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.454417" elapsed="0.000469"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.455493" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.455110" elapsed="0.000422"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.455778" elapsed="0.000461"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.450779" elapsed="0.005550"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.435067" elapsed="0.021341"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:14.434451" elapsed="0.022012"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:14.430373" elapsed="0.026172"/>
</kw>
<arg>route_es_mac</arg>
<status status="PASS" start="2026-06-06T03:25:10.311146" elapsed="4.145509"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:10.184050" elapsed="4.272755"/>
</test>
<test id="s1-s13-t14" name="Odl_To_Play_route_es_rou" line="96">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:14.461993" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:14.461656" elapsed="0.000604"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:14.463298" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.463175" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.463152" elapsed="0.000220"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:14.468412" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.468303" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.468284" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.469513" 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-06-06T03:25:14.469131" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.470050" 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-06-06T03:25:14.469744" elapsed="0.000332"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:14.470121" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:25:14.470280" 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-06-06T03:25:14.468749" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:14.476116" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.476006" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.475986" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:14.477661" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.477457" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.477438" elapsed="0.000391"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:14.478392" 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-06-06T03:25:14.477983" elapsed="0.000472"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:14.479139" level="INFO">${current_connection_index} = 7</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-06-06T03:25:14.478868" elapsed="0.000333"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:14.510000" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:14.481077" elapsed="0.029052"/>
</kw>
<msg time="2026-06-06T03:25:14.510266" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:14.510361" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:14.479515" elapsed="0.030920"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:14.536410" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "r "o "u "[K"
[?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-06-06T03:25:14.512405" elapsed="0.024153"/>
</kw>
<msg time="2026-06-06T03:25:14.536728" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:14.536826" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:14.510864" elapsed="0.026034"/>
</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-06-06T03:25:14.537556" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.537199" elapsed="0.000493"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.537176" elapsed="0.000575"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.538470" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "s "_ "r "o "u "[K"
[?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-06-06T03:25:14.537905" elapsed="0.000682"/>
</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-06-06T03:25:14.539133" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.538781" elapsed="0.000468"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.538760" elapsed="0.000548"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:14.539346" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:14.543062" elapsed="0.000140"/>
</kw>
<msg time="2026-06-06T03:25:14.543245" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:14.542523" elapsed="0.000789"/>
</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="NOT RUN" start="2026-06-06T03:25:14.543530" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.543769" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:14.541580" elapsed="0.002407"/>
</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-06-06T03:25:14.539617" elapsed="0.004455"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:14.477017" elapsed="0.067232"/>
</kw>
<msg time="2026-06-06T03:25:14.544343" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:14.544386" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:14.476345" elapsed="0.068079"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:14.544629" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:25:14.544501" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.544482" elapsed="0.000250"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.545194" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.545611" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:14.545808" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:14.475655" elapsed="0.070269"/>
</kw>
<msg time="2026-06-06T03:25:14.546019" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:14.546065" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:14.470699" elapsed="0.075404"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.546440" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.546180" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.546163" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:14.470536" elapsed="0.076008"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:14.470362" elapsed="0.076212"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:14.467925" elapsed="0.078703"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:14.462876" elapsed="0.083826"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:14.462417" elapsed="0.084333"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:14.458538" elapsed="0.088265"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.551602" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.551734" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.551840" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.547226" elapsed="0.004641"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.552038" elapsed="0.002852"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.558926" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.559030" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:14.559132" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.555059" elapsed="0.004100"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.563298" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.562898" elapsed="0.000440"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.563973" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.563565" elapsed="0.000447"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.564239" elapsed="0.000488"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.559390" elapsed="0.005425"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.546950" elapsed="0.017991"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:14.457878" elapsed="0.107121"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.566084" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.566298" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.565798" elapsed="0.000541"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.566857" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.567034" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
 ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.566564" elapsed="0.000509"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.567560" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/announce_route_es_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/announce_route_es_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.567759" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.567295" elapsed="0.000502"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:14.568310" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:14.568021" elapsed="0.000326"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.568902" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/withdraw_route_es_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/withdraw_route_es_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.569028" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.568613" elapsed="0.000441"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:14.569414" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:14.569214" elapsed="0.000226"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.569866" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.569601" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.570326" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.570080" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.570793" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.570531" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.571236" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.570997" elapsed="0.000284"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:14.571435" elapsed="0.002572"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.584616" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '785', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:14.584730" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.584863" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.574205" elapsed="0.010694"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.588837" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.585144" elapsed="0.003754"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.595015" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.595489" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '375'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:14.595634" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.589124" elapsed="0.006578"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.599391" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.595948" elapsed="0.003511"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.606013" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.606457" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '375'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:14.606590" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.600843" elapsed="0.005784"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.610295" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.606901" elapsed="0.003502"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.610626" elapsed="0.003524"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:14.616805" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.614382" elapsed="0.002453"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.617016" elapsed="0.002141"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:14.619209" elapsed="0.000032"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:14.600335" elapsed="0.019005"/>
</kw>
<msg time="2026-06-06T03:25:14.619419" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:14.599725" elapsed="0.019720"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.619876" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.619613" elapsed="0.000308"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.620827" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:14.620902" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:14.620540" elapsed="0.000387"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.621337" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:25:14.621411" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:14.621085" elapsed="0.000349"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.621590" elapsed="0.000325"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:14.622255" level="INFO">${sum_1} = 2242</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:14.622075" elapsed="0.000204"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:14.622610" level="INFO">${sum_2} = 2242</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:14.622433" elapsed="0.000202"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.622810" elapsed="0.000303"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:14.620153" elapsed="0.003019"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:14.623323" elapsed="0.002404"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.633154" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.633314" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '375'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:14.633446" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.626431" elapsed="0.007052"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.637418" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.633758" elapsed="0.003730"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.637730" elapsed="0.003602"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.645788" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.645936" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '375'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:14.646041" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.641562" elapsed="0.004505"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.648686" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.646242" elapsed="0.002494"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.648901" elapsed="0.002586"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:14.654461" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.651578" elapsed="0.002950"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.651554" elapsed="0.003007"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.661245" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.661310" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.661455" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.654805" elapsed="0.006689"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:14.626045" elapsed="0.035547"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.667863" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.668026" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.668156" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.663020" elapsed="0.005172"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.671854" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.668435" elapsed="0.003486"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.672144" elapsed="0.003548"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:14.678332" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.675927" elapsed="0.002446"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.678625" elapsed="0.003050"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:14.681748" elapsed="0.000046"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:14.662510" elapsed="0.019421"/>
</kw>
<msg time="2026-06-06T03:25:14.682045" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:14.661863" elapsed="0.020218"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.682752" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.682375" elapsed="0.000444"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.684064" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:14.684171" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:14.683692" elapsed="0.000513"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.684865" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:25:14.684942" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:14.684427" elapsed="0.000538"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.685125" elapsed="0.000309"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:14.685794" level="INFO">${sum_1} = 1795</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:14.685595" elapsed="0.000225"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:14.686154" level="INFO">${sum_2} = 1795</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:14.685976" elapsed="0.000204"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.686336" elapsed="0.000322"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:14.683147" elapsed="0.003576"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.691532" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.691660" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.691760" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.687281" elapsed="0.004505"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.695399" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.691960" elapsed="0.003507"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.695712" elapsed="0.003522"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.706141" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.706250" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.706352" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.699468" elapsed="0.006911"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.709015" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.706553" elapsed="0.002511"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.709222" elapsed="0.002509"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:14.714740" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:25:14.711809" elapsed="0.003019"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.711789" elapsed="0.003074"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.715077" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:14.686978" elapsed="0.028222"/>
</kw>
<arg>route_es_rou</arg>
<status status="PASS" start="2026-06-06T03:25:14.565353" elapsed="0.149911"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.457226" elapsed="0.258188"/>
</test>
<test id="s1-s13-t15" name="Play_To_Odl_route_es_rou" line="98">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:14.720683" elapsed="0.000292"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:14.720273" elapsed="0.000781"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:14.722449" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.722294" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.722266" elapsed="0.000279"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:14.728242" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.728134" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.728115" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.729440" 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-06-06T03:25:14.729055" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.729955" 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-06-06T03:25:14.729634" elapsed="0.000348"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:14.730027" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:14.730183" 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-06-06T03:25:14.728559" elapsed="0.001649"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:14.735998" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.735886" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.735867" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:14.737521" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:14.737338" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.737318" elapsed="0.000392"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:14.738275" 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-06-06T03:25:14.737866" elapsed="0.000471"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:14.738975" level="INFO">${current_connection_index} = 7</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-06-06T03:25:14.738703" elapsed="0.000335"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:14.782882" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:14.740940" elapsed="0.042085"/>
</kw>
<msg time="2026-06-06T03:25:14.783161" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:14.783257" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:14.739350" elapsed="0.043979"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:14.814181" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "r "o "u "[K"
[?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-06-06T03:25:14.785638" elapsed="0.028677"/>
</kw>
<msg time="2026-06-06T03:25:14.814445" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:14.814548" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:14.783755" elapsed="0.030864"/>
</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-06-06T03:25:14.815300" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.814941" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.814918" elapsed="0.000599"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.816259" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "s "_ "r "o "u "[K"
[?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-06-06T03:25:14.815686" elapsed="0.000702"/>
</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-06-06T03:25:14.816945" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.816572" elapsed="0.000490"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.816552" elapsed="0.000568"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:14.817157" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:14.820657" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:25:14.820843" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:14.820142" elapsed="0.000766"/>
</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="NOT RUN" start="2026-06-06T03:25:14.821128" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.821349" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:14.819369" elapsed="0.002199"/>
</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-06-06T03:25:14.817433" elapsed="0.004237"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:14.736894" elapsed="0.084959"/>
</kw>
<msg time="2026-06-06T03:25:14.822129" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:14.822172" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:14.736225" elapsed="0.085984"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:14.822392" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:14.822286" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.822266" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.823167" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.823600" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:14.823692" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:14.735531" elapsed="0.088277"/>
</kw>
<msg time="2026-06-06T03:25:14.823902" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:14.823947" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:14.730585" elapsed="0.093398"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.824316" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.824058" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.824041" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:14.730438" elapsed="0.093995"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:14.730263" elapsed="0.094199"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:14.727770" elapsed="0.096746"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:14.721891" elapsed="0.102681"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:14.721272" elapsed="0.103345"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:14.717178" elapsed="0.107596"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.837031" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.837181" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.837289" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.825250" elapsed="0.012066"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:14.837505" elapsed="0.002984"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.849482" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.849757" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:14.849987" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:14.840673" elapsed="0.009373"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.855420" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.854999" elapsed="0.000460"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:14.856090" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:14.855706" elapsed="0.000423"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.856352" elapsed="0.000499"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:14.850562" elapsed="0.006377"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.824970" elapsed="0.032049"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:14.716497" elapsed="0.140582"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.858165" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.858383" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.857865" elapsed="0.000559"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.885976" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_rou.vanadium/route_es_rou.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:14.885561" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.886810" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou.vanadium/route_es_rou.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:14.886534" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou.vanadium/route_es_rou.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:14.886989" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:14.886179" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.887636" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:14.887245" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.887981" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/route_es_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.888108" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.887846" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.888573" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.888299" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:14.889067" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:14.888720" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.889599" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:14.889303" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.889155" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:14.888694" elapsed="0.001033"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.890344" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:14.889895" elapsed="0.000477"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:14.890426" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:25:14.890588" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
 ...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:14.883224" elapsed="0.007390"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.890999" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/announce_route_es_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/announce_route_es_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.891124" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.890802" elapsed="0.000348"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:14.891498" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/withdraw_route_es_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_es_rou/withdraw_route_es_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:14.891618" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:14.891308" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.892073" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.891826" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.892542" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.892283" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.893044" level="INFO">ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.892799" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:14.893489" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:14.893246" elapsed="0.000289"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:14.893705" elapsed="0.002502"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:14.896421" elapsed="0.002252"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:14.908550" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:14.908746" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:14.908879" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:14.900020" elapsed="0.009351">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.909665" elapsed="0.000034"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:14.910003" elapsed="0.000033"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:14.899533" elapsed="0.010641">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:16.927165" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:16.927496" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '375'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:16.927766" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:16.911836" elapsed="0.015993"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:16.928912" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "es-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "orig-route-ip": "43.43.43.43"
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:16.934310" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:16.928240" elapsed="0.006197"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:16.938743" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:16.938252" elapsed="0.000520"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:16.939342" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:16.938940" elapsed="0.000447"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:16.939560" elapsed="0.000355"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:16.935045" elapsed="0.004936"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:16.910891" elapsed="0.029145"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:14.898920" elapsed="2.041163"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:16.940245" elapsed="0.003002"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:16.952603" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:16.952802" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:16.952956" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:16.944208" elapsed="0.008785"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:16.953237" elapsed="0.003630"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:16.962318" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:16.962938" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '523'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:16.963088" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:16.957105" elapsed="0.006021"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:16.967562" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:16.967137" elapsed="0.000465"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:16.968491" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:16.967851" elapsed="0.000679"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:16.969228" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "es-route": {
       "orig-route-ip": "43.43.43.43",
       "router-id-generated": {
        "local-discriminator": 2000,
        "router-id": "43.43.43.43"
       }
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:16.969573" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "orig-route-ip": "43.43.43.43",
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:16.968777" elapsed="0.000928">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "orig-route-ip": "43.43.43.43",
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:16.963497" elapsed="0.006409">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "orig-route-ip": "43.43.43.43",
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:16.943927" elapsed="0.026152">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "es-route": {
+       "orig-route-ip": "43.43.43.43",
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQQrKysrAAAH0AAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:18.979714" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:18.979915" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:18.980059" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:18.971619" elapsed="0.008478"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:18.980349" elapsed="0.003908"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:18.990723" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:18.990881" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:18.991026" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:18.984506" elapsed="0.006559"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:18.995416" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:18.994990" elapsed="0.000466"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:18.996167" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:18.995701" elapsed="0.000506"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:18.996434" elapsed="0.000488"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:18.991395" elapsed="0.005615"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:18.970808" elapsed="0.026279"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:16.943463" elapsed="2.053681"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:18.997935" elapsed="0.002934"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.007803" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.007960" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.008113" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.002522" elapsed="0.005629"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.008389" elapsed="0.003659"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.017968" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.018085" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:19.018197" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.012285" elapsed="0.005941"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:19.021667" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.021334" elapsed="0.000364"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:19.022140" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.021863" elapsed="0.000305"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.022333" elapsed="0.000400"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.018525" elapsed="0.004275"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:19.002064" elapsed="0.020795"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:19.001119" elapsed="0.021784"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:18.997406" elapsed="0.025556"/>
</kw>
<arg>route_es_rou</arg>
<status status="PASS" start="2026-06-06T03:25:14.857390" elapsed="4.165626"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:14.715858" elapsed="4.307272"/>
</test>
<test id="s1-s13-t16" name="Odl_To_Play_route_eth_arb" line="101">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:19.027170" elapsed="0.000300"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:19.026806" elapsed="0.000746"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:19.029172" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.028999" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.028965" elapsed="0.000313"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:19.036193" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.036081" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.036061" elapsed="0.000206"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.037298" 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-06-06T03:25:19.036908" elapsed="0.000418"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.037810" 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-06-06T03:25:19.037493" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:19.037882" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:25:19.038049" 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-06-06T03:25:19.036502" elapsed="0.001573"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:19.043747" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.043619" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.043600" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:19.046545" elapsed="0.000047"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.046075" elapsed="0.000780"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.046029" elapsed="0.000963"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:19.048290" 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-06-06T03:25:19.047346" elapsed="0.001083"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:19.050047" level="INFO">${current_connection_index} = 7</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-06-06T03:25:19.049305" elapsed="0.000880"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:19.086678" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:19.054546" elapsed="0.032378"/>
</kw>
<msg time="2026-06-06T03:25:19.087122" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:19.087219" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:19.050989" elapsed="0.036305"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:19.112923" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "a "r "b "[K"
[?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-06-06T03:25:19.089459" elapsed="0.023619"/>
</kw>
<msg time="2026-06-06T03:25:19.113238" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:19.113334" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:19.087800" elapsed="0.025607"/>
</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-06-06T03:25:19.114174" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.113763" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.113730" elapsed="0.000752"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.115263" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "a "r "b "[K"
[?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-06-06T03:25:19.114661" elapsed="0.000723"/>
</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-06-06T03:25:19.115935" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.115560" elapsed="0.000490"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.115539" elapsed="0.000571"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:19.116152" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:19.119971" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:25:19.120166" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:19.119377" elapsed="0.000858"/>
</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="NOT RUN" start="2026-06-06T03:25:19.120454" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.120692" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:19.118579" elapsed="0.002336"/>
</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-06-06T03:25:19.116563" elapsed="0.004441"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:19.045017" elapsed="0.076179"/>
</kw>
<msg time="2026-06-06T03:25:19.121323" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:19.121382" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:19.043978" elapsed="0.077453"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:19.121909" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:25:19.121536" elapsed="0.000459"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.121510" elapsed="0.000527"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.122548" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.123009" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:19.123087" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:19.043282" elapsed="0.079918"/>
</kw>
<msg time="2026-06-06T03:25:19.123297" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:19.123343" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:19.038500" elapsed="0.084881"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.123777" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.123459" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.123441" elapsed="0.000421"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:19.038322" elapsed="0.085564"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:19.038136" elapsed="0.085784"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:19.035701" elapsed="0.088277"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:19.028504" elapsed="0.095533"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:19.027871" elapsed="0.096215"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:19.024487" elapsed="0.099657"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.132171" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.132328" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.132525" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.124581" elapsed="0.007974"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.132769" elapsed="0.002696"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.141091" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.141247" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:19.141396" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.135636" elapsed="0.005799"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:19.146147" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.145700" elapsed="0.000490"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:19.146971" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.146517" elapsed="0.000497"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.147256" elapsed="0.000506"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.141823" elapsed="0.006033"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:19.124297" elapsed="0.023644"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:19.023992" elapsed="0.124012"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.149283" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.149599" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.148861" elapsed="0.000809"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.150206" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.150419" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.149923" elapsed="0.000542"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.151005" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/announce_route_eth_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/announce_route_eth_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.151190" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.150722" elapsed="0.000507"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:19.151799" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:19.151466" elapsed="0.000374"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.152355" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/withdraw_route_eth_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/withdraw_route_eth_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.152538" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.152078" elapsed="0.000541"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:19.153184" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:19.152883" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.153853" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.153466" elapsed="0.000473"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.154543" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.154169" elapsed="0.000447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.155226" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.154870" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.155905" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.155524" elapsed="0.000448"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:19.156199" elapsed="0.002812"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.177983" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '797', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:19.178075" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.178228" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.159285" elapsed="0.018981"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.182234" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.178548" elapsed="0.003789"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.189307" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.189803" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '367'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:19.190002" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.182585" elapsed="0.007455"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.193949" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.190281" elapsed="0.003738"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.200931" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.201373" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '367'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:19.201507" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.195415" elapsed="0.006128"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.205260" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.201809" elapsed="0.003519"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.205550" elapsed="0.003541"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:19.211258" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.209324" elapsed="0.001963"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.211465" elapsed="0.002151"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:19.213687" elapsed="0.000041"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:19.194941" elapsed="0.018889"/>
</kw>
<msg time="2026-06-06T03:25:19.213911" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:19.194263" elapsed="0.019673"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.214365" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.214104" elapsed="0.000310"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.215294" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:19.215370" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:19.215032" elapsed="0.000361"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.215822" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:19.215899" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:19.215551" elapsed="0.000374"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.216082" elapsed="0.000304"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:19.216750" level="INFO">${sum_1} = 1903</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:19.216545" elapsed="0.000231"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:19.217178" level="INFO">${sum_2} = 1903</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:19.216931" elapsed="0.000274"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.217364" elapsed="0.000328"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:19.214664" elapsed="0.003088"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:19.217942" elapsed="0.001935"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.224685" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.224842" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '367'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:19.224961" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.220397" elapsed="0.004593"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.228506" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.225211" elapsed="0.003364"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.228821" elapsed="0.003606"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.237855" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.237971" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '367'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:19.238077" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.232681" elapsed="0.005423"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.240726" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.238295" elapsed="0.002480"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.240935" elapsed="0.002751"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:19.246073" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.243779" elapsed="0.002340"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.243754" elapsed="0.002389"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.251940" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.252002" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.252143" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.246321" elapsed="0.005859"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:19.220117" elapsed="0.032162"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.258790" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.258965" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.259107" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.253778" elapsed="0.005367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.262947" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.259390" elapsed="0.003624"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.263240" elapsed="0.003643"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:19.269548" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.267133" elapsed="0.002457"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.269882" elapsed="0.003115"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:19.273072" elapsed="0.000052"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:19.253213" elapsed="0.020054"/>
</kw>
<msg time="2026-06-06T03:25:19.273382" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:19.252517" elapsed="0.020900"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.274023" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.273676" elapsed="0.000411"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.275355" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:19.275460" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:19.274993" elapsed="0.000500"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.276084" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:19.276186" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:19.275731" elapsed="0.000489"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.276439" elapsed="0.000444"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:19.277352" level="INFO">${sum_1} = 1456</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:19.277104" elapsed="0.000282"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:19.277863" level="INFO">${sum_2} = 1456</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:19.277598" elapsed="0.000301"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.278115" elapsed="0.000463"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:19.274443" elapsed="0.004239"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.283457" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.283585" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.283754" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.279397" elapsed="0.004384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.286636" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.283954" elapsed="0.002746"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.286860" elapsed="0.002526"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.296371" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.296521" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.296691" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.289553" elapsed="0.007177"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.300377" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.296972" elapsed="0.003471"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.300684" elapsed="0.003595"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:19.307717" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:25:19.304408" elapsed="0.003403"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.304372" elapsed="0.003475"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.308081" elapsed="0.000032"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:19.279081" elapsed="0.029131"/>
</kw>
<arg>route_eth_arb</arg>
<status status="PASS" start="2026-06-06T03:25:19.148395" elapsed="0.159882"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:19.023479" elapsed="0.284952"/>
</test>
<test id="s1-s13-t17" name="Play_To_Odl_route_eth_arb" line="103">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:19.313015" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:19.312745" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:19.314317" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.314191" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.314171" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:19.319392" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.319283" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.319265" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.320480" 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-06-06T03:25:19.320095" elapsed="0.000412"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.320997" 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-06-06T03:25:19.320695" elapsed="0.000329"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:19.321075" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:19.321230" 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-06-06T03:25:19.319710" elapsed="0.001545"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:19.327126" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.327015" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.326995" elapsed="0.000266"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:19.328744" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:19.328535" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.328515" elapsed="0.000402"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:19.329492" 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-06-06T03:25:19.329073" elapsed="0.000485"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:19.330215" level="INFO">${current_connection_index} = 7</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-06-06T03:25:19.329934" elapsed="0.000356"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:19.362080" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:19.332173" elapsed="0.030359"/>
</kw>
<msg time="2026-06-06T03:25:19.362920" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:19.363022" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:19.330606" elapsed="0.032491"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:19.387691" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "a "r "b "[K"
[?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-06-06T03:25:19.365167" elapsed="0.022668"/>
</kw>
<msg time="2026-06-06T03:25:19.387970" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:19.388064" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:19.363540" elapsed="0.024596"/>
</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-06-06T03:25:19.388858" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.388451" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.388422" elapsed="0.000615"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.389789" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "a "r "b "[K"
[?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-06-06T03:25:19.389194" elapsed="0.000715"/>
</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-06-06T03:25:19.390464" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.390085" elapsed="0.000495"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.390065" elapsed="0.000588"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:19.390696" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:19.394423" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:25:19.394616" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:19.393826" elapsed="0.000935"/>
</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="NOT RUN" start="2026-06-06T03:25:19.394981" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.395198" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:19.392991" elapsed="0.002423"/>
</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-06-06T03:25:19.391020" elapsed="0.004480"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:19.328084" elapsed="0.067616"/>
</kw>
<msg time="2026-06-06T03:25:19.395799" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:19.395844" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:19.327422" elapsed="0.068461"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:19.396072" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:19.395962" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.395943" elapsed="0.000270"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.396706" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.397148" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:19.397221" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:19.326665" elapsed="0.070667"/>
</kw>
<msg time="2026-06-06T03:25:19.397430" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:19.397476" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:19.321652" elapsed="0.075862"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.398001" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.397592" elapsed="0.000465"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.397574" elapsed="0.000507"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:19.321489" elapsed="0.076616"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:19.321313" elapsed="0.076826"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:19.318920" elapsed="0.079306"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:19.313894" elapsed="0.084393"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:19.313438" elapsed="0.084895"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:19.310286" elapsed="0.088102"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.404511" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.404679" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.404778" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.398990" elapsed="0.005814"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:19.404974" elapsed="0.002915"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.414005" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.414111" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:19.414231" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:19.408060" elapsed="0.006198"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:19.417353" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.417046" elapsed="0.000336"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:19.417878" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:19.417581" elapsed="0.000325"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.418068" elapsed="0.000358"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:19.414491" elapsed="0.003996"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:19.398539" elapsed="0.020002"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:19.309532" elapsed="0.109050"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.419322" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.419480" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.419120" elapsed="0.000389"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.447352" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_arb.vanadium/route_eth_arb.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:19.446910" elapsed="0.000474"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.448220" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb.vanadium/route_eth_arb.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:19.447948" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb.vanadium/route_eth_arb.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:19.448394" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:19.447568" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.449032" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:19.448591" elapsed="0.000473"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.449388" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/route_eth_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.449558" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.449238" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.450041" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.449785" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:19.450594" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:19.450207" elapsed="0.000467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.451160" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:19.450861" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:19.450703" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:19.450148" elapsed="0.001096"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.451867" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:19.451397" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:19.451950" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:25:19.452130" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:19.444446" elapsed="0.007842"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.452704" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/announce_route_eth_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/announce_route_eth_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.452839" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.452473" elapsed="0.000393"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:19.453222" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/withdraw_route_eth_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_arb/withdraw_route_eth_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:19.453343" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:19.453029" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.453800" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.453530" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.454276" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.454016" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.454797" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.454490" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:19.455236" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:19.454998" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:19.455431" elapsed="0.002538"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:19.458131" elapsed="0.002230"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:19.467823" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:19.468005" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:19.468142" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:19.461750" elapsed="0.007053">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.469186" elapsed="0.000038"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:19.469621" elapsed="0.000057"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:19.461262" elapsed="0.008569">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:21.481724" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:21.481979" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '367'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:21.482133" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:21.471557" elapsed="0.010613"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:21.482886" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:21.486136" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:21.482451" elapsed="0.003753"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:21.490775" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:21.490120" elapsed="0.000697"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:21.491614" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:21.491046" elapsed="0.000629"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:21.491903" elapsed="0.000522"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:21.486533" elapsed="0.005984"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:21.470550" elapsed="0.022044"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:19.460627" elapsed="2.032057"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:21.492912" elapsed="0.003035"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:21.503415" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:21.503589" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:21.503750" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:21.496993" elapsed="0.006794"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:21.504101" elapsed="0.004064"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:21.514335" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:21.514810" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '515'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:21.514922" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:21.508403" elapsed="0.006546"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:21.518050" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:21.517755" elapsed="0.000324"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:21.518763" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:21.518239" elapsed="0.000556"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:21.519285" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:21.519502" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:21.518966" elapsed="0.000618">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:21.515189" elapsed="0.004559">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:21.496696" elapsed="0.023179">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQAAAAAAAAAAAAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.530974" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.531162" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.531308" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.521496" elapsed="0.009850"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.531599" elapsed="0.003667"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.542416" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.542562" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:23.542733" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.535504" elapsed="0.007268"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.547096" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.546675" elapsed="0.000461"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.547763" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.547359" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.548030" elapsed="0.000481"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.543103" elapsed="0.005493"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.520627" elapsed="0.028069"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:21.496136" elapsed="2.052618"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:23.549518" elapsed="0.002903"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.558313" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.558420" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.558522" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.553576" elapsed="0.004972"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.558734" elapsed="0.002964"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.567108" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.567326" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:23.567470" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.561939" elapsed="0.005570"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.571916" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.571491" elapsed="0.000465"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.572575" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.572177" elapsed="0.000436"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.572855" elapsed="0.000461"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.567866" elapsed="0.005535"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.553060" elapsed="0.020418"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:23.552616" elapsed="0.020916"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:23.549019" elapsed="0.024590"/>
</kw>
<arg>route_eth_arb</arg>
<status status="PASS" start="2026-06-06T03:25:19.418815" elapsed="4.154885"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:19.308893" elapsed="4.264957"/>
</test>
<test id="s1-s13-t18" name="Odl_To_Play_route_eth_as" line="106">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:23.579038" elapsed="0.000292"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:23.578662" elapsed="0.000745"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:23.580894" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.580725" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.580693" elapsed="0.000307"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:23.587691" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.587565" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.587546" elapsed="0.000216"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.588789" 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-06-06T03:25:23.588387" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.589277" 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-06-06T03:25:23.588981" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:23.589348" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:25:23.589509" 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-06-06T03:25:23.587993" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:23.595104" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.594988" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.594969" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:23.596619" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.596438" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.596419" elapsed="0.000385"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:23.597365" 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-06-06T03:25:23.596958" elapsed="0.000469"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:23.598106" level="INFO">${current_connection_index} = 7</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-06-06T03:25:23.597834" elapsed="0.000332"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:23.628785" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:23.600043" elapsed="0.028872"/>
</kw>
<msg time="2026-06-06T03:25:23.629049" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:23.629143" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:23.598476" elapsed="0.030738"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:23.653845" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "a "s "[K"
[?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-06-06T03:25:23.631179" elapsed="0.022802"/>
</kw>
<msg time="2026-06-06T03:25:23.654110" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:23.654203" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:23.629612" elapsed="0.024663"/>
</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-06-06T03:25:23.654953" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.654574" elapsed="0.000501"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.654552" elapsed="0.000581"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.655873" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "a "s "[K"
[?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-06-06T03:25:23.655283" elapsed="0.000707"/>
</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-06-06T03:25:23.656547" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.656192" elapsed="0.000489"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.656145" elapsed="0.000596"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:23.656779" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:23.660266" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:25:23.660457" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:23.659736" elapsed="0.000788"/>
</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="NOT RUN" start="2026-06-06T03:25:23.660811" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.661032" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:23.658979" elapsed="0.002272"/>
</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-06-06T03:25:23.657046" elapsed="0.004288"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:23.595980" elapsed="0.065528"/>
</kw>
<msg time="2026-06-06T03:25:23.661599" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:23.661656" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:23.595328" elapsed="0.066367"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:23.662036" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:23.661771" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.661752" elapsed="0.000370"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.662578" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.663015" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:23.663122" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:23.594631" elapsed="0.068602"/>
</kw>
<msg time="2026-06-06T03:25:23.663324" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:23.663368" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:23.589929" elapsed="0.073476"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.663866" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.663478" elapsed="0.000444"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.663460" elapsed="0.000486"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:23.589782" elapsed="0.074187"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:23.589592" elapsed="0.074405"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:23.587196" elapsed="0.076854"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:23.580288" elapsed="0.083816"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:23.579624" elapsed="0.084525"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:23.575577" elapsed="0.088638"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.670300" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.670414" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.670518" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.664633" elapsed="0.005910"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.670729" elapsed="0.002559"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.679231" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.679375" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:23.679515" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.673455" elapsed="0.006097"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.683919" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.683480" elapsed="0.000479"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.684621" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.684227" elapsed="0.000455"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.684908" elapsed="0.000449"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.679899" elapsed="0.005545"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.664363" elapsed="0.021203"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:23.574917" elapsed="0.110704"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.686816" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:23.687024" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:23.686514" elapsed="0.000551"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.687554" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:23.687751" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:23.687288" elapsed="0.000501"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.688293" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/announce_route_eth_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/announce_route_eth_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:23.688466" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:23.688012" elapsed="0.000492"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:23.689046" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:23.688752" elapsed="0.000332"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.689579" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/withdraw_route_eth_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/withdraw_route_eth_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:23.689779" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:23.689311" elapsed="0.000505"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:23.690321" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:23.690040" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.690953" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.690583" elapsed="0.000448"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.691588" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.691252" elapsed="0.000424"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.692253" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.691896" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.692895" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.692536" elapsed="0.000422"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:23.693169" elapsed="0.002744"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.707897" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '845', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:23.708037" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.708301" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.696078" elapsed="0.012281"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.713815" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.708785" elapsed="0.005090"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.719883" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.720410" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '384'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:23.720560" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.714099" elapsed="0.006499"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.724408" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.720863" elapsed="0.003613"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.733236" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.733992" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '384'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:23.734211" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.725858" elapsed="0.008410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.740238" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.734692" elapsed="0.005731"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.740815" elapsed="0.003860"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:23.747557" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.744927" elapsed="0.002673"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.747892" elapsed="0.003270"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:23.751239" elapsed="0.000047"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:23.725367" elapsed="0.026067"/>
</kw>
<msg time="2026-06-06T03:25:23.751551" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:23.724743" elapsed="0.026845"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.752242" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.751859" elapsed="0.000449"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.753620" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:23.753757" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:23.753234" elapsed="0.000559"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.754402" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:23.754514" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:23.754025" elapsed="0.000524"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.754806" elapsed="0.000453"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:23.755786" level="INFO">${sum_1} = 2127</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:23.755495" elapsed="0.000329"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:23.756337" level="INFO">${sum_2} = 2127</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:23.756057" elapsed="0.000316"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.756606" elapsed="0.000469"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:23.752676" elapsed="0.004486"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:23.757386" elapsed="0.002185"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.765219" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.765335" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '384'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:23.765430" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.760124" elapsed="0.005331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.768510" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.765628" elapsed="0.002933"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.768744" elapsed="0.003719"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.780192" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.780419" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '384'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:23.780569" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.772739" elapsed="0.007868"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.784257" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.780886" elapsed="0.003439"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.784551" elapsed="0.003537"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:23.790783" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.788236" elapsed="0.002593"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.788205" elapsed="0.002648"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.797467" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.797529" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.797695" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.791009" elapsed="0.006725"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:23.759830" elapsed="0.038002"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.804683" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.804835" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.804964" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.799221" elapsed="0.005779"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.808703" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.805241" elapsed="0.003530"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.808993" elapsed="0.003671"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:23.815548" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.812899" elapsed="0.002690"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.815869" elapsed="0.003045"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:23.818985" elapsed="0.000052"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:23.798741" elapsed="0.020432"/>
</kw>
<msg time="2026-06-06T03:25:23.819283" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:23.798071" elapsed="0.021247"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.819970" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.819599" elapsed="0.000435"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.821289" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:23.821395" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:23.820918" elapsed="0.000510"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.822028" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:23.822133" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:23.821670" elapsed="0.000496"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.822387" elapsed="0.000453"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:23.823315" level="INFO">${sum_1} = 1680</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:23.823065" elapsed="0.000285"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:23.823833" level="INFO">${sum_2} = 1680</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:23.823566" elapsed="0.000302"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.824106" elapsed="0.000438"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:23.820374" elapsed="0.004255"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.830395" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.830503" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.830596" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.825438" elapsed="0.005184"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.833445" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.830817" elapsed="0.002676"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.833668" elapsed="0.002522"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.841209" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.841359" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.841500" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.836358" elapsed="0.005179"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.845245" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.841809" elapsed="0.003503"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.845536" elapsed="0.003543"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:23.852493" elapsed="0.000043"/>
</return>
<status status="PASS" start="2026-06-06T03:25:23.849193" elapsed="0.003388"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.849165" elapsed="0.003451"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.852853" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:23.825010" elapsed="0.027968"/>
</kw>
<arg>route_eth_as</arg>
<status status="PASS" start="2026-06-06T03:25:23.685989" elapsed="0.167050"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.574268" elapsed="0.278924"/>
</test>
<test id="s1-s13-t19" name="Play_To_Odl_route_eth_as" line="108">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:23.858033" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:23.857765" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:23.859301" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.859189" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.859168" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:23.864499" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.864392" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.864373" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.865584" 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-06-06T03:25:23.865201" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.866090" 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-06-06T03:25:23.865793" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:23.866160" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:23.866313" 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-06-06T03:25:23.864818" elapsed="0.001519"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:23.872132" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.871994" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.871974" elapsed="0.000229"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:23.873657" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:23.873456" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.873436" elapsed="0.000391"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:23.874389" 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-06-06T03:25:23.873981" elapsed="0.000469"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:23.875084" level="INFO">${current_connection_index} = 7</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-06-06T03:25:23.874818" elapsed="0.000327"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:23.906839" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:23.877403" elapsed="0.029570"/>
</kw>
<msg time="2026-06-06T03:25:23.907120" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:23.907217" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:23.875457" elapsed="0.031832"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:23.932496" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "a "s "[K"
[?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-06-06T03:25:23.909315" elapsed="0.023320"/>
</kw>
<msg time="2026-06-06T03:25:23.932792" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:23.932889" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:23.907721" elapsed="0.025240"/>
</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-06-06T03:25:23.933632" elapsed="0.000078"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.933261" elapsed="0.000565"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.933238" elapsed="0.000650"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.934622" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "a "s "[K"
[?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-06-06T03:25:23.934044" elapsed="0.000719"/>
</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-06-06T03:25:23.935297" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.934938" elapsed="0.000474"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.934917" elapsed="0.000553"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:23.935508" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:23.939124" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:25:23.939315" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:23.938524" elapsed="0.000858"/>
</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="NOT RUN" start="2026-06-06T03:25:23.939604" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.939849" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:23.937762" elapsed="0.002332"/>
</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-06-06T03:25:23.935809" elapsed="0.004378"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:23.873013" elapsed="0.067355"/>
</kw>
<msg time="2026-06-06T03:25:23.940464" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:23.940509" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:23.872361" elapsed="0.068186"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:23.940756" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:23.940626" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.940605" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.941313" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.941782" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:23.941859" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:23.871651" elapsed="0.070319"/>
</kw>
<msg time="2026-06-06T03:25:23.942066" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:23.942110" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:23.866743" elapsed="0.075405"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:23.942489" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.942226" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.942208" elapsed="0.000364"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:23.866577" elapsed="0.076019"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:23.866397" elapsed="0.076230"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:23.864008" elapsed="0.078722"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:23.858901" elapsed="0.083888"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:23.858452" elapsed="0.084385"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:23.854954" elapsed="0.087939"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.948753" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.948879" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:23.948974" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.943371" elapsed="0.005630"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:23.949181" elapsed="0.002910"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:23.958206" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:23.958364" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:23.958517" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:23.952268" elapsed="0.006290"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.963285" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.962828" elapsed="0.000499"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:23.964004" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:23.963569" elapsed="0.000533"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.964343" elapsed="0.000507"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:23.958943" elapsed="0.005998"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.943084" elapsed="0.021937"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:23.854279" elapsed="0.110802"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.966312" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:23.966527" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:23.966016" elapsed="0.000553"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.996321" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_as.vanadium/route_eth_as.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:23.995882" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.997169" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as.vanadium/route_eth_as.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:23.996905" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as.vanadium/route_eth_as.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:23.997343" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:23.996531" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.998014" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:23.997602" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:23.998352" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/route_eth_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:23.998498" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:23.998211" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:23.998999" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:23.998734" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:23.999483" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:23.999135" elapsed="0.000408"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:24.000069" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:23.999737" elapsed="0.000359"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.999569" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:23.999111" elapsed="0.001045"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:24.000813" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:24.000314" elapsed="0.000528"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:24.000897" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:25:24.001064" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:23.993479" elapsed="0.007613"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:24.001464" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/announce_route_eth_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/announce_route_eth_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:24.001595" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:24.001262" elapsed="0.000360"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:24.001994" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/withdraw_route_eth_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_as/withdraw_route_eth_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:24.002118" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:24.001801" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:24.002555" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:24.002307" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:24.003025" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:24.002782" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:24.003512" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:24.003266" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:24.003980" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:24.003733" elapsed="0.000316"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:24.004207" elapsed="0.003495"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:24.007886" elapsed="0.002130"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:24.016841" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:24.017010" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:24.017142" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:24.011358" elapsed="0.006274">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:24.017924" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:24.018261" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:24.010897" elapsed="0.007534">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:26.028806" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:26.029079" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '384'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:26.029302" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:26.020151" elapsed="0.009196"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:26.030184" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:26.033854" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:26.029692" elapsed="0.004245"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:26.039362" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:26.038543" elapsed="0.000862"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:26.040315" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:26.039671" elapsed="0.000686"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:26.040597" elapsed="0.000614"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:26.034482" elapsed="0.006803"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:26.019205" elapsed="0.022138"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:24.010287" elapsed="2.031106"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:26.041559" elapsed="0.002894"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:26.053301" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:26.053523" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:26.053730" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:26.045517" elapsed="0.008257"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:26.054079" elapsed="0.005370"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:26.066159" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:26.066872" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '532'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"as-generated":{"as":16843009,"local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:26.067126" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:26.059853" elapsed="0.007317"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:26.072598" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:26.072094" elapsed="0.000570"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:26.073632" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:26.072911" elapsed="0.000782"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:26.074460" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "as-generated": {
        "as": 16843009,
        "local-discriminator": 2000
       },
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:26.074899" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:26.073937" elapsed="0.001103">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:26.067634" elapsed="0.007651">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:26.045216" elapsed="0.030265">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQUBAQEBAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.085984" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.086335" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.086561" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.077085" elapsed="0.009537"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.087053" elapsed="0.003734"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.097284" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.097396" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:28.097502" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.091028" elapsed="0.006500"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.101075" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.100748" elapsed="0.000356"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.101627" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.101349" elapsed="0.000322"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.101837" elapsed="0.000395"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.097836" elapsed="0.004466"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.076185" elapsed="0.026174"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:26.044637" elapsed="2.057764"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:28.102977" elapsed="0.002901"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.113088" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.113257" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.113402" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.107532" elapsed="0.005907"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.113701" elapsed="0.003618"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.123321" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.123440" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:28.123547" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.117567" elapsed="0.006007"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.126789" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.126475" elapsed="0.000342"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.127245" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.126974" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.127432" elapsed="0.000359"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.123852" elapsed="0.004002"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.106801" elapsed="0.021110"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:28.106173" elapsed="0.021778"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:28.102604" elapsed="0.025402"/>
</kw>
<arg>route_eth_as</arg>
<status status="PASS" start="2026-06-06T03:25:23.965555" elapsed="4.162502"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:23.853618" elapsed="4.274553"/>
</test>
<test id="s1-s13-t20" name="Odl_To_Play_route_eth_lacp" line="111">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:28.132385" elapsed="0.000309"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:28.132011" elapsed="0.000832"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:28.134326" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.134155" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.134123" elapsed="0.000307"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:28.141468" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.141317" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.141291" elapsed="0.000273"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.143031" 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-06-06T03:25:28.142473" elapsed="0.000596"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.143589" 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-06-06T03:25:28.143296" elapsed="0.000318"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:28.143674" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:25:28.143839" 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-06-06T03:25:28.141905" elapsed="0.001959"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:28.149666" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.149541" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.149522" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:28.151326" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.151141" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.151121" elapsed="0.000368"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:28.152088" 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-06-06T03:25:28.151671" elapsed="0.000479"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:28.152790" level="INFO">${current_connection_index} = 7</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-06-06T03:25:28.152502" elapsed="0.000350"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:28.185936" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:28.154733" elapsed="0.031352"/>
</kw>
<msg time="2026-06-06T03:25:28.186225" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:28.186319" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:28.153161" elapsed="0.033229"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:28.213171" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "[K"
[?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-06-06T03:25:28.188357" elapsed="0.025088"/>
</kw>
<msg time="2026-06-06T03:25:28.213694" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:28.213797" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:28.186820" elapsed="0.027052"/>
</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-06-06T03:25:28.214804" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.214272" elapsed="0.000656"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.214222" elapsed="0.000769"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.215870" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "[K"
[?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-06-06T03:25:28.215151" elapsed="0.000844"/>
</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-06-06T03:25:28.216536" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.216172" elapsed="0.000493"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.216150" elapsed="0.000659"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:28.216861" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:28.220803" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:25:28.221001" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:28.220113" elapsed="0.000961"/>
</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="NOT RUN" start="2026-06-06T03:25:28.221297" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.221516" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:28.219303" elapsed="0.002450"/>
</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-06-06T03:25:28.217241" elapsed="0.004598"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:28.150695" elapsed="0.071341"/>
</kw>
<msg time="2026-06-06T03:25:28.222140" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:28.222352" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:28.149978" elapsed="0.072417"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:28.222625" elapsed="0.000104"/>
</return>
<status status="PASS" start="2026-06-06T03:25:28.222498" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.222471" elapsed="0.000321"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.223283" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.223741" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:28.223815" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:28.149198" elapsed="0.074732"/>
</kw>
<msg time="2026-06-06T03:25:28.224033" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:28.224078" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:28.144246" elapsed="0.079872"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.224505" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.224216" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.224191" elapsed="0.000394"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:28.144100" elapsed="0.080510"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:28.143922" elapsed="0.080741"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:28.140810" elapsed="0.083919"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:28.133703" elapsed="0.091089"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:28.133062" elapsed="0.091783"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:28.129508" elapsed="0.095396"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.231086" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.231256" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.231419" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.225350" elapsed="0.006096"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.231620" elapsed="0.002730"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.240163" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.240324" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:28.240477" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.234523" elapsed="0.005994"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.245266" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.244751" elapsed="0.000562"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.246061" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.245557" elapsed="0.000549"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.246355" elapsed="0.000530"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.240902" elapsed="0.006077"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.225063" elapsed="0.021999"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:28.129027" elapsed="0.118098"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.248336" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.248572" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.248032" elapsed="0.000583"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.249157" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.249341" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.248877" elapsed="0.000503"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.249917" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/announce_route_eth_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/announce_route_eth_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.250135" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.249616" elapsed="0.000558"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:28.250752" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:28.250417" elapsed="0.000375"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.251307" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/withdraw_route_eth_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/withdraw_route_eth_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.251491" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.251030" elapsed="0.000547"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:28.252136" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:28.251840" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.252812" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.252420" elapsed="0.000478"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.253490" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.253131" elapsed="0.000431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.254184" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.253815" elapsed="0.000438"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.254856" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.254485" elapsed="0.000437"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:28.255147" elapsed="0.003005"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.269689" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '894', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:28.269832" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQHyDN2An%2FcAFgAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.270058" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.258319" elapsed="0.011797"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.277939" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.270506" elapsed="0.007513"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.284495" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.285097" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '414'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:28.285312" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.278262" elapsed="0.007091"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.289584" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.285611" elapsed="0.004066"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.295916" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.296263" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '414'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:28.296359" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.291208" elapsed="0.005177"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.299049" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.296560" elapsed="0.002538"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.299261" elapsed="0.002659"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:28.305019" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.302262" elapsed="0.002800"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.305328" elapsed="0.003268"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:28.308696" elapsed="0.000063"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:28.290696" elapsed="0.018219"/>
</kw>
<msg time="2026-06-06T03:25:28.309033" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:28.289937" elapsed="0.019134"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.309707" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.309321" elapsed="0.000454"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.311108" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:28.311219" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:28.310718" elapsed="0.000539"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.311887" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:28.311998" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:28.311490" elapsed="0.000544"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.312290" elapsed="0.000500"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:28.313299" level="INFO">${sum_1} = 2935</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:28.313030" elapsed="0.000306"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:28.313853" level="INFO">${sum_2} = 2935</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:28.313566" elapsed="0.000324"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.314164" elapsed="0.000352"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:28.310146" elapsed="0.004429"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:28.314831" elapsed="0.002050"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.322540" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.322682" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '414'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:28.322780" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.317410" elapsed="0.005396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.326880" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.322980" elapsed="0.003975"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.327193" elapsed="0.003852"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.336563" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.336701" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '414'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:28.336806" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.331310" elapsed="0.005523"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.339436" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.337006" elapsed="0.002480"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.339659" elapsed="0.002532"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:28.345822" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.342318" elapsed="0.003569"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.342284" elapsed="0.003653"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.353065" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.353133" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.353281" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.346167" elapsed="0.007153"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:28.317128" elapsed="0.036291"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.360730" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.360896" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.361033" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.354998" elapsed="0.006073"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.365029" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.361333" elapsed="0.003767"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.365342" elapsed="0.003843"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:28.371929" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.369435" elapsed="0.002524"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.372118" elapsed="0.002281"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:28.374455" elapsed="0.000039"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:28.354473" elapsed="0.020123"/>
</kw>
<msg time="2026-06-06T03:25:28.374696" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:28.353751" elapsed="0.020972"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.375144" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.374896" elapsed="0.000293"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.376079" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:28.376158" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:28.375818" elapsed="0.000371"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.376768" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:28.376880" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:28.376395" elapsed="0.000522"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.377165" elapsed="0.000400"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:28.377992" level="INFO">${sum_1} = 2488</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:28.377763" elapsed="0.000256"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:28.378429" level="INFO">${sum_2} = 2488</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:28.378175" elapsed="0.000292"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.378724" elapsed="0.000455"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:28.375429" elapsed="0.003846"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.386106" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.386303" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.386525" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.380196" elapsed="0.006368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.390997" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.386848" elapsed="0.004220"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.391306" elapsed="0.003863"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.401740" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.401851" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.401971" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.395415" elapsed="0.006583"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.404596" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.402174" elapsed="0.002483"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.404820" elapsed="0.002569"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:28.409833" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:25:28.407482" elapsed="0.002461"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.407454" elapsed="0.002522"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.410137" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:28.379721" elapsed="0.030528"/>
</kw>
<arg>route_eth_lacp</arg>
<status status="PASS" start="2026-06-06T03:25:28.247554" elapsed="0.162763"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.128512" elapsed="0.281968"/>
</test>
<test id="s1-s13-t21" name="Play_To_Odl_route_eth_lacp" line="113">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:28.416975" elapsed="0.000307"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:28.416559" elapsed="0.000804"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:28.418893" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.418724" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.418694" elapsed="0.000301"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:28.425195" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.425086" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.425068" elapsed="0.000201"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.426313" 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-06-06T03:25:28.425923" elapsed="0.000417"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.426821" 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-06-06T03:25:28.426507" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:28.426891" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:25:28.427048" 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-06-06T03:25:28.425502" elapsed="0.001571"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:28.432990" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.432879" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.432859" elapsed="0.000258"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:28.434738" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:28.434520" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.434500" elapsed="0.000412"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:28.435506" 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-06-06T03:25:28.435071" elapsed="0.000501"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:28.436225" level="INFO">${current_connection_index} = 7</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-06-06T03:25:28.435949" elapsed="0.000339"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:28.466702" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:28.438219" elapsed="0.028665"/>
</kw>
<msg time="2026-06-06T03:25:28.467040" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:28.467136" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:28.436606" elapsed="0.030603"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:28.493105" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "[K"
[?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-06-06T03:25:28.469210" elapsed="0.024049"/>
</kw>
<msg time="2026-06-06T03:25:28.493404" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:28.493498" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:28.467632" elapsed="0.025938"/>
</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-06-06T03:25:28.494340" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.493928" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.493895" elapsed="0.000623"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.495293" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "[K"
[?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-06-06T03:25:28.494692" elapsed="0.000724"/>
</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-06-06T03:25:28.495970" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.495595" elapsed="0.000489"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.495573" elapsed="0.000568"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:28.496182" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:28.500022" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:25:28.500222" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:28.499338" elapsed="0.000957"/>
</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="NOT RUN" start="2026-06-06T03:25:28.500520" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.500757" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:28.498529" elapsed="0.002453"/>
</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-06-06T03:25:28.496510" elapsed="0.004718"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:28.434056" elapsed="0.067367"/>
</kw>
<msg time="2026-06-06T03:25:28.501524" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:28.501570" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:28.433290" elapsed="0.068321"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:28.501869" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:25:28.501732" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.501710" elapsed="0.000304"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.502501" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.503018" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:28.503093" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:28.432511" elapsed="0.070694"/>
</kw>
<msg time="2026-06-06T03:25:28.503302" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:28.503346" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:28.427470" elapsed="0.075913"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.503737" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.503461" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.503443" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:28.427318" elapsed="0.076524"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:28.427134" elapsed="0.076744"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:28.424722" elapsed="0.079214"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:28.418272" elapsed="0.085724"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:28.417592" elapsed="0.086451"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:28.413200" elapsed="0.090899"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.510434" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.510577" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.510727" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.504533" elapsed="0.006222"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:28.510929" elapsed="0.002903"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.518071" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.518179" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:28.518281" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:28.514017" elapsed="0.004291"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.521537" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.521222" elapsed="0.000344"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:28.522073" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:28.521780" elapsed="0.000321"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.522269" elapsed="0.000333"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:28.518540" elapsed="0.004140"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.504251" elapsed="0.018485"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:28.411939" elapsed="0.110838"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.523513" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.523688" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.523308" elapsed="0.000410"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.550191" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp.vanadium/route_eth_lacp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:28.549784" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.551061" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp.vanadium/route_eth_lacp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:28.550767" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp.vanadium/route_eth_lacp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:28.551240" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:28.550397" elapsed="0.000868"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.551846" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:28.551435" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.552174" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/route_eth_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.552306" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.552039" elapsed="0.000471"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.552932" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.552687" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:28.553569" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:28.553055" elapsed="0.000573"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.554141" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:28.553845" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.553670" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:28.553033" elapsed="0.001192"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.554848" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:28.554380" elapsed="0.000497"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:28.554929" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:25:28.555131" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:28.547427" elapsed="0.007731"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.555521" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/announce_route_eth_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/announce_route_eth_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.555661" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.555325" elapsed="0.000364"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:28.556043" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/withdraw_route_eth_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp/withdraw_route_eth_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:28.556166" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:28.555850" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.556598" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.556352" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.557070" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.556830" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.557516" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.557279" elapsed="0.000281"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:28.557982" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:28.557730" elapsed="0.000295"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:28.558182" elapsed="0.002574"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:28.560940" elapsed="0.001840"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:28.569656" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:28.569793" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:28.569930" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:28.563750" elapsed="0.006570">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.570554" elapsed="0.000023"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:28.570814" elapsed="0.000025"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:28.563403" elapsed="0.007540">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:30.581376" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:30.581596" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '414'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:30.581788" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:30.572757" elapsed="0.009072"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:30.582633" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:30.586212" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:30.582130" elapsed="0.004165"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:30.590674" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:30.590152" elapsed="0.000554"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:30.591321" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:30.590890" elapsed="0.000461"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:30.591516" elapsed="0.000359"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:30.586688" elapsed="0.005254"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:30.571604" elapsed="0.020397"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:28.562957" elapsed="2.029115"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:30.592283" elapsed="0.002862"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:30.602049" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:30.602225" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:30.602436" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:30.596232" elapsed="0.006243"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:30.602760" elapsed="0.004291"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:30.613529" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:30.614186" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '562'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:30.614342" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:30.607294" elapsed="0.007086"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:30.618860" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:30.618417" elapsed="0.000485"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:30.619838" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:30.619131" elapsed="0.000748"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:30.620619" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:30.620999" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:30.620109" elapsed="0.001010">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:30.614766" elapsed="0.006559">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:30.595944" elapsed="0.025572">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.631154" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.631441" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:32.631700" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.623207" elapsed="0.008555"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.632216" elapsed="0.004064"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.643184" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.643392" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:32.643561" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.636539" elapsed="0.007062"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:32.648446" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.647978" elapsed="0.000510"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:32.649178" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.648766" elapsed="0.000453"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.649458" elapsed="0.000528"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.644049" elapsed="0.006031"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:32.622250" elapsed="0.027911"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:30.595382" elapsed="2.054839"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:32.651048" elapsed="0.003122"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.660153" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.660306" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:32.660580" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.655433" elapsed="0.005198"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.660952" elapsed="0.004182"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.671037" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.671164" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:32.671278" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.665396" elapsed="0.005910"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:32.674658" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.674311" elapsed="0.000379"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:32.675133" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.674854" elapsed="0.000306"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.675328" elapsed="0.000375"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.671581" elapsed="0.004191"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:32.654863" elapsed="0.020967"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:32.654366" elapsed="0.021525"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:32.650500" elapsed="0.025453"/>
</kw>
<arg>route_eth_lacp</arg>
<status status="PASS" start="2026-06-06T03:25:28.523001" elapsed="4.153007"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:28.411110" elapsed="4.265017"/>
</test>
<test id="s1-s13-t22" name="Odl_To_Play_route_eth_lacp_extdef" line="116">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:32.681297" elapsed="0.000332"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:32.680880" elapsed="0.000863"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:32.683328" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.683142" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.683107" elapsed="0.000329"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:32.691318" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.691150" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.691121" elapsed="0.000302"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.693956" 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-06-06T03:25:32.692453" elapsed="0.001612"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.695401" 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-06-06T03:25:32.694563" elapsed="0.000898"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:32.695570" elapsed="0.000118"/>
</return>
<msg time="2026-06-06T03:25:32.696073" 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-06-06T03:25:32.691812" elapsed="0.004319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:32.709540" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.709418" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.709394" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:32.711195" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.711010" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.710990" elapsed="0.000377"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:32.712051" 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-06-06T03:25:32.711526" elapsed="0.000588"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:32.712769" level="INFO">${current_connection_index} = 7</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-06-06T03:25:32.712473" elapsed="0.000357"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:32.742949" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:32.714735" elapsed="0.028380"/>
</kw>
<msg time="2026-06-06T03:25:32.743274" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:32.743370" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:32.713145" elapsed="0.030297"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:32.770102" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "d "e "f "[K"
[?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-06-06T03:25:32.745530" elapsed="0.024714"/>
</kw>
<msg time="2026-06-06T03:25:32.770385" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:32.770480" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:32.743927" elapsed="0.026625"/>
</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-06-06T03:25:32.771282" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:32.770896" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.770867" elapsed="0.000593"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.772265" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "d "e "f "[K"
[?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-06-06T03:25:32.771619" elapsed="0.000776"/>
</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-06-06T03:25:32.772946" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:32.772572" elapsed="0.000491"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.772551" elapsed="0.000570"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:32.773161" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:32.776948" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:25:32.777141" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:32.776276" elapsed="0.000934"/>
</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="NOT RUN" start="2026-06-06T03:25:32.777434" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:32.777685" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:32.775471" elapsed="0.002441"/>
</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-06-06T03:25:32.773479" elapsed="0.004521"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:32.710534" elapsed="0.067648"/>
</kw>
<msg time="2026-06-06T03:25:32.778281" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:32.778328" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:32.709792" elapsed="0.068576"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:32.778556" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:32.778446" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.778427" elapsed="0.000293"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:32.779213" elapsed="0.000075"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:32.779748" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:32.779834" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:32.709027" elapsed="0.071085"/>
</kw>
<msg time="2026-06-06T03:25:32.780214" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:32.780260" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:32.697238" elapsed="0.083061"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:32.780673" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:32.780383" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.780365" elapsed="0.000429"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:32.696894" elapsed="0.083930"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:32.696269" elapsed="0.084590"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:32.690562" elapsed="0.090357"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:32.682687" elapsed="0.098292"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:32.681982" elapsed="0.099045"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:32.678159" elapsed="0.102925"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.786621" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.786776" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:32.786892" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.781519" elapsed="0.005400"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.787093" elapsed="0.002828"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.795854" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.796024" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:32.796178" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.790092" elapsed="0.006123"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:32.800686" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.800242" elapsed="0.000486"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:32.801333" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.800953" elapsed="0.000489"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.801694" elapsed="0.000476"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.796557" elapsed="0.005701"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:32.781238" elapsed="0.021098"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:32.677288" elapsed="0.125108"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:32.803504" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:32.803744" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:32.803222" elapsed="0.000564"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:32.804316" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:32.804500" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:32.804047" elapsed="0.000491"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:32.805049" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/announce_route_eth_lacp_extdef.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/announce_route_eth_lacp_extdef.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:32.805224" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:32.804781" elapsed="0.000480"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:32.805803" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:32.805488" elapsed="0.000353"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:32.806332" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/withdraw_route_eth_lacp_extdef.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/withdraw_route_eth_lacp_extdef.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:32.806508" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:32.806065" elapsed="0.000480"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:32.807072" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:32.806791" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.807702" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;default-gateway-extended-community&gt;
            &lt;/default-gateway-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.807339" elapsed="0.000461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.808382" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "default-gateway-extended-community": {}
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.808040" elapsed="0.000462"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.809090" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.808751" elapsed="0.000402"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.809728" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.809372" elapsed="0.000418"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:32.810004" elapsed="0.002498"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.826131" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1098', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;default-gateway-extended-community&gt;
            &lt;/default-gateway-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:32.826222" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQHyDN2An%2FcAFgAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.826353" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.812788" elapsed="0.013600"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.830298" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.826633" elapsed="0.003726"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.838444" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.839061" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '499'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:32.839210" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.830585" elapsed="0.008662"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.842962" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.839492" elapsed="0.003539"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.850486" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.851095" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '499'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:32.851235" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.844400" elapsed="0.006871"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.854973" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.851550" elapsed="0.003492"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.855262" elapsed="0.003542"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:32.861386" level="INFO">${update} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.859036" elapsed="0.002379"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.861600" elapsed="0.002217"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:32.863872" elapsed="0.000040"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:32.843938" elapsed="0.020074"/>
</kw>
<msg time="2026-06-06T03:25:32.864091" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:32.843276" elapsed="0.020841"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.864539" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.864285" elapsed="0.000299"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.865471" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:32.865546" level="INFO">${len_1} = 174</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:32.865205" elapsed="0.000364"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.865993" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:32.866067" level="INFO">${len_2} = 174</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:32.865742" elapsed="0.000348"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.866247" elapsed="0.000427"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:32.867021" level="INFO">${sum_1} = 3189</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:32.866836" elapsed="0.000210"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:32.867379" level="INFO">${sum_2} = 3189</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:32.867199" elapsed="0.000205"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.867559" elapsed="0.000354"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:32.864836" elapsed="0.003137"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:32.868125" elapsed="0.002091"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.876426" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.876593" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '499'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:32.876802" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.870960" elapsed="0.005880"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.880769" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.877085" elapsed="0.003814"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.881128" elapsed="0.003505"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.890962" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.891080" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '499'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:32.891184" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.884886" elapsed="0.006325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.893816" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.891385" elapsed="0.002481"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.894025" elapsed="0.002480"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:32.898898" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.896589" elapsed="0.002351"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.896567" elapsed="0.002397"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.904592" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.904682" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.904825" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.899115" elapsed="0.005748"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:32.870544" elapsed="0.034410"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.911231" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.911385" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:32.911514" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.906288" elapsed="0.005303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.915258" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.911886" elapsed="0.003439"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.915546" elapsed="0.003545"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:32.921573" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:32.919326" elapsed="0.002289"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.921893" elapsed="0.003019"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:32.924983" elapsed="0.000043"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:32.905824" elapsed="0.019337"/>
</kw>
<msg time="2026-06-06T03:25:32.925272" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:32.905187" elapsed="0.020123"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.925912" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.925545" elapsed="0.000430"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.927187" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:32.927292" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:32.926827" elapsed="0.000498"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.927953" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:32.928056" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:32.927544" elapsed="0.000545"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.928320" elapsed="0.000464"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:32.929258" level="INFO">${sum_1} = 2742</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:32.929006" elapsed="0.000287"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:32.929789" level="INFO">${sum_2} = 2742</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:32.929507" elapsed="0.000318"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:32.930043" elapsed="0.000421"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:32.926294" elapsed="0.004253"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.936868" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.937049" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:32.937200" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.931331" elapsed="0.005907"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.943296" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.937508" elapsed="0.005862"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.943590" elapsed="0.003552"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:32.954230" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:32.954390" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:32.954501" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:32.947378" elapsed="0.007150"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.957172" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:32.954732" elapsed="0.002487"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:32.957383" elapsed="0.002526"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:32.963123" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:25:32.959996" elapsed="0.003219"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.959972" elapsed="0.003279"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:32.963472" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:32.930911" elapsed="0.032689"/>
</kw>
<arg>route_eth_lacp_extdef</arg>
<status status="PASS" start="2026-06-06T03:25:32.802791" elapsed="0.160893"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:32.676686" elapsed="0.287161"/>
</test>
<test id="s1-s13-t23" name="Play_To_Odl_route_eth_lacp_extdef" line="118">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:32.969824" elapsed="0.000293"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:32.969429" elapsed="0.000766"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:32.971587" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.971433" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.971405" elapsed="0.000299"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:32.977008" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.976901" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.976883" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.978093" 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-06-06T03:25:32.977700" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:32.978578" 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-06-06T03:25:32.978283" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:32.978663" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:25:32.978821" 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-06-06T03:25:32.977304" elapsed="0.001542"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:32.984674" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.984549" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.984528" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:32.986195" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:32.986013" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:32.985994" elapsed="0.000363"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:32.986939" 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-06-06T03:25:32.986511" elapsed="0.000490"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:32.987611" level="INFO">${current_connection_index} = 7</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-06-06T03:25:32.987345" elapsed="0.000343"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:33.022583" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:32.989583" elapsed="0.033190"/>
</kw>
<msg time="2026-06-06T03:25:33.022927" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:33.023024" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:32.988047" elapsed="0.035048"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:33.053563" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "d "e "f "[K"
[?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-06-06T03:25:33.025181" elapsed="0.028539"/>
</kw>
<msg time="2026-06-06T03:25:33.053855" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:33.053949" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:33.023530" elapsed="0.030492"/>
</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-06-06T03:25:33.054745" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:33.054334" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:33.054306" elapsed="0.000616"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.055685" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "d "e "f "[K"
[?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-06-06T03:25:33.055077" elapsed="0.000731"/>
</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-06-06T03:25:33.056340" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:33.055985" elapsed="0.000469"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:33.055965" elapsed="0.000547"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:33.056552" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:33.060338" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:25:33.060530" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:33.059621" elapsed="0.000977"/>
</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="NOT RUN" start="2026-06-06T03:25:33.060833" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:33.061051" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:33.058856" elapsed="0.002410"/>
</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-06-06T03:25:33.056879" elapsed="0.004473"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:32.985545" elapsed="0.076164"/>
</kw>
<msg time="2026-06-06T03:25:33.061809" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:33.061855" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:32.984902" elapsed="0.076991"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:33.062084" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:33.061973" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:33.061953" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:33.062676" elapsed="0.000031"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:33.063115" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:33.063191" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:32.984205" elapsed="0.079097"/>
</kw>
<msg time="2026-06-06T03:25:33.063446" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:33.063490" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:32.979225" elapsed="0.084301"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:33.064029" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:33.063603" elapsed="0.000482"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:33.063586" elapsed="0.000523"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:32.979079" elapsed="0.085055"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:32.978903" elapsed="0.085264"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:32.976524" elapsed="0.087700"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:32.971032" elapsed="0.093251"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:32.970409" elapsed="0.093923"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:32.966328" elapsed="0.098065"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:33.069897" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:33.070034" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:33.070130" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:33.064840" elapsed="0.005317"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:33.070331" elapsed="0.002886"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:33.079604" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:33.079747" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:33.079851" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:33.073392" elapsed="0.006485"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:33.084119" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:33.083699" elapsed="0.000460"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:33.084784" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:33.084381" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:33.085046" elapsed="0.000453"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:33.080109" elapsed="0.005475"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:33.064541" elapsed="0.021141"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:32.965194" elapsed="0.120546"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:33.086810" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:33.087017" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:33.086508" elapsed="0.000550"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.113442" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef.vanadium/route_eth_lacp_extdef.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:33.113064" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:33.114257" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef.vanadium/route_eth_lacp_extdef.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:33.113997" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef.vanadium/route_eth_lacp_extdef.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:33.114434" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:33.113638" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.115030" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:33.114628" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:33.115358" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/route_eth_lacp_extdef.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:33.115485" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:33.115224" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.115946" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "default-gateway-extended-community": {}
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:33.115699" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:33.116380" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:33.116065" elapsed="0.000373"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.116921" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:33.116613" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:33.116464" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:33.116046" elapsed="0.000957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.117597" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:33.117155" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:33.117690" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:25:33.117844" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:33.110721" elapsed="0.007149"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:33.118225" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/announce_route_eth_lacp_extdef.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/announce_route_eth_lacp_extdef.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:33.118413" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:33.118033" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:33.118847" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/withdraw_route_eth_lacp_extdef.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extdef/withdraw_route_eth_lacp_extdef.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:33.118973" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:33.118633" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.119416" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;default-gateway-extended-community&gt;
            &lt;/default-gateway-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:33.119160" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.119935" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "default-gateway-extended-community": {}
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:33.119629" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.120375" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:33.120140" elapsed="0.000278"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:33.120829" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:33.120571" elapsed="0.000302"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:33.121024" elapsed="0.002347"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:33.123533" elapsed="0.002205"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:33.130865" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:33.131016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:33.131146" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:33.126702" elapsed="0.004985">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:33.131961" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:33.132290" elapsed="0.000033"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:33.126356" elapsed="0.006150">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:35.144182" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:35.144385" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '499'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:35.144533" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:35.134273" elapsed="0.010297"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:35.145267" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "default-gateway-extended-community": {}
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:35.148511" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:35.144868" elapsed="0.003714"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:35.153256" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "default-gateway-extended-community": {},
       "transitive": true
      }
  ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:35.152519" elapsed="0.000777"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:35.154188" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "default-gateway-extended-community": {},
       "transitive": true
      }
  ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:35.153521" elapsed="0.000706"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:35.154457" elapsed="0.000513"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:35.148926" elapsed="0.006132"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:35.133222" elapsed="0.021912"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:33.125913" elapsed="2.029286"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:35.155422" elapsed="0.003117"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:35.167255" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:35.167417" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:35.167618" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:35.160700" elapsed="0.006982"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:35.167924" elapsed="0.003927"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:35.178467" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:35.179195" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '647'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"default-gateway-extended-community":{},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:35.179352" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:35.172087" elapsed="0.007304"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:35.184027" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:35.183557" elapsed="0.000511"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:35.185068" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:35.184293" elapsed="0.000815"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:35.185831" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "default-gateway-extended-community": {},
         "transitive": true
        }
       ],
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:35.186170" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,42 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "default-gateway-extended-community": {},
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:35.185338" elapsed="0.000942">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,42 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "default-gateway-extended-community": {},
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:35.179761" elapsed="0.006756">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,42 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "default-gateway-extended-community": {},
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:35.160050" elapsed="0.026781">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,42 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "default-gateway-extended-community": {},
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.197771" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.197973" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.198128" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.188380" elapsed="0.009787"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.198438" elapsed="0.004091"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.209850" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.209999" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:37.210145" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.202970" elapsed="0.007213"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.214877" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.214423" elapsed="0.000494"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.215524" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.215144" elapsed="0.000419"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.215835" elapsed="0.000465"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.210540" elapsed="0.005849"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.187506" elapsed="0.028962"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:35.159049" elapsed="2.057475"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:37.217304" elapsed="0.003468"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.228701" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.228834" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.229004" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.222732" elapsed="0.006299"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.229206" elapsed="0.002681"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.236601" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.236733" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:37.236840" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.232060" elapsed="0.004808"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.240047" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.239746" elapsed="0.000330"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.240517" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.240239" elapsed="0.000309"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.240727" elapsed="0.000334"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.237107" elapsed="0.004019"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.221827" elapsed="0.019353"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:37.221089" elapsed="0.020129"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:37.216808" elapsed="0.024465"/>
</kw>
<arg>route_eth_lacp_extdef</arg>
<status status="PASS" start="2026-06-06T03:25:33.086087" elapsed="4.155234"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:32.964410" elapsed="4.277023"/>
</test>
<test id="s1-s13-t24" name="Odl_To_Play_route_eth_lacp_extesilab" line="121">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:37.245576" elapsed="0.000406"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:37.245297" elapsed="0.000744"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:37.247099" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.246975" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.246951" elapsed="0.000220"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:37.252145" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.252037" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.252019" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.253224" 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-06-06T03:25:37.252840" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.253746" 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-06-06T03:25:37.253416" elapsed="0.000356"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:37.253816" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:25:37.253979" 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-06-06T03:25:37.252443" elapsed="0.001561"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:37.259815" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.259703" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.259682" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:37.261410" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.261223" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.261204" elapsed="0.000371"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:37.262187" 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-06-06T03:25:37.261764" elapsed="0.000487"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:37.262895" level="INFO">${current_connection_index} = 7</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-06-06T03:25:37.262608" elapsed="0.000349"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:37.297959" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:37.264833" elapsed="0.033261"/>
</kw>
<msg time="2026-06-06T03:25:37.298230" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:37.298325" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:37.263271" elapsed="0.035126"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:37.325728" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "i "l "a "b "[K"
[?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-06-06T03:25:37.300394" elapsed="0.025538"/>
</kw>
<msg time="2026-06-06T03:25:37.326108" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:37.326204" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:37.298855" elapsed="0.027422"/>
</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-06-06T03:25:37.327087" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.326613" elapsed="0.000594"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.326580" elapsed="0.000688"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.328092" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "i "l "a "b "[K"
[?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-06-06T03:25:37.327426" elapsed="0.000789"/>
</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-06-06T03:25:37.328769" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.328392" elapsed="0.000497"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.328371" elapsed="0.000579"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:37.328991" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:37.332876" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:25:37.333069" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:37.332171" elapsed="0.000967"/>
</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="NOT RUN" start="2026-06-06T03:25:37.333358" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.333575" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:37.331342" elapsed="0.002490"/>
</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-06-06T03:25:37.329320" elapsed="0.004600"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:37.260777" elapsed="0.073327"/>
</kw>
<msg time="2026-06-06T03:25:37.334387" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:37.334435" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:37.260042" elapsed="0.074435"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:37.334692" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:37.334562" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.334542" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.335377" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.335908" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:37.335983" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:37.259339" elapsed="0.076757"/>
</kw>
<msg time="2026-06-06T03:25:37.336194" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:37.336238" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:37.254387" elapsed="0.081887"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.336615" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.336352" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.336334" elapsed="0.000376"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:37.254241" elapsed="0.082493"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:37.254063" elapsed="0.082706"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:37.251678" elapsed="0.085149"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:37.246671" elapsed="0.090215"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:37.246203" elapsed="0.090732"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:37.242803" elapsed="0.094189"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.346385" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.346540" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.346679" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.337446" elapsed="0.009262"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.346886" elapsed="0.002633"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.354463" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.354632" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:37.354824" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.349739" elapsed="0.005125"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.359598" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.359143" elapsed="0.000516"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.360391" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.359902" elapsed="0.000532"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.360701" elapsed="0.000508"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.355228" elapsed="0.006075"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.337149" elapsed="0.024236"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:37.242312" elapsed="0.119136"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.362630" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.362879" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.362328" elapsed="0.000594"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.363447" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.363633" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.363161" elapsed="0.000534"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.364221" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/announce_route_eth_lacp_extesilab.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/announce_route_eth_lacp_extesilab.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.364407" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.363935" elapsed="0.000511"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:37.365025" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:37.364712" elapsed="0.000354"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.365585" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/withdraw_route_eth_lacp_extesilab.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/withdraw_route_eth_lacp_extesilab.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.365815" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.365306" elapsed="0.000548"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:37.366384" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:37.366090" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.367079" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;esi-label-extended-community&gt;
                &lt;single-active-mode&gt;true&lt;/single-active-mode&gt;
                &lt;esi-label&gt;24001&lt;/esi-label&gt;
            &lt;/esi-label-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.366729" elapsed="0.000433"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.367737" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "esi-label-extended-community": {
                "single-active-mode": true,
                "esi-label": 24001
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.367380" elapsed="0.000477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.368420" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.368080" elapsed="0.000405"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.369067" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.368729" elapsed="0.000400"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:37.369343" elapsed="0.002022"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.382491" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1193', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;esi-label-extended-community&gt;
                &lt;single-active-mode&gt;true&lt;/single-active-mode&gt;
                &lt;esi-label&gt;24001&lt;/esi-label&gt;
            &lt;/esi-label-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:37.382572" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQHyDN2An%2FcAFgAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.382845" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.371555" elapsed="0.011352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.389380" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.383336" elapsed="0.006140"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.397391" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.397946" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '536'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:37.398056" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.389889" elapsed="0.008194"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.400751" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.398257" elapsed="0.002544"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.407023" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.407665" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '536'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:37.407807" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.401823" elapsed="0.006023"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.411568" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.408092" elapsed="0.003563"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.411885" elapsed="0.003631"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:37.417582" level="INFO">${update} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.415770" elapsed="0.001903"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.417926" elapsed="0.002994"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:37.420995" elapsed="0.000052"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:37.401450" elapsed="0.019737"/>
</kw>
<msg time="2026-06-06T03:25:37.421301" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:37.400978" elapsed="0.020359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.421958" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.421572" elapsed="0.000449"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.423251" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:37.423360" level="INFO">${len_1} = 174</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:37.422882" elapsed="0.000512"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.424021" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:37.424126" level="INFO">${len_2} = 174</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:37.423631" elapsed="0.000529"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.424381" elapsed="0.000457"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:37.425330" level="INFO">${sum_1} = 3422</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:37.425064" elapsed="0.000301"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:37.425913" level="INFO">${sum_2} = 3422</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:37.425628" elapsed="0.000322"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.426168" elapsed="0.000397"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:37.422345" elapsed="0.004281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:37.426799" elapsed="0.001469"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.433806" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.433947" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '536'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:37.434105" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.428839" elapsed="0.005292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.437994" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.434305" elapsed="0.003759"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.438289" elapsed="0.003612"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.447287" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.447471" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '536'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:37.447631" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.442131" elapsed="0.005569"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.451709" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.447968" elapsed="0.003821"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.452032" elapsed="0.003939"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:37.459684" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.456099" elapsed="0.003657"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.456064" elapsed="0.003728"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.467084" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.467129" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.467241" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.460032" elapsed="0.007246"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:37.428523" elapsed="0.038839"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.472706" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.472842" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.473001" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.468407" elapsed="0.004627"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.477895" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.473261" elapsed="0.004708"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.478209" elapsed="0.004269"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:37.484859" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.482724" elapsed="0.002174"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.485136" elapsed="0.002923"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:37.488126" elapsed="0.000048"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:37.468044" elapsed="0.020258"/>
</kw>
<msg time="2026-06-06T03:25:37.488394" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:37.467539" elapsed="0.020881"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.488870" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.488594" elapsed="0.000322"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.489853" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:37.489929" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:37.489563" elapsed="0.000391"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.490384" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:37.490458" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:37.490114" elapsed="0.000368"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.490661" elapsed="0.000313"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:37.491355" level="INFO">${sum_1} = 2975</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:37.491136" elapsed="0.000246"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:37.491747" level="INFO">${sum_2} = 2975</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:37.491541" elapsed="0.000232"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.491931" elapsed="0.000321"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:37.489160" elapsed="0.003154"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.497966" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.498085" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.498180" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.492907" elapsed="0.005299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.501052" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.498384" elapsed="0.002718"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.501265" elapsed="0.003312"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.509914" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.510082" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.510235" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.504889" elapsed="0.005386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.514289" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.510537" elapsed="0.003825"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.514604" elapsed="0.003876"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:37.522134" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:25:37.518604" elapsed="0.003620"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.518574" elapsed="0.003688"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.522494" elapsed="0.000034"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:37.492581" elapsed="0.030046"/>
</kw>
<arg>route_eth_lacp_extesilab</arg>
<status status="PASS" start="2026-06-06T03:25:37.361878" elapsed="0.160844"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.241867" elapsed="0.281020"/>
</test>
<test id="s1-s13-t25" name="Play_To_Odl_route_eth_lacp_extesilab" line="123">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:37.528425" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:37.528153" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:37.529841" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.529700" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.529673" elapsed="0.000255"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:37.535341" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.535231" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.535213" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.536459" 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-06-06T03:25:37.536051" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.537000" 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-06-06T03:25:37.536674" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:37.537074" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:37.537231" 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-06-06T03:25:37.535661" elapsed="0.001595"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:37.543121" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.543009" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.542989" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:37.544725" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:37.544503" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.544483" elapsed="0.000432"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:37.545636" 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-06-06T03:25:37.545075" elapsed="0.000645"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:37.546355" level="INFO">${current_connection_index} = 7</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-06-06T03:25:37.546081" elapsed="0.000379"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:37.579002" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:37.548460" elapsed="0.030742"/>
</kw>
<msg time="2026-06-06T03:25:37.579397" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:37.579513" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:37.546822" elapsed="0.032783"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:37.609548" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "i "l "a "b "[K"
[?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-06-06T03:25:37.582194" elapsed="0.027596"/>
</kw>
<msg time="2026-06-06T03:25:37.609976" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:37.610072" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:37.580175" elapsed="0.029971"/>
</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-06-06T03:25:37.610959" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.610480" elapsed="0.000598"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.610443" elapsed="0.000697"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.611958" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "i "l "a "b "[K"
[?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-06-06T03:25:37.611298" elapsed="0.000782"/>
</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-06-06T03:25:37.612614" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.612259" elapsed="0.000490"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.612237" elapsed="0.000570"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:37.612850" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:37.616636" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:25:37.616844" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:37.615984" elapsed="0.000929"/>
</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="NOT RUN" start="2026-06-06T03:25:37.617130" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.617348" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:37.615163" elapsed="0.002432"/>
</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-06-06T03:25:37.613175" elapsed="0.004524"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:37.544050" elapsed="0.073826"/>
</kw>
<msg time="2026-06-06T03:25:37.617974" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:37.618020" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:37.543353" elapsed="0.074707"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:37.618248" elapsed="0.000092"/>
</return>
<status status="PASS" start="2026-06-06T03:25:37.618138" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.618119" elapsed="0.000298"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.618916" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.619346" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:37.619420" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:37.542657" elapsed="0.076932"/>
</kw>
<msg time="2026-06-06T03:25:37.619880" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:37.619931" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:37.537695" elapsed="0.082275"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.620312" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.620051" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.620032" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:37.537498" elapsed="0.082917"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:37.537315" elapsed="0.083133"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:37.534862" elapsed="0.085648"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:37.529318" elapsed="0.091249"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:37.528866" elapsed="0.091747"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:37.525608" elapsed="0.095075"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.627983" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.628135" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.628258" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.621129" elapsed="0.007157"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:37.628485" elapsed="0.002930"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.636995" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.637149" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:37.637298" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:37.631686" elapsed="0.005651"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.642107" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.641659" elapsed="0.000490"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:37.642813" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:37.642386" elapsed="0.000468"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.643090" elapsed="0.000480"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:37.637750" elapsed="0.005933"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.620835" elapsed="0.022932"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:37.524382" elapsed="0.119513"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.644979" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.645195" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.644679" elapsed="0.000558"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.673399" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab.vanadium/route_eth_lacp_extesilab.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:37.673018" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.674238" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab.vanadium/route_eth_lacp_extesilab.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:37.673993" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab.vanadium/route_eth_lacp_extesilab.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:37.674413" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:37.673626" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.675014" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:37.674608" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.675341" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/route_eth_lacp_extesilab.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.675469" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.675208" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.675922" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "esi-label-extended-community": {
                "single-active-mode": true,
                "esi-label": 24001
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.675677" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:37.676372" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:37.676047" elapsed="0.000383"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.676938" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:37.676606" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.676457" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:37.676025" elapsed="0.000995"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.677632" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:37.677171" elapsed="0.000505"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:37.677730" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:25:37.677889" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:37.670670" elapsed="0.007246"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.678275" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/announce_route_eth_lacp_extesilab.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/announce_route_eth_lacp_extesilab.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.678433" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.678081" elapsed="0.000380"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:37.678832" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/withdraw_route_eth_lacp_extesilab.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesilab/withdraw_route_eth_lacp_extesilab.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:37.678955" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:37.678622" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.679389" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;esi-label-extended-community&gt;
                &lt;single-active-mode&gt;true&lt;/single-active-mode&gt;
                &lt;esi-label&gt;24001&lt;/esi-label&gt;
            &lt;/esi-label-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.679143" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.679863" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "esi-label-extended-community": {
                "single-active-mode": true,
                "esi-label": 24001
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.679606" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.680310" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.680071" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:37.680767" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:37.680510" elapsed="0.000302"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:37.680964" elapsed="0.002433"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:37.683556" elapsed="0.002242"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:37.691513" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:37.691681" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:37.691813" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:37.686753" elapsed="0.005552">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.692614" elapsed="0.000054"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:37.692969" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:37.686410" elapsed="0.006731">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:39.704462" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:39.706043" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '536'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:39.706402" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:39.694807" elapsed="0.011664"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:39.707897" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "esi-label-extended-community": {
                "single-active-mode": true,
                "esi-label": 24001
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:39.713620" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:39.707076" elapsed="0.006705"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:39.719594" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "esi-label-extended-community": {
        "esi-label": 24001,
        "single-...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:39.718977" elapsed="0.000647"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:39.720299" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "esi-label-extended-community": {
        "esi-label": 24001,
        "single-...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:39.719806" elapsed="0.000523"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:39.720512" elapsed="0.000368"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:39.714385" elapsed="0.006564"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:39.693866" elapsed="0.027144"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:37.685987" elapsed="2.035080"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:39.721235" elapsed="0.002861"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:39.730546" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:39.730760" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:39.730981" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:39.725106" elapsed="0.005914"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:39.731279" elapsed="0.004314"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:39.741175" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:39.741999" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '684'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"esi-label-extended-community":{"esi-label":24001,"single-active-mode":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:39.742166" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:39.735872" elapsed="0.006333"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:39.746894" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:39.746422" elapsed="0.000515"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:39.748008" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:39.747174" elapsed="0.000875"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:39.748841" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "esi-label-extended-community": {
          "esi-label": 24001,
          "single-active-mode": true
         },
         "transitive": true
        }
       ],
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:39.749222" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "esi-label-extended-community": {
+          "esi-label": 24001,
+          "single-active-mode": true
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:39.748288" elapsed="0.001057">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "esi-label-extended-community": {
+          "esi-label": 24001,
+          "single-active-mode": true
+         },
+         "transitive": true
+        }
+       ],
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:39.742573" elapsed="0.007111">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "esi-label-extended-community": {
+          "esi-label": 24001,
+          "single-active-mode": true
+         },
+         "transitive": true
+        }
+       ],
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:39.724816" elapsed="0.025090">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "esi-label-extended-community": {
+          "esi-label": 24001,
+          "single-active-mode": true
+         },
+         "transitive": true
+        }
+       ],
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.760406" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.760754" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:41.761052" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.751639" elapsed="0.009494"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:41.761567" elapsed="0.006502"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.773888" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.773997" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:41.774105" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.768487" elapsed="0.005645"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:41.777682" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.777228" elapsed="0.000497"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:41.778345" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.777953" elapsed="0.000431"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.778614" elapsed="0.000493"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.774379" elapsed="0.004818"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:41.750629" elapsed="0.028645"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:39.724297" elapsed="2.055032"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:41.780136" elapsed="0.002709"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.789476" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.789667" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:41.789831" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.784582" elapsed="0.005288"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:41.790110" elapsed="0.003645"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.801156" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.801307" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:41.801451" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.793995" elapsed="0.007495"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:41.806020" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.805590" elapsed="0.000470"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:41.806737" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.806285" elapsed="0.000502"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.807015" elapsed="0.000459"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.801855" elapsed="0.005738"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:41.783861" elapsed="0.023835"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:41.783189" elapsed="0.024564"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:41.779611" elapsed="0.028219"/>
</kw>
<arg>route_eth_lacp_extesilab</arg>
<status status="PASS" start="2026-06-06T03:25:37.644210" elapsed="4.163687"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:37.523489" elapsed="4.284562"/>
</test>
<test id="s1-s13-t26" name="Odl_To_Play_route_eth_lacp_extesr" line="126">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:41.813732" elapsed="0.000302"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:41.813308" elapsed="0.000806"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:41.815671" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:41.815421" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.815386" elapsed="0.000405"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:41.821268" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:41.821133" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.821113" elapsed="0.000228"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.822395" 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-06-06T03:25:41.821996" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.822965" 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-06-06T03:25:41.822591" elapsed="0.000561"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:41.823205" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:25:41.823380" 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-06-06T03:25:41.821583" elapsed="0.001822"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:41.829403" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:41.829285" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.829265" elapsed="0.000211"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:41.831048" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:41.830836" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.830811" elapsed="0.000404"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:41.831873" 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-06-06T03:25:41.831376" elapsed="0.000561"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:41.832585" level="INFO">${current_connection_index} = 7</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-06-06T03:25:41.832296" elapsed="0.000371"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:41.865279" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:41.834555" elapsed="0.030872"/>
</kw>
<msg time="2026-06-06T03:25:41.865576" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:41.865698" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:41.833003" elapsed="0.032769"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:41.907412" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "r "[K"
[?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-06-06T03:25:41.867928" elapsed="0.039693"/>
</kw>
<msg time="2026-06-06T03:25:41.907814" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:41.907911" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:41.866260" elapsed="0.041725"/>
</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-06-06T03:25:41.908798" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:41.908323" elapsed="0.000599"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.908287" elapsed="0.000698"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.909794" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "r "[K"
[?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-06-06T03:25:41.909147" elapsed="0.000772"/>
</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-06-06T03:25:41.910458" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:41.910098" elapsed="0.000477"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.910077" elapsed="0.000557"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:41.910692" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:41.914491" elapsed="0.000165"/>
</kw>
<msg time="2026-06-06T03:25:41.914704" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:41.913877" elapsed="0.000897"/>
</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="NOT RUN" start="2026-06-06T03:25:41.914997" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:41.915217" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:41.913078" elapsed="0.002379"/>
</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-06-06T03:25:41.911027" elapsed="0.004595"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:41.830327" elapsed="0.085497"/>
</kw>
<msg time="2026-06-06T03:25:41.915922" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:41.915968" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:41.829656" elapsed="0.086351"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:41.916199" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:25:41.916087" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.916066" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:41.916850" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:41.917348" elapsed="0.000029"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:41.917427" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:41.828923" elapsed="0.088620"/>
</kw>
<msg time="2026-06-06T03:25:41.917658" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:41.917706" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:41.823873" elapsed="0.093871"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:41.918083" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:41.917823" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:41.917805" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:41.823714" elapsed="0.094472"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:41.823469" elapsed="0.094751"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:41.820629" elapsed="0.097652"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:41.814996" elapsed="0.103343"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:41.814337" elapsed="0.104049"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:41.810160" elapsed="0.108281"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.924525" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.924709" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:41.924827" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.918898" elapsed="0.005957"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:41.925028" elapsed="0.002950"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.932084" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.932232" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:41.932432" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.928149" elapsed="0.004321"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:41.937049" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.936454" elapsed="0.000636"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:41.937719" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.937316" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.937983" elapsed="0.000464"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.932833" elapsed="0.005702"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:41.918595" elapsed="0.020017"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:41.809425" elapsed="0.129267"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:41.939822" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:41.940068" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:41.939513" elapsed="0.000596"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:41.940604" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:41.940807" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:41.940336" elapsed="0.000509"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:41.941336" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/announce_route_eth_lacp_extesr.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/announce_route_eth_lacp_extesr.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:41.941511" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:41.941070" elapsed="0.000478"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:41.942095" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:41.941800" elapsed="0.000333"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:41.942624" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/withdraw_route_eth_lacp_extesr.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/withdraw_route_eth_lacp_extesr.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:41.942821" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:41.942359" elapsed="0.000500"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:41.943362" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:41.943079" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.944042" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;es-import-route-extended-community&gt;
                &lt;es-import&gt;f2:0c:dd:80:9f:f8&lt;/es-import&gt;
            &lt;/es-import-route-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.943686" elapsed="0.000487"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.944767" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "es-import-route-extended-community": {
                "es-import": "f2:0c:dd:80:9f:f8"
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.944397" elapsed="0.000443"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.945403" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.945062" elapsed="0.000403"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.946043" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.945705" elapsed="0.000401"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:41.946319" elapsed="0.002962"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.960484" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1155', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;es-import-route-extended-community&gt;
                &lt;es-import&gt;f2:0c:dd:80:9f:f8&lt;/es-import&gt;
            &lt;/es-import-route-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:41.960576" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQHyDN2An%2FcAFgAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.960737" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.949513" elapsed="0.011262"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.964742" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.961023" elapsed="0.003781"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.971989" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.972589" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '530'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:41.972770" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.965031" elapsed="0.007777"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.976533" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.973052" elapsed="0.003614"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:41.983772" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:41.984341" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '530'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:41.984478" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:41.978032" elapsed="0.006482"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.988203" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.984786" elapsed="0.003487"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:41.988496" elapsed="0.003556"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:41.994898" level="INFO">${update} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:41.992283" elapsed="0.002645"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.995088" elapsed="0.002210"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:41.997351" elapsed="0.000039"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:41.977545" elapsed="0.019946"/>
</kw>
<msg time="2026-06-06T03:25:41.997571" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:41.976916" elapsed="0.020681"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.998032" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:41.997784" elapsed="0.000294"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.998963" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:41.999039" level="INFO">${len_1} = 174</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:41.998699" elapsed="0.000364"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:41.999489" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:41.999564" level="INFO">${len_2} = 174</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:41.999221" elapsed="0.000366"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:41.999762" elapsed="0.000309"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:42.000418" level="INFO">${sum_1} = 4191</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:42.000232" elapsed="0.000212"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:42.000804" level="INFO">${sum_2} = 4191</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:42.000599" elapsed="0.000231"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:42.000987" elapsed="0.000304"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:41.998313" elapsed="0.003038"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:42.001503" elapsed="0.002383"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.010007" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.010224" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '530'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:42.010358" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.004599" elapsed="0.005796"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.014516" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.010639" elapsed="0.003950"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:42.014841" elapsed="0.003548"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.023588" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.023732" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '530'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:42.023840" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.018625" elapsed="0.005243"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.026456" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.024043" elapsed="0.002464"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:42.026682" elapsed="0.002499"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:42.031605" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:42.029264" elapsed="0.002428"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.029242" elapsed="0.002484"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.040731" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.040795" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.040934" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.031941" elapsed="0.009030"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:42.004211" elapsed="0.036853"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.048165" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.048362" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:42.048494" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.042401" elapsed="0.006130"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.052218" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.048806" elapsed="0.003480"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:42.052509" elapsed="0.003573"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:42.058699" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:42.056317" elapsed="0.002425"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:42.058992" elapsed="0.003016"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:42.062079" elapsed="0.000043"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:42.041938" elapsed="0.020321"/>
</kw>
<msg time="2026-06-06T03:25:42.062369" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:42.041298" elapsed="0.021107"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.063008" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.062658" elapsed="0.000413"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.064318" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:42.064423" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:42.063954" elapsed="0.000502"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.065158" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:42.065263" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:42.064795" elapsed="0.000501"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:42.065517" elapsed="0.000462"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:42.066457" level="INFO">${sum_1} = 3744</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:42.066201" elapsed="0.000291"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:42.066991" level="INFO">${sum_2} = 3744</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:42.066733" elapsed="0.000294"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:42.067247" elapsed="0.000472"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:42.063405" elapsed="0.004400"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.073964" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.074114" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:42.074241" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.068577" elapsed="0.005700"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.080839" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.074518" elapsed="0.006587"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:42.081578" elapsed="0.005935"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.092314" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.092463" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:42.092580" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.087809" elapsed="0.004799"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.095256" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.092814" elapsed="0.002491"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:42.095480" elapsed="0.002533"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:42.100846" elapsed="0.000052"/>
</return>
<status status="PASS" start="2026-06-06T03:25:42.098113" elapsed="0.002833"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.098083" elapsed="0.002900"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.101202" elapsed="0.000032"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:42.068156" elapsed="0.033181"/>
</kw>
<arg>route_eth_lacp_extesr</arg>
<status status="PASS" start="2026-06-06T03:25:41.939057" elapsed="0.162347"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:41.808788" elapsed="0.292777"/>
</test>
<test id="s1-s13-t27" name="Play_To_Odl_route_eth_lacp_extesr" line="128">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:42.107151" elapsed="0.000335"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:42.106774" elapsed="0.000792"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:42.108631" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:42.108517" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.108497" elapsed="0.000219"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:42.113867" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:42.113759" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.113740" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.114964" 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-06-06T03:25:42.114558" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.115472" 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-06-06T03:25:42.115155" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:42.115541" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:42.115717" 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-06-06T03:25:42.114172" elapsed="0.001570"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:42.121773" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:42.121661" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.121626" elapsed="0.000216"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:42.123315" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:42.123128" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.123109" elapsed="0.000395"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:42.124139" 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-06-06T03:25:42.123679" elapsed="0.000523"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:42.124849" level="INFO">${current_connection_index} = 7</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-06-06T03:25:42.124560" elapsed="0.000352"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:42.153497" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:42.126813" elapsed="0.026892"/>
</kw>
<msg time="2026-06-06T03:25:42.153862" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:42.153964" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:42.125228" elapsed="0.028810"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:42.180294" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "r "[K"
[?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-06-06T03:25:42.156046" elapsed="0.024386"/>
</kw>
<msg time="2026-06-06T03:25:42.180564" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:42.180681" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:42.154451" elapsed="0.026306"/>
</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-06-06T03:25:42.181431" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:42.181058" elapsed="0.000492"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.181035" elapsed="0.000574"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.182364" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "e "s "r "[K"
[?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-06-06T03:25:42.181788" elapsed="0.000697"/>
</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-06-06T03:25:42.183033" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:42.182679" elapsed="0.000471"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.182657" elapsed="0.000550"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:42.183244" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:42.186800" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:25:42.186988" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:42.186253" elapsed="0.000802"/>
</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="NOT RUN" start="2026-06-06T03:25:42.187274" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.187526" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:42.185483" elapsed="0.002351"/>
</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-06-06T03:25:42.183543" elapsed="0.004377"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:42.122682" elapsed="0.065413"/>
</kw>
<msg time="2026-06-06T03:25:42.188190" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:42.188233" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:42.122001" elapsed="0.066270"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:42.188456" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:42.188349" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.188329" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.189021" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.189482" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:42.189555" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:42.121299" elapsed="0.068382"/>
</kw>
<msg time="2026-06-06T03:25:42.189777" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:42.189820" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:42.116139" elapsed="0.073719"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.190192" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:42.189934" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.189916" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:42.115990" elapsed="0.074303"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:42.115806" elapsed="0.074519"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:42.113378" elapsed="0.077002"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:42.108226" elapsed="0.082209"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:42.107776" elapsed="0.082704"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:42.103622" elapsed="0.086910"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.196045" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.196156" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:42.196250" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.190978" elapsed="0.005298"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:42.196445" elapsed="0.002801"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.205091" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.205239" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:42.205382" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:42.199471" elapsed="0.005948"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:42.209946" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:42.209471" elapsed="0.000515"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:42.210589" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:42.210211" elapsed="0.000416"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:42.210880" elapsed="0.000523"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:42.205777" elapsed="0.005714"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:42.190700" elapsed="0.020866"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:42.102858" elapsed="0.108763"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:42.212657" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:42.212891" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:42.212356" elapsed="0.000576"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.240834" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr.vanadium/route_eth_lacp_extesr.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:42.240420" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:42.241667" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr.vanadium/route_eth_lacp_extesr.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:42.241386" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr.vanadium/route_eth_lacp_extesr.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:42.241843" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:42.241037" elapsed="0.000831"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.242427" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:42.242040" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:42.242779" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/route_eth_lacp_extesr.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:42.242923" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:42.242621" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.243385" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "es-import-route-extended-community": {
                "es-import": "f2:0c:dd:80:9f:f8"
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.243112" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:42.243853" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:42.243508" elapsed="0.000404"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.244377" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:42.244087" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:42.243938" elapsed="0.000499"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:42.243487" elapsed="0.000971"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.245075" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:42.244611" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:42.245154" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:25:42.245311" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:42.238028" elapsed="0.007310"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:42.245791" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/announce_route_eth_lacp_extesr.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/announce_route_eth_lacp_extesr.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:42.245919" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:42.245543" elapsed="0.000402"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:42.246299" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/withdraw_route_eth_lacp_extesr.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extesr/withdraw_route_eth_lacp_extesr.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:42.246422" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:42.246106" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.246873" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;es-import-route-extended-community&gt;
                &lt;es-import&gt;f2:0c:dd:80:9f:f8&lt;/es-import&gt;
            &lt;/es-import-route-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.246608" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.247507" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "es-import-route-extended-community": {
                "es-import": "f2:0c:dd:80:9f:f8"
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.247090" elapsed="0.000475"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.248017" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.247759" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:42.248468" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:42.248227" elapsed="0.000286"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:42.248682" elapsed="0.002749"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:42.251595" elapsed="0.002314"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:42.260686" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:42.260864" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:42.261000" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:42.255271" elapsed="0.006302">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.261877" elapsed="0.000033"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:42.262211" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:42.254801" elapsed="0.007586">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:44.273253" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:44.273514" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '530'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:44.273734" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:44.264039" elapsed="0.009735"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:44.274460" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": true,
              "es-import-route-extended-community": {
                "es-import": "f2:0c:dd:80:9f:f8"
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:44.277625" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:44.274036" elapsed="0.003677"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:44.282351" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "es-import-route-extended-community": {
        "es-import": "f2:0c:dd:80:9f:f...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:44.281569" elapsed="0.000825"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:44.283305" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "es-import-route-extended-community": {
        "es-import": "f2:0c:dd:80:9f:f...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:44.282624" elapsed="0.000721"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:44.283570" elapsed="0.000485"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:44.278029" elapsed="0.006114"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:44.263085" elapsed="0.021135"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:42.254155" elapsed="2.030130"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:44.284511" elapsed="0.003092"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:44.296825" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:44.297052" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:44.297201" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:44.288923" elapsed="0.008315"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:44.297477" elapsed="0.003737"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:44.306875" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:44.307571" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '678'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"es-import-route-extended-community":{"es-import":"f2:0c:dd:80:9f:f8"},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:44.307749" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:44.301450" elapsed="0.006337"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:44.312121" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:44.311716" elapsed="0.000444"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:44.313140" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:44.312381" elapsed="0.000799"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:44.313875" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "es-import-route-extended-community": {
          "es-import": "f2:0c:dd:80:9f:f8"
         },
         "transitive": true
        }
       ],
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:44.314216" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "es-import-route-extended-community": {
+          "es-import": "f2:0c:dd:80:9f:f8"
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:44.313406" elapsed="0.000977">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "es-import-route-extended-community": {
+          "es-import": "f2:0c:dd:80:9f:f8"
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:44.308117" elapsed="0.006572">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "es-import-route-extended-community": {
+          "es-import": "f2:0c:dd:80:9f:f8"
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:44.288497" elapsed="0.026406">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "es-import-route-extended-community": {
+          "es-import": "f2:0c:dd:80:9f:f8"
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.326236" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.326462" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.326619" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.316450" elapsed="0.010238"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.326969" elapsed="0.004016"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.337956" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.338116" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:46.338268" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.331238" elapsed="0.007070"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.343472" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.342978" elapsed="0.000535"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.344170" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.343778" elapsed="0.000431"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.344435" elapsed="0.000506"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.338728" elapsed="0.006301"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.315596" elapsed="0.029520"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:44.287883" elapsed="2.057290"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:46.345954" elapsed="0.002999"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.354368" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.354480" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.354582" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.350245" elapsed="0.004364"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.354826" elapsed="0.003253"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.363983" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.364129" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:46.364270" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.358314" elapsed="0.005994"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.368713" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.368296" elapsed="0.000459"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.369352" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.368979" elapsed="0.000413"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.369616" elapsed="0.000476"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.364632" elapsed="0.005547"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.349929" elapsed="0.020325"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:46.349207" elapsed="0.021100"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:46.345437" elapsed="0.024944"/>
</kw>
<arg>route_eth_lacp_extesr</arg>
<status status="PASS" start="2026-06-06T03:25:42.211937" elapsed="4.158509"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:42.102150" elapsed="4.268448"/>
</test>
<test id="s1-s13-t28" name="Odl_To_Play_route_eth_lacp_extl2" line="131">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:46.374837" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:46.374527" elapsed="0.000593"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:46.376180" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.376057" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.376034" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:46.381601" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.381492" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.381473" elapsed="0.000216"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.382859" 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-06-06T03:25:46.382448" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.383370" 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-06-06T03:25:46.383053" elapsed="0.000389"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:46.383489" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:25:46.383674" 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-06-06T03:25:46.381930" elapsed="0.001771"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:46.389707" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.389577" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.389557" elapsed="0.000220"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:46.391252" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.391068" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.391049" elapsed="0.000391"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:46.392036" 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-06-06T03:25:46.391598" elapsed="0.000501"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:46.392736" level="INFO">${current_connection_index} = 7</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-06-06T03:25:46.392449" elapsed="0.000349"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:46.427883" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:46.394647" elapsed="0.033379"/>
</kw>
<msg time="2026-06-06T03:25:46.428164" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:46.428257" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:46.393109" elapsed="0.035217"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:46.460753" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "l "2 "[K"
[?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-06-06T03:25:46.430264" elapsed="0.030647"/>
</kw>
<msg time="2026-06-06T03:25:46.461054" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:46.461150" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:46.428748" elapsed="0.032473"/>
</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-06-06T03:25:46.461935" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.461529" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.461504" elapsed="0.000609"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.462880" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "l "2 "[K"
[?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-06-06T03:25:46.462270" elapsed="0.000729"/>
</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-06-06T03:25:46.463526" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.463173" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.463152" elapsed="0.000567"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:46.463758" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:46.467387" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:25:46.467573" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:46.466827" elapsed="0.000819"/>
</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="NOT RUN" start="2026-06-06T03:25:46.467938" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.468156" elapsed="0.000021"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:46.466043" elapsed="0.002328"/>
</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-06-06T03:25:46.464061" elapsed="0.004471"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:46.390593" elapsed="0.078140"/>
</kw>
<msg time="2026-06-06T03:25:46.468831" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:46.468877" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:46.389939" elapsed="0.078975"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:46.469304" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:25:46.468993" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.468973" elapsed="0.000421"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.469954" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.470389" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:46.470464" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:46.389233" elapsed="0.081344"/>
</kw>
<msg time="2026-06-06T03:25:46.470693" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:46.470741" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:46.384097" elapsed="0.086681"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.471118" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.470857" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.470838" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:46.383947" elapsed="0.087276"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:46.383764" elapsed="0.087492"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:46.381125" elapsed="0.090202"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:46.375757" elapsed="0.095648"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:46.375277" elapsed="0.096178"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:46.372292" elapsed="0.099218"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.478257" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.478435" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.478589" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.471973" elapsed="0.006655"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.478896" elapsed="0.003719"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.489010" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.489116" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:46.489258" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.482874" elapsed="0.006411"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.492395" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.492089" elapsed="0.000334"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.492911" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.492582" elapsed="0.000359"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.493106" elapsed="0.000328"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.489521" elapsed="0.003975"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.471692" elapsed="0.021860"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:46.371793" elapsed="0.121801"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.494698" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.494945" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.494396" elapsed="0.000590"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.495483" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.495690" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.495215" elapsed="0.000516"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.496223" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/announce_route_eth_lacp_extl2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/announce_route_eth_lacp_extl2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.496399" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.495957" elapsed="0.000479"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:46.497000" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:46.496688" elapsed="0.000350"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.497529" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/withdraw_route_eth_lacp_extl2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/withdraw_route_eth_lacp_extl2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.497730" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.497267" elapsed="0.000501"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:46.498267" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:46.497989" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.498907" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;false&lt;/transitive&gt;
            &lt;layer-2-attributes-extended-community&gt;
                &lt;primary-pe&gt;true&lt;/primary-pe&gt;
                &lt;backup-pe&gt;true&lt;/backup-pe&gt;
                &lt;control-word&gt;true&lt;/control-word&gt;
                &lt;l2-mtu&gt;200&lt;/l2-mtu&gt;
            &lt;/layer-2-attributes-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.498529" elapsed="0.000514"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.499612" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": false,
              "layer-2-attributes-extended-community": {
                "control-word": true,
                "backup-pe": true,
                "primary-pe": true,
                "l2-mtu": 200
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.499270" elapsed="0.000440"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.500275" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.499935" elapsed="0.000403"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.501027" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.500616" elapsed="0.000480"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:46.501317" elapsed="0.002577"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.514635" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1282', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;false&lt;/transitive&gt;
            &lt;layer-2-attributes-extended-community&gt;
                &lt;primary-pe&gt;true&lt;/primary-pe&gt;
                &lt;backup-pe&gt;true&lt;/backup-pe&gt;
                &lt;control-word&gt;true&lt;/control-word&gt;
                &lt;l2-mtu&gt;200&lt;/l2-mtu&gt;
            &lt;/layer-2-attributes-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:46.514758" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQHyDN2An%2FcAFgAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.514902" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.504068" elapsed="0.010870"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.518718" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.515183" elapsed="0.003599"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.525758" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.526379" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '570'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:46.526528" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.519009" elapsed="0.007558"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.530375" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.526874" elapsed="0.003572"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.536003" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.536430" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '570'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:46.536528" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.531823" elapsed="0.004731"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.539175" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.536752" elapsed="0.002474"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.539384" elapsed="0.002528"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:46.544581" level="INFO">${update} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.542079" elapsed="0.002544"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.544906" elapsed="0.003226"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:46.548205" elapsed="0.000048"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:46.531331" elapsed="0.017062"/>
</kw>
<msg time="2026-06-06T03:25:46.548505" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:46.530711" elapsed="0.017829"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.549150" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.548800" elapsed="0.000414"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.550477" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:46.550581" level="INFO">${len_1} = 174</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:46.550111" elapsed="0.000503"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.551223" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:46.551327" level="INFO">${len_2} = 174</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:46.550867" elapsed="0.000493"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.551582" elapsed="0.000459"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:46.552519" level="INFO">${sum_1} = 3454</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:46.552262" elapsed="0.000292"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:46.553053" level="INFO">${sum_2} = 3454</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:46.552797" elapsed="0.000291"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.553307" elapsed="0.000520"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:46.549539" elapsed="0.004373"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:46.554128" elapsed="0.002123"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.563817" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.563985" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '570'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:46.564119" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.556991" elapsed="0.007164"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.568106" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.564396" elapsed="0.003781"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.568398" elapsed="0.003521"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.576935" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.577056" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '570'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:46.577162" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.572151" elapsed="0.005038"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.579828" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.577363" elapsed="0.002516"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.580040" elapsed="0.002557"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:46.585927" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.582697" elapsed="0.003290"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.582674" elapsed="0.003347"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.594489" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.594602" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.594775" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.586234" elapsed="0.008580"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:46.556572" elapsed="0.038335"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.602007" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.602159" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.602290" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.596236" elapsed="0.006091"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.606069" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.602672" elapsed="0.003465"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.606360" elapsed="0.003547"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:46.612567" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.610140" elapsed="0.002470"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.612896" elapsed="0.003034"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:46.616002" elapsed="0.000045"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:46.595771" elapsed="0.020414"/>
</kw>
<msg time="2026-06-06T03:25:46.616297" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:46.595141" elapsed="0.021193"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.616949" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.616571" elapsed="0.000443"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.618248" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:46.618355" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:46.617883" elapsed="0.000506"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.619005" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:46.619110" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:46.618610" elapsed="0.000534"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.619366" elapsed="0.000451"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:46.620293" level="INFO">${sum_1} = 3007</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:46.620038" elapsed="0.000291"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:46.620820" level="INFO">${sum_2} = 3007</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:46.620545" elapsed="0.000311"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.621075" elapsed="0.000426"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:46.617336" elapsed="0.004250"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.626985" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.627131" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.627225" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.622391" elapsed="0.004860"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.630060" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.627425" elapsed="0.002683"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.630269" elapsed="0.003079"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.640003" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.640153" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.640295" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.633585" elapsed="0.006747"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.644001" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.640576" elapsed="0.003493"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.644292" elapsed="0.003607"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:46.651256" elapsed="0.000072"/>
</return>
<status status="PASS" start="2026-06-06T03:25:46.648025" elapsed="0.003348"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.647998" elapsed="0.003411"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.651621" elapsed="0.000052"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:46.621966" elapsed="0.029805"/>
</kw>
<arg>route_eth_lacp_extl2</arg>
<status status="PASS" start="2026-06-06T03:25:46.493964" elapsed="0.157866"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.371107" elapsed="0.280846"/>
</test>
<test id="s1-s13-t29" name="Play_To_Odl_route_eth_lacp_extl2" line="133">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:46.655715" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:46.655429" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:46.656989" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.656876" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.656856" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:46.662077" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.661968" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.661949" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.663160" 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-06-06T03:25:46.662775" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.663682" 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-06-06T03:25:46.663352" elapsed="0.000358"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:46.663755" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:46.663911" 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-06-06T03:25:46.662376" elapsed="0.001560"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:46.669884" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.669774" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.669754" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:46.671411" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:46.671227" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.671207" elapsed="0.000372"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:46.672190" 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-06-06T03:25:46.671773" elapsed="0.000479"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:46.672889" level="INFO">${current_connection_index} = 7</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-06-06T03:25:46.672603" elapsed="0.000347"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:46.705480" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:46.674832" elapsed="0.030777"/>
</kw>
<msg time="2026-06-06T03:25:46.705769" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:46.705865" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:46.673264" elapsed="0.032671"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:46.737941" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "l "2 "[K"
[?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-06-06T03:25:46.707886" elapsed="0.030190"/>
</kw>
<msg time="2026-06-06T03:25:46.738209" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:46.738302" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:46.706334" elapsed="0.032038"/>
</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-06-06T03:25:46.739059" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.738697" elapsed="0.000476"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.738673" elapsed="0.000560"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.739967" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "l "2 "[K"
[?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-06-06T03:25:46.739385" elapsed="0.000696"/>
</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-06-06T03:25:46.740600" elapsed="0.000073"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.740253" elapsed="0.000492"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.740233" elapsed="0.000575"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:46.740845" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:46.744340" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:25:46.744525" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:46.743817" elapsed="0.000774"/>
</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="NOT RUN" start="2026-06-06T03:25:46.744847" elapsed="0.000027"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.745070" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:46.743025" elapsed="0.002260"/>
</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-06-06T03:25:46.741120" elapsed="0.004249"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:46.670778" elapsed="0.074765"/>
</kw>
<msg time="2026-06-06T03:25:46.745637" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:46.745702" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:46.670113" elapsed="0.075659"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:46.745964" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:46.745854" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.745834" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.746506" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.747009" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:46.747084" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:46.669406" elapsed="0.077787"/>
</kw>
<msg time="2026-06-06T03:25:46.747287" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:46.747330" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:46.664368" elapsed="0.082997"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.747714" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.747441" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.747423" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:46.664219" elapsed="0.083603"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:46.664040" elapsed="0.083812"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:46.661582" elapsed="0.086324"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:46.656568" elapsed="0.091394"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:46.656141" elapsed="0.091865"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:46.653225" elapsed="0.094834"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.752950" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.753065" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.753158" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.748481" elapsed="0.004703"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:46.753354" elapsed="0.003790"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.763610" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.763791" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:46.763934" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:46.757382" elapsed="0.006589"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.768342" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.767926" elapsed="0.000455"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:46.769003" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:46.768601" elapsed="0.000440"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.769288" elapsed="0.000486"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:46.764335" elapsed="0.005545"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.748205" elapsed="0.021763"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:46.652754" elapsed="0.117269"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.771031" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.771248" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.770750" elapsed="0.000539"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.797965" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2.vanadium/route_eth_lacp_extl2.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:46.797546" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.798767" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2.vanadium/route_eth_lacp_extl2.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:46.798507" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2.vanadium/route_eth_lacp_extl2.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:46.798941" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:46.798164" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.799521" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:46.799136" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.799871" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/route_eth_lacp_extl2.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.799997" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.799735" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.800427" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": false,
              "layer-2-attributes-extended-community": {
                "control-word": true,
                "backup-pe": true,
                "primary-pe": true,
                "l2-mtu": 200
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.800184" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:46.800877" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:46.800547" elapsed="0.000389"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.801405" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:46.801112" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.800962" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:46.800528" elapsed="0.000989"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.802159" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:46.801703" elapsed="0.000485"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:46.802239" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:25:46.802392" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:46.795204" elapsed="0.007215"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.802795" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/announce_route_eth_lacp_extl2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/announce_route_eth_lacp_extl2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.802920" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.802582" elapsed="0.000365"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:46.803297" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/withdraw_route_eth_lacp_extl2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extl2/withdraw_route_eth_lacp_extl2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:46.803417" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:46.803105" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.803898" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;false&lt;/transitive&gt;
            &lt;layer-2-attributes-extended-community&gt;
                &lt;primary-pe&gt;true&lt;/primary-pe&gt;
                &lt;backup-pe&gt;true&lt;/backup-pe&gt;
                &lt;control-word&gt;true&lt;/control-word&gt;
                &lt;l2-mtu&gt;200&lt;/l2-mtu&gt;
            &lt;/layer-2-attributes-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.803603" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.804358" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": false,
              "layer-2-attributes-extended-community": {
                "control-word": true,
                "backup-pe": true,
                "primary-pe": true,
                "l2-mtu": 200
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.804117" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.804824" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.804565" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:46.805259" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:46.805023" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:46.805454" elapsed="0.002716"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:46.808338" elapsed="0.002164"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:46.816222" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:46.816417" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:46.816549" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:46.811471" elapsed="0.005609">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.817347" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:46.817706" elapsed="0.000035"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:46.811142" elapsed="0.006761">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:48.831094" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:48.831314" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '570'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:48.831493" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:48.819990" elapsed="0.011544"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:48.832258" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "transitive": false,
              "layer-2-attributes-extended-community": {
                "control-word": true,
                "backup-pe": true,
                "primary-pe": true,
                "l2-mtu": 200
              }
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:48.835718" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:48.831835" elapsed="0.003959"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:48.840390" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "layer-2-attributes-extended-community": {
        "backup-pe": true,
        ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:48.839766" elapsed="0.000653"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:48.841097" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "layer-2-attributes-extended-community": {
        "backup-pe": true,
        ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:48.840581" elapsed="0.000544"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:48.841288" elapsed="0.000331"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:48.836173" elapsed="0.005529"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:48.818602" elapsed="0.023231"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:46.810704" elapsed="2.031182"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:48.842050" elapsed="0.003259"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:48.851072" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:48.851224" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:48.851355" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:48.846244" elapsed="0.005147"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:48.851687" elapsed="0.003850"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:48.861232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:48.862025" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '718'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"layer-2-attributes-extended-community":{"primary-pe":true,"control-word":true,"l2-mtu":200,"backup-pe":true},"transitive":false}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:48.862178" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:48.855845" elapsed="0.006370"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:48.866508" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:48.866115" elapsed="0.000432"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:48.867549" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:48.866794" elapsed="0.000794"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:48.868293" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "layer-2-attributes-extended-community": {
          "backup-pe": true,
          "control-word": true,
          "l2-mtu": 200,
          "primary-pe": true
         },
         "transitive": false
        }
       ],
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:48.868644" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,47 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "layer-2-attributes-extended-community": {
+          "backup-pe": true,
+          "control-word": true,
+          "l2-mtu": 200,
+          "primary-pe": true
+         },
+         "transitive": false
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:48.867852" elapsed="0.000971">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,47 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "layer-2-attributes-extended-community": {
+          "backup-pe": true,
+          "control-word": true,
+          "l2-mtu": 200,
+          "primary-pe": true
+         },
+         "transitive": false
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:48.862536" elapsed="0.006526">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,47 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "layer-2-attributes-extended-community": {
+          "backup-pe": true,
+          "control-word": true,
+          "l2-mtu": 200,
+          "primary-pe": true
+         },
+         "transitive": false
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:48.845967" elapsed="0.023303">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,47 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "layer-2-attributes-extended-community": {
+          "backup-pe": true,
+          "control-word": true,
+          "l2-mtu": 200,
+          "primary-pe": true
+         },
+         "transitive": false
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:50.880158" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:50.880444" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:50.880709" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:50.870916" elapsed="0.009855"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:50.881171" elapsed="0.004722"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:50.893591" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:50.893777" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:50.893930" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:50.886134" elapsed="0.007838"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:50.898349" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:50.897933" elapsed="0.000456"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:50.899021" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:50.898613" elapsed="0.000515"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:50.899394" elapsed="0.000495"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:50.894312" elapsed="0.005668"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:50.870043" elapsed="0.030014"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:48.845486" elapsed="2.054627"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:50.900905" elapsed="0.002970"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:50.909682" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:50.909791" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:50.909898" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:50.905051" elapsed="0.004888"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:50.910172" elapsed="0.003580"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:50.919554" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:50.919728" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:50.919870" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:50.913989" elapsed="0.005920"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:50.924262" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:50.923873" elapsed="0.000428"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:50.924915" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:50.924520" elapsed="0.000433"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:50.925172" elapsed="0.000446"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:50.920228" elapsed="0.005500"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:50.904494" elapsed="0.021308"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:50.904073" elapsed="0.021781"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:50.900378" elapsed="0.025550"/>
</kw>
<arg>route_eth_lacp_extl2</arg>
<status status="PASS" start="2026-06-06T03:25:46.770311" elapsed="4.155680"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:46.652266" elapsed="4.273875"/>
</test>
<test id="s1-s13-t30" name="Odl_To_Play_route_eth_lacp_extmac" line="136">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:50.930396" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:50.930129" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:50.931736" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:50.931596" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:50.931573" elapsed="0.000275"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:50.938435" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:50.938326" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:50.938306" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:50.939568" 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-06-06T03:25:50.939141" elapsed="0.000458"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:50.940090" 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-06-06T03:25:50.939784" elapsed="0.000333"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:50.940163" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:25:50.940329" 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-06-06T03:25:50.938752" elapsed="0.001602"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:50.945996" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:50.945886" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:50.945866" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:50.947720" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:50.947497" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:50.947478" elapsed="0.000417"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:50.948456" 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-06-06T03:25:50.948050" elapsed="0.000468"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:50.949151" level="INFO">${current_connection_index} = 7</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-06-06T03:25:50.948886" elapsed="0.000325"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:50.978909" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:50.951072" elapsed="0.027965"/>
</kw>
<msg time="2026-06-06T03:25:50.979171" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:50.979264" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:50.949518" elapsed="0.029817"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:51.004934" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "m "a "c "[K"
[?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-06-06T03:25:50.981320" elapsed="0.023746"/>
</kw>
<msg time="2026-06-06T03:25:51.005196" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:51.005288" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:50.979759" elapsed="0.025600"/>
</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-06-06T03:25:51.006027" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.005671" elapsed="0.000469"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.005629" elapsed="0.000569"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.006937" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "m "a "c "[K"
[?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-06-06T03:25:51.006350" elapsed="0.000706"/>
</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-06-06T03:25:51.007575" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.007227" elapsed="0.000479"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.007207" elapsed="0.000558"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:51.007802" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:51.011336" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:25:51.011522" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:51.010815" elapsed="0.000783"/>
</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="NOT RUN" start="2026-06-06T03:25:51.011897" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.012146" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:51.010009" elapsed="0.002365"/>
</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-06-06T03:25:51.008103" elapsed="0.004366"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:50.946908" elapsed="0.065735"/>
</kw>
<msg time="2026-06-06T03:25:51.012762" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:51.012806" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:50.946223" elapsed="0.066620"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:51.013213" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:25:51.012933" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.012913" elapsed="0.000387"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.013851" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.014286" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:51.014360" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:50.945527" elapsed="0.068941"/>
</kw>
<msg time="2026-06-06T03:25:51.014563" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:51.014607" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:50.940762" elapsed="0.073899"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.014997" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.014739" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.014721" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:50.940593" elapsed="0.074505"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:50.940414" elapsed="0.074714"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:50.937957" elapsed="0.077224"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:50.931281" elapsed="0.083956"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:50.930835" elapsed="0.084446"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:50.927951" elapsed="0.087382"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.021939" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.022061" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:51.022168" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.015873" elapsed="0.006322"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.022402" elapsed="0.002597"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.029973" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.030080" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:51.030195" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.025170" elapsed="0.005052"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:51.033378" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:51.033083" elapsed="0.000323"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:51.033861" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:51.033564" elapsed="0.000326"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.034050" elapsed="0.000338"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.030454" elapsed="0.003995"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:51.015477" elapsed="0.019027"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:50.927228" elapsed="0.107316"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.035356" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.035514" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.035152" elapsed="0.000392"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.035911" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.036038" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.035719" elapsed="0.000347"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.036443" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/announce_route_eth_lacp_extmac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/announce_route_eth_lacp_extmac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.036569" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.036223" elapsed="0.000373"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:51.036980" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:51.036773" elapsed="0.000234"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.037356" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/withdraw_route_eth_lacp_extmac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/withdraw_route_eth_lacp_extmac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.037481" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.037167" elapsed="0.000379"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:51.037929" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:51.037724" elapsed="0.000232"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.038368" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;mac-mobility-extended-community&gt;
                &lt;static&gt;true&lt;/static&gt;
                &lt;seq-number&gt;200&lt;/seq-number&gt;
            &lt;/mac-mobility-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.038119" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.038850" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "mac-mobility-extended-community": {
                "seq-number": 200,
                "static": true
              },
              "transitive": true
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.038584" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.039301" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.039063" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.039773" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.039500" elapsed="0.000319"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:51.039970" elapsed="0.002472"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.055078" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1175', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;mac-mobility-extended-community&gt;
                &lt;static&gt;true&lt;/static&gt;
                &lt;seq-number&gt;200&lt;/seq-number&gt;
            &lt;/mac-mobility-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:51.055146" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQHyDN2An%2FcAFgAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.055248" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.042628" elapsed="0.012647"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.058854" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.055453" elapsed="0.003445"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.063565" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.064022" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '526'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:51.064129" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.059095" elapsed="0.005061"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.066805" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.064328" elapsed="0.002527"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.073635" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.074063" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '526'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:51.074161" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.067830" elapsed="0.006358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.076856" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.074362" elapsed="0.002544"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.077066" elapsed="0.002676"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:51.081993" level="INFO">${update} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:51.079910" elapsed="0.002113"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.082202" elapsed="0.002171"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:51.084428" elapsed="0.000036"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:51.067479" elapsed="0.017084"/>
</kw>
<msg time="2026-06-06T03:25:51.084685" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:51.067033" elapsed="0.017682"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.085139" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.084888" elapsed="0.000296"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.086111" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:51.086186" level="INFO">${len_1} = 174</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:51.085842" elapsed="0.000368"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.086625" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:25:51.086721" level="INFO">${len_2} = 174</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:51.086368" elapsed="0.000377"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.086905" elapsed="0.000309"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:51.087561" level="INFO">${sum_1} = 3380</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:51.087374" elapsed="0.000212"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:51.087947" level="INFO">${sum_2} = 3380</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:51.087762" elapsed="0.000210"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.088128" elapsed="0.000304"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:51.085419" elapsed="0.003074"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:51.088662" elapsed="0.002782"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.095935" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.096055" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '526'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:51.096150" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.091987" elapsed="0.004189"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.098999" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.096352" elapsed="0.002697"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.099209" elapsed="0.002538"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.107883" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.108000" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '526'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:51.108105" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.101920" elapsed="0.006211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.110763" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.108305" elapsed="0.002542"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.111015" elapsed="0.002511"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:51.115927" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:51.113609" elapsed="0.002362"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.113587" elapsed="0.002408"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.122578" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.122623" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.122743" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.116148" elapsed="0.006622"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:51.091699" elapsed="0.031139"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.128280" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.128387" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:51.128481" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.123802" elapsed="0.004704"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.131132" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.128699" elapsed="0.002481"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.131341" elapsed="0.002537"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:51.136674" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:51.134044" elapsed="0.002660"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.136883" elapsed="0.002190"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:51.139124" elapsed="0.000032"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:51.123450" elapsed="0.015803"/>
</kw>
<msg time="2026-06-06T03:25:51.139332" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:51.123012" elapsed="0.016345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.139793" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.139526" elapsed="0.000312"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.140707" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:51.140783" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:51.140429" elapsed="0.000378"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.141259" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:25:51.141333" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:51.140965" elapsed="0.000391"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.141515" elapsed="0.000348"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:51.142208" level="INFO">${sum_1} = 2933</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:51.142025" elapsed="0.000243"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:51.142614" level="INFO">${sum_2} = 2933</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:51.142428" elapsed="0.000215"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.142826" elapsed="0.000317"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:51.140067" elapsed="0.003137"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.147604" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.147733" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:51.147827" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.143777" elapsed="0.004076"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.150686" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.148031" elapsed="0.002704"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.150896" elapsed="0.002523"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.157801" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.157908" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:51.158010" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.153587" elapsed="0.004449"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.160645" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.158210" elapsed="0.002496"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.160865" elapsed="0.002536"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:51.165841" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:25:51.163477" elapsed="0.002423"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.163457" elapsed="0.002468"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.166076" elapsed="0.000022"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:51.143455" elapsed="0.022710"/>
</kw>
<arg>route_eth_lacp_extmac</arg>
<status status="PASS" start="2026-06-06T03:25:51.034836" elapsed="0.131374"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:50.926563" elapsed="0.239754"/>
</test>
<test id="s1-s13-t31" name="Play_To_Odl_route_eth_lacp_extmac" line="138">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:51.170067" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:51.169797" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:51.171399" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:51.171286" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.171266" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:51.176545" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:51.176437" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.176418" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.177668" 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-06-06T03:25:51.177245" elapsed="0.000451"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.178161" 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-06-06T03:25:51.177863" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:51.178231" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:25:51.178388" 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-06-06T03:25:51.176860" elapsed="0.001553"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:51.184291" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:51.184180" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.184161" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:51.185871" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:51.185685" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.185663" elapsed="0.000374"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:51.186609" 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-06-06T03:25:51.186193" elapsed="0.000498"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:51.187305" level="INFO">${current_connection_index} = 7</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-06-06T03:25:51.187040" elapsed="0.000326"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:51.217553" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:51.189228" elapsed="0.028528"/>
</kw>
<msg time="2026-06-06T03:25:51.217908" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:51.218002" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:51.187699" elapsed="0.030375"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:51.246723" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "m "a "c "[K"
[?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-06-06T03:25:51.220083" elapsed="0.026777"/>
</kw>
<msg time="2026-06-06T03:25:51.246991" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:51.247086" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:51.218493" elapsed="0.028665"/>
</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-06-06T03:25:51.247859" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.247462" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.247436" elapsed="0.000599"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.248780" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "c "p "_ "e "x "t "m "a "c "[K"
[?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-06-06T03:25:51.248191" elapsed="0.000709"/>
</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-06-06T03:25:51.249426" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.249076" elapsed="0.000466"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.249055" elapsed="0.000545"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:51.249718" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:51.253375" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:25:51.253566" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:51.252825" elapsed="0.000809"/>
</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="NOT RUN" start="2026-06-06T03:25:51.253872" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.254129" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:51.252028" elapsed="0.002320"/>
</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-06-06T03:25:51.250051" elapsed="0.004384"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:51.185189" elapsed="0.069426"/>
</kw>
<msg time="2026-06-06T03:25:51.254729" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:51.254775" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:51.184529" elapsed="0.070283"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:51.255036" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:25:51.254890" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.254871" elapsed="0.000260"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.255627" elapsed="0.000047"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.256118" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:51.256198" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:51.183809" elapsed="0.072506"/>
</kw>
<msg time="2026-06-06T03:25:51.256419" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:51.256466" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:51.178815" elapsed="0.077693"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.256883" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.256590" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.256571" elapsed="0.000396"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:51.178664" elapsed="0.078327"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:51.178469" elapsed="0.078558"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:51.176071" elapsed="0.081015"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:51.170993" elapsed="0.086155"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:51.170535" elapsed="0.086666"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:51.167575" elapsed="0.089686"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.263102" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.263232" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:51.263364" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.257778" elapsed="0.005613"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:51.263561" elapsed="0.003012"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.272341" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.272447" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:51.272550" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:51.266759" elapsed="0.005817"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:51.275723" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:51.275403" elapsed="0.000350"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:51.276190" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:51.275914" elapsed="0.000304"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.276379" elapsed="0.000346"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:51.272830" elapsed="0.003958"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:51.257420" elapsed="0.019424"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:51.167114" elapsed="0.109771"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.277602" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.277772" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.277398" elapsed="0.000403"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.303826" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac.vanadium/route_eth_lacp_extmac.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:51.303409" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.304634" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac.vanadium/route_eth_lacp_extmac.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:51.304378" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac.vanadium/route_eth_lacp_extmac.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:51.304826" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:51.304031" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.305413" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:51.305027" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.305759" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/route_eth_lacp_extmac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.305941" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.305607" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.306449" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "mac-mobility-extended-community": {
                "seq-number": 200,
                "static": true
              },
              "transitive": true
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.306183" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:51.306936" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:51.306583" elapsed="0.000413"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.307463" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:51.307171" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:51.307022" elapsed="0.000502"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:51.306563" elapsed="0.000982"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.308172" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:51.307715" elapsed="0.000486"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:51.308252" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:25:51.308406" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:51.300869" elapsed="0.007564"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.308818" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/announce_route_eth_lacp_extmac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/announce_route_eth_lacp_extmac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.308944" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.308605" elapsed="0.000366"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:51.309421" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/withdraw_route_eth_lacp_extmac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lacp_extmac/withdraw_route_eth_lacp_extmac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:51.309542" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:51.309230" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.309993" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;mac-mobility-extended-community&gt;
                &lt;static&gt;true&lt;/static&gt;
                &lt;seq-number&gt;200&lt;/seq-number&gt;
            &lt;/mac-mobility-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.309745" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.310486" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "mac-mobility-extended-community": {
                "seq-number": 200,
                "static": true
              },
              "transitive": true
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.310211" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.310988" level="INFO">ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.310742" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:51.311427" level="INFO">ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:51.311188" elapsed="0.000283"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:51.311622" elapsed="0.003335"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:51.315117" elapsed="0.001815"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:51.322577" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:51.322756" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:51.322888" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:51.317903" elapsed="0.005478">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.323668" elapsed="0.000034"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:51.324004" elapsed="0.000033"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:51.317549" elapsed="0.006767">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:53.334451" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:53.334750" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '526'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:53.334952" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:53.325954" elapsed="0.009042"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:53.335693" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "extended-communities": [
            {
              "mac-mobility-extended-community": {
                "seq-number": 200,
                "static": true
              },
              "transitive": true
            }
          ],
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:53.338954" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:53.335259" elapsed="0.003836"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:53.344010" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "mac-mobility-extended-community": {
        "seq-number": 200,
        "stati...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:53.343106" elapsed="0.000945"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:53.345150" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "mac-mobility-extended-community": {
        "seq-number": 200,
        "stati...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:53.344455" elapsed="0.000728"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:53.345348" elapsed="0.000351"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:53.339424" elapsed="0.006339"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:53.325019" elapsed="0.020799"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:51.317125" elapsed="2.028741"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:53.346027" elapsed="0.002524"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:53.355443" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:53.355595" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:53.355754" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:53.349471" elapsed="0.006320"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:53.356028" elapsed="0.003913"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:53.364533" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:53.365266" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '674'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"extended-communities":[{"mac-mobility-extended-community":{"seq-number":200,"static":true},"transitive":true}],"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:53.365415" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:53.360176" elapsed="0.005276"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:53.369770" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:53.369350" elapsed="0.000460"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:53.370805" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:53.370038" elapsed="0.000808"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:53.371509" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "mac-mobility-extended-community": {
          "seq-number": 200,
          "static": true
         },
         "transitive": true
        }
       ],
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:53.371919" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "mac-mobility-extended-community": {
+          "seq-number": 200,
+          "static": true
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:53.371069" elapsed="0.000966">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "mac-mobility-extended-community": {
+          "seq-number": 200,
+          "static": true
+         },
+         "transitive": true
+        }
+       ],
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:53.365792" elapsed="0.006474">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "mac-mobility-extended-community": {
+          "seq-number": 200,
+          "static": true
+         },
+         "transitive": true
+        }
+       ],
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:53.349193" elapsed="0.023319">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,45 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "mac-mobility-extended-community": {
+          "seq-number": 200,
+          "static": true
+         },
+         "transitive": true
+        }
+       ],
    [ Message content over the limit has been removed. ]
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQHyDN2An/cAFgAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.383137" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.383330" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.383480" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.374007" elapsed="0.009511"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.383825" elapsed="0.003798"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.393150" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.393302" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:55.393446" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.387887" elapsed="0.005597"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.398028" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.397582" elapsed="0.000491"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.398726" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.398300" elapsed="0.000466"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.398995" elapsed="0.000465"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.393925" elapsed="0.005622"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.373179" elapsed="0.026448"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:53.348768" elapsed="2.050942"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:55.400475" elapsed="0.002262"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.407854" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.407963" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.408067" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.403923" elapsed="0.004171"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.408263" elapsed="0.002572"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.415913" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.416059" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:55.416200" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.411004" elapsed="0.005234"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.420805" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.420356" elapsed="0.000490"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.421446" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.421070" elapsed="0.000414"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.421731" elapsed="0.000575"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.416556" elapsed="0.005841"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.403362" elapsed="0.019112"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:55.402935" elapsed="0.019596"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:25:55.399978" elapsed="0.022630"/>
</kw>
<arg>route_eth_lacp_extmac</arg>
<status status="PASS" start="2026-06-06T03:25:51.277098" elapsed="4.145710"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:51.166624" elapsed="4.256342"/>
</test>
<test id="s1-s13-t32" name="Odl_To_Play_route_eth_lan" line="141">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:55.428390" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:55.428119" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:55.429740" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.429594" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.429568" elapsed="0.000251"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:55.434844" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.434711" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.434693" elapsed="0.000221"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.435942" 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-06-06T03:25:55.435529" elapsed="0.000440"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.436434" 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-06-06T03:25:55.436134" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:55.436504" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:25:55.436685" 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-06-06T03:25:55.435146" elapsed="0.001565"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:55.442556" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.442445" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.442426" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:55.444264" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.444063" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.444040" elapsed="0.000434"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:55.445079" 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-06-06T03:25:55.444634" elapsed="0.000506"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:55.445781" level="INFO">${current_connection_index} = 7</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-06-06T03:25:55.445491" elapsed="0.000351"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:55.481045" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:55.447916" elapsed="0.033320"/>
</kw>
<msg time="2026-06-06T03:25:55.481410" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:55.481507" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:55.446156" elapsed="0.035423"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:55.511006" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "n "[K"
[?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-06-06T03:25:55.483792" elapsed="0.027378"/>
</kw>
<msg time="2026-06-06T03:25:55.511305" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:55.511400" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:25:55.482075" elapsed="0.029397"/>
</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-06-06T03:25:55.512213" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.511815" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.511785" elapsed="0.000607"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.513159" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "n "[K"
[?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-06-06T03:25:55.512549" elapsed="0.000802"/>
</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-06-06T03:25:55.513908" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.513531" elapsed="0.000491"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.513510" elapsed="0.000570"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:55.514122" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:55.517888" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:25:55.518078" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:55.517296" elapsed="0.000859"/>
</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="NOT RUN" start="2026-06-06T03:25:55.518377" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.518593" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:55.516482" elapsed="0.002347"/>
</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-06-06T03:25:55.514465" elapsed="0.004451"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:55.443548" elapsed="0.075567"/>
</kw>
<msg time="2026-06-06T03:25:55.519213" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:55.519257" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:55.442875" elapsed="0.076419"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:55.519482" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:25:55.519373" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.519353" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.520055" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.520483" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:55.520556" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:55.442100" elapsed="0.078700"/>
</kw>
<msg time="2026-06-06T03:25:55.520901" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:55.520946" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:55.437099" elapsed="0.083883"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.521319" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.521061" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.521042" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:55.436954" elapsed="0.084466"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:55.436769" elapsed="0.084685"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:55.434332" elapsed="0.087179"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:55.429289" elapsed="0.092280"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:55.428837" elapsed="0.092780"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:55.425432" elapsed="0.096258"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.528505" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.528722" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.528838" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.522125" elapsed="0.006741"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.529042" elapsed="0.002633"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.536198" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.536303" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:55.536406" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.531848" elapsed="0.004585"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.539569" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.539258" elapsed="0.000340"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.540047" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.539775" elapsed="0.000300"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.540236" elapsed="0.000325"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.536692" elapsed="0.003930"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.521845" elapsed="0.018849"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:55.424413" elapsed="0.116323"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.541516" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.541711" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.541312" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.542099" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.542227" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.541905" elapsed="0.000350"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.542606" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/announce_route_eth_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/announce_route_eth_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.542750" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.542414" elapsed="0.000363"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:55.543149" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:55.542939" elapsed="0.000240"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.543589" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/withdraw_route_eth_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/withdraw_route_eth_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.543734" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.543395" elapsed="0.000365"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:25:55.544121" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:25:55.543920" elapsed="0.000227"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.544559" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.544309" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.545033" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.544791" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.545476" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.545239" elapsed="0.000281"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.545931" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.545694" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:55.546126" elapsed="0.002543"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.558757" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '908', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:25:55.558819" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQLyDN2An%2FcAFAAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.558911" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.548873" elapsed="0.010064"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.563155" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.559113" elapsed="0.004086"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.569702" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.570119" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '421'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:55.570225" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.563394" elapsed="0.006857"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.572910" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.570424" elapsed="0.002535"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.579132" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.579768" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '421'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:55.579908" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.573927" elapsed="0.006009"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.582773" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.580163" elapsed="0.002660"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.582985" elapsed="0.002532"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:55.587923" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.585704" elapsed="0.002248"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.588135" elapsed="0.002155"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:55.590345" elapsed="0.000042"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:55.573577" elapsed="0.016919"/>
</kw>
<msg time="2026-06-06T03:25:55.590578" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:55.573131" elapsed="0.017472"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.591040" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.590792" elapsed="0.000294"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.592050" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:55.592131" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:55.591776" elapsed="0.000378"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.592570" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:25:55.592663" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:55.592312" elapsed="0.000377"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.592852" elapsed="0.000313"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:55.593511" level="INFO">${sum_1} = 2934</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:55.593326" elapsed="0.000210"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:55.593961" level="INFO">${sum_2} = 2934</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:55.593772" elapsed="0.000215"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.594145" elapsed="0.000309"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:55.591343" elapsed="0.003180"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:55.594696" elapsed="0.002111"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.603627" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.603788" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '421'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:55.603898" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.597335" elapsed="0.006591"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.606771" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.604104" elapsed="0.002717"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.606978" elapsed="0.002507"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.613976" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.614092" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '421'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:55.614196" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.609666" elapsed="0.004557"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.616835" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.614398" elapsed="0.002486"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.617043" elapsed="0.002503"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:25:55.621949" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.619634" elapsed="0.002362"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.619609" elapsed="0.002412"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.629113" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.629225" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.629343" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.622173" elapsed="0.007197"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:55.597056" elapsed="0.032391"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.635823" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.635940" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.636033" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.630535" elapsed="0.005524"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.638719" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.636235" elapsed="0.002533"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.638926" elapsed="0.002526"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:55.643825" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.641619" elapsed="0.002236"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.644035" elapsed="0.002163"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:25:55.646253" elapsed="0.000042"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:25:55.630186" elapsed="0.016208"/>
</kw>
<msg time="2026-06-06T03:25:55.646474" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:55.629645" elapsed="0.016855"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.646939" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.646686" elapsed="0.000299"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.647886" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:55.647963" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:55.647586" elapsed="0.000401"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.648398" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:25:55.648472" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:25:55.648146" elapsed="0.000350"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.648669" elapsed="0.000307"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:55.649311" level="INFO">${sum_1} = 2487</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:55.649134" elapsed="0.000202"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:25:55.649687" level="INFO">${sum_2} = 2487</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:25:55.649492" elapsed="0.000222"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.649871" elapsed="0.000307"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:25:55.647220" elapsed="0.003017"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.656403" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.656804" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.657031" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.650819" elapsed="0.006272"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.664332" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.657498" elapsed="0.006895"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.664567" elapsed="0.003263"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.672897" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.673067" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.673260" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.668007" elapsed="0.005334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.678382" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.673640" elapsed="0.004814"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.678738" elapsed="0.002988"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:25:55.684205" elapsed="0.000045"/>
</return>
<status status="PASS" start="2026-06-06T03:25:55.681818" elapsed="0.002465"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.681792" elapsed="0.002518"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.684474" elapsed="0.000022"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:25:55.650499" elapsed="0.034071"/>
</kw>
<arg>route_eth_lan</arg>
<status status="PASS" start="2026-06-06T03:25:55.541006" elapsed="0.143613"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.423704" elapsed="0.261154"/>
</test>
<test id="s1-s13-t33" name="Play_To_Odl_route_eth_lan" line="143">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:25:55.689384" elapsed="0.000372"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:25:55.689115" elapsed="0.000746"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:55.691324" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.691210" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.691189" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:25:55.697215" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.697108" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.697090" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.698364" 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-06-06T03:25:55.697954" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.698868" 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-06-06T03:25:55.698555" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:25:55.698938" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:25:55.699104" 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-06-06T03:25:55.697528" elapsed="0.001619"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:25:55.705485" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.705375" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.705355" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:25:55.707037" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:25:55.706853" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.706834" elapsed="0.000367"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:25:55.707789" 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-06-06T03:25:55.707358" elapsed="0.000493"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:25:55.708500" level="INFO">${current_connection_index} = 7</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-06-06T03:25:55.708231" elapsed="0.000330"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:25:55.742013" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:25:55.710433" elapsed="0.031713"/>
</kw>
<msg time="2026-06-06T03:25:55.742283" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:25:55.742379" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:25:55.708895" elapsed="0.033555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:25:55.768872" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "n "[K"
[?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-06-06T03:25:55.744459" elapsed="0.024548"/>
</kw>
<msg time="2026-06-06T03:25:55.769146" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:25:55.769239" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:25:55.742886" elapsed="0.026423"/>
</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-06-06T03:25:55.770000" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.769608" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.769586" elapsed="0.000589"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.770920" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "l "a "n "[K"
[?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-06-06T03:25:55.770329" elapsed="0.000704"/>
</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-06-06T03:25:55.771562" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.771210" elapsed="0.000488"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.771189" elapsed="0.000568"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:25:55.771794" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:25:55.775395" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:25:55.775580" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:25:55.774864" elapsed="0.000800"/>
</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="NOT RUN" start="2026-06-06T03:25:55.775884" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.776102" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:25:55.774059" elapsed="0.002300"/>
</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-06-06T03:25:55.772077" elapsed="0.004367"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:25:55.706384" elapsed="0.070235"/>
</kw>
<msg time="2026-06-06T03:25:55.776732" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:55.776777" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:55.705734" elapsed="0.071080"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:25:55.777042" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:25:55.776932" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.776912" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.777592" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.778100" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:25:55.778174" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:25:55.705024" elapsed="0.073258"/>
</kw>
<msg time="2026-06-06T03:25:55.778377" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:25:55.778421" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:25:55.699693" elapsed="0.078763"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.778808" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.778533" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.778515" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:25:55.699529" elapsed="0.079381"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:25:55.699305" elapsed="0.079636"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:25:55.696724" elapsed="0.082273"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:25:55.690824" elapsed="0.088229"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:25:55.690204" elapsed="0.088895"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:25:55.686427" elapsed="0.092725"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.785338" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.785510" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.785639" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.779577" elapsed="0.006114"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:55.785915" elapsed="0.003183"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.794337" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.794441" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:25:55.794543" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:55.789269" elapsed="0.005301"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.797824" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.797495" elapsed="0.000357"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:55.798284" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:55.798012" elapsed="0.000300"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.798470" elapsed="0.000347"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:55.794903" elapsed="0.003976"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.779302" elapsed="0.019632"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:25:55.685715" elapsed="0.113260"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.799725" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.799892" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.799499" elapsed="0.000423"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.825858" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lan.vanadium/route_eth_lan.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:55.825454" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.826702" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan.vanadium/route_eth_lan.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:25:55.826421" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan.vanadium/route_eth_lan.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:25:55.826876" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:25:55.826060" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.827467" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:25:55.827076" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.827814" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/route_eth_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.827949" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.827677" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.828384" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.828140" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:25:55.828900" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:25:55.828541" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.829434" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:25:55.829142" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.828988" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:25:55.828516" elapsed="0.001000"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.830136" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:25:55.829686" elapsed="0.000533"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:25:55.830276" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:25:55.830441" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:25:55.823122" elapsed="0.007346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.830849" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/announce_route_eth_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/announce_route_eth_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.831088" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.830634" elapsed="0.000482"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:25:55.831472" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/withdraw_route_eth_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_lan/withdraw_route_eth_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:25:55.831594" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:25:55.831278" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.832051" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.831804" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.832553" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.832262" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.833226" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.832876" elapsed="0.000400"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:25:55.833698" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:25:55.833435" elapsed="0.000308"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:25:55.833899" elapsed="0.002952"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:55.837012" elapsed="0.002428"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:55.847295" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:55.847476" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:55.847619" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:25:55.840941" elapsed="0.007280">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.848515" elapsed="0.000034"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:25:55.848883" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:25:55.840367" elapsed="0.008689">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:58.454048" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:58.454371" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '421'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:25:58.454634" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:57.850773" elapsed="0.603958"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:25:58.455873" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:25:58.461058" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:25:58.455195" elapsed="0.005973"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:58.465070" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:58.464570" elapsed="0.000530"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:58.465715" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:58.465278" elapsed="0.000466"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:25:58.465908" elapsed="0.000331"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:25:58.461767" elapsed="0.004535"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:25:57.849791" elapsed="0.616567"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:55.839708" elapsed="2.626701"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:25:58.466572" elapsed="0.003122"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:58.477764" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:58.477946" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:25:58.478171" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:58.470885" elapsed="0.007326"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:25:58.478468" elapsed="0.004289"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:25:58.488846" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:25:58.489555" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '569'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:25:58.489737" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:25:58.483008" elapsed="0.006770"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:58.494416" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:58.493983" elapsed="0.000475"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:25:58.495430" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:25:58.494716" elapsed="0.000757"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:25:58.496217" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "lan-auto-generated": {
        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
        "root-bridge-priority": 20
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:25:58.496523" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:25:58.495734" elapsed="0.000900">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:25:58.490129" elapsed="0.006742">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:25:58.470444" elapsed="0.026682">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQLyDN2An/cAFAAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.507596" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.507836" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.508003" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.498722" elapsed="0.009322"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.508345" elapsed="0.004011"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.519759" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.519899" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:00.520027" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.512621" elapsed="0.007433"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.523349" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.523029" elapsed="0.000349"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.523882" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.523539" elapsed="0.000372"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.524076" elapsed="0.000368"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.520334" elapsed="0.004171"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.497862" elapsed="0.026700"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:25:58.469876" elapsed="2.054728"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:00.525170" elapsed="0.002964"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.535142" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.535321" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.535543" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.529912" elapsed="0.005672"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.535869" elapsed="0.003907"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.545098" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.545219" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:00.545328" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.540029" elapsed="0.005327"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.548602" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.548296" elapsed="0.000335"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.549083" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.548807" elapsed="0.000305"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.549282" elapsed="0.000347"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.545613" elapsed="0.004098"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.529090" elapsed="0.020678"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:00.528426" elapsed="0.021384"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:00.524814" elapsed="0.025055"/>
</kw>
<arg>route_eth_lan</arg>
<status status="PASS" start="2026-06-06T03:25:55.799194" elapsed="4.750726"/>
</kw>
<status status="PASS" start="2026-06-06T03:25:55.685211" elapsed="4.864821"/>
</test>
<test id="s1-s13-t34" name="Odl_To_Play_route_eth_mac" line="146">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:00.555180" elapsed="0.000311"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:00.554786" elapsed="0.000786"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:00.557117" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.556935" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.556902" elapsed="0.000321"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:00.563136" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.563001" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.562977" elapsed="0.000241"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.564361" 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-06-06T03:26:00.563922" elapsed="0.000467"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.564885" 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-06-06T03:26:00.564559" elapsed="0.000352"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:00.564957" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:26:00.565125" 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-06-06T03:26:00.563497" elapsed="0.001654"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:00.571567" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.571419" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.571392" elapsed="0.000280"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:00.573492" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.573288" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.573266" elapsed="0.000416"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:00.574351" 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-06-06T03:26:00.573858" elapsed="0.000557"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:00.575073" level="INFO">${current_connection_index} = 7</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-06-06T03:26:00.574801" elapsed="0.000332"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:00.608262" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:00.577059" elapsed="0.031449"/>
</kw>
<msg time="2026-06-06T03:26:00.608746" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:00.608847" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:00.575452" elapsed="0.033470"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:00.638224" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "m "a "c "[K"
[?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-06-06T03:26:00.611101" elapsed="0.027304"/>
</kw>
<msg time="2026-06-06T03:26:00.638557" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:00.638679" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:00.609405" elapsed="0.029351"/>
</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-06-06T03:26:00.639513" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.639089" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.639057" elapsed="0.000655"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.640483" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "m "a "c "[K"
[?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-06-06T03:26:00.639872" elapsed="0.000734"/>
</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-06-06T03:26:00.641160" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.640802" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.640780" elapsed="0.000556"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:00.641379" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:00.645196" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:26:00.645390" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:00.644545" elapsed="0.000915"/>
</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="NOT RUN" start="2026-06-06T03:26:00.645695" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.645918" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:00.643749" elapsed="0.002388"/>
</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-06-06T03:26:00.641737" elapsed="0.004487"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:00.572815" elapsed="0.073622"/>
</kw>
<msg time="2026-06-06T03:26:00.646538" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:00.646584" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:00.571881" elapsed="0.074744"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:00.646833" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:00.646723" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.646703" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.647394" elapsed="0.000081"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.647904" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:00.647979" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:00.570941" elapsed="0.077151"/>
</kw>
<msg time="2026-06-06T03:26:00.648188" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:00.648233" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:00.565556" elapsed="0.082716"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.648609" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.648349" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.648331" elapsed="0.000384"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:00.565403" elapsed="0.083337"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:00.565213" elapsed="0.083560"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:00.562515" elapsed="0.086315"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:00.556473" elapsed="0.092416"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:00.555825" elapsed="0.093111"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:00.551472" elapsed="0.097520"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.655505" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.655718" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.655883" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.649423" elapsed="0.006500"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.656180" elapsed="0.004140"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.666571" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.666700" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:00.666805" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.660570" elapsed="0.006262"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.670069" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.669761" elapsed="0.000337"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.670552" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.670257" elapsed="0.000364"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.670801" elapsed="0.000327"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.667069" elapsed="0.004121"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.649143" elapsed="0.022108"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:00.550889" elapsed="0.120424"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.672462" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.672738" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.672162" elapsed="0.000621"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.673303" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.673488" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.673020" elapsed="0.000507"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.674171" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/announce_route_eth_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/announce_route_eth_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.674373" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.673783" elapsed="0.000629"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:00.674975" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:00.674668" elapsed="0.000348"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.675535" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/withdraw_route_eth_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/withdraw_route_eth_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.675740" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.675257" elapsed="0.000523"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:00.676305" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:00.676013" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.676975" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.676581" elapsed="0.000477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.677664" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.677291" elapsed="0.000448"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.678411" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.678015" elapsed="0.000464"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.679093" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.678735" elapsed="0.000424"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:00.679331" elapsed="0.002287"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.694243" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '898', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:00.694381" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQPyDN2An%2FcAB9AAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.694528" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.681860" elapsed="0.012705"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.700713" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.694860" elapsed="0.005953"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.707128" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.707522" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '417'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:00.707627" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.701174" elapsed="0.006499"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.710284" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.707848" elapsed="0.002485"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.717323" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.717866" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '417'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:00.718071" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.711469" elapsed="0.006641"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.722014" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.718367" elapsed="0.003721"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.722324" elapsed="0.003760"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:00.729033" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.726330" elapsed="0.002732"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.729246" elapsed="0.002164"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:00.731467" elapsed="0.000038"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:00.711034" elapsed="0.020575"/>
</kw>
<msg time="2026-06-06T03:26:00.731709" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:00.710540" elapsed="0.021196"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.732162" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.731909" elapsed="0.000299"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.733105" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:26:00.733181" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:00.732843" elapsed="0.000362"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.733618" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:26:00.733711" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:00.733364" elapsed="0.000372"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.733895" elapsed="0.000310"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:00.734580" level="INFO">${sum_1} = 3130</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:00.734366" elapsed="0.000240"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:00.734962" level="INFO">${sum_2} = 3130</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:00.734782" elapsed="0.000206"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.735145" elapsed="0.000392"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:00.732448" elapsed="0.003177"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:00.735876" elapsed="0.002211"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.744449" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.744625" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '417'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:00.744793" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.738899" elapsed="0.005933"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.748981" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.745087" elapsed="0.004105"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.749437" elapsed="0.003745"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.758696" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.758865" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '417'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:00.759015" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.753430" elapsed="0.005623"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.762905" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.759310" elapsed="0.003667"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.763213" elapsed="0.003742"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:00.769405" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.767075" elapsed="0.002373"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.767043" elapsed="0.002429"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.777020" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.777068" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.777173" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.769625" elapsed="0.007576"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:00.738455" elapsed="0.038815"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.785627" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.785903" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.786108" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.778288" elapsed="0.007877"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.791828" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.786571" elapsed="0.005328"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.792134" elapsed="0.003741"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:00.798799" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.796118" elapsed="0.002751"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.799109" elapsed="0.003209"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:00.802394" elapsed="0.000048"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:00.777943" elapsed="0.024659"/>
</kw>
<msg time="2026-06-06T03:26:00.802742" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:00.777445" elapsed="0.025335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.803397" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.803031" elapsed="0.000434"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.804797" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:26:00.804909" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:00.804389" elapsed="0.000557"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.805559" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:26:00.805690" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:00.805181" elapsed="0.000546"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.805964" elapsed="0.000453"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:00.806974" level="INFO">${sum_1} = 2683</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:00.806705" elapsed="0.000307"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:00.807423" level="INFO">${sum_2} = 2683</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:00.807243" elapsed="0.000205"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.807604" elapsed="0.000321"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:00.803838" elapsed="0.004149"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.813788" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.813900" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.813994" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.808543" elapsed="0.005477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.819528" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.814192" elapsed="0.005409"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.819871" elapsed="0.003649"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.827963" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.828074" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.828218" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.823705" elapsed="0.004540"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.830902" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.828420" elapsed="0.002531"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.831110" elapsed="0.003732"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:00.838432" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:26:00.834959" elapsed="0.003564"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.834928" elapsed="0.003633"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.838839" elapsed="0.000033"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:00.808241" elapsed="0.030731"/>
</kw>
<arg>route_eth_mac</arg>
<status status="PASS" start="2026-06-06T03:26:00.671721" elapsed="0.167316"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.550396" elapsed="0.288796"/>
</test>
<test id="s1-s13-t35" name="Play_To_Odl_route_eth_mac" line="148">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:00.843089" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:00.842818" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:00.844362" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.844248" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.844227" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:00.849469" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.849361" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.849342" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.850555" 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-06-06T03:26:00.850171" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.851075" 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-06-06T03:26:00.850775" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:00.851145" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:26:00.851300" 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-06-06T03:26:00.849788" elapsed="0.001538"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:00.857225" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.857116" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.857096" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:00.858782" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:00.858562" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.858542" elapsed="0.000408"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:00.859526" 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-06-06T03:26:00.859106" elapsed="0.000484"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:00.860236" level="INFO">${current_connection_index} = 7</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-06-06T03:26:00.859965" elapsed="0.000332"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:00.892022" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:00.862273" elapsed="0.029949"/>
</kw>
<msg time="2026-06-06T03:26:00.892398" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:00.892497" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:00.860613" elapsed="0.031957"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:00.919232" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "m "a "c "[K"
[?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-06-06T03:26:00.894721" elapsed="0.024651"/>
</kw>
<msg time="2026-06-06T03:26:00.919507" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:00.919604" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:00.893063" elapsed="0.026642"/>
</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-06-06T03:26:00.920419" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.920025" elapsed="0.000511"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.919997" elapsed="0.000602"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.921354" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "m "a "c "[K"
[?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-06-06T03:26:00.920771" elapsed="0.000700"/>
</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-06-06T03:26:00.922020" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.921662" elapsed="0.000477"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.921627" elapsed="0.000571"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:00.922241" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:00.925960" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:26:00.926150" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:00.925375" elapsed="0.000844"/>
</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="NOT RUN" start="2026-06-06T03:26:00.926436" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.926672" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:00.924589" elapsed="0.002329"/>
</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-06-06T03:26:00.922565" elapsed="0.004443"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:00.858118" elapsed="0.069068"/>
</kw>
<msg time="2026-06-06T03:26:00.927287" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:00.927332" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:00.857453" elapsed="0.069916"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:00.927558" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:00.927448" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.927429" elapsed="0.000231"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.928137" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.928570" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:00.928658" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:00.856773" elapsed="0.072000"/>
</kw>
<msg time="2026-06-06T03:26:00.928872" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:00.928917" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:00.851717" elapsed="0.077236"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:00.929290" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.929032" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.929013" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:00.851555" elapsed="0.077837"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:00.851382" elapsed="0.078080"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:00.848991" elapsed="0.080534"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:00.843958" elapsed="0.085628"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:00.843510" elapsed="0.086124"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:00.840594" elapsed="0.089127"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.935864" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.936046" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.936186" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.930157" elapsed="0.006066"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:00.936467" elapsed="0.004377"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.946136" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.946254" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:00.946358" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:00.941084" elapsed="0.005301"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.949566" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.949248" elapsed="0.000347"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:00.950047" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:00.949772" elapsed="0.000302"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.950237" elapsed="0.000329"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:00.946627" elapsed="0.004001"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.929874" elapsed="0.020829"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:00.840114" elapsed="0.110632"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.951614" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.951852" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.951330" elapsed="0.000562"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.980173" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_mac.vanadium/route_eth_mac.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:00.979791" elapsed="0.000461"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.981053" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac.vanadium/route_eth_mac.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:00.980803" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac.vanadium/route_eth_mac.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:00.981230" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:00.980430" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.981837" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:00.981427" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.982167" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/route_eth_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.982297" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.982031" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.982751" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.982487" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:00.983230" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:00.982878" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.983780" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:00.983466" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.983316" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:00.982854" elapsed="0.001011"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.984464" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:00.984019" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:00.984545" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:26:00.984721" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:00.977441" elapsed="0.007307"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.985111" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/announce_route_eth_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/announce_route_eth_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.985236" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.984916" elapsed="0.000347"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:00.985614" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/withdraw_route_eth_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_mac/withdraw_route_eth_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:00.985753" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:00.985423" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.986189" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.985943" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.986719" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.986438" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.987213" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.986968" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:00.987719" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:00.987421" elapsed="0.000347"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:00.987926" elapsed="0.002744"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:00.990850" elapsed="0.002269"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:00.999289" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:00.999460" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:00.999594" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:00.994469" elapsed="0.005648">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:01.000536" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:01.000890" elapsed="0.000035"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:00.994006" elapsed="0.007058">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:03.012533" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:03.012771" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '417'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:03.012923" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:03.002823" elapsed="0.010137"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:03.013630" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:03.017054" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:03.013223" elapsed="0.003901"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:03.022205" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:03.021483" elapsed="0.000763"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:03.023100" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:03.022482" elapsed="0.000657"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:03.023373" elapsed="0.000500"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:03.017462" elapsed="0.006502"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:03.001804" elapsed="0.022238"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:00.993367" elapsed="2.030742"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:03.024335" elapsed="0.003352"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:03.034061" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:03.034228" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:03.034365" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:03.028983" elapsed="0.005419"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:03.034667" elapsed="0.004016"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:03.044162" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:03.044819" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '565'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:03.044971" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:03.038921" elapsed="0.006087"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:03.049362" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:03.048965" elapsed="0.000438"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:03.050359" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:03.049627" elapsed="0.000772"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:03.051143" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "mac-auto-generated": {
        "local-discriminator": 2000,
        "system-mac-address": "f2:0c:dd:80:9f:f7"
       },
       "mpls-label": 24001
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:03.051433" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:03.050699" elapsed="0.000841">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:03.045327" elapsed="0.006433">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:03.028558" elapsed="0.023380">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label": 24001
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQPyDN2An/cAB9AAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.063954" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.064255" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.064447" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.053453" elapsed="0.011034"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.064805" elapsed="0.003986"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.076080" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.076290" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:05.076536" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.069052" elapsed="0.007525"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.081382" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.080930" elapsed="0.000494"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.082088" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.081681" elapsed="0.000448"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.082373" elapsed="0.000540"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.076976" elapsed="0.006029"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.052621" elapsed="0.030466"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:03.027966" elapsed="2.055181"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:05.083977" elapsed="0.003344"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.095406" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.095594" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.095784" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.089144" elapsed="0.006680"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.096086" elapsed="0.003948"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.107688" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.107869" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:05.108033" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.100305" elapsed="0.007768"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.112948" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.112480" elapsed="0.000511"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.113639" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.113228" elapsed="0.000474"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.113946" elapsed="0.000516"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.108473" elapsed="0.006185"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.088305" elapsed="0.026442"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:05.087608" elapsed="0.027201"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:05.083429" elapsed="0.031465"/>
</kw>
<arg>route_eth_mac</arg>
<status status="PASS" start="2026-06-06T03:26:00.950995" elapsed="4.163975"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:00.839628" elapsed="4.275501"/>
</test>
<test id="s1-s13-t36" name="Odl_To_Play_route_eth_rou" line="151">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:05.119499" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:05.119227" elapsed="0.000558"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:05.120864" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.120731" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.120707" elapsed="0.000231"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:05.125949" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.125839" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.125820" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.127053" 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-06-06T03:26:05.126657" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.127548" 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-06-06T03:26:05.127247" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:05.127619" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:26:05.127800" 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-06-06T03:26:05.126252" elapsed="0.001574"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:05.133743" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.133616" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.133597" elapsed="0.000216"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:05.135401" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.135210" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.135191" elapsed="0.000376"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:05.136166" 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-06-06T03:26:05.135747" elapsed="0.000520"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:05.136914" level="INFO">${current_connection_index} = 7</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-06-06T03:26:05.136631" elapsed="0.000343"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:05.174072" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:05.138828" elapsed="0.035474"/>
</kw>
<msg time="2026-06-06T03:26:05.174489" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:05.174588" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:05.137288" elapsed="0.037403"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:05.204990" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "r "o "u "[K"
[?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-06-06T03:26:05.176867" elapsed="0.028362"/>
</kw>
<msg time="2026-06-06T03:26:05.205418" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:05.205515" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:05.175164" elapsed="0.030425"/>
</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-06-06T03:26:05.206403" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.205948" elapsed="0.000653"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.205912" elapsed="0.000774"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.207485" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "e "t "h "_ "r "o "u "[K"
[?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-06-06T03:26:05.206847" elapsed="0.000757"/>
</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-06-06T03:26:05.208155" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.207798" elapsed="0.000506"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.207777" elapsed="0.000588"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:05.208407" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:05.212176" elapsed="0.000174"/>
</kw>
<msg time="2026-06-06T03:26:05.212394" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:05.211692" elapsed="0.000772"/>
</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="NOT RUN" start="2026-06-06T03:26:05.212698" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.212916" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:05.210870" elapsed="0.002260"/>
</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-06-06T03:26:05.208762" elapsed="0.004453"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:05.134751" elapsed="0.078641"/>
</kw>
<msg time="2026-06-06T03:26:05.213492" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:05.213537" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:05.133972" elapsed="0.079605"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:05.213869" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:05.213750" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.213635" elapsed="0.000322"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.214441" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.214886" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:05.214959" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:05.133272" elapsed="0.081799"/>
</kw>
<msg time="2026-06-06T03:26:05.215168" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:05.215214" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:05.128237" elapsed="0.087015"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.215587" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.215329" elapsed="0.000404"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.215311" elapsed="0.000448"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:05.128059" elapsed="0.087725"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:05.127884" elapsed="0.087934"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:05.125458" elapsed="0.090418"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:05.120413" elapsed="0.095523"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:05.119944" elapsed="0.096039"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:05.116851" elapsed="0.099189"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.222671" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.222816" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.222940" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.216573" elapsed="0.006395"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.223154" elapsed="0.002966"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.232181" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.232393" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:05.232552" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.226373" elapsed="0.006219"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.237738" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.237269" elapsed="0.000512"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.238420" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.238021" elapsed="0.000441"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.238723" elapsed="0.000533"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.232996" elapsed="0.006353"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.216244" elapsed="0.023187"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:05.116061" elapsed="0.123433"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.240711" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.240966" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.240392" elapsed="0.000617"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.241528" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.241735" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.241247" elapsed="0.000529"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.242292" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/announce_route_eth_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/announce_route_eth_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.242476" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.242012" elapsed="0.000572"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:05.243167" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:05.242853" elapsed="0.000355"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.243758" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/withdraw_route_eth_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/withdraw_route_eth_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.243945" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.243455" elapsed="0.000529"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:05.244560" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:05.244218" elapsed="0.000382"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.245238" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.244867" elapsed="0.000453"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.245745" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.245491" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.246190" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.245950" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.246635" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.246396" elapsed="0.000322"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:05.246881" elapsed="0.003230"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.261030" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '876', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:05.261136" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.261298" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.250279" elapsed="0.011058"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.268169" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.261880" elapsed="0.006385"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.274365" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.274783" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '403'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:05.274902" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.268722" elapsed="0.006208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.277834" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.275115" elapsed="0.002792"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.285592" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.286159" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '403'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:05.286310" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.279386" elapsed="0.006964"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.290400" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.286623" elapsed="0.003852"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.290736" elapsed="0.003785"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:05.297310" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.294791" elapsed="0.002549"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.297523" elapsed="0.002181"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:05.299763" elapsed="0.000041"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:05.278874" elapsed="0.021040"/>
</kw>
<msg time="2026-06-06T03:26:05.300000" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:05.278167" elapsed="0.021859"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.300486" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.300202" elapsed="0.000330"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.301473" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:26:05.301549" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:05.301200" elapsed="0.000373"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.302074" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:26:05.302152" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:05.301812" elapsed="0.000364"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.302339" elapsed="0.000336"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:05.303029" level="INFO">${sum_1} = 2294</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:05.302841" elapsed="0.000214"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:05.303395" level="INFO">${sum_2} = 2294</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:05.303212" elapsed="0.000209"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.303578" elapsed="0.000326"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:05.300809" elapsed="0.003172"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:05.304135" elapsed="0.002128"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.314581" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.314837" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '403'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:05.315012" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.307085" elapsed="0.007969"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.319545" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.315371" elapsed="0.004252"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.319901" elapsed="0.003819"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.328278" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.328457" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '403'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:05.328582" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.323977" elapsed="0.004633"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.331385" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","path-id":0,"ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.328835" elapsed="0.002601"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.331601" elapsed="0.002528"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:05.336635" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.334295" elapsed="0.002402"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.334268" elapsed="0.002453"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.343115" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.343179" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.343315" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.336891" elapsed="0.006454"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:05.306625" elapsed="0.036805"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.349957" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.350152" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.350305" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.344614" elapsed="0.005732"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.354718" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.350839" elapsed="0.003954"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.355040" elapsed="0.003898"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:05.361900" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.359205" elapsed="0.002727"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.362103" elapsed="0.002326"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:05.364487" elapsed="0.000044"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:05.344206" elapsed="0.020451"/>
</kw>
<msg time="2026-06-06T03:26:05.364748" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:05.343664" elapsed="0.021111"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.365212" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.364957" elapsed="0.000300"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.366208" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:26:05.366285" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:05.365928" elapsed="0.000380"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.366736" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:26:05.366811" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:05.366469" elapsed="0.000365"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.366992" elapsed="0.000307"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:05.367662" level="INFO">${sum_1} = 1847</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:05.367458" elapsed="0.000231"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:05.368021" level="INFO">${sum_2} = 1847</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:05.367844" elapsed="0.000274"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.368278" elapsed="0.000327"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:05.365518" elapsed="0.003166"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.375114" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.375284" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.375416" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.369300" elapsed="0.006145"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.378722" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.375712" elapsed="0.003064"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.378966" elapsed="0.002664"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.390587" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.390853" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.391057" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.381918" elapsed="0.009182"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.395336" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.391430" elapsed="0.003986"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.395717" elapsed="0.003880"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:05.405310" elapsed="0.000088"/>
</return>
<status status="PASS" start="2026-06-06T03:26:05.399762" elapsed="0.005723"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.399724" elapsed="0.005825"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.406023" elapsed="0.000057"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:05.368979" elapsed="0.037284"/>
</kw>
<arg>route_eth_rou</arg>
<status status="PASS" start="2026-06-06T03:26:05.239923" elapsed="0.166454"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.115427" elapsed="0.291200"/>
</test>
<test id="s1-s13-t37" name="Play_To_Odl_route_eth_rou" line="153">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:05.411997" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:05.411725" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:05.413345" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.413228" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.413207" elapsed="0.000271"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:05.418493" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.418383" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.418365" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.419600" 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-06-06T03:26:05.419205" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.420111" 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-06-06T03:26:05.419810" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:05.420181" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:26:05.420337" 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-06-06T03:26:05.418820" elapsed="0.001542"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:05.426190" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.426078" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.426058" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:05.427738" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:05.427530" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.427511" elapsed="0.000389"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:05.428502" 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-06-06T03:26:05.428054" elapsed="0.000516"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:05.429200" level="INFO">${current_connection_index} = 7</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-06-06T03:26:05.428934" elapsed="0.000327"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:05.463252" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:05.431162" elapsed="0.032238"/>
</kw>
<msg time="2026-06-06T03:26:05.463539" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:05.463633" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:05.429569" elapsed="0.034161"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:05.494883" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "r "o "u "[K"
[?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-06-06T03:26:05.465732" elapsed="0.029308"/>
</kw>
<msg time="2026-06-06T03:26:05.495179" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:05.495273" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:05.464136" elapsed="0.031208"/>
</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-06-06T03:26:05.496076" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.495682" elapsed="0.000509"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.495632" elapsed="0.000619"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.497035" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "e "t "h "_ "r "o "u "[K"
[?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-06-06T03:26:05.496404" elapsed="0.000749"/>
</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-06-06T03:26:05.497697" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.497328" elapsed="0.000484"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.497308" elapsed="0.000563"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:05.497910" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:05.501924" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:26:05.502179" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:05.501328" elapsed="0.000921"/>
</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="NOT RUN" start="2026-06-06T03:26:05.502471" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.502734" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:05.500327" elapsed="0.002629"/>
</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-06-06T03:26:05.498215" elapsed="0.004826"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:05.427087" elapsed="0.076141"/>
</kw>
<msg time="2026-06-06T03:26:05.503325" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:05.503370" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:05.426422" elapsed="0.076985"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:05.503593" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:05.503484" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.503465" elapsed="0.000231"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.504159" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.504625" elapsed="0.000040"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:05.504714" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:05.425721" elapsed="0.079105"/>
</kw>
<msg time="2026-06-06T03:26:05.504922" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:05.504966" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:05.420799" elapsed="0.084204"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.505334" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.505078" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.505061" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:05.420634" elapsed="0.084800"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:05.420448" elapsed="0.085019"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:05.418018" elapsed="0.087505"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:05.412924" elapsed="0.092656"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:05.412456" elapsed="0.093169"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:05.409498" elapsed="0.096236"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.513552" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.514027" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.514181" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.506164" elapsed="0.008055"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:05.514463" elapsed="0.003666"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.523070" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.523176" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:05.523278" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:05.518365" elapsed="0.004939"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.526432" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.526123" elapsed="0.000338"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:05.526907" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:05.526619" elapsed="0.000324"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.527103" elapsed="0.000326"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:05.523541" elapsed="0.003949"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.505886" elapsed="0.021659"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:05.408363" elapsed="0.119220"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.528312" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.528488" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;4...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.528108" elapsed="0.000423"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.556492" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_rou.vanadium/route_eth_rou.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:05.556107" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.557345" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou.vanadium/route_eth_rou.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:05.557092" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou.vanadium/route_eth_rou.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:05.557516" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:05.556736" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.558154" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:05.557735" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.558492" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/route_eth_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.558658" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.558350" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.559103" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.558850" elapsed="0.000355"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:05.559637" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:05.559285" elapsed="0.000429"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.560195" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:05.559896" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.559741" elapsed="0.000516"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:05.559261" elapsed="0.001018"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.560920" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:05.560433" elapsed="0.000516"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:05.561003" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:05.561170" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:05.553811" elapsed="0.007386"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.561562" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/announce_route_eth_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/announce_route_eth_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.561703" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.561364" elapsed="0.000366"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:05.562083" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/withdraw_route_eth_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_eth_rou/withdraw_route_eth_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:05.562204" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:05.561891" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.562636" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;ethernet-a-d-route&gt;
        &lt;mpls-label&gt;24001&lt;/mpls-label&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
    &lt;/ethernet-a-d-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.562391" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.563105" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.562865" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.563547" level="INFO">ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.563309" elapsed="0.000282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:05.564047" level="INFO">ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:05.563805" elapsed="0.000286"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:05.564244" elapsed="0.002663"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:05.567067" elapsed="0.001835"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:05.573907" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:05.574133" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:05.574269" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:05.569884" elapsed="0.004963">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.575115" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:05.575450" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:05.569527" elapsed="0.006097">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:07.587062" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:07.587320" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '403'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:07.587489" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:07.577360" elapsed="0.010169"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:07.588317" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK",
        "route-distinguisher": "429496729:1",
        "ethernet-a-d-route": {
          "router-id-generated": {
            "local-discriminator": 2000,
            "router-id": "43.43.43.43"
          },
          "mpls-label": 24001,
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:07.591835" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:07.587868" elapsed="0.004042"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:07.596862" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:07.596137" elapsed="0.000769"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:07.598153" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:07.597156" elapsed="0.001053"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:07.598470" elapsed="0.000399"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:07.592262" elapsed="0.006676"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:07.576320" elapsed="0.022677"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:05.569078" elapsed="2.029969"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:07.599212" elapsed="0.002354"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:07.607074" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:07.607213" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:07.607311" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:07.602638" elapsed="0.004699"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:07.607560" elapsed="0.004330"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:07.617876" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:07.618694" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '551'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK","ethernet-a-d-route":{"mpls-label":24001,"ethernet-tag-id":{"vlan-id":10},"router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:07.618915" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:07.612143" elapsed="0.006815"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:07.624007" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:07.623492" elapsed="0.000561"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:07.625063" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:07.624303" elapsed="0.000804"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:07.625964" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "ethernet-a-d-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "mpls-label": 24001,
       "router-id-generated": {
        "local-discriminator": 2000,
        "router-id": "43.43.43.43"
       }
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK"
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:07.626286" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:07.625359" elapsed="0.001038">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:07.619392" elapsed="0.007237">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:07.602338" elapsed="0.024443">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "ethernet-a-d-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "mpls-label": 24001,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "ARYAAhmZmZkAAQQrKysrAAAH0AAAAAAK"
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.636841" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.637030" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:09.637177" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.628322" elapsed="0.008893"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.637471" elapsed="0.003801"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.648817" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.648987" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:09.649137" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.641522" elapsed="0.007652"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:09.653600" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.653172" elapsed="0.000489"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:09.654280" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.653893" elapsed="0.000426"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.654564" elapsed="0.000494"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.649528" elapsed="0.005620"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:09.627447" elapsed="0.027780"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:07.601876" elapsed="2.053408"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:09.656076" elapsed="0.003019"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.665902" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.666120" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:09.666264" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.660768" elapsed="0.005533"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.666566" elapsed="0.003546"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.675285" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.675431" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:09.675574" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.670347" elapsed="0.005264"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:09.680019" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.679601" elapsed="0.000457"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:09.680686" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.680284" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.680952" elapsed="0.000454"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.675960" elapsed="0.005533"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:09.660008" elapsed="0.021560"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:09.659379" elapsed="0.022243"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:09.655549" elapsed="0.026176"/>
</kw>
<arg>route_eth_rou</arg>
<status status="PASS" start="2026-06-06T03:26:05.527811" elapsed="4.153979"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:05.407330" elapsed="4.274610"/>
</test>
<test id="s1-s13-t38" name="Odl_To_Play_route_inc_arb" line="156">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:09.687215" elapsed="0.000295"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:09.686834" elapsed="0.000738"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:09.688621" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.688498" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.688474" elapsed="0.000235"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:09.693917" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.693805" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.693786" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.695411" 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-06-06T03:26:09.694958" elapsed="0.000481"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.695925" 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-06-06T03:26:09.695607" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:09.696046" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:26:09.696216" 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-06-06T03:26:09.694221" elapsed="0.002020"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:09.702087" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.701974" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.701954" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:09.703687" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.703467" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.703447" elapsed="0.000408"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:09.704434" 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-06-06T03:26:09.704011" elapsed="0.000487"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:09.705142" level="INFO">${current_connection_index} = 7</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-06-06T03:26:09.704873" elapsed="0.000330"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:09.738882" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:09.707120" elapsed="0.031904"/>
</kw>
<msg time="2026-06-06T03:26:09.739161" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:09.739254" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:09.705520" elapsed="0.033803"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:09.780001" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "a "r "b "[K"
[?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-06-06T03:26:09.741307" elapsed="0.038829"/>
</kw>
<msg time="2026-06-06T03:26:09.780268" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:09.780360" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:09.739745" elapsed="0.040684"/>
</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-06-06T03:26:09.781116" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:09.780752" elapsed="0.000478"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.780730" elapsed="0.000558"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.782033" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "a "r "b "[K"
[?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-06-06T03:26:09.781444" elapsed="0.000704"/>
</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-06-06T03:26:09.782716" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:09.782321" elapsed="0.000513"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.782301" elapsed="0.000591"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:09.782930" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:09.786439" elapsed="0.000171"/>
</kw>
<msg time="2026-06-06T03:26:09.786674" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:09.785905" elapsed="0.000838"/>
</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="NOT RUN" start="2026-06-06T03:26:09.786963" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:09.787179" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:09.785125" elapsed="0.002269"/>
</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-06-06T03:26:09.783210" elapsed="0.004270"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:09.703011" elapsed="0.084700"/>
</kw>
<msg time="2026-06-06T03:26:09.787809" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:09.787853" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:09.702318" elapsed="0.085571"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:09.788077" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:09.787967" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.787947" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:09.788633" elapsed="0.000044"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:09.789077" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:09.789152" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:09.701616" elapsed="0.087648"/>
</kw>
<msg time="2026-06-06T03:26:09.789361" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:09.789407" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:09.696657" elapsed="0.092786"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:09.789855" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:09.789520" elapsed="0.000391"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.789502" elapsed="0.000434"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:09.696494" elapsed="0.093466"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:09.696306" elapsed="0.093686"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:09.693414" elapsed="0.096633"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:09.688197" elapsed="0.101908"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:09.687748" elapsed="0.102403"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:09.683710" elapsed="0.106496"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.796240" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.796360" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:09.796469" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.790685" elapsed="0.005812"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.796697" elapsed="0.002897"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.804813" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.804962" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:09.805155" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.799857" elapsed="0.005337"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:09.809555" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.809150" elapsed="0.000445"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:09.810226" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.809843" elapsed="0.000422"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.810492" elapsed="0.000500"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.805522" elapsed="0.005559"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:09.790362" elapsed="0.020796"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:09.683028" elapsed="0.128186"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:09.812293" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:09.812506" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:09.812011" elapsed="0.000535"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:09.813068" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:09.813245" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:09.812799" elapsed="0.000483"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:09.813800" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/announce_route_inc_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/announce_route_inc_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:09.813977" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:09.813506" elapsed="0.000507"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:09.814524" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:09.814237" elapsed="0.000356"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:09.815112" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/withdraw_route_inc_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/withdraw_route_inc_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:09.815288" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:09.814847" elapsed="0.000478"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:09.815760" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:09.815542" elapsed="0.000246"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.816201" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.815953" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.816671" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.816413" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.817158" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.816915" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.817600" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.817360" elapsed="0.000298"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:09.817813" elapsed="0.002218"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.830432" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '732', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:09.830518" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AxEAAhmZmZkAAQAAAAogKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.830715" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.820199" elapsed="0.010555"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.836571" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.831005" elapsed="0.005697"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.843696" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.844058" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:09.844182" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.837067" elapsed="0.007144"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.846967" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.844409" elapsed="0.002607"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.851755" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.852058" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:09.852208" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.848172" elapsed="0.004064"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.854875" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.852413" elapsed="0.002512"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.855087" elapsed="0.002527"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:09.860223" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.857797" elapsed="0.002457"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.860439" elapsed="0.002194"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:09.862704" elapsed="0.000039"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:09.847686" elapsed="0.015158"/>
</kw>
<msg time="2026-06-06T03:26:09.862926" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:09.847194" elapsed="0.015758"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.863373" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.863123" elapsed="0.000297"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.864312" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:09.864388" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:09.864048" elapsed="0.000364"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.864845" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:09.864921" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:09.864569" elapsed="0.000376"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.865104" elapsed="0.000311"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:09.865777" level="INFO">${sum_1} = 1836</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:09.865575" elapsed="0.000229"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:09.866139" level="INFO">${sum_2} = 1836</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:09.865960" elapsed="0.000204"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.866321" elapsed="0.000338"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:09.863676" elapsed="0.003046"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:09.866876" elapsed="0.001910"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.876186" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.876301" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:09.876396" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.869309" elapsed="0.007113"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.879274" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.876600" elapsed="0.002724"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.879533" elapsed="0.002535"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.886661" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.886778" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:09.886883" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.882237" elapsed="0.004673"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.889511" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.887087" elapsed="0.002476"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.889743" elapsed="0.002513"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:09.894690" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.892338" elapsed="0.002397"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.892317" elapsed="0.002442"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.901495" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.901546" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.901668" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.894912" elapsed="0.006785"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:09.869010" elapsed="0.032757"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.906703" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.906813" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:09.906906" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.902759" elapsed="0.004173"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.909512" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.907103" elapsed="0.002457"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.909735" elapsed="0.002519"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:09.914699" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:09.912422" elapsed="0.002309"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.914938" elapsed="0.002200"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:09.917192" elapsed="0.000037"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:09.902386" elapsed="0.014944"/>
</kw>
<msg time="2026-06-06T03:26:09.917411" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:09.901937" elapsed="0.015499"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.917877" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.917611" elapsed="0.000312"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.918844" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:09.918922" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:09.918542" elapsed="0.000405"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.919363" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:09.919438" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:09.919106" elapsed="0.000357"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.919622" elapsed="0.000330"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:09.920290" level="INFO">${sum_1} = 1389</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:09.920113" elapsed="0.000202"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:09.920654" level="INFO">${sum_2} = 1389</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:09.920468" elapsed="0.000213"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:09.920839" elapsed="0.000305"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:09.918164" elapsed="0.003040"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.926869" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.927008" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:09.927107" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.921796" elapsed="0.005337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.930106" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.927313" elapsed="0.002842"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.930316" elapsed="0.002543"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:09.939519" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:09.939634" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:09.939759" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:09.933027" elapsed="0.006759"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.942498" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:09.940020" elapsed="0.002532"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:09.942763" elapsed="0.002551"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:09.947948" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:26:09.945403" elapsed="0.002615"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.945378" elapsed="0.002666"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:09.948207" elapsed="0.000024"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:09.921470" elapsed="0.026834"/>
</kw>
<arg>route_inc_arb</arg>
<status status="PASS" start="2026-06-06T03:26:09.811570" elapsed="0.136782"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:09.682363" elapsed="0.266109"/>
</test>
<test id="s1-s13-t39" name="Play_To_Odl_route_inc_arb" line="158">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:09.952363" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:09.952093" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:09.953660" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.953531" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.953512" elapsed="0.000218"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:09.958787" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.958679" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.958659" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.959868" 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-06-06T03:26:09.959466" elapsed="0.000428"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:09.960354" 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-06-06T03:26:09.960059" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:09.960423" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:26:09.960577" 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-06-06T03:26:09.959084" elapsed="0.001518"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:09.966375" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.966264" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.966244" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:09.967930" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:09.967748" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:09.967728" elapsed="0.000365"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:09.968674" 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-06-06T03:26:09.968247" elapsed="0.000491"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:09.969353" level="INFO">${current_connection_index} = 7</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-06-06T03:26:09.969088" elapsed="0.000326"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:10.002385" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:09.971267" elapsed="0.031245"/>
</kw>
<msg time="2026-06-06T03:26:10.002701" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:10.002798" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:09.969739" elapsed="0.033131"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:10.035757" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "a "r "b "[K"
[?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-06-06T03:26:10.004821" elapsed="0.031109"/>
</kw>
<msg time="2026-06-06T03:26:10.036063" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:10.036156" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:10.003261" elapsed="0.032967"/>
</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-06-06T03:26:10.036902" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:10.036521" elapsed="0.000495"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:10.036498" elapsed="0.000576"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.037805" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "a "r "b "[K"
[?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-06-06T03:26:10.037224" elapsed="0.000697"/>
</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-06-06T03:26:10.038444" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:10.038094" elapsed="0.000464"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:10.038074" elapsed="0.000586"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:10.038702" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:10.042212" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:26:10.042399" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:10.041630" elapsed="0.000834"/>
</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="NOT RUN" start="2026-06-06T03:26:10.042877" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:10.043100" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:10.040890" elapsed="0.002424"/>
</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-06-06T03:26:10.038976" elapsed="0.004423"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:09.967278" elapsed="0.076300"/>
</kw>
<msg time="2026-06-06T03:26:10.043688" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:10.043734" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:09.966617" elapsed="0.077154"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:10.043957" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:10.043849" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:10.043830" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:10.044499" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:10.044947" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:10.045021" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:09.965920" elapsed="0.079210"/>
</kw>
<msg time="2026-06-06T03:26:10.045224" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:10.045268" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:09.960998" elapsed="0.084307"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:10.045655" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:10.045381" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:10.045363" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:09.960852" elapsed="0.084909"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:09.960674" elapsed="0.085119"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:09.958292" elapsed="0.087557"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:09.953242" elapsed="0.092711"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:09.952804" elapsed="0.093197"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:09.949821" elapsed="0.096236"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:10.052853" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:10.052991" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:10.053090" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:10.046507" elapsed="0.006609"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:10.053287" elapsed="0.002929"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:10.062630" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:10.062756" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:10.062860" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:10.056384" elapsed="0.006503"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:10.065989" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:10.065678" elapsed="0.000339"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:10.066449" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:10.066177" elapsed="0.000300"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:10.066680" elapsed="0.000332"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:10.063119" elapsed="0.003955"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:10.046217" elapsed="0.020911"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:09.949300" elapsed="0.117869"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:10.067905" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:10.068060" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:10.067700" elapsed="0.000390"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.093782" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_arb.vanadium/route_inc_arb.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:10.093389" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:10.094654" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb.vanadium/route_inc_arb.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:10.094367" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb.vanadium/route_inc_arb.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:10.094830" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:10.093980" elapsed="0.000875"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.095418" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:10.095026" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:10.095765" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/route_inc_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:10.095891" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:10.095613" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.096322" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:10.096079" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:10.096773" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:10.096442" elapsed="0.000390"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.097298" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:10.097005" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:10.096857" elapsed="0.000502"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:10.096421" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.097994" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:10.097531" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:10.098074" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:26:10.098231" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:10.091093" elapsed="0.007166"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:10.098662" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/announce_route_inc_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/announce_route_inc_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:10.098806" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:10.098423" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:10.099330" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/withdraw_route_inc_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_arb/withdraw_route_inc_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:10.099557" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:10.099140" elapsed="0.000444"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.100016" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:10.099766" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.100507" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:10.100262" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.100970" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:10.100729" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:10.101409" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:10.101169" elapsed="0.000285"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:10.101612" elapsed="0.002356"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:10.104151" elapsed="0.001797"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:10.111030" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:10.111140" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:10.111234" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:10.106935" elapsed="0.004667">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:10.111818" elapsed="0.000023"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:10.112052" elapsed="0.000024"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:10.106568" elapsed="0.005608">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:12.125028" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:12.125339" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:12.125625" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:12.114166" elapsed="0.011528"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:12.127055" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:12.131165" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:12.126258" elapsed="0.004983"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:12.136024" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:12.135345" elapsed="0.000720"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:12.136875" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:12.136291" elapsed="0.000623"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:12.137145" elapsed="0.000467"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:12.131678" elapsed="0.006053"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:12.113051" elapsed="0.024765"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:10.106125" elapsed="2.031765"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:12.138118" elapsed="0.002983"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:12.151056" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:12.151229" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:12.151387" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:12.142102" elapsed="0.009321"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:12.151691" elapsed="0.003616"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:12.160728" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:12.161207" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '489'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:12.161356" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:12.155543" elapsed="0.005843"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:12.165356" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:12.164908" elapsed="0.000488"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:12.166294" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:12.165626" elapsed="0.000708"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:12.167182" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "inc-multi-ethernet-tag-res": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:12.167484" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:12.166561" elapsed="0.001037">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:12.161739" elapsed="0.006089">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:12.141814" elapsed="0.026190">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.176886" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.177077" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.177222" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.169533" elapsed="0.007727"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.177510" elapsed="0.003717"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.187538" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.187715" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:14.187863" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.181467" elapsed="0.006434"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.192406" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.191979" elapsed="0.000466"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.193075" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.192690" elapsed="0.000424"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.193341" elapsed="0.000481"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.188364" elapsed="0.005545"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.168721" elapsed="0.025265"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:12.141287" elapsed="2.052754"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:14.194847" elapsed="0.002819"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.248181" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.248341" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.248489" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.243319" elapsed="0.005200"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.248956" elapsed="0.002812"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.257103" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.257263" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:14.257411" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.251949" elapsed="0.005499"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.261927" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.261488" elapsed="0.000478"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.262566" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.262189" elapsed="0.000415"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.262883" elapsed="0.000469"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.257825" elapsed="0.005615"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.242916" elapsed="0.020602"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:14.197959" elapsed="0.065615"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:14.194321" elapsed="0.069354"/>
</kw>
<arg>route_inc_arb</arg>
<status status="PASS" start="2026-06-06T03:26:10.067383" elapsed="4.196479"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:09.948823" elapsed="4.315199"/>
</test>
<test id="s1-s13-t40" name="Odl_To_Play_route_inc_as" line="161">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:14.269406" elapsed="0.000317"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:14.269027" elapsed="0.000775"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:14.271511" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.271342" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.271309" elapsed="0.000305"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:14.276672" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.276547" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.276529" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.277766" 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-06-06T03:26:14.277360" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.278257" 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-06-06T03:26:14.277959" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:14.278329" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:14.278492" 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-06-06T03:26:14.276974" elapsed="0.001543"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:14.284133" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.284024" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.284005" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:14.285630" elapsed="0.000037"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.285447" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.285428" elapsed="0.000389"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:14.286390" 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-06-06T03:26:14.285975" elapsed="0.000477"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:14.287109" level="INFO">${current_connection_index} = 7</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-06-06T03:26:14.286843" elapsed="0.000328"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:14.321454" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:14.289032" elapsed="0.032658"/>
</kw>
<msg time="2026-06-06T03:26:14.321864" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:14.321961" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:14.287486" elapsed="0.034546"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:14.348731" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "a "s "[K"
[?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-06-06T03:26:14.324154" elapsed="0.024904"/>
</kw>
<msg time="2026-06-06T03:26:14.349209" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:14.349307" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:14.322484" elapsed="0.026894"/>
</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-06-06T03:26:14.350145" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.349723" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.349691" elapsed="0.000637"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.351129" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "a "s "[K"
[?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-06-06T03:26:14.350486" elapsed="0.000829"/>
</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-06-06T03:26:14.351871" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.351493" elapsed="0.000493"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.351472" elapsed="0.000574"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:14.352088" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:14.355839" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:26:14.356032" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:14.355251" elapsed="0.000850"/>
</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="NOT RUN" start="2026-06-06T03:26:14.356323" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.356542" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:14.354404" elapsed="0.002378"/>
</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-06-06T03:26:14.352421" elapsed="0.004450"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:14.285007" elapsed="0.072043"/>
</kw>
<msg time="2026-06-06T03:26:14.357147" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:14.357192" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:14.284359" elapsed="0.072869"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:14.357417" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:14.357307" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.357287" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.357988" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.358417" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:14.358491" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:14.283686" elapsed="0.074915"/>
</kw>
<msg time="2026-06-06T03:26:14.358779" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:14.358826" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:14.278935" elapsed="0.079927"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.359198" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.358940" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.358922" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:14.278785" elapsed="0.080515"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:14.278575" elapsed="0.080759"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:14.276186" elapsed="0.083204"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:14.270633" elapsed="0.088812"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:14.270020" elapsed="0.089469"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:14.265785" elapsed="0.093759"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.364233" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.364408" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.364523" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.359994" elapsed="0.004555"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.364763" elapsed="0.003824"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.375856" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.376003" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:14.376144" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.368845" elapsed="0.007336"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.380777" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.380335" elapsed="0.000483"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.381420" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.381043" elapsed="0.000416"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.381706" elapsed="0.000455"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.376503" elapsed="0.005746"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.359715" elapsed="0.022610"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:14.265105" elapsed="0.117276"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.383477" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.383718" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.383198" elapsed="0.000564"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.384248" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.384423" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.383985" elapsed="0.000475"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.384968" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/announce_route_inc_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/announce_route_inc_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.385175" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.384703" elapsed="0.000509"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:14.385749" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:14.385435" elapsed="0.000351"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.386321" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/withdraw_route_inc_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/withdraw_route_inc_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.386495" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.386011" elapsed="0.000520"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:14.387089" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:14.386807" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.387710" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.387355" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.388167" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.387924" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.388609" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.388371" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.389067" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.388831" elapsed="0.000282"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:14.389266" elapsed="0.002078"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.400874" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '732', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:14.400958" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AxEAAhmZmZkAAQAAAAogKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.401087" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.391511" elapsed="0.009612"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.404990" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.401369" elapsed="0.003683"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.411950" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.412110" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:14.412297" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.405277" elapsed="0.007060"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.416127" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.412579" elapsed="0.003617"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.423605" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.423790" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:14.423923" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.417552" elapsed="0.006409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.427726" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.424205" elapsed="0.003590"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.428019" elapsed="0.003580"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:14.434188" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.431854" elapsed="0.002375"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.434479" elapsed="0.003045"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:14.437596" elapsed="0.000063"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:14.417086" elapsed="0.020715"/>
</kw>
<msg time="2026-06-06T03:26:14.437912" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:14.416439" elapsed="0.021508"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.438525" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.438182" elapsed="0.000405"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.439850" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:14.439954" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:14.439461" elapsed="0.000526"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.440553" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:14.440676" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:14.440205" elapsed="0.000506"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.440930" elapsed="0.000427"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:14.441851" level="INFO">${sum_1} = 1836</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:14.441579" elapsed="0.000308"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:14.442343" level="INFO">${sum_2} = 1836</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:14.442103" elapsed="0.000275"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.442595" elapsed="0.000465"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:14.438949" elapsed="0.004194"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:14.443356" elapsed="0.002239"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.450184" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.450298" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:14.450392" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.446130" elapsed="0.004287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.453211" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.450589" elapsed="0.002671"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.453419" elapsed="0.002645"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.463515" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.463722" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:14.463884" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.456295" elapsed="0.007626"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.467979" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.464184" elapsed="0.003863"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.468271" elapsed="0.003506"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:14.475139" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.471899" elapsed="0.003303"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.471866" elapsed="0.003368"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.481288" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.481334" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.481432" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.475448" elapsed="0.006011"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:14.445852" elapsed="0.035679"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.487254" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.487416" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.487511" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.482553" elapsed="0.004984"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.491183" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.487767" elapsed="0.003483"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.491474" elapsed="0.003539"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:14.497559" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.495286" elapsed="0.002303"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.497795" elapsed="0.002409"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:14.500277" elapsed="0.000054"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:14.482207" elapsed="0.018256"/>
</kw>
<msg time="2026-06-06T03:26:14.500565" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:14.481725" elapsed="0.018873"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.501113" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.500828" elapsed="0.000337"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.502215" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:14.502305" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:14.501904" elapsed="0.000426"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.502818" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:14.502896" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:14.502503" elapsed="0.000417"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.503082" elapsed="0.000311"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:14.503754" level="INFO">${sum_1} = 1389</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:14.503557" elapsed="0.000223"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:14.504111" level="INFO">${sum_2} = 1389</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:14.503937" elapsed="0.000200"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.504292" elapsed="0.000306"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:14.501448" elapsed="0.003228"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.509409" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.509550" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.509684" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.505250" elapsed="0.004463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.512714" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.509912" elapsed="0.002913"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.512991" elapsed="0.002535"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.520444" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.520595" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.520765" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.515718" elapsed="0.005085"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.525386" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.521048" elapsed="0.004407"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.525705" elapsed="0.003628"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:14.532778" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:26:14.529460" elapsed="0.003413"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.529425" elapsed="0.003484"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.533129" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:14.504944" elapsed="0.028316"/>
</kw>
<arg>route_inc_as</arg>
<status status="PASS" start="2026-06-06T03:26:14.382775" elapsed="0.150552"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.264444" elapsed="0.269036"/>
</test>
<test id="s1-s13-t41" name="Play_To_Odl_route_inc_as" line="163">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:14.538819" elapsed="0.000300"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:14.538379" elapsed="0.000818"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:14.540348" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.540234" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.540214" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:14.545439" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.545331" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.545313" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.546521" 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-06-06T03:26:14.546139" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.547032" 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-06-06T03:26:14.546727" elapsed="0.000331"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:14.547102" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:26:14.547257" 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-06-06T03:26:14.545756" elapsed="0.001525"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:14.553156" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.553038" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.553017" elapsed="0.000213"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:14.554774" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:14.554547" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.554528" elapsed="0.000413"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:14.555578" 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-06-06T03:26:14.555096" elapsed="0.000559"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:14.556286" level="INFO">${current_connection_index} = 7</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-06-06T03:26:14.556014" elapsed="0.000334"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:14.588499" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:14.558230" elapsed="0.030495"/>
</kw>
<msg time="2026-06-06T03:26:14.588927" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:14.589066" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:14.556680" elapsed="0.032490"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:14.618135" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "a "s "[K"
[?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-06-06T03:26:14.591987" elapsed="0.026280"/>
</kw>
<msg time="2026-06-06T03:26:14.618399" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:14.618492" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:14.589789" elapsed="0.028772"/>
</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-06-06T03:26:14.619267" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.618905" elapsed="0.000477"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.618881" elapsed="0.000561"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.620185" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "a "s "[K"
[?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-06-06T03:26:14.619594" elapsed="0.000705"/>
</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-06-06T03:26:14.620844" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.620474" elapsed="0.000486"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.620454" elapsed="0.000564"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:14.621056" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:14.624680" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:26:14.624869" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:14.624112" elapsed="0.000824"/>
</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="NOT RUN" start="2026-06-06T03:26:14.625157" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.625375" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:14.623337" elapsed="0.002258"/>
</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-06-06T03:26:14.621352" elapsed="0.004347"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:14.554099" elapsed="0.071778"/>
</kw>
<msg time="2026-06-06T03:26:14.625970" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:14.626015" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:14.553400" elapsed="0.072653"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:14.626240" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:14.626131" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.626111" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.626819" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.627245" elapsed="0.000062"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:14.627358" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:14.552684" elapsed="0.074786"/>
</kw>
<msg time="2026-06-06T03:26:14.627566" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:14.627611" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:14.547678" elapsed="0.079984"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.627998" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.627741" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.627723" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:14.547517" elapsed="0.080585"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:14.547340" elapsed="0.080795"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:14.544969" elapsed="0.083223"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:14.539943" elapsed="0.088307"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:14.539417" elapsed="0.088880"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:14.535300" elapsed="0.093054"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.633240" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.633378" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.633473" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.628817" elapsed="0.004681"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:14.633685" elapsed="0.002612"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.642625" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.642824" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:14.642974" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:14.636467" elapsed="0.006546"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.647625" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.647185" elapsed="0.000503"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:14.648332" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:14.647928" elapsed="0.000445"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.648612" elapsed="0.000506"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:14.643351" elapsed="0.005981"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.628505" elapsed="0.020909"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:14.534566" elapsed="0.114907"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.650565" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.650815" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.650268" elapsed="0.000590"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.679581" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_as.vanadium/route_inc_as.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:14.679128" elapsed="0.000485"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.680463" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as.vanadium/route_inc_as.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:14.680187" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as.vanadium/route_inc_as.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:14.680637" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:14.679822" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.681245" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:14.680855" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.681582" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/route_inc_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.681761" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.681439" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.682201" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.681952" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:14.682828" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:14.682334" elapsed="0.000559"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.683366" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:14.683071" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.682919" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:14.682308" elapsed="0.001141"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.684066" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:14.683600" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:14.684147" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:26:14.684314" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:14.676618" elapsed="0.007723"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.684720" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/announce_route_inc_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/announce_route_inc_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.684919" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.684507" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:14.685303" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/withdraw_route_inc_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_as/withdraw_route_inc_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:14.685426" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:14.685110" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.685885" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.685613" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.686343" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.686100" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.686825" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.686551" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:14.687526" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:14.687027" elapsed="0.000545"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:14.687745" elapsed="0.002243"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:14.690173" elapsed="0.002174"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:14.699040" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:14.699233" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:14.699386" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:14.693862" elapsed="0.006097">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.700266" elapsed="0.000035"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:14.700634" elapsed="0.000059"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:14.693326" elapsed="0.007517">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:16.711001" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:16.711322" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:16.711471" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:16.702583" elapsed="0.008925"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:16.712199" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:16.715424" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:16.711796" elapsed="0.003697"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:16.720291" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:16.719676" elapsed="0.000657"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:16.721131" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:16.720560" elapsed="0.000610"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:16.721400" elapsed="0.000485"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:16.715835" elapsed="0.006138"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:16.701532" elapsed="0.020517"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:14.692636" elapsed="2.029478"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:16.722338" elapsed="0.002709"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:16.731081" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:16.731197" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:16.731302" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:16.726014" elapsed="0.005314"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:16.731496" elapsed="0.002542"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:16.739318" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:16.739482" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '489'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:16.739736" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:16.734203" elapsed="0.005573"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:16.744115" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:16.743714" elapsed="0.000441"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:16.745207" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:16.744383" elapsed="0.000864"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:16.745931" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "inc-multi-ethernet-tag-res": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:16.746206" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:16.745471" elapsed="0.000842">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:16.740102" elapsed="0.006425">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:16.725687" elapsed="0.021033">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.755515" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.755733" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:18.755881" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.748314" elapsed="0.007603"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:18.756170" elapsed="0.003823"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.766313" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.766469" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:18.766612" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.760338" elapsed="0.006339"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:18.771332" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.770921" elapsed="0.000451"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:18.772019" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.771595" elapsed="0.000463"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.772282" elapsed="0.000485"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.767019" elapsed="0.005860"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:18.747463" elapsed="0.025496"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:16.725234" elapsed="2.047781"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:18.773789" elapsed="0.002392"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.782172" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.782325" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:18.782456" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.777541" elapsed="0.004951"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:18.782753" elapsed="0.003594"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.792019" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.792167" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:18.792309" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.786581" elapsed="0.005767"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:18.796777" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.796355" elapsed="0.000462"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:18.797498" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.797116" elapsed="0.000421"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.797780" elapsed="0.000519"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.792697" elapsed="0.005692"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:18.777120" elapsed="0.021344"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:18.776456" elapsed="0.022061"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:18.773275" elapsed="0.025317"/>
</kw>
<arg>route_inc_as</arg>
<status status="PASS" start="2026-06-06T03:26:14.649818" elapsed="4.148867"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:14.533928" elapsed="4.264921"/>
</test>
<test id="s1-s13-t42" name="Odl_To_Play_route_inc_lacp" line="166">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:18.805152" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:18.804832" elapsed="0.000593"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:18.806482" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:18.806356" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.806332" elapsed="0.000223"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:18.811619" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:18.811511" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.811493" elapsed="0.000213"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.812719" 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-06-06T03:26:18.812316" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.813227" 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-06-06T03:26:18.812929" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:18.813298" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:26:18.813463" 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-06-06T03:26:18.811935" elapsed="0.001553"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:18.819146" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:18.819038" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.819018" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:18.820665" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:18.820461" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.820441" elapsed="0.000392"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:18.821411" 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-06-06T03:26:18.821001" elapsed="0.000470"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:18.822105" level="INFO">${current_connection_index} = 7</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-06-06T03:26:18.821840" elapsed="0.000326"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:18.856873" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:18.824026" elapsed="0.033147"/>
</kw>
<msg time="2026-06-06T03:26:18.857392" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:18.857490" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:18.822477" elapsed="0.035086"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:18.889621" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:18.859852" elapsed="0.030166"/>
</kw>
<msg time="2026-06-06T03:26:18.890365" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:18.890465" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:18.858100" elapsed="0.032440"/>
</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-06-06T03:26:18.891461" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:18.890947" elapsed="0.000639"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.890901" elapsed="0.000770"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.892538" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:18.891834" elapsed="0.000842"/>
</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-06-06T03:26:18.893243" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:18.892863" elapsed="0.000497"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.892841" elapsed="0.000579"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:18.893465" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:18.897436" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:26:18.897638" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:18.896742" elapsed="0.000994"/>
</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="NOT RUN" start="2026-06-06T03:26:18.897964" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:18.898183" elapsed="0.000021"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:18.895934" elapsed="0.002470"/>
</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-06-06T03:26:18.893848" elapsed="0.004644"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:18.820022" elapsed="0.078680"/>
</kw>
<msg time="2026-06-06T03:26:18.898804" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:18.898849" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:18.819371" elapsed="0.079517"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:18.899080" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:18.898969" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.898949" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:18.899778" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:18.900231" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:18.900307" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:18.818687" elapsed="0.081735"/>
</kw>
<msg time="2026-06-06T03:26:18.900521" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:18.900566" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:18.813883" elapsed="0.086723"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:18.900967" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:18.900703" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:18.900684" elapsed="0.000392"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:18.813736" elapsed="0.087365"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:18.813545" elapsed="0.087594"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:18.811146" elapsed="0.090056"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:18.806049" elapsed="0.095260"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:18.805583" elapsed="0.095779"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:18.800689" elapsed="0.100734"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.906378" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.906538" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:18.906694" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.901885" elapsed="0.004839"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:18.906910" elapsed="0.002770"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.916059" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.916228" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:18.916386" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.909857" elapsed="0.006569"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:18.921235" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.920749" elapsed="0.000529"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:18.921945" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.921519" elapsed="0.000467"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.922226" elapsed="0.000525"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.916833" elapsed="0.006014"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:18.901580" elapsed="0.021352"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:18.800013" elapsed="0.122983"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:18.924155" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:18.924397" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:18.923855" elapsed="0.000586"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:18.924986" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:18.925413" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:18.924704" elapsed="0.000856"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:18.927050" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/announce_route_inc_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/announce_route_inc_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:18.927340" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:18.925981" elapsed="0.001418"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:18.928278" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:18.927802" elapsed="0.000536"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:18.929224" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/withdraw_route_inc_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/withdraw_route_inc_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:18.929506" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:18.928733" elapsed="0.000830"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:18.930399" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:18.929952" elapsed="0.000505"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.931408" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.930846" elapsed="0.000682"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.932441" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.931906" elapsed="0.000640"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.933483" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.932924" elapsed="0.000655"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.934480" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.933954" elapsed="0.000623"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:18.934944" elapsed="0.002961"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.949366" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '732', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:18.949463" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AxEAAhmZmZkAAQAAAAogKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.949730" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.938086" elapsed="0.011687"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.954090" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.950055" elapsed="0.004102"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.962116" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.962326" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:18.962489" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.954406" elapsed="0.008122"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.966579" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.962823" elapsed="0.003845"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:18.974063" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:18.974189" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:18.974287" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.968309" elapsed="0.006004"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.976949" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.974493" elapsed="0.002505"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:18.977178" elapsed="0.002536"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:18.982312" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:18.979885" elapsed="0.002470"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.982593" elapsed="0.003316"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:18.985990" elapsed="0.000059"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:18.967690" elapsed="0.018517"/>
</kw>
<msg time="2026-06-06T03:26:18.986326" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:18.966940" elapsed="0.019423"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.987001" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:18.986616" elapsed="0.000452"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.988430" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:18.988541" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:18.988038" elapsed="0.000652"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:18.989350" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:18.989463" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:18.988934" elapsed="0.000564"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.989761" elapsed="0.000460"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:18.990751" level="INFO">${sum_1} = 1836</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:18.990460" elapsed="0.000329"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:18.991277" level="INFO">${sum_2} = 1836</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:18.991019" elapsed="0.000295"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:18.991545" elapsed="0.000477"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:18.987431" elapsed="0.004679"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:18.992338" elapsed="0.002258"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.002387" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.002580" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:19.002772" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:18.995777" elapsed="0.007035"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.006828" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.003077" elapsed="0.003824"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:19.007139" elapsed="0.003813"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.016159" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.016288" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:19.016398" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.011201" elapsed="0.005225"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.019090" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.016607" elapsed="0.002532"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:19.019301" elapsed="0.002564"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:19.025581" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:19.021996" elapsed="0.003680"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.021960" elapsed="0.003755"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.033204" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.033253" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.033367" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.025951" elapsed="0.007444"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:18.994996" elapsed="0.038477"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.040019" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.040204" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:19.040343" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.034572" elapsed="0.005809"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.044377" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.040675" elapsed="0.003773"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:19.044708" elapsed="0.003854"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:19.051087" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:19.048840" elapsed="0.002317"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:19.051397" elapsed="0.003005"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:19.054461" elapsed="0.000045"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:19.034211" elapsed="0.020410"/>
</kw>
<msg time="2026-06-06T03:26:19.054725" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:19.033684" elapsed="0.021068"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.055182" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.054932" elapsed="0.000295"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.056152" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:19.056228" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:19.055888" elapsed="0.000364"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.056691" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:19.056768" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:19.056410" elapsed="0.000382"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:19.056952" elapsed="0.000321"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:19.057611" level="INFO">${sum_1} = 1389</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:19.057435" elapsed="0.000201"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:19.057986" level="INFO">${sum_2} = 1389</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:19.057809" elapsed="0.000202"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:19.058234" elapsed="0.000315"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:19.055487" elapsed="0.003123"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.062526" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.062685" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:19.062782" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.059220" elapsed="0.003588"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.065733" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.062987" elapsed="0.002794"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:19.065946" elapsed="0.002526"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.072052" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.072170" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:19.072274" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.068656" elapsed="0.003645"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.077841" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.072474" elapsed="0.005520"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:19.078512" elapsed="0.006058"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:19.087795" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:26:19.084809" elapsed="0.003075"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.084749" elapsed="0.003163"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.088089" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:19.058910" elapsed="0.029289"/>
</kw>
<arg>route_inc_lacp</arg>
<status status="PASS" start="2026-06-06T03:26:18.923386" elapsed="0.164869"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:18.799354" elapsed="0.289030"/>
</test>
<test id="s1-s13-t43" name="Play_To_Odl_route_inc_lacp" line="168">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:19.092310" elapsed="0.000220"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:19.092036" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:19.093763" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:19.093591" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.093567" elapsed="0.000274"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:19.100795" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:19.100684" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.100665" elapsed="0.000287"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.102079" 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-06-06T03:26:19.101671" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.102577" 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-06-06T03:26:19.102276" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:19.102665" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:26:19.102827" 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-06-06T03:26:19.101193" elapsed="0.001659"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:19.108788" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:19.108674" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.108652" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:19.110422" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:19.110236" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.110216" elapsed="0.000372"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:19.111183" 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-06-06T03:26:19.110763" elapsed="0.000483"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:19.111895" level="INFO">${current_connection_index} = 7</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-06-06T03:26:19.111606" elapsed="0.000352"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:19.146199" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:19.114152" elapsed="0.032188"/>
</kw>
<msg time="2026-06-06T03:26:19.146485" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:19.146580" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:19.112422" elapsed="0.034265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:19.176291" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:19.148663" elapsed="0.027772"/>
</kw>
<msg time="2026-06-06T03:26:19.176573" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:19.176698" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:19.147099" elapsed="0.029672"/>
</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-06-06T03:26:19.177507" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:19.177080" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.177054" elapsed="0.000664"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.178463" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:19.177880" elapsed="0.000700"/>
</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-06-06T03:26:19.179136" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:19.178775" elapsed="0.000478"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.178754" elapsed="0.000558"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:19.179351" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:19.182995" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:26:19.183184" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:19.182474" elapsed="0.000782"/>
</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="NOT RUN" start="2026-06-06T03:26:19.183531" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.183776" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:19.181699" elapsed="0.002306"/>
</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-06-06T03:26:19.179663" elapsed="0.004429"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:19.109779" elapsed="0.074493"/>
</kw>
<msg time="2026-06-06T03:26:19.184369" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:19.184414" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:19.109021" elapsed="0.075429"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:19.184766" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:26:19.184528" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.184508" elapsed="0.000356"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.185377" elapsed="0.000032"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.185889" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:19.185966" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:19.108313" elapsed="0.077768"/>
</kw>
<msg time="2026-06-06T03:26:19.186177" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:19.186223" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:19.103255" elapsed="0.083004"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.186598" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:19.186336" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.186318" elapsed="0.000389"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:19.103104" elapsed="0.083628"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:19.102914" elapsed="0.083852"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:19.100301" elapsed="0.086525"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:19.093225" elapsed="0.093661"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:19.092764" elapsed="0.094169"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:19.089792" elapsed="0.097197"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.191322" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.191472" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:19.191574" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.187428" elapsed="0.004172"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:19.191794" elapsed="0.003572"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.200757" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.200992" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:19.201148" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:19.195622" elapsed="0.005565"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:19.206162" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:19.205700" elapsed="0.000505"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:19.206872" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:19.206441" elapsed="0.000472"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:19.207157" elapsed="0.000543"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:19.201631" elapsed="0.006165"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:19.187145" elapsed="0.020734"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:19.089163" elapsed="0.118779"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:19.209117" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:19.209342" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:19.208805" elapsed="0.000624"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.235837" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_lacp.vanadium/route_inc_lacp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:19.235417" elapsed="0.000451"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:19.236697" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp.vanadium/route_inc_lacp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:19.236413" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp.vanadium/route_inc_lacp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:19.236881" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:19.236048" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.237496" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:19.237082" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:19.237902" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/route_inc_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:19.238058" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:19.237744" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.238515" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.238267" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:19.239025" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:19.238663" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.239620" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:19.239264" elapsed="0.000403"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:19.239114" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:19.238621" elapsed="0.001105"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.240346" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:19.239888" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:19.240429" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:26:19.240595" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:19.232993" elapsed="0.007628"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:19.241060" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/announce_route_inc_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/announce_route_inc_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:19.241188" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:19.240862" elapsed="0.000351"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:19.241625" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/withdraw_route_inc_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lacp/withdraw_route_inc_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:19.241783" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:19.241373" elapsed="0.000439"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.242225" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.241978" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.242693" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.242436" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.243140" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.242902" elapsed="0.000282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:19.243572" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:19.243337" elapsed="0.000280"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:19.243787" elapsed="0.002200"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:19.246175" elapsed="0.001438"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:19.252897" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:19.253083" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:19.253273" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:19.248617" elapsed="0.005270">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.254162" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:19.254494" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:19.248282" elapsed="0.006410">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:21.265708" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:21.265908" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:21.266054" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:21.256395" elapsed="0.009697"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:21.266769" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:21.269996" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:21.266354" elapsed="0.003711"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:21.274565" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:21.273963" elapsed="0.000642"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:21.275387" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:21.274847" elapsed="0.000579"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:21.275670" elapsed="0.000505"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:21.270383" elapsed="0.005880"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:21.255381" elapsed="0.020958"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:19.247835" elapsed="2.028569"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:21.276627" elapsed="0.002464"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:21.284662" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:21.284837" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:21.284958" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:21.280047" elapsed="0.004948"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:21.285231" elapsed="0.003908"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:21.296398" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:21.296516" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '489'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:21.296621" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:21.289380" elapsed="0.007288"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:21.299733" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:21.299434" elapsed="0.000357"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:21.300394" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:21.299952" elapsed="0.000471"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:21.300913" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "inc-multi-ethernet-tag-res": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:21.301117" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:21.300581" elapsed="0.000612">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:21.296909" elapsed="0.004425">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:21.279768" elapsed="0.021753">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.312685" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.312876" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.313024" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.303081" elapsed="0.009980"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.313310" elapsed="0.003759"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.324399" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.324593" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:23.324824" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.317307" elapsed="0.007557"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.329438" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.329005" elapsed="0.000472"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.330144" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.329743" elapsed="0.000440"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.330407" elapsed="0.000500"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.325231" elapsed="0.005762"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.302210" elapsed="0.028862"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:21.279269" elapsed="2.051860"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:23.331940" elapsed="0.002433"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.339877" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.339988" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.340142" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.335561" elapsed="0.004608"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.340338" elapsed="0.004053"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.349569" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.349791" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:23.349941" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.344636" elapsed="0.005341"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.354340" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.353944" elapsed="0.000436"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.355001" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.354603" elapsed="0.000437"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.355263" elapsed="0.000478"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.350312" elapsed="0.005516"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.335030" elapsed="0.020873"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:23.334553" elapsed="0.021404"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:23.331409" elapsed="0.024628"/>
</kw>
<arg>route_inc_lacp</arg>
<status status="PASS" start="2026-06-06T03:26:19.208270" elapsed="4.147834"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:19.088668" elapsed="4.267591"/>
</test>
<test id="s1-s13-t44" name="Odl_To_Play_route_inc_lan" line="171">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:23.360542" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:23.360274" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:23.361893" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.361769" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.361744" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:23.367151" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.367040" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.367021" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.368243" 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-06-06T03:26:23.367856" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.368754" 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-06-06T03:26:23.368437" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:23.368825" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:23.368996" 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-06-06T03:26:23.367454" elapsed="0.001567"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:23.374614" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.374504" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.374484" elapsed="0.000216"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:23.376200" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.376020" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.376000" elapsed="0.000361"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:23.376944" 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-06-06T03:26:23.376517" elapsed="0.000488"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:23.377618" level="INFO">${current_connection_index} = 7</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-06-06T03:26:23.377352" elapsed="0.000344"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:23.409338" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:23.379567" elapsed="0.030044"/>
</kw>
<msg time="2026-06-06T03:26:23.409899" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:23.410003" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:23.378034" elapsed="0.032041"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:23.437254" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "n "[K"
[?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-06-06T03:26:23.412291" elapsed="0.025099"/>
</kw>
<msg time="2026-06-06T03:26:23.437525" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:23.437622" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:23.410583" elapsed="0.027134"/>
</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-06-06T03:26:23.438489" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.438077" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.438040" elapsed="0.000655"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.439449" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "n "[K"
[?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-06-06T03:26:23.438859" elapsed="0.000709"/>
</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-06-06T03:26:23.440125" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.439766" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.439744" elapsed="0.000555"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:23.440344" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:23.444138" elapsed="0.000358"/>
</kw>
<msg time="2026-06-06T03:26:23.444545" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:23.443508" elapsed="0.001108"/>
</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="NOT RUN" start="2026-06-06T03:26:23.444857" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.445085" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:23.442724" elapsed="0.002585"/>
</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-06-06T03:26:23.440697" elapsed="0.004702"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:23.375540" elapsed="0.070041"/>
</kw>
<msg time="2026-06-06T03:26:23.445695" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:23.445743" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:23.374856" elapsed="0.070923"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:23.446125" elapsed="0.000040"/>
</return>
<status status="PASS" start="2026-06-06T03:26:23.445887" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.445865" elapsed="0.000363"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.446833" elapsed="0.000073"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.447381" elapsed="0.000032"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:23.447470" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:23.374154" elapsed="0.073432"/>
</kw>
<msg time="2026-06-06T03:26:23.447701" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:23.447748" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:23.369400" elapsed="0.078384"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.448127" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.447862" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.447843" elapsed="0.000363"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:23.369254" elapsed="0.078978"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:23.369077" elapsed="0.079190"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:23.366672" elapsed="0.081653"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:23.361430" elapsed="0.086955"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:23.360981" elapsed="0.087452"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:23.358082" elapsed="0.090409"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.454634" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.454828" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.454945" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.448955" elapsed="0.006020"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.455155" elapsed="0.002620"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.462556" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.462738" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:23.462883" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.458022" elapsed="0.004898"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.467749" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.466985" elapsed="0.000831"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.468812" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.468182" elapsed="0.000764"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.469317" elapsed="0.000873"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.463255" elapsed="0.007076"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.448664" elapsed="0.021786"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:23.357383" elapsed="0.113155"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.471549" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.471734" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.471346" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.472143" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.472271" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.471928" elapsed="0.000371"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.472664" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/announce_route_inc_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/announce_route_inc_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.472792" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.472459" elapsed="0.000360"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:23.473194" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:23.472982" elapsed="0.000239"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.473570" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/withdraw_route_inc_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/withdraw_route_inc_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.473713" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.473383" elapsed="0.000357"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:23.474116" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:23.473912" elapsed="0.000232"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.474551" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.474305" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.475018" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.474776" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.475458" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.475220" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.475948" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.475704" elapsed="0.000290"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:23.476145" elapsed="0.004190"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.490037" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '732', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:23.490127" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AxEAAhmZmZkAAQAAAAogKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.490270" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.480504" elapsed="0.009802"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.494068" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.490555" elapsed="0.003574"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.500486" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.500672" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:23.500819" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.494355" elapsed="0.006501"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.504558" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.501098" elapsed="0.003528"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.512369" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.512523" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:23.512694" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.506012" elapsed="0.006722"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.516467" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.512977" elapsed="0.003559"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.516779" elapsed="0.003548"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:23.522978" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.520559" elapsed="0.002461"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.523242" elapsed="0.003091"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:23.526404" elapsed="0.000045"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:23.505502" elapsed="0.021086"/>
</kw>
<msg time="2026-06-06T03:26:23.526722" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:23.504886" elapsed="0.021873"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.527340" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.526999" elapsed="0.000404"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.528623" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:23.528758" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:23.528260" elapsed="0.000532"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.529365" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:23.529467" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:23.529012" elapsed="0.000488"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.529740" elapsed="0.000444"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:23.530671" level="INFO">${sum_1} = 1836</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:23.530406" elapsed="0.000303"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:23.531164" level="INFO">${sum_2} = 1836</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:23.530924" elapsed="0.000275"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.531414" elapsed="0.000442"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:23.527744" elapsed="0.004196"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:23.532152" elapsed="0.002667"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.543930" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.544055" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:23.544152" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.536110" elapsed="0.008068"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.547008" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.544358" elapsed="0.002700"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.547219" elapsed="0.002511"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.556473" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.556629" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:23.556803" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.549910" elapsed="0.006930"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.560475" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.557084" elapsed="0.003459"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.560785" elapsed="0.003520"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:23.567680" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.564420" elapsed="0.003324"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.564390" elapsed="0.003387"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.575976" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.576064" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.576247" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.567993" elapsed="0.008306"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:23.535380" elapsed="0.041045"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.584232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.584475" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.584723" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.577658" elapsed="0.007126"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.589275" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.585178" elapsed="0.004163"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.589564" elapsed="0.003532"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:23.595815" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.593329" elapsed="0.002524"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.596012" elapsed="0.002202"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:23.598265" elapsed="0.000032"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:23.577310" elapsed="0.021120"/>
</kw>
<msg time="2026-06-06T03:26:23.598511" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:23.576778" elapsed="0.021759"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.598973" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.598723" elapsed="0.000296"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.600040" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:23.600114" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:23.599780" elapsed="0.000359"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.600547" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:23.600621" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:23.600295" elapsed="0.000365"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.600821" elapsed="0.000304"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:23.601459" level="INFO">${sum_1} = 1389</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:23.601285" elapsed="0.000199"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:23.601831" level="INFO">${sum_2} = 1389</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:23.601655" elapsed="0.000201"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.602041" elapsed="0.000308"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:23.599396" elapsed="0.003013"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.609044" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.609193" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.609321" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.602989" elapsed="0.006368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.613346" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.609595" elapsed="0.003817"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.613636" elapsed="0.003564"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.622115" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.622222" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.622323" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.617432" elapsed="0.004918"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.624972" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.622524" elapsed="0.002531"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.625217" elapsed="0.002884"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:23.631499" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:26:23.628208" elapsed="0.003376"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.628180" elapsed="0.003439"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.631880" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:23.602676" elapsed="0.029334"/>
</kw>
<arg>route_inc_lan</arg>
<status status="PASS" start="2026-06-06T03:26:23.471046" elapsed="0.161026"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.356733" elapsed="0.275484"/>
</test>
<test id="s1-s13-t45" name="Play_To_Odl_route_inc_lan" line="173">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:23.637261" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:23.636995" elapsed="0.000531"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:23.638546" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.638434" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.638414" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:23.643607" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.643501" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.643483" elapsed="0.000208"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.644702" 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-06-06T03:26:23.644303" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.645190" 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-06-06T03:26:23.644894" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:23.645260" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:26:23.645416" 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-06-06T03:26:23.643917" elapsed="0.001524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:23.651356" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.651246" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.651226" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:23.652879" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:23.652695" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.652674" elapsed="0.000366"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:23.653605" 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-06-06T03:26:23.653193" elapsed="0.000491"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:23.654330" level="INFO">${current_connection_index} = 7</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-06-06T03:26:23.654063" elapsed="0.000328"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:23.689477" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:23.656254" elapsed="0.033362"/>
</kw>
<msg time="2026-06-06T03:26:23.689774" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:23.689869" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:23.654718" elapsed="0.035222"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:23.718793" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "n "[K"
[?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-06-06T03:26:23.691908" elapsed="0.027015"/>
</kw>
<msg time="2026-06-06T03:26:23.719052" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:23.719146" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:23.690355" elapsed="0.028897"/>
</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-06-06T03:26:23.719943" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.719556" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.719533" elapsed="0.000589"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.720862" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "l "a "n "[K"
[?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-06-06T03:26:23.720275" elapsed="0.000703"/>
</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-06-06T03:26:23.721507" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.721157" elapsed="0.000467"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.721137" elapsed="0.000563"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:23.721739" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:23.725328" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:26:23.725513" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:23.724763" elapsed="0.000814"/>
</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="NOT RUN" start="2026-06-06T03:26:23.725812" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.726063" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:23.723963" elapsed="0.002323"/>
</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-06-06T03:26:23.722009" elapsed="0.004362"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:23.652233" elapsed="0.074316"/>
</kw>
<msg time="2026-06-06T03:26:23.726657" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:23.726703" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:23.651583" elapsed="0.075155"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:23.727068" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:23.726955" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.726930" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.727619" elapsed="0.000040"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.728061" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:23.728135" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:23.650905" elapsed="0.077340"/>
</kw>
<msg time="2026-06-06T03:26:23.728339" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:23.728382" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:23.645949" elapsed="0.082468"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.728829" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.728494" elapsed="0.000391"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.728476" elapsed="0.000433"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:23.645796" elapsed="0.083137"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:23.645498" elapsed="0.083465"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:23.643142" elapsed="0.085875"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:23.638143" elapsed="0.090929"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:23.637694" elapsed="0.091423"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:23.634441" elapsed="0.094767"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.734876" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.735016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.735145" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.729627" elapsed="0.005553"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:23.735416" elapsed="0.003943"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.745232" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.745377" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:23.745518" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:23.739596" elapsed="0.005960"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.749909" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.749478" elapsed="0.000470"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:23.750565" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:23.750190" elapsed="0.000413"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.750848" elapsed="0.000456"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:23.745908" elapsed="0.005480"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.729353" elapsed="0.022109"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:23.633506" elapsed="0.118012"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.752519" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.752735" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.752246" elapsed="0.000531"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.779097" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_lan.vanadium/route_inc_lan.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:23.778720" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.779888" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan.vanadium/route_inc_lan.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:23.779634" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan.vanadium/route_inc_lan.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:23.780094" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:23.779294" elapsed="0.000826"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.780696" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:23.780291" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.781027" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/route_inc_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.781154" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.780892" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.781589" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.781343" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:23.782025" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:23.781724" elapsed="0.000374"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.782568" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:23.782277" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.782124" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:23.781704" elapsed="0.000987"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.783286" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:23.782843" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:23.783363" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:26:23.783516" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:23.776382" elapsed="0.007160"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.783914" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/announce_route_inc_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/announce_route_inc_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.784044" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.783721" elapsed="0.000350"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:23.784417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/withdraw_route_inc_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_lan/withdraw_route_inc_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:23.784537" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:23.784228" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.784996" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.784750" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.785442" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.785204" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.785997" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.785738" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:23.786466" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:23.786224" elapsed="0.000286"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:23.786677" elapsed="0.002577"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:23.789430" elapsed="0.001624"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:23.796197" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:23.796346" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:23.796476" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:23.792033" elapsed="0.004966">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.797270" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:23.797602" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:23.791701" elapsed="0.006108">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:25.808557" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:25.808795" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:25.808947" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:25.799546" elapsed="0.009437"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:25.809688" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:25.813030" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:25.809251" elapsed="0.003933"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:25.817755" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:25.817097" elapsed="0.000699"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:25.818569" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:25.818019" elapsed="0.000589"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:25.818857" elapsed="0.000465"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:25.813509" elapsed="0.005901"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:25.798532" elapsed="0.020953"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:23.791243" elapsed="2.028308"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:25.819827" elapsed="0.002350"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:25.828897" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:25.829005" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:25.829134" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:25.823136" elapsed="0.006033"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:25.829407" elapsed="0.004294"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:25.839277" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:25.839448" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '489'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:25.839595" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:25.833955" elapsed="0.005677"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:25.844028" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:25.843585" elapsed="0.000485"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:25.844937" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:25.844292" elapsed="0.000685"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:25.845670" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "inc-multi-ethernet-tag-res": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:25.846017" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:25.845202" elapsed="0.000924">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:25.840026" elapsed="0.006306">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:25.822852" elapsed="0.023650">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:27.857024" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:27.857244" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:27.857400" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:27.848318" elapsed="0.009121"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:27.857737" elapsed="0.003726"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:27.869135" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:27.869323" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:27.869519" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:27.861731" elapsed="0.007841"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:27.875223" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:27.874786" elapsed="0.000479"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:27.875891" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:27.875491" elapsed="0.000509"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:27.876230" elapsed="0.000502"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:27.870066" elapsed="0.006756"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:27.847271" elapsed="0.029627"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:25.822357" elapsed="2.054597"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:27.877807" elapsed="0.002942"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:27.886914" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:27.887080" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:27.887225" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:27.882006" elapsed="0.005257"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:27.887498" elapsed="0.003570"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:27.895714" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:27.895819" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:27.895920" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:27.891301" elapsed="0.004645"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:27.899072" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:27.898792" elapsed="0.000308"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:27.899524" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:27.899258" elapsed="0.000293"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:27.899735" elapsed="0.000324"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:27.896180" elapsed="0.003940"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:27.881436" elapsed="0.018740"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:27.880930" elapsed="0.019284"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:27.877289" elapsed="0.022978"/>
</kw>
<arg>route_inc_lan</arg>
<status status="PASS" start="2026-06-06T03:26:23.751824" elapsed="4.148490"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:23.632783" elapsed="4.267642"/>
</test>
<test id="s1-s13-t46" name="Odl_To_Play_route_inc_mac" line="176">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:27.904755" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:27.904470" elapsed="0.000592"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:27.906116" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:27.905993" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.905970" elapsed="0.000269"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:27.911250" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:27.911142" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.911124" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:27.912339" 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-06-06T03:26:27.911951" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:27.912840" 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-06-06T03:26:27.912529" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:27.912911" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:27.913103" 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-06-06T03:26:27.911552" elapsed="0.001576"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:27.919054" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:27.918929" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.918904" elapsed="0.000228"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:27.920700" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:27.920491" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.920472" elapsed="0.000389"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:27.921552" 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-06-06T03:26:27.921089" elapsed="0.000526"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:27.922267" level="INFO">${current_connection_index} = 7</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-06-06T03:26:27.921997" elapsed="0.000330"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:27.956695" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:27.924197" elapsed="0.032643"/>
</kw>
<msg time="2026-06-06T03:26:27.956989" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:27.957117" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:27.922657" elapsed="0.034531"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:27.983867" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "m "a "c "[K"
[?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-06-06T03:26:27.959211" elapsed="0.024808"/>
</kw>
<msg time="2026-06-06T03:26:27.984159" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:27.984253" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:27.957611" elapsed="0.026711"/>
</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-06-06T03:26:27.985097" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:27.984665" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.984612" elapsed="0.000667"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:27.986051" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "m "a "c "[K"
[?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-06-06T03:26:27.985438" elapsed="0.000732"/>
</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-06-06T03:26:27.986715" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:27.986346" elapsed="0.000484"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.986324" elapsed="0.000564"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:27.986929" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:27.990919" elapsed="0.000247"/>
</kw>
<msg time="2026-06-06T03:26:27.991212" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:27.990332" elapsed="0.000952"/>
</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="NOT RUN" start="2026-06-06T03:26:27.991506" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:27.991750" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:27.989525" elapsed="0.002450"/>
</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-06-06T03:26:27.987411" elapsed="0.004652"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:27.920048" elapsed="0.072198"/>
</kw>
<msg time="2026-06-06T03:26:27.992344" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:27.992390" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:27.919318" elapsed="0.073109"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:27.992618" elapsed="0.000159"/>
</return>
<status status="PASS" start="2026-06-06T03:26:27.992506" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.992486" elapsed="0.000358"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:27.993366" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:27.993871" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:27.993946" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:27.918501" elapsed="0.075736"/>
</kw>
<msg time="2026-06-06T03:26:27.994335" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:27.994381" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:27.913509" elapsed="0.080909"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:27.994801" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:27.994495" elapsed="0.000361"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:27.994477" elapsed="0.000404"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:27.913362" elapsed="0.081543"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:27.913187" elapsed="0.081751"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:27.910780" elapsed="0.084217"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:27.905696" elapsed="0.089359"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:27.905232" elapsed="0.089869"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:27.901949" elapsed="0.093209"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.001806" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.001947" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:28.002059" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:27.995589" elapsed="0.006502"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.002384" elapsed="0.003625"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.012087" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.012192" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:28.012292" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.006247" elapsed="0.006072"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:28.015441" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:28.015133" elapsed="0.000337"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:28.015921" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:28.015630" elapsed="0.000320"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.016110" elapsed="0.000334"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.012551" elapsed="0.003956"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:27.995311" elapsed="0.021254"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:27.901447" elapsed="0.115162"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.017430" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.017609" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.017224" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.018008" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.018135" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.017816" elapsed="0.000346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.018510" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/announce_route_inc_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/announce_route_inc_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.018636" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.018320" elapsed="0.000359"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:28.019054" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:28.018841" elapsed="0.000241"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.019434" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/withdraw_route_inc_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/withdraw_route_inc_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.019561" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.019243" elapsed="0.000344"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:28.019964" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:28.019761" elapsed="0.000267"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.020449" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.020196" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.020925" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.020676" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.021403" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.021159" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.021865" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.021607" elapsed="0.000304"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:28.022066" elapsed="0.002535"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.037682" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '732', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:28.037774" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AxEAAhmZmZkAAQAAAAogKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.037915" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.024894" elapsed="0.013056"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.044940" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.038271" elapsed="0.006776"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.052414" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.052555" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:28.052689" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.045469" elapsed="0.007249"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.055416" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.052896" elapsed="0.002626"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.062012" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.062171" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:28.062305" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.056551" elapsed="0.005791"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.066067" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.062585" elapsed="0.003550"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.066358" elapsed="0.003610"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:28.072716" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:28.070203" elapsed="0.002556"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.073011" elapsed="0.003039"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:28.076127" elapsed="0.000055"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:28.056203" elapsed="0.020119"/>
</kw>
<msg time="2026-06-06T03:26:28.076436" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:28.055720" elapsed="0.020752"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.077071" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.076725" elapsed="0.000445"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.078405" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:28.078508" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:28.078041" elapsed="0.000500"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.079134" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:28.079238" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:28.078781" elapsed="0.000490"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.079489" elapsed="0.000445"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:28.080400" level="INFO">${sum_1} = 1836</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:28.080156" elapsed="0.000280"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:28.080909" level="INFO">${sum_2} = 1836</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:28.080666" elapsed="0.000279"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.081178" elapsed="0.000424"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:28.077500" elapsed="0.004207"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:28.081920" elapsed="0.002327"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.089683" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.089892" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:28.090026" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.084985" elapsed="0.005077"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.093965" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.090304" elapsed="0.003729"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.094362" elapsed="0.003541"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.103158" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.103271" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:28.103374" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.098142" elapsed="0.005259"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.106022" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.103576" elapsed="0.002495"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.106234" elapsed="0.002487"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:28.111108" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:28.108805" elapsed="0.002345"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.108784" elapsed="0.002390"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.117089" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.117156" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.117347" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.111325" elapsed="0.006071"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:28.084572" elapsed="0.032947"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.124001" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.124168" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:28.124371" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.118754" elapsed="0.005656"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.128156" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.124698" elapsed="0.003524"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.128445" elapsed="0.003557"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:28.134693" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:28.132239" elapsed="0.002498"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.134960" elapsed="0.003079"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:28.138113" elapsed="0.000050"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:28.118408" elapsed="0.019896"/>
</kw>
<msg time="2026-06-06T03:26:28.138416" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:28.117862" elapsed="0.020590"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.139054" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.138708" elapsed="0.000410"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.140372" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:28.140477" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:28.140002" elapsed="0.000509"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.141111" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:28.141251" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:28.140755" elapsed="0.000531"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.141508" elapsed="0.000457"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:28.142439" level="INFO">${sum_1} = 1389</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:28.142192" elapsed="0.000283"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:28.142961" level="INFO">${sum_2} = 1389</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:28.142716" elapsed="0.000282"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.143215" elapsed="0.000458"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:28.139454" elapsed="0.004306"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.149717" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.149867" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:28.149997" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.144553" elapsed="0.005479"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.155602" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.150275" elapsed="0.005415"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.155916" elapsed="0.003186"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.162908" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.163056" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:28.163158" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.159270" elapsed="0.003915"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.165829" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.163357" elapsed="0.002520"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.166035" elapsed="0.003512"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:28.172909" elapsed="0.000041"/>
</return>
<status status="PASS" start="2026-06-06T03:26:28.169680" elapsed="0.003313"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.169630" elapsed="0.003399"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.173273" elapsed="0.000034"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:28.144120" elapsed="0.029284"/>
</kw>
<arg>route_inc_mac</arg>
<status status="PASS" start="2026-06-06T03:26:28.016900" elapsed="0.156566"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:27.900888" elapsed="0.272721"/>
</test>
<test id="s1-s13-t47" name="Play_To_Odl_route_inc_mac" line="178">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:28.177721" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:28.177438" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:28.179000" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:28.178887" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.178867" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:28.184104" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:28.183997" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.183978" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.185209" 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-06-06T03:26:28.184800" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.185723" 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-06-06T03:26:28.185409" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:28.185793" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:26:28.185949" 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-06-06T03:26:28.184401" elapsed="0.001573"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:28.191930" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:28.191816" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.191795" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:28.193491" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:28.193306" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.193286" elapsed="0.000387"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:28.194394" 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-06-06T03:26:28.193830" elapsed="0.000626"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:28.195089" level="INFO">${current_connection_index} = 7</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-06-06T03:26:28.194821" elapsed="0.000329"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:28.226482" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:28.197162" elapsed="0.029523"/>
</kw>
<msg time="2026-06-06T03:26:28.226966" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:28.227063" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:28.195460" elapsed="0.031676"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:28.253096" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "m "a "c "[K"
[?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-06-06T03:26:28.229166" elapsed="0.024173"/>
</kw>
<msg time="2026-06-06T03:26:28.253523" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:28.253662" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:28.227574" elapsed="0.026166"/>
</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-06-06T03:26:28.254590" elapsed="0.000070"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:28.254082" elapsed="0.000652"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.254045" elapsed="0.000753"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.255595" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "m "a "c "[K"
[?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-06-06T03:26:28.254958" elapsed="0.000807"/>
</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-06-06T03:26:28.256333" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:28.255947" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.255926" elapsed="0.000585"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:28.256553" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:28.260541" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:26:28.260752" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:28.259830" elapsed="0.000992"/>
</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="NOT RUN" start="2026-06-06T03:26:28.261044" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.261310" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:28.259034" elapsed="0.002505"/>
</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-06-06T03:26:28.256915" elapsed="0.004714"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:28.192844" elapsed="0.069150"/>
</kw>
<msg time="2026-06-06T03:26:28.262109" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:28.262157" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:28.192162" elapsed="0.070036"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:28.262389" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:28.262278" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.262258" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.262992" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.263425" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:28.263499" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:28.191442" elapsed="0.072168"/>
</kw>
<msg time="2026-06-06T03:26:28.263768" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:28.263813" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:28.186348" elapsed="0.077502"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.264243" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:28.263982" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.263963" elapsed="0.000358"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:28.186203" elapsed="0.078142"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:28.186029" elapsed="0.078351"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:28.183618" elapsed="0.080819"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:28.178580" elapsed="0.085917"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:28.178147" elapsed="0.086398"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:28.175064" elapsed="0.089537"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.269913" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.270050" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:28.270146" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.265051" elapsed="0.005121"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:28.270345" elapsed="0.002922"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.279443" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.279591" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:28.279760" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:28.273438" elapsed="0.006361"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:28.284151" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:28.283732" elapsed="0.000459"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:28.284823" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:28.284416" elapsed="0.000446"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.285089" elapsed="0.000491"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:28.280120" elapsed="0.005569"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:28.264769" elapsed="0.021003"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:28.174390" elapsed="0.111441"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.286848" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.287056" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.286546" elapsed="0.000603"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.314448" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_mac.vanadium/route_inc_mac.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:28.314058" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.315279" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac.vanadium/route_inc_mac.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:28.315026" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac.vanadium/route_inc_mac.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:28.315456" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:28.314668" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.316058" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:28.315667" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.316388" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/route_inc_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.316523" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.316252" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.316975" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.316728" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:28.317444" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:28.317100" elapsed="0.000405"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.317994" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:28.317697" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:28.317532" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:28.317077" elapsed="0.001000"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.318692" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:28.318229" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:28.318774" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:26:28.318935" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:28.311702" elapsed="0.007259"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.319320" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/announce_route_inc_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/announce_route_inc_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.319446" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.319126" elapsed="0.000346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:28.319863" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/withdraw_route_inc_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_mac/withdraw_route_inc_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:28.319996" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:28.319630" elapsed="0.000425"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.320472" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.320225" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.320941" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.320700" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.321414" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.321143" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:28.321872" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:28.321616" elapsed="0.000301"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:28.322070" elapsed="0.002615"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:28.324873" elapsed="0.002327"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:28.332874" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:28.333050" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:28.333191" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:28.328249" elapsed="0.005497">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.334020" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:28.334355" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:28.327899" elapsed="0.006629">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:30.345439" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:30.345639" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:30.345907" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:30.336265" elapsed="0.009682"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:30.346708" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:30.350041" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:30.346210" elapsed="0.003901"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:30.354753" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:30.354096" elapsed="0.000699"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:30.355574" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:30.355023" elapsed="0.000590"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:30.355867" elapsed="0.000469"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:30.350488" elapsed="0.005938"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:30.335236" elapsed="0.021268"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:28.327393" elapsed="2.029175"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:30.356855" elapsed="0.002665"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:30.365218" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:30.365330" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:30.365424" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:30.360467" elapsed="0.004984"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:30.365621" elapsed="0.003418"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:30.374525" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:30.374723" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '489'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:30.374875" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:30.369275" elapsed="0.005637"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:30.379353" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:30.378892" elapsed="0.000500"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:30.380269" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:30.379616" elapsed="0.000692"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:30.381002" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "inc-multi-ethernet-tag-res": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:30.381292" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:30.380533" elapsed="0.000868">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:30.375257" elapsed="0.006341">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:30.360188" elapsed="0.021603">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.391051" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.391283" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.391440" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.383344" elapsed="0.008135"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.391754" elapsed="0.003693"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.402164" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.402390" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:32.402536" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.395711" elapsed="0.006862"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.406972" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.406515" elapsed="0.000496"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.407841" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.407254" elapsed="0.000632"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.408144" elapsed="0.000470"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.402932" elapsed="0.005791"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.382473" elapsed="0.026327"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:30.359730" elapsed="2.049125"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:32.409613" elapsed="0.002848"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.417386" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.417495" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.417599" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.413692" elapsed="0.003934"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.417817" elapsed="0.002615"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.424403" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.424551" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:32.424721" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.420689" elapsed="0.004072"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.428893" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.428595" elapsed="0.000326"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.429346" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.429081" elapsed="0.000293"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.429533" elapsed="0.000340"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.425091" elapsed="0.004883"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.413135" elapsed="0.016893"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:32.412679" elapsed="0.017387"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:32.409117" elapsed="0.021003"/>
</kw>
<arg>route_inc_mac</arg>
<status status="PASS" start="2026-06-06T03:26:28.286126" elapsed="4.144041"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:28.173905" elapsed="4.256376"/>
</test>
<test id="s1-s13-t48" name="Odl_To_Play_route_inc_rou" line="181">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:32.434453" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:32.434180" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:32.435795" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.435669" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.435631" elapsed="0.000236"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:32.440902" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.440794" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.440775" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.441986" 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-06-06T03:26:32.441585" elapsed="0.000428"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.442471" 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-06-06T03:26:32.442178" elapsed="0.000319"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:32.442541" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:26:32.442719" 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-06-06T03:26:32.441198" elapsed="0.001546"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:32.448545" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.448435" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.448415" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:32.450090" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.449906" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.449886" elapsed="0.000367"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:32.450840" 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-06-06T03:26:32.450410" elapsed="0.000493"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:32.451538" level="INFO">${current_connection_index} = 7</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-06-06T03:26:32.451270" elapsed="0.000330"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:32.485415" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:32.453479" elapsed="0.032156"/>
</kw>
<msg time="2026-06-06T03:26:32.485856" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:32.485957" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:32.451936" elapsed="0.034097"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:32.517582" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "r "o "u "[K"
[?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-06-06T03:26:32.488237" elapsed="0.029808"/>
</kw>
<msg time="2026-06-06T03:26:32.518432" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:32.518698" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:32.486495" elapsed="0.032368"/>
</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-06-06T03:26:32.520545" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.519681" elapsed="0.001007"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.519575" elapsed="0.001184"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.521614" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "i "n "c "_ "r "o "u "[K"
[?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-06-06T03:26:32.520922" elapsed="0.000833"/>
</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-06-06T03:26:32.522306" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.521938" elapsed="0.000487"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.521916" elapsed="0.000569"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:32.522530" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:32.526516" elapsed="0.000171"/>
</kw>
<msg time="2026-06-06T03:26:32.526733" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:32.525790" elapsed="0.001017"/>
</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="NOT RUN" start="2026-06-06T03:26:32.527030" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.527265" elapsed="0.000029"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:32.524977" elapsed="0.002522"/>
</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-06-06T03:26:32.522904" elapsed="0.004682"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:32.449437" elapsed="0.078349"/>
</kw>
<msg time="2026-06-06T03:26:32.527886" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:32.527931" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:32.448790" elapsed="0.079179"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:32.528160" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:32.528048" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.528028" elapsed="0.000594"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.529140" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.529580" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:32.529672" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:32.448094" elapsed="0.081695"/>
</kw>
<msg time="2026-06-06T03:26:32.529895" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:32.529940" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:32.443126" elapsed="0.086852"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.530325" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.530057" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.530039" elapsed="0.000363"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:32.442978" elapsed="0.087449"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:32.442802" elapsed="0.087661"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:32.440416" elapsed="0.090108"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:32.435358" elapsed="0.095226"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:32.434893" elapsed="0.095740"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:32.431632" elapsed="0.099076"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.536937" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.537081" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.537201" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.531213" elapsed="0.006016"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.537407" elapsed="0.002682"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.545288" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.545438" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:32.545581" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.540259" elapsed="0.005362"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.550105" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.549674" elapsed="0.000471"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.550772" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.550369" elapsed="0.000444"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.551038" elapsed="0.000481"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.545981" elapsed="0.005625"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.530902" elapsed="0.020805"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:32.431136" elapsed="0.120632"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.552960" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.553213" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.552674" elapsed="0.000580"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.553770" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.553946" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.553481" elapsed="0.000503"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.554466" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/announce_route_inc_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/announce_route_inc_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.554657" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.554204" elapsed="0.000535"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:32.555300" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:32.554968" elapsed="0.000371"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.555857" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/withdraw_route_inc_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/withdraw_route_inc_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.556034" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.555569" elapsed="0.000502"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:32.556479" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:32.556277" elapsed="0.000229"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.556942" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.556689" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.557406" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.557160" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.557939" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.557623" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.558473" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.558189" elapsed="0.000334"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:32.558723" elapsed="0.002849"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.573709" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '732', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:32.573847" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AxEAAhmZmZkAAQAAAAogKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.574056" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.561776" elapsed="0.012336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.580432" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.574508" elapsed="0.006019"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.589385" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.589508" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:32.589612" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.580921" elapsed="0.008718"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.592357" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.589839" elapsed="0.002587"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.599788" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.599951" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:32.600085" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.593863" elapsed="0.006257"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.603777" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.600363" elapsed="0.003482"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.604069" elapsed="0.003540"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:32.609923" level="INFO">${update} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.607864" elapsed="0.002088"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.610134" elapsed="0.002197"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:32.612389" elapsed="0.000046"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:32.593357" elapsed="0.019183"/>
</kw>
<msg time="2026-06-06T03:26:32.612621" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:32.592694" elapsed="0.019969"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.613087" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.612837" elapsed="0.000297"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.614021" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:32.614097" level="INFO">${len_1} = 136</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:32.613758" elapsed="0.000362"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.614537" level="INFO">Length is 136.</msg>
<msg time="2026-06-06T03:26:32.614611" level="INFO">${len_2} = 136</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:32.614283" elapsed="0.000352"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.614967" elapsed="0.000358"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:32.615751" level="INFO">${sum_1} = 1836</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:32.615544" elapsed="0.000234"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:32.616112" level="INFO">${sum_2} = 1836</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:32.615936" elapsed="0.000202"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.616329" elapsed="0.000452"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:32.613373" elapsed="0.003493"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:32.617081" elapsed="0.002172"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.627560" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.627935" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:32.628173" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.620002" elapsed="0.008216"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.633530" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.628594" elapsed="0.005021"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.633979" elapsed="0.003383"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.642466" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.642603" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:32.642742" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.637536" elapsed="0.005247"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.646059" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","path-id":0,"inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.643013" elapsed="0.003115"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.646361" elapsed="0.003506"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:32.653084" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.649996" elapsed="0.003142"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.649958" elapsed="0.003205"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.659356" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.659473" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.659580" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.653331" elapsed="0.006276"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:32.619583" elapsed="0.040123"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.666069" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.666265" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.666414" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.661000" elapsed="0.005451"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.670380" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.666750" elapsed="0.003699"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.670697" elapsed="0.003526"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:32.676786" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.674461" elapsed="0.002355"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.677001" elapsed="0.002154"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:32.679211" elapsed="0.000069"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:32.660483" elapsed="0.018911"/>
</kw>
<msg time="2026-06-06T03:26:32.679479" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:32.659888" elapsed="0.019617"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.679942" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.679693" elapsed="0.000294"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.680921" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:32.680996" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:32.680653" elapsed="0.000367"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.681429" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:26:32.681502" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:32.681176" elapsed="0.000350"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.681701" elapsed="0.000308"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:32.682353" level="INFO">${sum_1} = 1389</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:32.682169" elapsed="0.000209"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:32.682725" level="INFO">${sum_2} = 1389</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:32.682531" elapsed="0.000219"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.682907" elapsed="0.000305"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:32.680248" elapsed="0.003036"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.687621" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.687815" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.687912" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.683894" elapsed="0.004044"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.690794" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.688112" elapsed="0.002730"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.691001" elapsed="0.002522"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.697684" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.697840" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.697983" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.693706" elapsed="0.004314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.701689" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.698263" elapsed="0.003495"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.701980" elapsed="0.003533"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:32.708938" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:26:32.705632" elapsed="0.003393"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.705600" elapsed="0.003461"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.709279" elapsed="0.000030"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:32.683569" elapsed="0.025834"/>
</kw>
<arg>route_inc_rou</arg>
<status status="PASS" start="2026-06-06T03:26:32.552218" elapsed="0.157250"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.430700" elapsed="0.278928"/>
</test>
<test id="s1-s13-t49" name="Play_To_Odl_route_inc_rou" line="183">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:32.715738" elapsed="0.000294"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:32.715344" elapsed="0.000766"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:32.717207" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.717092" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.717072" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:32.722276" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.722170" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.722152" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.723472" 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-06-06T03:26:32.723047" elapsed="0.000452"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.723989" 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-06-06T03:26:32.723688" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:32.724059" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:26:32.724215" 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-06-06T03:26:32.722575" elapsed="0.001665"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:32.730123" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.730008" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.729987" elapsed="0.000209"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:32.731802" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:32.731586" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.731566" elapsed="0.000402"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:32.732561" 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-06-06T03:26:32.732128" elapsed="0.000498"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:32.733272" level="INFO">${current_connection_index} = 7</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-06-06T03:26:32.733002" elapsed="0.000333"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:32.771945" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:32.735457" elapsed="0.036790"/>
</kw>
<msg time="2026-06-06T03:26:32.772475" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:32.772619" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:32.733813" elapsed="0.038949"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:32.801734" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "r "o "u "[K"
[?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-06-06T03:26:32.775833" elapsed="0.026048"/>
</kw>
<msg time="2026-06-06T03:26:32.802037" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:32.802162" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:32.773380" elapsed="0.028864"/>
</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-06-06T03:26:32.803043" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.802597" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.802571" elapsed="0.000672"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.804210" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "i "n "c "_ "r "o "u "[K"
[?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-06-06T03:26:32.803479" elapsed="0.000890"/>
</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-06-06T03:26:32.805070" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.804592" elapsed="0.000637"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.804565" elapsed="0.000746"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:32.805369" elapsed="0.000053"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:32.809803" elapsed="0.000172"/>
</kw>
<msg time="2026-06-06T03:26:32.810026" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:32.808937" elapsed="0.001163"/>
</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="NOT RUN" start="2026-06-06T03:26:32.810330" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.810620" elapsed="0.000110"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:32.808015" elapsed="0.002972"/>
</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-06-06T03:26:32.805832" elapsed="0.005274"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:32.731115" elapsed="0.080275"/>
</kw>
<msg time="2026-06-06T03:26:32.811519" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:32.811572" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:32.730371" elapsed="0.081240"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:32.812086" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:26:32.811963" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.811938" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.812757" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.813309" elapsed="0.000035"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:32.813406" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:32.729656" elapsed="0.083890"/>
</kw>
<msg time="2026-06-06T03:26:32.813679" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:32.813742" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:32.724756" elapsed="0.089037"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.814192" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.813898" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.813873" elapsed="0.000402"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:32.724587" elapsed="0.089714"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:32.724392" elapsed="0.089947"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:32.721808" elapsed="0.092596"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:32.716799" elapsed="0.097665"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:32.716338" elapsed="0.098174"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:32.712249" elapsed="0.102320"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.823480" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.823674" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.823790" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.815043" elapsed="0.008774"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:32.823993" elapsed="0.003877"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.834591" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.834719" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:32.834825" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:32.828125" elapsed="0.006727"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.838138" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.837817" elapsed="0.000349"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:32.838599" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:32.838326" elapsed="0.000301"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.838805" elapsed="0.000335"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:32.835145" elapsed="0.004056"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.814746" elapsed="0.024511"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:32.710984" elapsed="0.128327"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.840089" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.840259" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;42949...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.839865" elapsed="0.000426"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.869440" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_rou.vanadium/route_inc_rou.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:32.869053" elapsed="0.000416"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.870277" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou.vanadium/route_inc_rou.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:32.870020" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou.vanadium/route_inc_rou.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:32.870457" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:32.869660" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.871061" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:32.870668" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.871417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/route_inc_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.871570" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.871254" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.872046" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.871795" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:32.872499" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:32.872168" elapsed="0.000390"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.873048" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:32.872750" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.872584" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:32.872145" elapsed="0.000987"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.873755" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:32.873285" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:32.873872" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:32.874037" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:32.866586" elapsed="0.007478"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.874425" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/announce_route_inc_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/announce_route_inc_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.874552" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.874228" elapsed="0.000350"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:32.874977" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/withdraw_route_inc_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_inc_rou/withdraw_route_inc_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:32.875101" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:32.874772" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.875606" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AxEAAhmZmZkAAQAAAAogKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;inc-multi-ethernet-tag-res&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
    &lt;/inc-multi-ethernet-tag-res&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.875290" elapsed="0.000401"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.876107" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.875861" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.876554" level="INFO">ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.876313" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:32.877010" level="INFO">ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:32.876770" elapsed="0.000284"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:32.877205" elapsed="0.002426"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:32.879821" elapsed="0.001841"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:32.886813" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:32.886979" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:32.887121" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:32.882617" elapsed="0.005166">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.888122" elapsed="0.000035"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:32.888481" elapsed="0.000036"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:32.882291" elapsed="0.006405">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:34.899852" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:34.900107" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '341'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:34.900272" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:34.890578" elapsed="0.009734"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:34.901079" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "inc-multi-ethernet-tag-res": {
          "orig-route-ip": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw==",
        "route-distinguisher": "429496729:1"
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:34.904893" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:34.900605" elapsed="0.004365"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:34.910021" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:34.909265" elapsed="0.000798"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:34.910878" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:34.910293" elapsed="0.000626"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:34.911148" elapsed="0.000466"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:34.905328" elapsed="0.006400"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:34.889453" elapsed="0.022352"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:32.881859" elapsed="2.030014"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:34.912139" elapsed="0.003210"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:34.923190" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:34.923357" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:34.923493" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:34.916706" elapsed="0.006823"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:34.923872" elapsed="0.003983"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:34.933150" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:34.933314" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '489'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AxEAAhmZmZkAAQAAAAogKysrKw==","inc-multi-ethernet-tag-res":{"orig-route-ip":"43.43.43.43","ethernet-tag-id":{"vlan-id":10}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:34.933462" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:34.928115" elapsed="0.005384"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:34.937842" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:34.937420" elapsed="0.000463"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:34.938829" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:34.938108" elapsed="0.000765"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:34.939547" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "inc-multi-ethernet-tag-res": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:34.939863" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:34.939102" elapsed="0.000901">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:34.933851" elapsed="0.006360">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:34.916289" elapsed="0.024094">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "inc-multi-ethernet-tag-res": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AxEAAhmZmZkAAQAAAAogKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:36.951534" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:36.951757" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:36.951906" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:36.941998" elapsed="0.009945"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:36.952196" elapsed="0.003704"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:36.962748" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:36.962897" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:36.963040" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:36.956142" elapsed="0.006935"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:36.967428" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:36.967008" elapsed="0.000459"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:36.968088" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:36.967711" elapsed="0.000416"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:36.968349" elapsed="0.000525"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:36.963414" elapsed="0.005557"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:36.941159" elapsed="0.027888"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:34.915628" elapsed="2.053474"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:36.969877" elapsed="0.002997"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:36.978453" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:36.978562" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:36.978683" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:36.974060" elapsed="0.004651"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:36.978878" elapsed="0.002930"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:36.987912" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:36.988122" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:36.988263" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:36.982043" elapsed="0.006258"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:36.992736" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:36.992309" elapsed="0.000467"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:36.993373" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:36.992999" elapsed="0.000413"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:36.993633" elapsed="0.000472"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:36.988682" elapsed="0.005510"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:36.973504" elapsed="0.020765"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:36.973052" elapsed="0.021270"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:36.969363" elapsed="0.025036"/>
</kw>
<arg>route_inc_rou</arg>
<status status="PASS" start="2026-06-06T03:26:32.839542" elapsed="4.154923"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:32.710233" elapsed="4.284381"/>
</test>
<test id="s1-s13-t50" name="Odl_To_Play_route_mac_arb" line="186">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:36.999871" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:36.999587" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:37.001202" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.001079" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.001055" elapsed="0.000221"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:37.006289" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.006181" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.006163" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.007375" 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-06-06T03:26:37.006990" elapsed="0.000412"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.007881" 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-06-06T03:26:37.007567" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:37.007952" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:37.008115" 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-06-06T03:26:37.006590" elapsed="0.001550"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:37.013987" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.013876" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.013857" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:37.015516" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.015329" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.015309" elapsed="0.000388"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:37.016262" 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-06-06T03:26:37.015854" elapsed="0.000468"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:37.017060" level="INFO">${current_connection_index} = 7</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-06-06T03:26:37.016784" elapsed="0.000339"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:37.051291" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:37.019025" elapsed="0.032401"/>
</kw>
<msg time="2026-06-06T03:26:37.051565" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:37.051870" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:37.017450" elapsed="0.034493"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:37.078874" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "a "r "b "[K"
[?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-06-06T03:26:37.053929" elapsed="0.025121"/>
</kw>
<msg time="2026-06-06T03:26:37.079209" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:37.079304" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:37.052347" elapsed="0.027030"/>
</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-06-06T03:26:37.080166" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.079739" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.079707" elapsed="0.000641"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.081177" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "a "r "b "[K"
[?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-06-06T03:26:37.080539" elapsed="0.000758"/>
</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-06-06T03:26:37.081852" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.081476" elapsed="0.000494"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.081455" elapsed="0.000575"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:37.082074" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:37.085931" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:26:37.086125" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:37.085244" elapsed="0.000950"/>
</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="NOT RUN" start="2026-06-06T03:26:37.086417" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.086652" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:37.084413" elapsed="0.002464"/>
</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-06-06T03:26:37.082403" elapsed="0.004561"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:37.014888" elapsed="0.072259"/>
</kw>
<msg time="2026-06-06T03:26:37.087244" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:37.087290" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:37.014216" elapsed="0.073113"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:37.087517" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:37.087408" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.087389" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.088169" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.088660" elapsed="0.000078"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:37.088855" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:37.013521" elapsed="0.075451"/>
</kw>
<msg time="2026-06-06T03:26:37.089069" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:37.089114" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:37.008542" elapsed="0.080609"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.089489" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.089229" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.089211" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:37.008373" elapsed="0.081220"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:37.008198" elapsed="0.081428"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:37.005818" elapsed="0.083924"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:37.000779" elapsed="0.089023"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:37.000295" elapsed="0.089556"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:36.997289" elapsed="0.092618"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.097252" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.097390" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:37.097505" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.090337" elapsed="0.007195"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.097905" elapsed="0.002888"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.107072" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.107220" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:37.107364" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.100962" elapsed="0.006441"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:37.111780" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:37.111340" elapsed="0.000480"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:37.112431" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:37.112047" elapsed="0.000423"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.112749" elapsed="0.000459"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.107756" elapsed="0.005539"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:37.090058" elapsed="0.023365"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:36.996152" elapsed="0.117329"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.114569" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.114802" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.114282" elapsed="0.000562"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.115335" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.115511" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.115068" elapsed="0.000481"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.116065" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/announce_route_mac_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/announce_route_mac_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.116242" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.115795" elapsed="0.000485"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:37.116854" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:37.116537" elapsed="0.000355"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.117389" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/withdraw_route_mac_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/withdraw_route_mac_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.117516" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.117121" elapsed="0.000422"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:37.117925" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:37.117722" elapsed="0.000230"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.118361" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.118115" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.118838" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.118575" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.119282" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.119043" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.119741" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.119483" elapsed="0.000335"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:37.119975" elapsed="0.002510"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.137832" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '938', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:37.137973" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AhgAAhmZmZkAAQAAAAow8gzdgJ%2F3ICsrKys%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.138179" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.122697" elapsed="0.015539"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.143364" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.138636" elapsed="0.004789"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.151196" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.151771" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '451'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:37.151922" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.143672" elapsed="0.008287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.155637" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.152203" elapsed="0.003524"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.162734" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.163098" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '451'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:37.163226" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.157098" elapsed="0.006155"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.165891" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.163430" elapsed="0.002510"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.166099" elapsed="0.002554"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:37.171183" level="INFO">${update} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:37.168822" elapsed="0.002402"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.171478" elapsed="0.003042"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:37.174591" elapsed="0.000045"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:37.156611" elapsed="0.018184"/>
</kw>
<msg time="2026-06-06T03:26:37.174905" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:37.155969" elapsed="0.018972"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.175522" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.175177" elapsed="0.000408"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.176888" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:37.176994" level="INFO">${len_1} = 182</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:37.176445" elapsed="0.000583"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.177608" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:37.177735" level="INFO">${len_2} = 182</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:37.177253" elapsed="0.000525"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.177998" elapsed="0.000428"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:37.178933" level="INFO">${sum_1} = 3514</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:37.178669" elapsed="0.000300"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:37.179441" level="INFO">${sum_2} = 3514</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:37.179188" elapsed="0.000288"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.179716" elapsed="0.000426"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:37.175931" elapsed="0.004294"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:37.180437" elapsed="0.002180"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.189612" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.189806" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '451'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:37.189941" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.183352" elapsed="0.006627"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.193948" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.190222" elapsed="0.003851"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.194300" elapsed="0.003537"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.205007" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.205168" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '451'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:37.205313" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.198072" elapsed="0.007279"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.209139" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.205594" elapsed="0.003616"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.209434" elapsed="0.003573"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:37.216464" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.213120" elapsed="0.003436"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.213090" elapsed="0.003500"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.223575" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.223619" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.223739" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.216824" elapsed="0.006942"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:37.182964" elapsed="0.040871"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.230150" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.230299" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:37.230430" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.224849" elapsed="0.005617"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.234145" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.230736" elapsed="0.003476"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.234436" elapsed="0.003621"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:37.241040" level="INFO">${update} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:37.238339" elapsed="0.002743"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.241303" elapsed="0.003062"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:37.244436" elapsed="0.000045"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:37.224464" elapsed="0.020200"/>
</kw>
<msg time="2026-06-06T03:26:37.244779" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:37.224003" elapsed="0.020812"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.245396" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.245050" elapsed="0.000409"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.246710" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:37.246818" level="INFO">${len_1} = 170</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:37.246315" elapsed="0.000538"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.247433" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:37.247539" level="INFO">${len_2} = 170</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:37.247077" elapsed="0.000496"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.247816" elapsed="0.000428"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:37.248770" level="INFO">${sum_1} = 3067</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:37.248473" elapsed="0.000333"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:37.249275" level="INFO">${sum_2} = 3067</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:37.249024" elapsed="0.000286"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.249533" elapsed="0.000448"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:37.245804" elapsed="0.004261"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.256104" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.256219" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:37.256312" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.250857" elapsed="0.005481"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.259225" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.256541" elapsed="0.002733"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.259437" elapsed="0.002753"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.267534" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.267746" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:37.268000" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.262425" elapsed="0.005615"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.271866" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.268315" elapsed="0.003620"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.272161" elapsed="0.003575"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:37.279151" elapsed="0.000047"/>
</return>
<status status="PASS" start="2026-06-06T03:26:37.275859" elapsed="0.003387"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.275826" elapsed="0.003455"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.279504" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:37.250414" elapsed="0.029221"/>
</kw>
<arg>route_mac_arb</arg>
<status status="PASS" start="2026-06-06T03:26:37.113863" elapsed="0.165863"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:36.995328" elapsed="0.284548"/>
</test>
<test id="s1-s13-t51" name="Play_To_Odl_route_mac_arb" line="188">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:37.284116" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:37.283848" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:37.285426" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.285315" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.285295" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:37.290597" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.290489" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.290470" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.291702" 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-06-06T03:26:37.291301" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.292191" 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-06-06T03:26:37.291895" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:37.292261" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:26:37.292416" 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-06-06T03:26:37.290917" elapsed="0.001524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:37.298268" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.298159" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.298139" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:37.299823" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:37.299612" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.299593" elapsed="0.000392"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:37.300592" 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-06-06T03:26:37.300139" elapsed="0.000536"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:37.301300" level="INFO">${current_connection_index} = 7</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-06-06T03:26:37.301032" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:37.334998" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:37.303250" elapsed="0.031881"/>
</kw>
<msg time="2026-06-06T03:26:37.335265" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:37.335359" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:37.301696" elapsed="0.033736"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:37.380459" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "a "r "b "[K"
[?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-06-06T03:26:37.337625" elapsed="0.043002"/>
</kw>
<msg time="2026-06-06T03:26:37.380782" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:37.380877" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:37.335860" elapsed="0.045090"/>
</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-06-06T03:26:37.381608" elapsed="0.000066"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.381248" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.381226" elapsed="0.000578"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.382527" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "a "r "b "[K"
[?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-06-06T03:26:37.381956" elapsed="0.000704"/>
</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-06-06T03:26:37.383192" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.382838" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.382818" elapsed="0.000550"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:37.383406" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:37.386960" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:26:37.387146" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:37.386421" elapsed="0.000790"/>
</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="NOT RUN" start="2026-06-06T03:26:37.387427" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.387666" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:37.385669" elapsed="0.002217"/>
</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-06-06T03:26:37.383698" elapsed="0.004274"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:37.299168" elapsed="0.088978"/>
</kw>
<msg time="2026-06-06T03:26:37.388241" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:37.388286" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:37.298498" elapsed="0.089825"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:37.388510" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-06-06T03:26:37.388401" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.388382" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.389096" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.389526" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:37.389600" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:37.297819" elapsed="0.091972"/>
</kw>
<msg time="2026-06-06T03:26:37.389887" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:37.389931" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:37.292868" elapsed="0.097102"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.390303" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.390047" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.390029" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:37.292720" elapsed="0.097686"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:37.292496" elapsed="0.097973"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:37.290122" elapsed="0.100406"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:37.285025" elapsed="0.105560"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:37.284569" elapsed="0.106062"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:37.281662" elapsed="0.109041"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.401463" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.401626" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:37.401790" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.391132" elapsed="0.010694"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:37.402063" elapsed="0.004239"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.412344" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.412490" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:37.412674" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:37.406549" elapsed="0.006165"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:37.417072" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:37.416637" elapsed="0.000474"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:37.417732" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:37.417335" elapsed="0.000435"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.417996" elapsed="0.000456"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:37.413041" elapsed="0.005496"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:37.390853" elapsed="0.027761"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:37.280999" elapsed="0.137692"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.419707" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.419906" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.419406" elapsed="0.000540"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.448489" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_arb.vanadium/route_mac_arb.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:37.448109" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.449359" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb.vanadium/route_mac_arb.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:37.449115" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb.vanadium/route_mac_arb.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:37.449533" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:37.448760" elapsed="0.000798"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.450134" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:37.449745" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.450463" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/route_mac_arb.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.450599" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.450328" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.451050" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.450806" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:37.451480" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:37.451168" elapsed="0.000370"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.452021" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:37.451727" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:37.451563" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:37.451149" elapsed="0.000954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.452785" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:37.452255" elapsed="0.000560"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:37.452867" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:26:37.453025" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:37.445811" elapsed="0.007240"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.453411" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/announce_route_mac_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/announce_route_mac_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.453549" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.453217" elapsed="0.000359"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:37.453944" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/withdraw_route_mac_arb.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_arb/withdraw_route_mac_arb.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:37.454149" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:37.453752" elapsed="0.000424"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.454583" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.454338" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.455097" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.454855" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.455541" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.455303" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:37.456002" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:37.455758" elapsed="0.000289"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:37.456200" elapsed="0.002852"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:37.459223" elapsed="0.002085"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:37.469291" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:37.469452" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:37.469586" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:37.462696" elapsed="0.007416">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.470397" elapsed="0.000033"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:37.470780" elapsed="0.000035"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:37.462213" elapsed="0.008746">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:39.489077" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:39.489424" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '451'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:39.489739" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:39.472690" elapsed="0.017122"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:39.490946" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:39.495410" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:39.490254" elapsed="0.005234"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:39.500207" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:39.499519" elapsed="0.000728"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:39.501117" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:39.500471" elapsed="0.000685"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:39.501382" elapsed="0.000489"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:39.495914" elapsed="0.006047"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:39.471718" elapsed="0.030319"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:37.461567" elapsed="2.040535"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:39.502327" elapsed="0.002698"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:39.514997" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:39.515208" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:39.515374" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:39.505975" elapsed="0.009438"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:39.515712" elapsed="0.003738"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:39.525627" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:39.526144" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '599'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:39.526255" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:39.519714" elapsed="0.006568"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:39.529896" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:39.529455" elapsed="0.000480"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:39.530863" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:39.530158" elapsed="0.000745"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:39.531720" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "mac-ip-adv-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "ip-address": "43.43.43.43",
       "mac-address": "f2:0c:dd:80:9f:f7",
       "mpls-label1": 24002,
       "mpls-label2": 24003
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:39.532061" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "mac-ip-adv-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:39.531204" elapsed="0.000971">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:39.526593" elapsed="0.005823">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:39.505693" elapsed="0.026936">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.543298" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.543483" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.543626" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.534246" elapsed="0.009444"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.543945" elapsed="0.005686"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.557722" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.557979" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:41.558142" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.550167" elapsed="0.008013"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.562727" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.562273" elapsed="0.000496"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.563377" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.562992" elapsed="0.000424"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.563667" elapsed="0.000494"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.558541" elapsed="0.005709"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:41.533347" elapsed="0.030983"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:39.505207" elapsed="2.059181"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:41.565187" elapsed="0.002496"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.572485" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.572598" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.572722" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.568893" elapsed="0.003855"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.572918" elapsed="0.002570"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.581995" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.582150" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:41.582298" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.575670" elapsed="0.006668"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.587134" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.586711" elapsed="0.000464"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.587835" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.587410" elapsed="0.000465"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.588111" elapsed="0.000479"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.582705" elapsed="0.006066"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:41.568562" elapsed="0.020291"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:41.567865" elapsed="0.021046"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:41.564676" elapsed="0.024314"/>
</kw>
<arg>route_mac_arb</arg>
<status status="PASS" start="2026-06-06T03:26:37.418981" elapsed="4.170079"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:37.280297" elapsed="4.308947"/>
</test>
<test id="s1-s13-t52" name="Odl_To_Play_route_mac_as" line="191">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:41.594624" elapsed="0.000322"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:41.594244" elapsed="0.000780"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:41.596484" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.596311" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.596277" elapsed="0.000314"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:41.602155" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.602048" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.602029" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.603242" 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-06-06T03:26:41.602857" elapsed="0.000412"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.603747" 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-06-06T03:26:41.603434" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:41.603818" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:26:41.603983" 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-06-06T03:26:41.602457" elapsed="0.001551"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:41.609703" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.609578" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.609558" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:41.611212" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.611031" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.611011" elapsed="0.000361"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:41.611957" 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-06-06T03:26:41.611527" elapsed="0.000493"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:41.612653" level="INFO">${current_connection_index} = 7</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-06-06T03:26:41.612371" elapsed="0.000345"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:41.647365" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:41.614577" elapsed="0.032972"/>
</kw>
<msg time="2026-06-06T03:26:41.647737" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:41.647834" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:41.613031" elapsed="0.034874"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:41.676859" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "a "s "[K"
[?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-06-06T03:26:41.650003" elapsed="0.026994"/>
</kw>
<msg time="2026-06-06T03:26:41.677155" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:41.677251" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:41.648343" elapsed="0.028978"/>
</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-06-06T03:26:41.678152" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:41.677638" elapsed="0.000634"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.677609" elapsed="0.000724"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.679082" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "a "s "[K"
[?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-06-06T03:26:41.678488" elapsed="0.000710"/>
</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-06-06T03:26:41.679749" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:41.679375" elapsed="0.000490"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.679354" elapsed="0.000570"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:41.679964" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:41.683662" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:26:41.683858" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:41.683060" elapsed="0.000867"/>
</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="NOT RUN" start="2026-06-06T03:26:41.684145" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.684366" elapsed="0.000021"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:41.682243" elapsed="0.002338"/>
</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-06-06T03:26:41.680276" elapsed="0.004412"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:41.610568" elapsed="0.074303"/>
</kw>
<msg time="2026-06-06T03:26:41.684972" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:41.685018" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:41.609928" elapsed="0.075131"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:41.685597" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:26:41.685191" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.685164" elapsed="0.000558"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.686264" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.686811" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:41.686888" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:41.609237" elapsed="0.077762"/>
</kw>
<msg time="2026-06-06T03:26:41.687095" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:41.687138" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:41.604400" elapsed="0.082773"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.687518" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:41.687249" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.687231" elapsed="0.000365"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:41.604251" elapsed="0.083369"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:41.604068" elapsed="0.083602"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:41.601684" elapsed="0.086046"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:41.595891" elapsed="0.091898"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:41.595244" elapsed="0.092593"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:41.591122" elapsed="0.096773"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.695341" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.695482" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.695633" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.688417" elapsed="0.007277"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.695936" elapsed="0.003811"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.705397" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.705552" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:41.705733" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.699996" elapsed="0.005779"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.710464" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.710023" elapsed="0.000484"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.711171" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.710768" elapsed="0.000445"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.711454" elapsed="0.000513"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.706121" elapsed="0.005938"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:41.688114" elapsed="0.024028"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:41.590379" elapsed="0.121823"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:41.713396" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:41.713618" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:41.713059" elapsed="0.000607"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:41.714022" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:41.714150" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:41.713831" elapsed="0.000346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:41.714525" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/announce_route_mac_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/announce_route_mac_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:41.714667" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:41.714336" elapsed="0.000390"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:41.715108" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:41.714894" elapsed="0.000241"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:41.715494" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/withdraw_route_mac_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/withdraw_route_mac_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:41.715630" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:41.715303" elapsed="0.000370"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:41.716033" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:41.715833" elapsed="0.000228"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.716474" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.716224" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.716949" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.716704" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.717418" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.717173" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.717874" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.717620" elapsed="0.000300"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:41.718073" elapsed="0.002345"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.736566" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '986', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:41.736748" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AhgAAhmZmZkAAQAAAAow8gzdgJ%2F3ICsrKys%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.737040" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.720584" elapsed="0.016515"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.742581" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.737517" elapsed="0.005147"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.748755" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.749377" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '468'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:41.749540" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.742907" elapsed="0.006674"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.753609" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.749860" elapsed="0.003843"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.760309" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.760708" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '468'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:41.760807" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.755140" elapsed="0.005693"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.763506" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.761009" elapsed="0.002547"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.763730" elapsed="0.002564"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:41.768864" level="INFO">${update} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.766464" elapsed="0.002445"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.769192" elapsed="0.003245"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:41.772513" elapsed="0.000052"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:41.754625" elapsed="0.018110"/>
</kw>
<msg time="2026-06-06T03:26:41.772854" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:41.753964" elapsed="0.018928"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.773586" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.773167" elapsed="0.000508"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.774988" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:41.775100" level="INFO">${len_1} = 182</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:41.774573" elapsed="0.000563"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.775764" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:41.775875" level="INFO">${len_2} = 182</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:41.775369" elapsed="0.000541"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.776144" elapsed="0.000452"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:41.777162" level="INFO">${sum_1} = 3738</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:41.776855" elapsed="0.000347"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:41.777660" level="INFO">${sum_2} = 3738</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:41.777433" elapsed="0.000255"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.777846" elapsed="0.000304"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:41.774028" elapsed="0.004182"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:41.778362" elapsed="0.002184"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.785946" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.786123" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '468'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:41.786262" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.781080" elapsed="0.005220"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.790480" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.786556" elapsed="0.003998"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.790811" elapsed="0.003765"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.801951" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.802071" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '468'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:41.802175" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.794843" elapsed="0.007360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.804832" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.802409" elapsed="0.002472"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.805040" elapsed="0.003268"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:41.811924" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.808433" elapsed="0.003559"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.808399" elapsed="0.003629"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.819210" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.819263" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.819408" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.812266" elapsed="0.007170"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:41.780803" elapsed="0.038715"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.826068" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.826202" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.826296" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.820635" elapsed="0.005687"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.829023" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.826501" elapsed="0.002570"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.829275" elapsed="0.003628"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:41.835740" level="INFO">${update} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.833166" elapsed="0.002618"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.836047" elapsed="0.003274"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:41.839400" elapsed="0.000058"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:41.820270" elapsed="0.019345"/>
</kw>
<msg time="2026-06-06T03:26:41.839768" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:41.819740" elapsed="0.020067"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.840451" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.840076" elapsed="0.000441"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.841930" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:41.842041" level="INFO">${len_1} = 170</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:41.841504" elapsed="0.000572"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.842704" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:41.842901" level="INFO">${len_2} = 170</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:41.842311" elapsed="0.000626"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.843175" elapsed="0.000456"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:41.844171" level="INFO">${sum_1} = 3291</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:41.843891" elapsed="0.000318"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:41.844742" level="INFO">${sum_2} = 3291</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:41.844445" elapsed="0.000334"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.845015" elapsed="0.000473"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:41.840919" elapsed="0.004660"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.851846" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.851980" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.852075" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.846463" elapsed="0.005638"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.855088" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.852279" elapsed="0.002857"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.855295" elapsed="0.004014"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.867229" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.867511" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.867799" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.859831" elapsed="0.008031"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.872535" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:41.868280" elapsed="0.004324"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.872859" elapsed="0.003542"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:41.879868" elapsed="0.000053"/>
</return>
<status status="PASS" start="2026-06-06T03:26:41.876530" elapsed="0.003441"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.876493" elapsed="0.003516"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.880231" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:41.846009" elapsed="0.034359"/>
</kw>
<arg>route_mac_as</arg>
<status status="PASS" start="2026-06-06T03:26:41.712593" elapsed="0.167846"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:41.589708" elapsed="0.290893"/>
</test>
<test id="s1-s13-t53" name="Play_To_Odl_route_mac_as" line="193">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:41.884843" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:41.884557" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:41.886150" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.886036" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.886016" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:41.891290" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.891177" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.891158" elapsed="0.000204"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.892412" 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-06-06T03:26:41.892010" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.892923" 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-06-06T03:26:41.892605" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:41.892995" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:26:41.893191" 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-06-06T03:26:41.891602" elapsed="0.001615"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:41.899244" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.899133" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.899112" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:41.900801" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:41.900590" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.900570" elapsed="0.000391"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:41.901568" 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-06-06T03:26:41.901118" elapsed="0.000511"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:41.902267" level="INFO">${current_connection_index} = 7</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-06-06T03:26:41.902000" elapsed="0.000328"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:41.935572" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:41.904216" elapsed="0.031656"/>
</kw>
<msg time="2026-06-06T03:26:41.936095" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:41.936196" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:41.902654" elapsed="0.033615"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:41.966009" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "a "s "[K"
[?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-06-06T03:26:41.938580" elapsed="0.027565"/>
</kw>
<msg time="2026-06-06T03:26:41.966278" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:41.966373" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:41.936822" elapsed="0.029622"/>
</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-06-06T03:26:41.967209" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:41.966800" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.966766" elapsed="0.000624"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:41.968147" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "a "s "[K"
[?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-06-06T03:26:41.967547" elapsed="0.000721"/>
</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-06-06T03:26:41.968900" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:41.968519" elapsed="0.000497"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.968497" elapsed="0.000577"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:41.969119" elapsed="0.000063"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:41.972896" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:26:41.973090" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:41.972285" elapsed="0.000909"/>
</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="NOT RUN" start="2026-06-06T03:26:41.973421" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.973655" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:41.971474" elapsed="0.002405"/>
</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-06-06T03:26:41.969482" elapsed="0.004484"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:41.900147" elapsed="0.074000"/>
</kw>
<msg time="2026-06-06T03:26:41.974247" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:41.974292" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:41.899472" elapsed="0.074857"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:41.974518" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:41.974409" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.974389" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.975100" elapsed="0.000032"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.975588" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:41.975683" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:41.898747" elapsed="0.077053"/>
</kw>
<msg time="2026-06-06T03:26:41.975898" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:41.975942" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:41.893615" elapsed="0.082364"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:41.976315" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:41.976056" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:41.976039" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:41.893465" elapsed="0.082953"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:41.893281" elapsed="0.083172"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:41.890795" elapsed="0.085718"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:41.885744" elapsed="0.090826"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:41.885279" elapsed="0.091338"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:41.882336" elapsed="0.094382"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.983219" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.983416" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:41.983614" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.977171" elapsed="0.006509"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:41.983937" elapsed="0.004506"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:41.993772" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:41.993878" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:41.993981" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:41.988718" elapsed="0.005290"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.997103" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.996788" elapsed="0.000344"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:41.997584" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:41.997311" elapsed="0.000301"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.997790" elapsed="0.000331"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:41.994241" elapsed="0.003941"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:41.976875" elapsed="0.021360"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:41.881810" elapsed="0.116466"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:41.999024" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:41.999185" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:41.998819" elapsed="0.000395"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.029210" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_as.vanadium/route_mac_as.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:42.028720" elapsed="0.000527"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:42.030128" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as.vanadium/route_mac_as.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:42.029836" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as.vanadium/route_mac_as.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:42.030305" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:42.029438" elapsed="0.000891"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.030910" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:42.030502" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:42.031248" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/route_mac_as.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:42.031411" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:42.031106" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.031939" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:42.031684" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:42.032465" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:42.032077" elapsed="0.000449"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.033026" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:42.032729" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:42.032559" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:42.032049" elapsed="0.001061"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.033822" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:42.033290" elapsed="0.000562"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:42.033907" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:26:42.034073" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:42.026216" elapsed="0.007883"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:42.034462" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/announce_route_mac_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/announce_route_mac_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:42.034589" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:42.034266" elapsed="0.000351"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:42.034987" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/withdraw_route_mac_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_as/withdraw_route_mac_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:42.035109" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:42.034794" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.035542" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;as-generated&gt;
            &lt;as&gt;16843009&lt;/as&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/as-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:42.035295" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.036013" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:42.035772" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.036455" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:42.036218" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:42.036988" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:42.036743" elapsed="0.000291"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:42.037217" elapsed="0.002695"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:42.040096" elapsed="0.001752"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:42.049534" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:42.049777" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:42.049945" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:42.042848" elapsed="0.007647">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:42.050827" elapsed="0.000038"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:42.051190" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:42.042490" elapsed="0.008880">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:44.062073" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:44.062300" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '468'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:44.062466" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:44.053018" elapsed="0.009486"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:44.063198" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "as-generated": {
            "as": 16843009,
            "local-discriminator": 2000
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:44.066416" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:44.062798" elapsed="0.003688"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:44.071170" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:44.070476" elapsed="0.000735"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:44.072068" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:44.071437" elapsed="0.000671"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:44.072333" elapsed="0.000480"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:44.066828" elapsed="0.006073"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:44.052093" elapsed="0.020884"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:42.042048" elapsed="2.030993"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:44.073281" elapsed="0.002986"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:44.082491" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:44.082601" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:44.082765" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:44.077201" elapsed="0.005601"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:44.083036" elapsed="0.003883"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:44.093356" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:44.094048" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '616'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","as-generated":{"as":16843009,"local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:44.094199" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:44.087154" elapsed="0.007083"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:44.098565" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:44.098105" elapsed="0.000515"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:44.099584" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:44.098891" elapsed="0.000732"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:44.100305" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "mac-ip-adv-route": {
       "as-generated": {
        "as": 16843009,
        "local-discriminator": 2000
       },
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "ip-address": "43.43.43.43",
       "mac-address": "f2:0c:dd:80:9f:f7",
       "mpls-label1": 24002,
       "mpls-label2": 24003
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:44.100695" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "mac-ip-adv-route": {
+       "as-generated": {
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:44.099869" elapsed="0.000936">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:44.094557" elapsed="0.006481">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:44.076923" elapsed="0.024321">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "as": 16843009,
+        "local-discriminator": 2000
+       },
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.111722" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.111912" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.112059" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.103012" elapsed="0.009084"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.112348" elapsed="0.003646"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.123275" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.123424" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:46.123566" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.116229" elapsed="0.007374"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.128043" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.127604" elapsed="0.000479"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.128705" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.128307" elapsed="0.000438"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.128973" elapsed="0.000477"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.123961" elapsed="0.005578"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.102157" elapsed="0.027458"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:44.076446" elapsed="2.053245"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:46.130447" elapsed="0.002568"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.139691" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.139801" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.139904" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.134626" elapsed="0.005304"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.140099" elapsed="0.002532"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.147052" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.147155" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:46.147256" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.142821" elapsed="0.004462"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.151500" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.151106" elapsed="0.000433"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.152168" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.151791" elapsed="0.000417"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.152431" elapsed="0.000480"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.147513" elapsed="0.005485"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.133919" elapsed="0.019155"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:46.133300" elapsed="0.019829"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:46.129952" elapsed="0.023256"/>
</kw>
<arg>route_mac_as</arg>
<status status="PASS" start="2026-06-06T03:26:41.998501" elapsed="4.154795"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:41.881193" elapsed="4.272269"/>
</test>
<test id="s1-s13-t54" name="Odl_To_Play_route_mac_lacp" line="196">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:46.158475" elapsed="0.000224"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:46.158206" elapsed="0.000549"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:46.159791" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.159666" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.159629" elapsed="0.000234"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:46.166372" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.166263" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.166244" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.167464" 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-06-06T03:26:46.167079" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.167970" 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-06-06T03:26:46.167671" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:46.168042" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:26:46.168203" 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-06-06T03:26:46.166690" elapsed="0.001538"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:46.173825" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.173716" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.173696" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:46.175328" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.175147" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.175127" elapsed="0.000361"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:46.176219" 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-06-06T03:26:46.175657" elapsed="0.000625"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:46.176918" level="INFO">${current_connection_index} = 7</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-06-06T03:26:46.176632" elapsed="0.000344"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:46.210962" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:46.178860" elapsed="0.032520"/>
</kw>
<msg time="2026-06-06T03:26:46.211814" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:46.212033" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:46.177292" elapsed="0.034902"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:46.242324" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:46.215769" elapsed="0.026712"/>
</kw>
<msg time="2026-06-06T03:26:46.242627" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:46.242753" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:46.213242" elapsed="0.029613"/>
</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-06-06T03:26:46.243759" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.243265" elapsed="0.000617"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.243220" elapsed="0.000731"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.244759" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:46.244123" elapsed="0.000760"/>
</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-06-06T03:26:46.245583" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.245139" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.245116" elapsed="0.000673"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:46.245835" elapsed="0.000046"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:46.250072" elapsed="0.000157"/>
</kw>
<msg time="2026-06-06T03:26:46.250300" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:46.249336" elapsed="0.001047"/>
</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="NOT RUN" start="2026-06-06T03:26:46.250611" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.250854" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:46.248423" elapsed="0.002653"/>
</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-06-06T03:26:46.246193" elapsed="0.004974"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:46.174705" elapsed="0.076649"/>
</kw>
<msg time="2026-06-06T03:26:46.251457" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:46.251503" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:46.174049" elapsed="0.077491"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:46.252086" elapsed="0.000208"/>
</return>
<status status="PASS" start="2026-06-06T03:26:46.251623" elapsed="0.000717"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.251602" elapsed="0.000779"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.252985" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.253521" elapsed="0.000029"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:46.253631" elapsed="0.000046"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:46.173362" elapsed="0.080446"/>
</kw>
<msg time="2026-06-06T03:26:46.253941" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:46.253996" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:46.168604" elapsed="0.085428"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.254447" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.254136" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.254111" elapsed="0.000436"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:46.168459" elapsed="0.086120"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:46.168283" elapsed="0.086338"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:46.165891" elapsed="0.088838"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:46.159356" elapsed="0.095459"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:46.158911" elapsed="0.095973"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:46.155296" elapsed="0.099673"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.262723" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.262903" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.263115" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.255506" elapsed="0.007636"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.263351" elapsed="0.003220"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.271731" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.271888" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:46.272032" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.266838" elapsed="0.005232"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.277094" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.276582" elapsed="0.000556"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.277869" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.277412" elapsed="0.000499"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.278165" elapsed="0.000545"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.272416" elapsed="0.006411"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.255176" elapsed="0.023740"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:46.154616" elapsed="0.124364"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.280393" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.280683" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.280061" elapsed="0.000688"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.281479" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.281769" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.281066" elapsed="0.000760"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.282567" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/announce_route_mac_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/announce_route_mac_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.282847" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.282172" elapsed="0.000731"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:46.283772" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:46.283304" elapsed="0.000524"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.284560" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/withdraw_route_mac_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/withdraw_route_mac_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.284865" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.284175" elapsed="0.000910"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:46.285872" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:46.285505" elapsed="0.000405"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.286507" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.286151" elapsed="0.000440"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.287183" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.286842" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.287844" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.287481" elapsed="0.000428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.288473" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.288138" elapsed="0.000398"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:46.288781" elapsed="0.002738"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.305984" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1035', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:46.306152" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AhgAAhmZmZkAAQAAAAow8gzdgJ%2F3ICsrKys%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.306394" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.291722" elapsed="0.014729"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.313063" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.306882" elapsed="0.006278"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.319691" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.320426" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '498'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:46.320588" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.313579" elapsed="0.007050"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.324612" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.320912" elapsed="0.003798"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.332495" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.333205" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '498'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:46.333404" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.326327" elapsed="0.007118"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.337607" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.333840" elapsed="0.003862"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.337946" elapsed="0.003867"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:46.344369" level="INFO">${update} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.341990" elapsed="0.002409"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.344560" elapsed="0.002363"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:46.346986" elapsed="0.000053"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:46.325808" elapsed="0.021351"/>
</kw>
<msg time="2026-06-06T03:26:46.347245" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:46.324975" elapsed="0.022297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.347718" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.347450" elapsed="0.000314"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.348735" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:46.348812" level="INFO">${len_1} = 182</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:46.348428" elapsed="0.000408"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.349253" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:46.349345" level="INFO">${len_2} = 182</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:46.348997" elapsed="0.000372"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.349533" elapsed="0.000365"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:46.350317" level="INFO">${sum_1} = 4546</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:46.350123" elapsed="0.000220"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:46.350706" level="INFO">${sum_2} = 4546</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:46.350501" elapsed="0.000231"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.350891" elapsed="0.000313"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:46.348034" elapsed="0.003232"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:46.351423" elapsed="0.001962"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.359018" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.359170" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '498'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:46.359267" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.353991" elapsed="0.005303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.362490" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.359476" elapsed="0.003088"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.362829" elapsed="0.003867"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.371951" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.372090" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '498'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:46.372201" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.366989" elapsed="0.005246"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.375034" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.372436" elapsed="0.002654"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.375259" elapsed="0.002608"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:46.380302" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.377964" elapsed="0.002440"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.377935" elapsed="0.002499"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.386762" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.386835" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.387006" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.380595" elapsed="0.006464"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:46.353633" elapsed="0.033535"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.393804" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.393971" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.394110" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.388758" elapsed="0.005390"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.398333" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.394410" elapsed="0.004017"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.398769" elapsed="0.004177"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:46.405559" level="INFO">${update} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.403297" elapsed="0.002319"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.405926" elapsed="0.003447"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:46.409461" elapsed="0.000059"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:46.388223" elapsed="0.021470"/>
</kw>
<msg time="2026-06-06T03:26:46.409780" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:46.387465" elapsed="0.022341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.410234" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.409981" elapsed="0.000299"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.411191" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:46.411267" level="INFO">${len_1} = 170</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:46.410926" elapsed="0.000364"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.411717" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:46.411792" level="INFO">${len_2} = 170</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:46.411449" elapsed="0.000366"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.411975" elapsed="0.000303"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:46.412622" level="INFO">${sum_1} = 4099</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:46.412439" elapsed="0.000223"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:46.413002" level="INFO">${sum_2} = 4099</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:46.412823" elapsed="0.000204"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.413234" elapsed="0.000331"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:46.410527" elapsed="0.003099"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.418201" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.418322" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.418415" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.414228" elapsed="0.004213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.421319" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.418618" elapsed="0.002749"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.421528" elapsed="0.002534"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.427931" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.428041" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.428145" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.424231" elapsed="0.003940"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.430830" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.428349" elapsed="0.002529"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.431041" elapsed="0.002530"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:46.435994" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:26:46.433677" elapsed="0.002381"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.433636" elapsed="0.002448"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.436241" elapsed="0.000021"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:46.413921" elapsed="0.022410"/>
</kw>
<arg>route_mac_lacp</arg>
<status status="PASS" start="2026-06-06T03:26:46.279409" elapsed="0.156968"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.153986" elapsed="0.282515"/>
</test>
<test id="s1-s13-t55" name="Play_To_Odl_route_mac_lacp" line="198">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:46.446420" elapsed="0.000518"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:46.445819" elapsed="0.001262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:46.449591" elapsed="0.000035"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.449302" elapsed="0.000432"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.449233" elapsed="0.000556"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:46.457083" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.456891" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.456873" elapsed="0.000283"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.458215" 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-06-06T03:26:46.457815" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.458731" 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-06-06T03:26:46.458410" elapsed="0.000347"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:46.458802" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:26:46.458969" 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-06-06T03:26:46.457410" elapsed="0.001584"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:46.464896" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.464786" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.464766" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:46.466463" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:46.466278" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.466259" elapsed="0.000370"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:46.467225" 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-06-06T03:26:46.466803" elapsed="0.000486"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:46.467935" level="INFO">${current_connection_index} = 7</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-06-06T03:26:46.467658" elapsed="0.000338"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:46.501986" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:46.469956" elapsed="0.032169"/>
</kw>
<msg time="2026-06-06T03:26:46.502263" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:46.502356" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:46.468313" elapsed="0.034114"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:46.531666" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:46.504410" elapsed="0.027568"/>
</kw>
<msg time="2026-06-06T03:26:46.532112" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:46.532205" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:46.502861" elapsed="0.029414"/>
</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-06-06T03:26:46.532969" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.532574" elapsed="0.000511"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.532550" elapsed="0.000596"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.534213" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "c "p "[K"
[?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-06-06T03:26:46.533521" elapsed="0.000817"/>
</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-06-06T03:26:46.534918" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.534520" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.534498" elapsed="0.000596"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:46.535131" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:46.538694" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:26:46.538881" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:46.538186" elapsed="0.000764"/>
</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="NOT RUN" start="2026-06-06T03:26:46.539212" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.539438" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:46.537397" elapsed="0.002283"/>
</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-06-06T03:26:46.535412" elapsed="0.004357"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:46.465835" elapsed="0.074112"/>
</kw>
<msg time="2026-06-06T03:26:46.540042" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:46.540087" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:46.465123" elapsed="0.075000"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:46.540310" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:46.540200" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.540181" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.540994" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.541440" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:46.541515" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:46.464422" elapsed="0.077202"/>
</kw>
<msg time="2026-06-06T03:26:46.541745" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:46.541789" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:46.459401" elapsed="0.082423"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.542160" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.541901" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.541884" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:46.459250" elapsed="0.083012"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:46.459059" elapsed="0.083236"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:46.456511" elapsed="0.085838"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:46.448584" elapsed="0.093821"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:46.447430" elapsed="0.095021"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:46.440561" elapsed="0.101942"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.547227" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.547377" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.547474" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.542991" elapsed="0.004508"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:46.547686" elapsed="0.003186"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.557091" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.557213" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:46.557340" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:46.551082" elapsed="0.006286"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.561707" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.561221" elapsed="0.000527"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:46.562354" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:46.561971" elapsed="0.000421"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.562620" elapsed="0.000490"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:46.557612" elapsed="0.005585"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.542710" elapsed="0.020563"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:46.438669" elapsed="0.124659"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.564355" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.564598" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.564072" elapsed="0.000585"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.590927" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_lacp.vanadium/route_mac_lacp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:46.590439" elapsed="0.000517"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.591764" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp.vanadium/route_mac_lacp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:46.591481" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp.vanadium/route_mac_lacp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:46.591942" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:46.591130" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.592530" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:46.592141" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.592876" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/route_mac_lacp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.593004" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.592740" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.593461" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.593197" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:46.593961" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:46.593621" elapsed="0.000399"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.594489" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:46.594196" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.594047" elapsed="0.000504"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:46.593599" elapsed="0.000973"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.595202" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:46.594744" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:46.595284" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:26:46.595441" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:46.588097" elapsed="0.007370"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.595848" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/announce_route_mac_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/announce_route_mac_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.595974" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.595629" elapsed="0.000371"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:46.596349" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/withdraw_route_mac_lacp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lacp/withdraw_route_mac_lacp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:46.596471" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:46.596159" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.596920" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;lacp-auto-generated&gt;
            &lt;ce-lacp-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/ce-lacp-mac-address&gt;
            &lt;ce-lacp-port-key&gt;22&lt;/ce-lacp-port-key&gt;
        &lt;/lacp-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.596673" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.597418" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.597133" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.597917" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.597628" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:46.598355" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:46.598117" elapsed="0.000282"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:46.598561" elapsed="0.002977"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:46.601729" elapsed="0.002113"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:46.609111" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:46.609263" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:46.609416" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:46.604863" elapsed="0.005089">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.610219" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:46.610548" elapsed="0.000033"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:46.604517" elapsed="0.006239">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:48.621788" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:48.621993" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '498'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:48.622144" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:48.612282" elapsed="0.009899"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:48.622881" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lacp-auto-generated": {
            "ce-lacp-port-key": 22,
            "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:48.626173" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:48.622445" elapsed="0.003798"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:48.630552" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:48.630046" elapsed="0.000535"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:48.631209" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:48.630761" elapsed="0.000477"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:48.631452" elapsed="0.000358"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:48.626564" elapsed="0.005309"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:48.611366" elapsed="0.020560"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:46.604062" elapsed="2.027912"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:48.632136" elapsed="0.002724"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:48.642127" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:48.642286" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:48.642419" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:48.635825" elapsed="0.006629"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:48.642720" elapsed="0.003951"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:48.655915" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:48.656597" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '646'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lacp-auto-generated":{"ce-lacp-mac-address":"f2:0c:dd:80:9f:f7","ce-lacp-port-key":22},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:48.656769" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:48.646909" elapsed="0.009899"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:48.661112" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:48.660711" elapsed="0.000441"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:48.662136" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:48.661405" elapsed="0.000772"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:48.662868" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "mac-ip-adv-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "ip-address": "43.43.43.43",
       "lacp-auto-generated": {
        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
        "ce-lacp-port-key": 22
       },
       "mac-address": "f2:0c:dd:80:9f:f7",
       "mpls-label1": 24002,
       "mpls-label2": 24003
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:48.663202" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "mac-ip-adv-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:48.662404" elapsed="0.000963">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:48.657131" elapsed="0.006477">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:48.635513" elapsed="0.028331">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lacp-auto-generated": {
+        "ce-lacp-mac-address": "f2:0c:dd:80:9f:f7",
+        "ce-lacp-port-key": 22
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.674559" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.674830" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:50.675016" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.665464" elapsed="0.009593"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.675375" elapsed="0.004164"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.687597" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.687902" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:50.688101" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.679860" elapsed="0.008284"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:50.693141" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.692630" elapsed="0.000557"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:50.693850" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.693426" elapsed="0.000465"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.694212" elapsed="0.000549"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.688580" elapsed="0.006277"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:50.664548" elapsed="0.030394"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:48.635048" elapsed="2.059957"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:50.695841" elapsed="0.002489"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.704152" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.704288" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:50.704396" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.699602" elapsed="0.004821"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.704596" elapsed="0.003330"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.712996" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.713193" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:50.713349" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.708178" elapsed="0.005210"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:50.718104" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.717669" elapsed="0.000477"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:50.718805" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.718382" elapsed="0.000464"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.719081" elapsed="0.000484"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.713760" elapsed="0.005917"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:50.699011" elapsed="0.020749"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:50.698512" elapsed="0.021307"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:50.695290" elapsed="0.024614"/>
</kw>
<arg>route_mac_lacp</arg>
<status status="PASS" start="2026-06-06T03:26:46.563632" elapsed="4.156346"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:46.437085" elapsed="4.283049"/>
</test>
<test id="s1-s13-t56" name="Odl_To_Play_route_mac_lan" line="201">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:50.725789" elapsed="0.000237"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:50.725367" elapsed="0.000716"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:50.727131" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:50.727003" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.726979" elapsed="0.000291"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:50.732301" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:50.732191" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.732172" elapsed="0.000201"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.733437" 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-06-06T03:26:50.733025" elapsed="0.000439"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.733945" 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-06-06T03:26:50.733630" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:50.734015" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:26:50.734180" 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-06-06T03:26:50.732609" elapsed="0.001596"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:50.740071" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:50.739960" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.739939" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:50.741960" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:50.741767" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.741746" elapsed="0.000384"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:50.742747" 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-06-06T03:26:50.742302" elapsed="0.000508"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:50.743434" level="INFO">${current_connection_index} = 7</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-06-06T03:26:50.743164" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:50.780454" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:50.745429" elapsed="0.035310"/>
</kw>
<msg time="2026-06-06T03:26:50.780938" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:50.781037" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:50.743835" elapsed="0.037308"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:50.813998" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "n "[K"
[?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-06-06T03:26:50.783322" elapsed="0.031131"/>
</kw>
<msg time="2026-06-06T03:26:50.814881" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:50.815102" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:50.781634" elapsed="0.033633"/>
</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-06-06T03:26:50.816998" elapsed="0.000165"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:50.816030" elapsed="0.001301"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.815963" elapsed="0.001507"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.819293" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "n "[K"
[?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-06-06T03:26:50.817861" elapsed="0.001702"/>
</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-06-06T03:26:50.820866" elapsed="0.000108"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:50.820013" elapsed="0.001171"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.819964" elapsed="0.001364"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:50.821418" elapsed="0.000078"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:50.825545" elapsed="0.000245"/>
</kw>
<msg time="2026-06-06T03:26:50.825837" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:50.824919" elapsed="0.000990"/>
</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="NOT RUN" start="2026-06-06T03:26:50.826133" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:50.826355" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:50.824115" elapsed="0.002459"/>
</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-06-06T03:26:50.821984" elapsed="0.004691"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:50.740972" elapsed="0.085892"/>
</kw>
<msg time="2026-06-06T03:26:50.826966" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:50.827012" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:50.740302" elapsed="0.086749"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:50.827244" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:50.827131" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.827110" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:50.827890" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:50.828328" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:50.828403" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:50.739598" elapsed="0.088920"/>
</kw>
<msg time="2026-06-06T03:26:50.828616" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:50.828679" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:50.734593" elapsed="0.094125"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:50.829061" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:50.828796" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.828778" elapsed="0.000377"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:50.734446" elapsed="0.094734"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:50.734264" elapsed="0.094951"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:50.731819" elapsed="0.097455"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:50.726700" elapsed="0.102633"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:50.726238" elapsed="0.103142"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:50.722016" elapsed="0.107422"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.836204" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.836349" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:50.836466" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.829894" elapsed="0.006599"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.836732" elapsed="0.002607"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.843852" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.844003" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:50.844149" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.839515" elapsed="0.004672"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:50.848551" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.848126" elapsed="0.000466"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:50.849271" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.848846" elapsed="0.000465"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.849545" elapsed="0.000488"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.844518" elapsed="0.005603"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:50.829592" elapsed="0.020606"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:50.721289" elapsed="0.128967"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:50.851355" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:50.851571" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:50.851073" elapsed="0.000538"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:50.852134" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:50.852311" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:50.851867" elapsed="0.000482"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:50.852865" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/announce_route_mac_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/announce_route_mac_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:50.853040" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:50.852572" elapsed="0.000536"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:50.853664" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:50.853343" elapsed="0.000362"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:50.854198" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/withdraw_route_mac_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/withdraw_route_mac_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:50.854383" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:50.853933" elapsed="0.000486"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:50.855002" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:50.854666" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.855625" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.855272" elapsed="0.000459"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.856299" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.855960" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.856947" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.856586" elapsed="0.000424"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.857587" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.857248" elapsed="0.000422"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:50.857890" elapsed="0.002401"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.876991" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1049', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:50.877158" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AhgAAhmZmZkAAQAAAAow8gzdgJ%2F3ICsrKys%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.877369" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.860551" elapsed="0.016878"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.884781" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.877863" elapsed="0.006982"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.891968" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.892583" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '505'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:50.892756" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.885093" elapsed="0.007701"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.896550" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.893036" elapsed="0.003586"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.904107" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.904498" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '505'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:50.904596" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.898044" elapsed="0.006578"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.907278" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.904823" elapsed="0.002504"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.907490" elapsed="0.002658"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:50.912422" level="INFO">${update} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.910382" elapsed="0.002082"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.912742" elapsed="0.003074"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:50.915892" elapsed="0.000046"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:50.897550" elapsed="0.018528"/>
</kw>
<msg time="2026-06-06T03:26:50.916188" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:50.896885" elapsed="0.019338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.916830" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.916459" elapsed="0.000434"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.918086" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:50.918162" level="INFO">${len_1} = 182</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:50.917812" elapsed="0.000374"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.918598" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:50.918689" level="INFO">${len_2} = 182</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:50.918344" elapsed="0.000370"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.918872" elapsed="0.000306"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:50.919565" level="INFO">${sum_1} = 4545</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:50.919374" elapsed="0.000217"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:50.919951" level="INFO">${sum_2} = 4545</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:50.919765" elapsed="0.000212"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.920134" elapsed="0.000307"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:50.917261" elapsed="0.003240"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:50.920668" elapsed="0.001770"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.928850" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.929046" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '505'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:50.929242" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.922968" elapsed="0.006313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.933449" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.929571" elapsed="0.003949"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.933766" elapsed="0.003537"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.942341" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.942507" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '505'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:50.942684" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.937548" elapsed="0.005177"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.946405" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.942973" elapsed="0.003502"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.946722" elapsed="0.003509"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:50.953720" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:50.950354" elapsed="0.003440"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:50.950320" elapsed="0.003512"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.960133" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.960239" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.960472" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.954059" elapsed="0.006472"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:50.922689" elapsed="0.038035"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.968635" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.968831" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:50.968970" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.963049" elapsed="0.005959"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.972935" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.969295" elapsed="0.003710"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:50.973277" elapsed="0.003754"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:50.980351" level="INFO">${update} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:50.977296" elapsed="0.003099"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.980685" elapsed="0.003332"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:50.984094" elapsed="0.000052"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:50.962243" elapsed="0.022048"/>
</kw>
<msg time="2026-06-06T03:26:50.984410" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:50.961147" elapsed="0.023300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.985105" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.984720" elapsed="0.000453"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.986478" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:50.986589" level="INFO">${len_1} = 170</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:50.986090" elapsed="0.000535"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:50.987257" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:50.987366" level="INFO">${len_2} = 170</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:50.986882" elapsed="0.000518"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.987632" elapsed="0.000470"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:50.988609" level="INFO">${sum_1} = 4098</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:50.988338" elapsed="0.000332"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:50.989186" level="INFO">${sum_2} = 4098</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:50.988904" elapsed="0.000319"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:50.989508" elapsed="0.000482"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:50.985518" elapsed="0.004562"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:50.997946" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:50.998064" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:50.998158" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:50.990930" elapsed="0.007254"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.001028" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:50.998369" elapsed="0.002741"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:51.001273" elapsed="0.003481"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:51.009795" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:51.009952" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:51.010100" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:51.005002" elapsed="0.005137"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.014064" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:51.010396" elapsed="0.003738"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:51.014371" elapsed="0.003774"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:51.020574" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:26:51.018225" elapsed="0.002409"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.018204" elapsed="0.002471"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.020832" elapsed="0.000022"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:50.990459" elapsed="0.030471"/>
</kw>
<arg>route_mac_lan</arg>
<status status="PASS" start="2026-06-06T03:26:50.850626" elapsed="0.170351"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:50.720571" elapsed="0.300535"/>
</test>
<test id="s1-s13-t57" name="Play_To_Odl_route_mac_lan" line="203">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:51.025144" elapsed="0.000222"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:51.024814" elapsed="0.000610"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:51.026479" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:51.026359" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.026338" elapsed="0.000213"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:51.031761" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:51.031586" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.031568" elapsed="0.000267"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.032859" 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-06-06T03:26:51.032456" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.033376" 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-06-06T03:26:51.033051" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:51.033447" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:26:51.033605" 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-06-06T03:26:51.032071" elapsed="0.001559"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:51.039421" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:51.039311" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.039291" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:51.040951" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:51.040770" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.040751" elapsed="0.000393"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:51.041731" 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-06-06T03:26:51.041301" elapsed="0.000492"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:51.042412" level="INFO">${current_connection_index} = 7</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-06-06T03:26:51.042146" elapsed="0.000328"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:51.075127" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:51.044329" elapsed="0.030959"/>
</kw>
<msg time="2026-06-06T03:26:51.075441" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:51.075537" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:51.042802" elapsed="0.032807"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:51.103118" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "n "[K"
[?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-06-06T03:26:51.077708" elapsed="0.025549"/>
</kw>
<msg time="2026-06-06T03:26:51.103391" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:51.103485" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:51.076067" elapsed="0.027488"/>
</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-06-06T03:26:51.104285" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:51.103895" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.103866" elapsed="0.000597"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.105235" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "l "a "n "[K"
[?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-06-06T03:26:51.104622" elapsed="0.000733"/>
</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-06-06T03:26:51.105913" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:51.105537" elapsed="0.000493"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.105516" elapsed="0.000573"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:51.106130" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:51.109844" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:26:51.110036" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:51.109245" elapsed="0.000860"/>
</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="NOT RUN" start="2026-06-06T03:26:51.110381" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.110607" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:51.108421" elapsed="0.002426"/>
</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-06-06T03:26:51.106457" elapsed="0.004476"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:51.040307" elapsed="0.070807"/>
</kw>
<msg time="2026-06-06T03:26:51.111211" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:51.111256" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:51.039664" elapsed="0.071629"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:51.111482" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:26:51.111373" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.111353" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.112061" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.112492" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:51.112567" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:51.038966" elapsed="0.073797"/>
</kw>
<msg time="2026-06-06T03:26:51.112861" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:51.112905" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:51.034039" elapsed="0.078901"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.113291" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:51.113017" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.112999" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:51.033891" elapsed="0.079503"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:51.033708" elapsed="0.079719"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:51.031221" elapsed="0.082264"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:51.026060" elapsed="0.087483"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:51.025583" elapsed="0.088009"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:51.022409" elapsed="0.091254"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:51.119027" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:51.119165" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:51.119263" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:51.114094" elapsed="0.005194"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:51.119457" elapsed="0.002925"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:51.127430" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:51.127579" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:51.127757" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:51.122589" elapsed="0.005207"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:51.132248" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:51.131811" elapsed="0.000477"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:51.132923" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:51.132512" elapsed="0.000450"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:51.133222" elapsed="0.000501"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:51.128137" elapsed="0.005675"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:51.113817" elapsed="0.020074"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:51.021942" elapsed="0.112007"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:51.134983" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:51.135239" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:51.134695" elapsed="0.000584"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.164228" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_lan.vanadium/route_mac_lan.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:51.163848" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:51.165087" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan.vanadium/route_mac_lan.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:51.164805" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan.vanadium/route_mac_lan.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:51.165264" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:51.164431" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.165869" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:51.165462" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:51.166195" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/route_mac_lan.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:51.166322" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:51.166062" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.166775" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:51.166512" elapsed="0.000374"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:51.167304" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:51.166967" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.167904" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:51.167544" elapsed="0.000386"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:51.167392" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:51.166943" elapsed="0.001045"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.168598" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:51.168142" elapsed="0.000485"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:51.168697" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:26:51.168864" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:51.161523" elapsed="0.007367"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:51.169262" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/announce_route_mac_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/announce_route_mac_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:51.169388" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:51.169065" elapsed="0.000350"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:51.169783" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/withdraw_route_mac_lan.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_lan/withdraw_route_mac_lan.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:51.169905" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:51.169574" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.170336" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;lan-auto-generated&gt;
            &lt;root-bridge-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/root-bridge-mac-address&gt;
            &lt;root-bridge-priority&gt;20&lt;/root-bridge-priority&gt;
        &lt;/lan-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:51.170092" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.170805" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:51.170548" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.171247" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:51.171010" elapsed="0.000281"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:51.171696" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:51.171444" elapsed="0.000296"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:51.171894" elapsed="0.002349"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:51.174424" elapsed="0.002068"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:51.181486" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:51.181611" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:51.181725" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:51.177522" elapsed="0.004594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.182309" elapsed="0.000023"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:51.182545" elapsed="0.000024"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:51.177194" elapsed="0.005491">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:53.193604" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:53.193944" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '505'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:53.194123" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:53.184299" elapsed="0.009864"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:53.194917" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "lan-auto-generated": {
            "root-bridge-priority": 20,
            "root-bridge-mac-address": "f2:0c:dd:80:9f:f7"
          },
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:53.198505" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:53.194458" elapsed="0.004120"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:53.203092" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:53.202565" elapsed="0.000556"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:53.203739" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:53.203282" elapsed="0.000556"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:53.204007" elapsed="0.000345"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:53.198961" elapsed="0.005454"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:53.183371" elapsed="0.021101"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:51.176737" elapsed="2.027784"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:53.204700" elapsed="0.003362"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:53.215762" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:53.215955" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:53.216098" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:53.209146" elapsed="0.006990"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:53.216389" elapsed="0.004392"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:53.226350" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:53.227127" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '653'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","lan-auto-generated":{"root-bridge-priority":20,"root-bridge-mac-address":"f2:0c:dd:80:9f:f7"},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:53.227291" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:53.221121" elapsed="0.006210"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:53.232309" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:53.231858" elapsed="0.000493"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:53.233480" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:53.232588" elapsed="0.000935"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:53.234284" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "mac-ip-adv-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "ip-address": "43.43.43.43",
       "lan-auto-generated": {
        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
        "root-bridge-priority": 20
       },
       "mac-address": "f2:0c:dd:80:9f:f7",
       "mpls-label1": 24002,
       "mpls-label2": 24003
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:53.234633" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "mac-ip-adv-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:53.233792" elapsed="0.001096">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:53.227719" elapsed="0.007422">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:53.208756" elapsed="0.026610">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "lan-auto-generated": {
+        "root-bridge-mac-address": "f2:0c:dd:80:9f:f7",
+        "root-bridge-priority": 20
+       },
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.245933" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.246126" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.246270" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.236968" elapsed="0.009339"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.246556" elapsed="0.003714"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.257243" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.257393" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:55.257537" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.250507" elapsed="0.007067"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.261982" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.261528" elapsed="0.000499"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.262631" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.262250" elapsed="0.000441"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.262985" elapsed="0.000462"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.257932" elapsed="0.005600"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.236093" elapsed="0.027514"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:53.208253" elapsed="2.055430"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:55.264434" elapsed="0.003120"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.275209" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.275360" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.275501" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.269467" elapsed="0.006070"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.275798" elapsed="0.003616"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.286585" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.286763" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:55.286908" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.279669" elapsed="0.007277"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.291330" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.290934" elapsed="0.000435"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.291996" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.291594" elapsed="0.000441"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.292259" elapsed="0.000504"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.287272" elapsed="0.005580"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.268589" elapsed="0.024336"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:55.267833" elapsed="0.025147"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:55.263943" elapsed="0.029117"/>
</kw>
<arg>route_mac_lan</arg>
<status status="PASS" start="2026-06-06T03:26:51.134253" elapsed="4.158876"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:51.021446" elapsed="4.271837"/>
</test>
<test id="s1-s13-t58" name="Odl_To_Play_route_mac_mac" line="206">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:55.298144" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:55.297871" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:55.299450" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.299328" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.299303" elapsed="0.000291"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:55.304618" elapsed="0.000040"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.304510" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.304492" elapsed="0.000222"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.305745" 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-06-06T03:26:55.305337" elapsed="0.000435"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.306236" 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-06-06T03:26:55.305939" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:55.306307" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:26:55.306470" 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-06-06T03:26:55.304947" elapsed="0.001548"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:55.312336" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.312226" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.312206" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:55.313892" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.313707" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.313686" elapsed="0.000369"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:55.314626" 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-06-06T03:26:55.314211" elapsed="0.000495"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:55.315331" level="INFO">${current_connection_index} = 7</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-06-06T03:26:55.315064" elapsed="0.000328"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:55.347795" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:55.317458" elapsed="0.030469"/>
</kw>
<msg time="2026-06-06T03:26:55.348065" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:55.348159" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:55.315722" elapsed="0.032508"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:55.374079" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "m "a "c "[K"
[?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-06-06T03:26:55.350241" elapsed="0.023982"/>
</kw>
<msg time="2026-06-06T03:26:55.374363" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:55.374460" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:55.348679" elapsed="0.025855"/>
</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-06-06T03:26:55.375311" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.374890" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.374860" elapsed="0.000634"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.376295" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "m "a "c "[K"
[?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-06-06T03:26:55.375667" elapsed="0.000753"/>
</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-06-06T03:26:55.376999" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.376600" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.376579" elapsed="0.000769"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:55.377389" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:55.381127" elapsed="0.000208"/>
</kw>
<msg time="2026-06-06T03:26:55.381381" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:55.380501" elapsed="0.000950"/>
</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="NOT RUN" start="2026-06-06T03:26:55.381689" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.381912" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:55.379725" elapsed="0.002407"/>
</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-06-06T03:26:55.377720" elapsed="0.004498"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:55.313238" elapsed="0.069159"/>
</kw>
<msg time="2026-06-06T03:26:55.382497" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:55.382542" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:55.312564" elapsed="0.070017"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:55.382787" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:55.382674" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.382653" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.383354" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.383805" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:55.383879" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:55.311879" elapsed="0.072111"/>
</kw>
<msg time="2026-06-06T03:26:55.384084" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:55.384130" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:55.306901" elapsed="0.077265"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.384500" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.384242" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.384225" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:55.306751" elapsed="0.077852"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:55.306553" elapsed="0.078154"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:55.304147" elapsed="0.080623"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:55.299030" elapsed="0.085797"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:55.298563" elapsed="0.086310"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:55.295102" elapsed="0.089827"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.390315" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.390457" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.390570" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.385364" elapsed="0.005233"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.390820" elapsed="0.003183"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.400477" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.400690" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:55.400840" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.394255" elapsed="0.006623"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.405436" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.404997" elapsed="0.000481"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.406141" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.405739" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.406417" elapsed="0.000502"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.401226" elapsed="0.005784"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.385087" elapsed="0.022004"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:55.294400" elapsed="0.112750"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.408294" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.408521" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.407997" elapsed="0.000567"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.409137" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.409324" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.408848" elapsed="0.000516"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.409904" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/announce_route_mac_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/announce_route_mac_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.410086" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.409599" elapsed="0.000526"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:55.410690" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:55.410363" elapsed="0.000369"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.411241" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/withdraw_route_mac_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/withdraw_route_mac_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.411414" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.410974" elapsed="0.000477"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:55.412027" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:55.411691" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.412741" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.412304" elapsed="0.000524"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.413273" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.413031" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.413735" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.413478" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.414170" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.413933" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:55.414365" elapsed="0.002491"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.429084" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1039', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:55.429188" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AhgAAhmZmZkAAQAAAAow8gzdgJ%2F3ICsrKys%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.429335" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.417028" elapsed="0.012345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.433741" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.429682" elapsed="0.004124"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.439750" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.440447" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '501'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:55.440608" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.434049" elapsed="0.006675"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.444692" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.441012" elapsed="0.003756"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.451887" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.452469" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '501'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:55.452633" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.446247" elapsed="0.006446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.456564" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.452951" elapsed="0.003737"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.456930" elapsed="0.003808"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:55.463105" level="INFO">${update} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.460980" elapsed="0.002154"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.463314" elapsed="0.002170"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:55.465538" elapsed="0.000040"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:55.445744" elapsed="0.019953"/>
</kw>
<msg time="2026-06-06T03:26:55.465778" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:55.445028" elapsed="0.020776"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.466217" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.465973" elapsed="0.000290"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.467142" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:55.467218" level="INFO">${len_1} = 182</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:55.466880" elapsed="0.000362"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.467672" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:26:55.467750" level="INFO">${len_2} = 182</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:55.467400" elapsed="0.000374"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.467933" elapsed="0.000308"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:55.468665" level="INFO">${sum_1} = 4741</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:55.468439" elapsed="0.000254"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:55.469042" level="INFO">${sum_2} = 4741</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:55.468853" elapsed="0.000215"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.469227" elapsed="0.000308"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:55.466496" elapsed="0.003098"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:55.469763" elapsed="0.001848"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.478575" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.478775" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '501'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:55.478915" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.472381" elapsed="0.006573"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.483107" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.479211" elapsed="0.003969"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.483415" elapsed="0.003751"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.492414" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.492533" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '501'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:55.492666" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.487413" elapsed="0.005282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.495255" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.492871" elapsed="0.002433"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.495463" elapsed="0.002509"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:26:55.500334" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.498055" elapsed="0.002353"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.498032" elapsed="0.002403"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.509121" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.509186" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.509329" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.500592" elapsed="0.008777"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:55.471976" elapsed="0.037491"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.516290" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.516448" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.516584" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.510898" elapsed="0.005765"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.520511" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.516925" elapsed="0.003656"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.520886" elapsed="0.003802"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:55.527138" level="INFO">${update} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.524936" elapsed="0.002246"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.527444" elapsed="0.003265"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:26:55.530785" elapsed="0.000046"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:26:55.510386" elapsed="0.020587"/>
</kw>
<msg time="2026-06-06T03:26:55.531088" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:55.509743" elapsed="0.021382"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.531755" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.531374" elapsed="0.000448"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.533112" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:55.533221" level="INFO">${len_1} = 170</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:55.532732" elapsed="0.000524"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.533881" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:26:55.533989" level="INFO">${len_2} = 170</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:26:55.533489" elapsed="0.000534"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.534255" elapsed="0.000464"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:55.535225" level="INFO">${sum_1} = 4294</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:55.534954" elapsed="0.000308"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:26:55.535775" level="INFO">${sum_2} = 4294</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:26:55.535489" elapsed="0.000323"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.536094" elapsed="0.000456"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:26:55.532159" elapsed="0.004530"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.544521" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.544673" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.544769" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.537528" elapsed="0.007266"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.548850" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.544970" elapsed="0.003930"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.549092" elapsed="0.003792"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.559536" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.559665" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.559770" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.553133" elapsed="0.006664"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.562408" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.559970" elapsed="0.002485"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.562613" elapsed="0.002519"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:26:55.567508" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:26:55.565211" elapsed="0.002357"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.565191" elapsed="0.002402"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.567761" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:26:55.537080" elapsed="0.030772"/>
</kw>
<arg>route_mac_mac</arg>
<status status="PASS" start="2026-06-06T03:26:55.407534" elapsed="0.160363"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.293756" elapsed="0.274251"/>
</test>
<test id="s1-s13-t59" name="Play_To_Odl_route_mac_mac" line="208">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:55.573198" elapsed="0.000308"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:55.572799" elapsed="0.000790"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:55.575091" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.574927" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.574897" elapsed="0.000299"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:55.581088" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.580908" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.580886" elapsed="0.000278"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.582234" 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-06-06T03:26:55.581826" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.582748" 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-06-06T03:26:55.582428" elapsed="0.000347"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:55.582820" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:26:55.582984" 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-06-06T03:26:55.581418" elapsed="0.001595"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:55.588858" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.588749" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.588729" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:55.590388" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:55.590209" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.590189" elapsed="0.000364"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:55.591133" 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-06-06T03:26:55.590724" elapsed="0.000470"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:55.591825" level="INFO">${current_connection_index} = 7</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-06-06T03:26:55.591541" elapsed="0.000344"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:55.629836" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:55.593768" elapsed="0.036205"/>
</kw>
<msg time="2026-06-06T03:26:55.630115" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:55.630211" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:55.592199" elapsed="0.038083"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:55.657895" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "m "a "c "[K"
[?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-06-06T03:26:55.632276" elapsed="0.025792"/>
</kw>
<msg time="2026-06-06T03:26:55.658226" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:55.658321" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:26:55.630715" elapsed="0.027677"/>
</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-06-06T03:26:55.659152" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.658738" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.658706" elapsed="0.000623"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.660165" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "m "a "c "[K"
[?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-06-06T03:26:55.659486" elapsed="0.000797"/>
</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-06-06T03:26:55.660869" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.660463" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.660443" elapsed="0.000604"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:55.661088" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:55.664842" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:26:55.665038" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:55.664184" elapsed="0.000922"/>
</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="NOT RUN" start="2026-06-06T03:26:55.665390" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.665610" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:55.663389" elapsed="0.002482"/>
</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-06-06T03:26:55.661405" elapsed="0.004553"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:55.589770" elapsed="0.076365"/>
</kw>
<msg time="2026-06-06T03:26:55.666232" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:55.666276" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:55.589091" elapsed="0.077220"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:55.666498" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:26:55.666390" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.666370" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.667117" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.667543" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:55.667617" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:55.588357" elapsed="0.079517"/>
</kw>
<msg time="2026-06-06T03:26:55.667971" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:55.668016" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:55.583400" elapsed="0.084652"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.668388" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.668130" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.668112" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:55.583252" elapsed="0.085237"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:55.583071" elapsed="0.085451"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:55.580454" elapsed="0.088155"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:55.574477" elapsed="0.094213"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:55.573839" elapsed="0.094901"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:55.569487" elapsed="0.099307"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.675391" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.675532" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.675628" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.669218" elapsed="0.006461"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:55.675849" elapsed="0.002859"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.683352" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.683507" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:55.683685" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:55.678913" elapsed="0.004815"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.688498" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.688059" elapsed="0.000481"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:55.689235" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:55.688829" elapsed="0.000447"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.689514" elapsed="0.000506"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:55.684073" elapsed="0.006038"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.668943" elapsed="0.021249"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:55.568848" elapsed="0.121403"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.691329" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.691568" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.691028" elapsed="0.000582"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.719139" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_mac.vanadium/route_mac_mac.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:55.718758" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.719934" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac.vanadium/route_mac_mac.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:26:55.719693" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac.vanadium/route_mac_mac.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:26:55.720102" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:26:55.719336" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.720726" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:26:55.720298" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.721055" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/route_mac_mac.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.721180" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.720920" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.721612" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.721368" elapsed="0.000344"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:26:55.722095" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:55.721783" elapsed="0.000372"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.722623" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:26:55.722331" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.722180" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:55.721763" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.723317" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:26:55.722873" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:26:55.723396" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:26:55.723550" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:26:55.716422" elapsed="0.007155"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.723976" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/announce_route_mac_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/announce_route_mac_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.724105" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.723778" elapsed="0.000354"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:55.724480" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/withdraw_route_mac_mac.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_mac/withdraw_route_mac_mac.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:55.724630" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:55.724290" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.725078" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;mac-auto-generated&gt;
            &lt;system-mac-address&gt;f2:0c:dd:80:9f:f7&lt;/system-mac-address&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/mac-auto-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.724833" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.725531" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.725292" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.725994" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.725755" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:55.726430" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:55.726194" elapsed="0.000279"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:55.726623" elapsed="0.002313"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:55.729104" elapsed="0.002125"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:55.737220" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:55.737330" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:55.737425" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:26:55.732224" elapsed="0.005597">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.738014" elapsed="0.000022"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:55.738248" elapsed="0.000025"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:26:55.731894" elapsed="0.006479">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:57.751023" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:57.751530" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '501'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:26:57.751948" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:57.739967" elapsed="0.012051"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:26:57.753630" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "path-id": 0,
        "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
        "route-distinguisher": "429496729:1",
        "mac-ip-adv-route": {
          "mac-auto-generated": {
            "system-mac-address": "f2:0c:dd:80:9f:f7",
            "local-discriminator": 2000
          },
          "mpls-label1": 24002,
          "mpls-label2": 24003,
          "ip-address": "43.43.43.43",
          "ethernet-tag-id": {
            "vlan-id": 10
          },
          "mac-address": "f2:0c:dd:80:9f:f7"
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:26:57.758569" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:26:57.752749" elapsed="0.005911"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:57.763843" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:57.762963" elapsed="0.000923"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:57.764838" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:57.764119" elapsed="0.000996"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:57.765366" elapsed="0.000521"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:57.759092" elapsed="0.006869"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:26:57.739030" elapsed="0.027000"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:55.731452" elapsed="2.034637"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:57.766268" elapsed="0.002741"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:57.776421" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:57.776592" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:57.776759" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:57.770053" elapsed="0.006745"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:57.777052" elapsed="0.004215"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:57.786321" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:57.787088" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '649'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","mac-auto-generated":{"system-mac-address":"f2:0c:dd:80:9f:f7","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:26:57.787246" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:57.781514" elapsed="0.005771"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:57.791708" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:57.791276" elapsed="0.000475"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:57.793816" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:57.792010" elapsed="0.001917"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:26:57.795497" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "mac-ip-adv-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "ip-address": "43.43.43.43",
       "mac-address": "f2:0c:dd:80:9f:f7",
       "mac-auto-generated": {
        "local-discriminator": 2000,
        "system-mac-address": "f2:0c:dd:80:9f:f7"
       },
       "mpls-label1": 24002,
       "mpls-label2": 24003
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:26:57.796122" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "mac-ip-adv-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:26:57.794490" elapsed="0.002057">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:26:57.787662" elapsed="0.009341">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:26:57.769753" elapsed="0.027497">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mac-auto-generated": {
+        "local-discriminator": 2000,
+        "system-mac-address": "f2:0c:dd:80:9f:f7"
+       },
+       "mpls-label1": 24002,
+       "mpls-label2": 24003
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.807635" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.807960" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:59.808222" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.798854" elapsed="0.009427"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:59.808714" elapsed="0.006234"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.823792" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.823898" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:59.824020" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.815328" elapsed="0.008719"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:59.827151" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:59.826840" elapsed="0.000339"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:59.827607" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:59.827338" elapsed="0.000297"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:59.827874" elapsed="0.000369"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:59.824286" elapsed="0.004020"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:59.798004" elapsed="0.030356"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:57.769222" elapsed="2.059179"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:26:59.828967" elapsed="0.002787"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.838500" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.838676" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:59.838824" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.833385" elapsed="0.005476"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:59.839110" elapsed="0.003576"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.848217" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.848369" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:59.848516" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.842925" elapsed="0.005630"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:59.852971" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:59.852549" elapsed="0.000463"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:59.853616" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:59.853239" elapsed="0.000436"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:59.853901" elapsed="0.000462"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:59.848912" elapsed="0.005539"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:59.832630" elapsed="0.021897"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:26:59.832047" elapsed="0.022535"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:26:59.828591" elapsed="0.026089"/>
</kw>
<arg>route_mac_mac</arg>
<status status="PASS" start="2026-06-06T03:26:55.690563" elapsed="4.164187"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:55.568332" elapsed="4.286569"/>
</test>
<test id="s1-s13-t60" name="Odl_To_Play_route_mac_rou" line="211">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:26:59.860147" elapsed="0.000291"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:26:59.859754" elapsed="0.000764"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:59.861978" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:59.861809" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.861778" elapsed="0.000358"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:26:59.869335" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:59.869217" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.869197" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.870474" 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-06-06T03:26:59.870063" elapsed="0.000439"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.870987" 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-06-06T03:26:59.870684" elapsed="0.000329"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:26:59.871058" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:26:59.871222" 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-06-06T03:26:59.869672" elapsed="0.001576"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:26:59.877239" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:59.877126" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.877104" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:26:59.878791" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:26:59.878579" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.878560" elapsed="0.000392"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:26:59.879519" 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-06-06T03:26:59.879106" elapsed="0.000475"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:26:59.880236" level="INFO">${current_connection_index} = 7</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-06-06T03:26:59.879948" elapsed="0.000348"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:26:59.911742" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:26:59.882188" elapsed="0.029696"/>
</kw>
<msg time="2026-06-06T03:26:59.912044" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:26:59.912155" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:26:59.880609" elapsed="0.031620"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:26:59.938068" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "r "o "u "[K"
[?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-06-06T03:26:59.914216" elapsed="0.023996"/>
</kw>
<msg time="2026-06-06T03:26:59.938347" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:26:59.938440" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:26:59.912630" elapsed="0.025883"/>
</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-06-06T03:26:59.939238" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:59.938856" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.938829" elapsed="0.000585"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.940209" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "o "u "t "e "_ "m "a "c "_ "r "o "u "[K"
[?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-06-06T03:26:59.939570" elapsed="0.000759"/>
</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-06-06T03:26:59.940877" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:59.940505" elapsed="0.000488"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.940484" elapsed="0.000567"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:26:59.941091" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:26:59.944784" elapsed="0.000221"/>
</kw>
<msg time="2026-06-06T03:26:59.945050" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:26:59.944172" elapsed="0.000947"/>
</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="NOT RUN" start="2026-06-06T03:26:59.945342" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:59.945560" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:26:59.943369" elapsed="0.002435"/>
</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-06-06T03:26:59.941398" elapsed="0.004493"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:26:59.878134" elapsed="0.067936"/>
</kw>
<msg time="2026-06-06T03:26:59.946171" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:59.946215" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:59.877465" elapsed="0.068787"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:26:59.946438" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:26:59.946329" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.946309" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:59.947003" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:59.947427" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:26:59.947499" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:26:59.876781" elapsed="0.070828"/>
</kw>
<msg time="2026-06-06T03:26:59.947721" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:26:59.947767" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:26:59.871633" elapsed="0.076171"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:26:59.948171" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:26:59.947880" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:26:59.947862" elapsed="0.000386"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:26:59.871487" elapsed="0.076784"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:26:59.871307" elapsed="0.076997"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:26:59.868709" elapsed="0.079653"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:26:59.861376" elapsed="0.087042"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:26:59.860759" elapsed="0.087704"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:26:59.856697" elapsed="0.091822"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.955671" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.955810" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:26:59.955923" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.948984" elapsed="0.006967"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:26:59.956195" elapsed="0.003489"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.965615" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.965794" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:26:59.965939" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.959926" elapsed="0.006051"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:59.970453" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:59.969897" elapsed="0.000596"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:26:59.971117" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:26:59.970737" elapsed="0.000419"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:26:59.971380" elapsed="0.000476"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:26:59.966306" elapsed="0.005636"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:59.948705" elapsed="0.023334"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:26:59.855975" elapsed="0.116121"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:59.973193" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:59.973426" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:59.972901" elapsed="0.000566"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:59.973983" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:59.974161" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:59.973713" elapsed="0.000486"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:59.974710" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/announce_route_mac_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/announce_route_mac_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:59.974889" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:59.974423" elapsed="0.000504"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:59.975440" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:59.975151" elapsed="0.000327"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:26:59.976027" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/withdraw_route_mac_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/withdraw_route_mac_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:26:59.976205" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:26:59.975725" elapsed="0.000517"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:26:59.976824" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:26:59.976465" elapsed="0.000399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.977355" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:59.977092" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.977835" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "path-id": 0,
                "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
                "route-distinguisher": "429496729:1",
                "mac-ip-adv-route": {
                    "router-id-generated": {
                        "local-discriminator": 2000,
                        "router-id": "43.43.43.43"
                    },
                    "mpls-label1": 24002,
                    "mpls-label2": 24003,
                    "ip-address": "43.43.43.43",
                    "ethernet-tag-id": {
                        "vlan-id": 10
                    },
                    "mac-address": "f2:0c:dd:80:9f:f7"
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:59.977572" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.978290" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:59.978050" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.978748" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:59.978491" elapsed="0.000302"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:26:59.978945" elapsed="0.002527"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:26:59.992435" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1017', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:26:59.992524" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=AhgAAhmZmZkAAQAAAAow8gzdgJ%2F3ICsrKys%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:26:59.992680" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.981638" elapsed="0.011080"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:26:59.996668" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:26:59.992966" elapsed="0.003766"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.003532" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.004192" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:00.004352" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:26:59.996958" elapsed="0.007431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.008135" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.004630" elapsed="0.003579"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.014968" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.015374" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:00.015472" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.009598" elapsed="0.005900"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.018163" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.015697" elapsed="0.002515"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.018373" elapsed="0.002511"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:00.023349" level="INFO">${update} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:00.021051" elapsed="0.002339"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.023666" elapsed="0.003110"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:00.026850" elapsed="0.000051"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:00.009127" elapsed="0.017913"/>
</kw>
<msg time="2026-06-06T03:27:00.027151" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:00.008460" elapsed="0.018727"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.027784" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.027420" elapsed="0.000428"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.029084" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:27:00.029194" level="INFO">${len_1} = 182</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:00.028720" elapsed="0.000507"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.029821" level="INFO">Length is 182.</msg>
<msg time="2026-06-06T03:27:00.029926" level="INFO">${len_2} = 182</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:00.029447" elapsed="0.000512"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.030178" elapsed="0.000423"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:00.031176" level="INFO">${sum_1} = 3905</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:00.030906" elapsed="0.000306"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:00.031716" level="INFO">${sum_2} = 3905</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:00.031432" elapsed="0.000321"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.032007" elapsed="0.000432"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:00.028184" elapsed="0.004338"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:00.032787" elapsed="0.002239"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.039310" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.039427" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:00.039523" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.035536" elapsed="0.004013"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.043157" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.039739" elapsed="0.003488"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.043448" elapsed="0.003503"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.051904" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.052036" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:00.052142" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.047182" elapsed="0.004986"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.054754" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","path-id":0,"mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.052343" elapsed="0.002461"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.054961" elapsed="0.002484"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:00.059842" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:00.057528" elapsed="0.002356"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.057506" elapsed="0.002432"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.066034" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.066098" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.066244" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.060126" elapsed="0.006156"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:00.035239" elapsed="0.031137"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.074025" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.074189" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:00.074322" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.067790" elapsed="0.006568"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.078063" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.074603" elapsed="0.003528"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.078353" elapsed="0.003541"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:00.084571" level="INFO">${update} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:00.082126" elapsed="0.002486"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.084890" elapsed="0.003011"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:00.088010" elapsed="0.000053"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:00.067277" elapsed="0.020924"/>
</kw>
<msg time="2026-06-06T03:27:00.088312" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:00.066608" elapsed="0.021740"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.088947" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.088582" elapsed="0.000428"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.090231" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:27:00.090336" level="INFO">${len_1} = 170</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:00.089870" elapsed="0.000500"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.090961" level="INFO">Length is 170.</msg>
<msg time="2026-06-06T03:27:00.091064" level="INFO">${len_2} = 170</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:00.090586" elapsed="0.000511"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.091319" elapsed="0.000446"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:00.092263" level="INFO">${sum_1} = 3458</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:00.092001" elapsed="0.000299"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:00.092795" level="INFO">${sum_2} = 3458</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:00.092516" elapsed="0.000315"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.093103" elapsed="0.000434"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:00.089335" elapsed="0.004286"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.099314" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.099422" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:00.099515" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.094427" elapsed="0.005114"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.102356" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.099731" elapsed="0.002672"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.102563" elapsed="0.002517"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.111990" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.112141" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:00.112283" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.105245" elapsed="0.007079"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.116078" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.112569" elapsed="0.003577"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.116372" elapsed="0.003597"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:00.123434" elapsed="0.000045"/>
</return>
<status status="PASS" start="2026-06-06T03:27:00.120096" elapsed="0.003429"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.120066" elapsed="0.003495"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.123810" elapsed="0.000032"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:00.093997" elapsed="0.029958"/>
</kw>
<arg>route_mac_rou</arg>
<status status="PASS" start="2026-06-06T03:26:59.972462" elapsed="0.151565"/>
</kw>
<status status="PASS" start="2026-06-06T03:26:59.855325" elapsed="0.268865"/>
</test>
<test id="s1-s13-t61" name="Play_To_Odl_route_mac_rou" line="213">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:00.129167" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:00.128893" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:00.130450" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:00.130337" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.130316" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:00.135622" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:00.135515" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.135496" elapsed="0.000290"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.136822" 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-06-06T03:27:00.136418" elapsed="0.000431"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.137311" 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-06-06T03:27:00.137014" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:00.137382" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:00.137537" 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-06-06T03:27:00.136031" elapsed="0.001531"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:00.143583" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:00.143473" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.143453" elapsed="0.000227"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:00.145171" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:00.144983" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.144963" elapsed="0.000371"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:00.145924" 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-06-06T03:27:00.145489" elapsed="0.000496"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:00.146602" level="INFO">${current_connection_index} = 7</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-06-06T03:27:00.146336" elapsed="0.000344"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:00.178491" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:00.148662" elapsed="0.029967"/>
</kw>
<msg time="2026-06-06T03:27:00.178792" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:00.178886" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:00.146995" elapsed="0.031962"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:00.207174" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "r "o "u "[K"
[?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-06-06T03:27:00.180931" elapsed="0.026542"/>
</kw>
<msg time="2026-06-06T03:27:00.207605" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:00.207723" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:00.179359" elapsed="0.028437"/>
</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-06-06T03:27:00.208528" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:00.208110" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.208087" elapsed="0.000636"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.209444" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "o "u "t "e "_ "m "a "c "_ "r "o "u "[K"
[?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-06-06T03:27:00.208880" elapsed="0.000680"/>
</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-06-06T03:27:00.210110" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:00.209755" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.209734" elapsed="0.000550"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:00.210321" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:00.213874" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:27:00.214068" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:00.213296" elapsed="0.000844"/>
</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="NOT RUN" start="2026-06-06T03:27:00.214416" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.214634" elapsed="0.000039"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:00.212535" elapsed="0.002336"/>
</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-06-06T03:27:00.210594" elapsed="0.004363"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:00.144506" elapsed="0.070628"/>
</kw>
<msg time="2026-06-06T03:27:00.215230" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:00.215274" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:00.143842" elapsed="0.071469"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:00.215501" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:00.215389" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.215369" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.216086" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.216512" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:00.216584" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:00.143124" elapsed="0.073660"/>
</kw>
<msg time="2026-06-06T03:27:00.216881" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:00.216925" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:00.137962" elapsed="0.079000"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.217303" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:00.217038" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.217021" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:00.137816" elapsed="0.079588"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:00.137620" elapsed="0.079816"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:00.135149" elapsed="0.082344"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:00.130044" elapsed="0.087504"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:00.129591" elapsed="0.088003"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:00.125992" elapsed="0.091674"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.223900" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.224052" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:00.224158" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.218098" elapsed="0.006087"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:00.224357" elapsed="0.002616"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.232787" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.232932" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:00.233036" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:00.227142" elapsed="0.005921"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:00.236200" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:00.235873" elapsed="0.000355"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:00.236672" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:00.236387" elapsed="0.000314"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.236861" elapsed="0.000328"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:00.233300" elapsed="0.003951"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:00.217818" elapsed="0.019488"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:00.125292" elapsed="0.112052"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:00.238069" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:00.238223" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:00.237866" elapsed="0.000387"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.267970" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_rou.vanadium/route_mac_rou.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:00.267553" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:00.268814" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou.vanadium/route_mac_rou.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:00.268519" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou.vanadium/route_mac_rou.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:00.268984" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:00.268171" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.269568" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:00.269180" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:00.269914" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/route_mac_rou.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:00.270048" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:00.269776" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.270483" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "path-id": 0,
                "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
                "route-distinguisher": "429496729:1",
                "mac-ip-adv-route": {
                    "router-id-generated": {
                        "local-discriminator": 2000,
                        "router-id": "43.43.43.43"
                    },
                    "mpls-label1": 24002,
                    "mpls-label2": 24003,
                    "ip-address": "43.43.43.43",
                    "ethernet-tag-id": {
                        "vlan-id": 10
                    },
                    "mac-address": "f2:0c:dd:80:9f:f7"
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.270235" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:00.271044" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:00.270679" elapsed="0.000426"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.271590" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:00.271287" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:00.271132" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:00.270653" elapsed="0.001038"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.272336" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:00.271844" elapsed="0.000521"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:00.272419" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:27:00.272585" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:00.265246" elapsed="0.007366"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:00.273039" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/announce_route_mac_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/announce_route_mac_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:00.273175" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:00.272838" elapsed="0.000364"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:00.273552" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/withdraw_route_mac_rou.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/route_mac_rou/withdraw_route_mac_rou.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:00.273688" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:00.273362" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.274126" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;mac-ip-adv-route&gt;
        &lt;router-id-generated&gt;
            &lt;router-id&gt;43.43.43.43&lt;/router-id&gt;
            &lt;local-discriminator&gt;2000&lt;/local-discriminator&gt;
        &lt;/router-id-generated&gt;
        &lt;ethernet-tag-id&gt;
            &lt;vlan-id&gt;10&lt;/vlan-id&gt;
        &lt;/ethernet-tag-id&gt;
        &lt;mac-address&gt;f2:0c:dd:80:9f:f7&lt;/mac-address&gt;
        &lt;ip-address&gt;43.43.43.43&lt;/ip-address&gt;
        &lt;mpls-label1&gt;24002&lt;/mpls-label1&gt;
        &lt;mpls-label2&gt;24003&lt;/mpls-label2&gt;
    &lt;/mac-ip-adv-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.273879" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.274583" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "path-id": 0,
                "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
                "route-distinguisher": "429496729:1",
                "mac-ip-adv-route": {
                    "router-id-generated": {
                        "local-discriminator": 2000,
                        "router-id": "43.43.43.43"
                    },
                    "mpls-label1": 24002,
                    "mpls-label2": 24003,
                    "ip-address": "43.43.43.43",
                    "ethernet-tag-id": {
                        "vlan-id": 10
                    },
                    "mac-address": "f2:0c:dd:80:9f:f7"
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.274345" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.275046" level="INFO">ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.274807" elapsed="0.000282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:00.275480" level="INFO">ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:00.275243" elapsed="0.000282"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:00.275692" elapsed="0.002476"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:00.278367" elapsed="0.001925"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:00.286403" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:00.286579" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:00.286739" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:00.281281" elapsed="0.005958">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.287505" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:00.287864" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:00.280948" elapsed="0.007110">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:02.299151" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:02.299374" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:02.299529" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:02.289722" elapsed="0.009865"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:02.300327" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "path-id": 0,
                "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=",
                "route-distinguisher": "429496729:1",
                "mac-ip-adv-route": {
                    "router-id-generated": {
                        "local-discriminator": 2000,
                        "router-id": "43.43.43.43"
                    },
                    "mpls-label1": 24002,
                    "mpls-label2": 24003,
                    "ip-address": "43.43.43.43",
                    "ethernet-tag-id": {
                        "vlan-id": 10
                    },
                    "mac-address": "f2:0c:dd:80:9f:f7"
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:02.303599" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:02.299905" elapsed="0.003792"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:02.308258" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:02.307552" elapsed="0.000735"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:02.308967" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:02.308511" elapsed="0.000484"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:02.309159" elapsed="0.000334"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:02.304030" elapsed="0.005528"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:02.288736" elapsed="0.020877"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:00.280474" elapsed="2.029205"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:02.309843" elapsed="0.002703"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:02.317718" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:02.317871" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:02.318004" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:02.313484" elapsed="0.004557"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:02.318279" elapsed="0.003903"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:02.327304" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:02.328011" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '635'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys=","mac-ip-adv-route":{"ip-address":"43.43.43.43","router-id-generated":{"router-id":"43.43.43.43","local-discriminator":2000},"ethernet-tag-id":{"vlan-id":10},"mac-address":"f2:0c:dd:80:9f:f7","mpls-label2":24003,"mpls-label1":24002},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:02.328163" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:02.322419" elapsed="0.005782"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:02.332485" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:02.332092" elapsed="0.000433"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:02.333469" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:02.332774" elapsed="0.000736"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:02.334206" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "mac-ip-adv-route": {
       "ethernet-tag-id": {
        "vlan-id": 10
       },
       "ip-address": "43.43.43.43",
       "mac-address": "f2:0c:dd:80:9f:f7",
       "mpls-label1": 24002,
       "mpls-label2": 24003,
       "router-id-generated": {
        "local-discriminator": 2000,
        "router-id": "43.43.43.43"
       }
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:02.334574" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "mac-ip-adv-route": {
+       "ethernet-tag-id": {
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:02.333761" elapsed="0.000942">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:02.328522" elapsed="0.006413">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:02.313206" elapsed="0.021939">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
    [ Message content over the limit has been removed. ]
+        "vlan-id": 10
+       },
+       "ip-address": "43.43.43.43",
+       "mac-address": "f2:0c:dd:80:9f:f7",
+       "mpls-label1": 24002,
+       "mpls-label2": 24003,
+       "router-id-generated": {
+        "local-discriminator": 2000,
+        "router-id": "43.43.43.43"
+       }
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "AhgAAhmZmZkAAQAAAAow8gzdgJ/3ICsrKys="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.344089" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.344310" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.344475" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.336379" elapsed="0.008141"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.344822" elapsed="0.003952"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.353902" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.354038" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:04.354168" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.349021" elapsed="0.005180"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.358451" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.358026" elapsed="0.000464"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.359099" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.358732" elapsed="0.000406"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.359414" elapsed="0.000472"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.354579" elapsed="0.005389"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.335742" elapsed="0.024300"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:02.312751" elapsed="2.047349"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:04.360838" elapsed="0.002291"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.374077" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.374358" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.374611" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.365864" elapsed="0.008843"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.375129" elapsed="0.004161"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.385392" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.385571" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:04.385770" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.379548" elapsed="0.006261"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.390543" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.390078" elapsed="0.000507"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.391282" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.390853" elapsed="0.000470"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.391564" elapsed="0.000556"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.386182" elapsed="0.006033"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.364682" elapsed="0.027616"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:04.363609" elapsed="0.028749"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:04.360357" elapsed="0.032088"/>
</kw>
<arg>route_mac_rou</arg>
<status status="PASS" start="2026-06-06T03:27:00.237553" elapsed="4.154965"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:00.124626" elapsed="4.268164"/>
</test>
<test id="s1-s13-t62" name="Odl_To_Play_pmsi_rsvp_te_p2mp_lsp" line="216">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:04.397879" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:04.397592" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:04.399265" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.399090" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.399063" elapsed="0.000296"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:04.404426" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.404311" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.404292" elapsed="0.000205"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.405545" 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-06-06T03:27:04.405139" elapsed="0.000434"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.406058" 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-06-06T03:27:04.405755" elapsed="0.000329"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:04.406129" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:27:04.406292" 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-06-06T03:27:04.404750" elapsed="0.001567"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:04.412248" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.412136" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.412115" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:04.413804" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.413590" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.413571" elapsed="0.000395"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:04.414583" 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-06-06T03:27:04.414122" elapsed="0.000537"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:04.415303" level="INFO">${current_connection_index} = 7</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-06-06T03:27:04.415015" elapsed="0.000348"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:04.448780" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:04.417215" elapsed="0.031794"/>
</kw>
<msg time="2026-06-06T03:27:04.449194" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:04.449294" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:04.415693" elapsed="0.033673"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:04.478936" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "r "s "v "p "_ "t "e "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:04.451555" elapsed="0.027676"/>
</kw>
<msg time="2026-06-06T03:27:04.479452" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:04.479551" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:04.449864" elapsed="0.029761"/>
</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-06-06T03:27:04.480514" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.480024" elapsed="0.000613"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.479982" elapsed="0.000740"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.481563" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "r "s "v "p "_ "t "e "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:04.480885" elapsed="0.000819"/>
</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-06-06T03:27:04.482333" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.481966" elapsed="0.000483"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.481945" elapsed="0.000562"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:04.482551" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:04.486355" elapsed="0.000152"/>
</kw>
<msg time="2026-06-06T03:27:04.486555" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:04.485767" elapsed="0.000862"/>
</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="NOT RUN" start="2026-06-06T03:27:04.486867" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.487091" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:04.484966" elapsed="0.002384"/>
</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-06-06T03:27:04.482907" elapsed="0.004533"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:04.413148" elapsed="0.074474"/>
</kw>
<msg time="2026-06-06T03:27:04.487758" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:04.487804" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:04.412475" elapsed="0.075366"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:04.488038" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:04.487924" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.487903" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.488611" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.489085" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:04.489159" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:04.411790" elapsed="0.077486"/>
</kw>
<msg time="2026-06-06T03:27:04.489378" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:04.489422" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:04.406726" elapsed="0.082735"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.489819" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.489540" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.489521" elapsed="0.000379"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:04.406560" elapsed="0.083365"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:04.406377" elapsed="0.083584"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:04.403934" elapsed="0.086088"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:04.398778" elapsed="0.091302"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:04.398305" elapsed="0.091823"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:04.394843" elapsed="0.095343"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.496538" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.496837" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.497006" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.490627" elapsed="0.006419"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.497306" elapsed="0.004312"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.507487" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.507613" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:04.507753" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.501897" elapsed="0.005884"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.511008" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.510691" elapsed="0.000346"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.511492" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.511214" elapsed="0.000306"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.511719" elapsed="0.000353"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.508039" elapsed="0.004098"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.490338" elapsed="0.021857"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:04.394083" elapsed="0.118157"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.513041" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.513263" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.512836" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.513663" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.513794" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.513455" elapsed="0.000366"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.514172" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/announce_pmsi_rsvp_te_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/announce_pmsi_rsvp_te_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.514299" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.513980" elapsed="0.000345"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:04.514718" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:04.514490" elapsed="0.000256"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.515147" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/withdraw_pmsi_rsvp_te_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/withdraw_pmsi_rsvp_te_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.515316" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.514955" elapsed="0.000389"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:04.515726" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:04.515505" elapsed="0.000249"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.516173" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;rsvp-te-p2mp-lsp&gt;
                &lt;p2mp-id&gt;1111111111&lt;/p2mp-id&gt;
                &lt;tunnel-id&gt;11111&lt;/tunnel-id&gt;
                &lt;extended-tunnel-id&gt;10.10.10.10&lt;/extended-tunnel-id&gt;
            &lt;/rsvp-te-p2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.515918" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.516858" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "rsvp-te-p2mp-lsp": {
                            "extended-tunnel-id": "10.10.10.10",
                            "p2mp-id": 1111111111,
                            "tunnel-id": 11111
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.516471" elapsed="0.000466"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.517531" level="INFO">ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.517171" elapsed="0.000427"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.518217" level="INFO">ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.517855" elapsed="0.000429"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:04.518513" elapsed="0.002886"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.534230" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1089', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;rsvp-te-p2mp-lsp&gt;
                &lt;p2mp-id&gt;1111111111&lt;/p2mp-id&gt;
                &lt;tunnel-id&gt;11111&lt;/tunnel-id&gt;
                &lt;extended-tunnel-id&gt;10.10.10.10&lt;/extended-tunnel-id&gt;
            &lt;/rsvp-te-p2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:04.534372" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.534707" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.521715" elapsed="0.013056"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.541417" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.535197" elapsed="0.006317"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.549250" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.549731" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '502'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:04.549840" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.541914" elapsed="0.007954"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.552503" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.550041" elapsed="0.002512"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.558924" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.559493" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '502'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:04.559629" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.553594" elapsed="0.006093"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.563411" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.559933" elapsed="0.003548"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.563726" elapsed="0.003544"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:04.570168" level="INFO">${update} = ffffffffffffffffffffffffffffffff005e02000000474001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.567502" elapsed="0.002707"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.570458" elapsed="0.003090"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:04.573623" elapsed="0.000076"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:04.553247" elapsed="0.020599"/>
</kw>
<msg time="2026-06-06T03:27:04.573958" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005e02000000474001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:04.552748" elapsed="0.021246"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.574626" level="INFO">ffffffffffffffffffffffffffffffff005e02000000474001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.574280" elapsed="0.000454"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.576165" level="INFO">Length is 188.</msg>
<msg time="2026-06-06T03:27:04.576274" level="INFO">${len_1} = 188</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:04.575790" elapsed="0.000518"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.576912" level="INFO">Length is 188.</msg>
<msg time="2026-06-06T03:27:04.577016" level="INFO">${len_2} = 188</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:04.576528" elapsed="0.000521"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.577274" elapsed="0.000454"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:04.578217" level="INFO">${sum_1} = 3045</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:04.577953" elapsed="0.000301"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:04.578758" level="INFO">${sum_2} = 3045</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:04.578475" elapsed="0.000318"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.579013" elapsed="0.000447"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:04.575064" elapsed="0.004479"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:04.579780" elapsed="0.002100"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.586446" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.586564" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '502'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:04.586686" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.582405" elapsed="0.004310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.589503" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.586890" elapsed="0.002664"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.589728" elapsed="0.002524"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.599702" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.599868" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '502'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:04.600014" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.592493" elapsed="0.007618"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.603793" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.600367" elapsed="0.003496"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.604087" elapsed="0.003528"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:04.610982" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.607753" elapsed="0.003289"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.607722" elapsed="0.003354"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.618626" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.618692" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.618794" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.611332" elapsed="0.007489"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:04.582122" elapsed="0.036765"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.625309" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.625459" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.625589" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.619880" elapsed="0.005745"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.629283" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.625893" elapsed="0.003456"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.629572" elapsed="0.003545"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:04.635795" level="INFO">${update} = ffffffffffffffffffffffffffffffff005802000000414001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.633347" elapsed="0.002489"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.636082" elapsed="0.003032"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:04.639243" elapsed="0.000047"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:04.619529" elapsed="0.020016"/>
</kw>
<msg time="2026-06-06T03:27:04.639692" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff005802000000414001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:04.619053" elapsed="0.020678"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.640311" level="INFO">ffffffffffffffffffffffffffffffff005802000000414001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.639966" elapsed="0.000409"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.641589" level="INFO">Length is 176.</msg>
<msg time="2026-06-06T03:27:04.641716" level="INFO">${len_1} = 176</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:04.641229" elapsed="0.000566"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.642378" level="INFO">Length is 176.</msg>
<msg time="2026-06-06T03:27:04.642481" level="INFO">${len_2} = 176</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:04.642021" elapsed="0.000493"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.642754" elapsed="0.000463"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:04.643728" level="INFO">${sum_1} = 2598</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:04.643442" elapsed="0.000322"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:04.644239" level="INFO">${sum_2} = 2598</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:04.643980" elapsed="0.000294"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.644490" elapsed="0.000451"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:04.640719" elapsed="0.004307"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.650886" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.650994" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.651088" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.645823" elapsed="0.005292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.653942" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.651322" elapsed="0.002668"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.654147" elapsed="0.002529"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.662091" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.662242" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.662384" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.656842" elapsed="0.005580"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.666107" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.662690" elapsed="0.003486"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.666396" elapsed="0.003555"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:04.673346" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:27:04.670058" elapsed="0.003373"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.670031" elapsed="0.003434"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.673700" elapsed="0.000032"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:04.645381" elapsed="0.028500"/>
</kw>
<arg>pmsi_rsvp_te_p2mp_lsp</arg>
<status status="PASS" start="2026-06-06T03:27:04.512513" elapsed="0.161434"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.393258" elapsed="0.280841"/>
</test>
<test id="s1-s13-t63" name="Play_To_Odl_pmsi_rsvp_te_p2mp_lsp" line="219">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:04.678583" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:04.678312" elapsed="0.000557"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:04.679905" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.679791" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.679771" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:04.684978" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.684870" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.684852" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.686157" 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-06-06T03:27:04.685771" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.686666" 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-06-06T03:27:04.686354" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:04.686738" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:04.686891" 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-06-06T03:27:04.685278" elapsed="0.001638"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:04.692729" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.692603" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.692583" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:04.694252" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:04.694067" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.694048" elapsed="0.000367"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:04.694997" 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-06-06T03:27:04.694568" elapsed="0.000491"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:04.695715" level="INFO">${current_connection_index} = 7</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-06-06T03:27:04.695436" elapsed="0.000342"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:04.727389" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:04.697613" elapsed="0.029907"/>
</kw>
<msg time="2026-06-06T03:27:04.727696" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:04.727792" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:04.696089" elapsed="0.031773"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:04.778744" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "r "s "v "p "_ "t "e "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:04.729774" elapsed="0.049136"/>
</kw>
<msg time="2026-06-06T03:27:04.779060" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:04.779189" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:04.728252" elapsed="0.051011"/>
</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-06-06T03:27:04.780029" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.779587" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.779558" elapsed="0.000651"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.781044" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "r "s "v "p "_ "t "e "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:04.780364" elapsed="0.000876"/>
</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-06-06T03:27:04.781801" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.781421" elapsed="0.000497"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.781400" elapsed="0.000578"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:04.782020" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:04.785734" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:27:04.785936" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:04.785127" elapsed="0.000883"/>
</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="NOT RUN" start="2026-06-06T03:27:04.786231" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.786454" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:04.784338" elapsed="0.002359"/>
</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-06-06T03:27:04.782343" elapsed="0.004444"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:04.693598" elapsed="0.093370"/>
</kw>
<msg time="2026-06-06T03:27:04.787071" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:04.787171" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:04.692958" elapsed="0.094256"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:04.787418" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:04.787300" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.787278" elapsed="0.000227"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.788015" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.788448" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:04.788522" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:04.692262" elapsed="0.096374"/>
</kw>
<msg time="2026-06-06T03:27:04.788815" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:04.788859" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:04.687321" elapsed="0.101576"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.789234" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.788975" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.788957" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:04.687166" elapsed="0.102170"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:04.686973" elapsed="0.102397"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:04.684494" elapsed="0.104934"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:04.679484" elapsed="0.110002"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:04.679028" elapsed="0.110507"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:04.676057" elapsed="0.113536"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.795950" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.796166" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.796270" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.790055" elapsed="0.006243"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:04.796475" elapsed="0.003362"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.806223" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.806415" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:04.806581" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:04.800010" elapsed="0.006611"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.811712" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.810990" elapsed="0.000767"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:04.812426" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:04.812018" elapsed="0.000449"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.812728" elapsed="0.000513"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:04.807037" elapsed="0.006297"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.789762" elapsed="0.023654"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:04.675368" elapsed="0.138112"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.814593" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.814861" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.814293" elapsed="0.000611"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.842626" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp.vanadium/pmsi_rsvp_te_p2mp_lsp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:04.842186" elapsed="0.000495"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.843564" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp.vanadium/pmsi_rsvp_te_p2mp_lsp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:04.843270" elapsed="0.000389">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp.vanadium/pmsi_rsvp_te_p2mp_lsp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:04.843758" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:04.842871" elapsed="0.000914"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.844353" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:04.843957" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.844802" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/pmsi_rsvp_te_p2mp_lsp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.844959" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.844654" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.845401" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "rsvp-te-p2mp-lsp": {
                            "extended-tunnel-id": "10.10.10.10",
                            "p2mp-id": 1111111111,
                            "tunnel-id": 11111
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.845152" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:04.845932" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:04.845538" elapsed="0.000455"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.846469" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:04.846172" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.846020" elapsed="0.000512"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:04.845512" elapsed="0.001042"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.847249" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:04.846768" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:04.847336" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:27:04.847499" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:04.839737" elapsed="0.007789"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.847906" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/announce_pmsi_rsvp_te_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/announce_pmsi_rsvp_te_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.848032" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.847708" elapsed="0.000350"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:04.848414" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/withdraw_pmsi_rsvp_te_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_rsvp_te_p2mp_lsp/withdraw_pmsi_rsvp_te_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:04.848533" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:04.848218" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.848980" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;rsvp-te-p2mp-lsp&gt;
                &lt;p2mp-id&gt;1111111111&lt;/p2mp-id&gt;
                &lt;tunnel-id&gt;11111&lt;/tunnel-id&gt;
                &lt;extended-tunnel-id&gt;10.10.10.10&lt;/extended-tunnel-id&gt;
            &lt;/rsvp-te-p2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.848733" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.849478" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "rsvp-te-p2mp-lsp": {
                            "extended-tunnel-id": "10.10.10.10",
                            "p2mp-id": 1111111111,
                            "tunnel-id": 11111
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.849226" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.849947" level="INFO">ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.849703" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:04.850387" level="INFO">ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:04.850145" elapsed="0.000285"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:04.850583" elapsed="0.003022"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:04.853802" elapsed="0.002156"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:04.863392" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:04.863572" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:04.863736" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:04.856951" elapsed="0.007275">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.864501" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:04.864856" elapsed="0.000034"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:04.856593" elapsed="0.008434">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:06.875856" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:06.876115" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '502'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:06.876309" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:06.866773" elapsed="0.009583"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:06.877120" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "rsvp-te-p2mp-lsp": {
                            "extended-tunnel-id": "10.10.10.10",
                            "p2mp-id": 1111111111,
                            "tunnel-id": 11111
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:06.880325" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:06.876716" elapsed="0.003680"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:06.885148" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:06.884282" elapsed="0.000907"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:06.886062" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:06.885414" elapsed="0.000687"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:06.886327" elapsed="0.000500"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:06.880742" elapsed="0.006173"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:06.865761" elapsed="0.021230"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:04.856155" elapsed="2.030901"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:06.887280" elapsed="0.002876"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:06.899204" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:06.899359" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:06.899504" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:06.891095" elapsed="0.008446"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:06.899799" elapsed="0.003529"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:06.909034" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:06.909515" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '650'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"rsvp-te-p2mp-lsp":{"p2mp-id":1111111111,"tunnel-id":11111,"extended-tunnel-id":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:06.909677" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:06.903562" elapsed="0.006144"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:06.912841" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:06.912541" elapsed="0.000329"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:06.913540" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:06.913029" elapsed="0.000540"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:06.914076" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "leaf-information-required": true,
        "mpls-label": 20024,
        "rsvp-te-p2mp-lsp": {
         "extended-tunnel-id": "10.10.10.10",
         "p2mp-id": 1111111111,
         "tunnel-id": 11111
        }
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:06.914315" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,41 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "leaf-information-required": true,
+        "mpls-label": 20024,
+        "rsvp-te-p2mp-lsp": {
+         "extended-tunnel-id": "10.10.10.10",
+         "p2mp-id": 1111111111,
+         "tunnel-id": 11111
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:06.913751" elapsed="0.000652">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,41 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p2mp-id": 1111111111,
+         "tunnel-id": 11111
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:06.909934" elapsed="0.004637">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,41 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p2mp-id": 1111111111,
+         "tunnel-id": 11111
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:06.890818" elapsed="0.023953">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,41 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p2mp-id": 1111111111,
+         "tunnel-id": 11111
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:08.925465" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:08.925695" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:08.925929" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:08.916315" elapsed="0.009652"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:08.926223" elapsed="0.003846"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:08.935190" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:08.935339" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:08.935484" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:08.930326" elapsed="0.005194"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:08.939960" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:08.939495" elapsed="0.000505"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:08.940613" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:08.940227" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:08.940901" elapsed="0.000461"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:08.935880" elapsed="0.005569"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:08.915406" elapsed="0.026119"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:06.890332" elapsed="2.051247"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:08.942389" elapsed="0.002757"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:08.953961" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:08.954110" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:08.954254" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:08.946863" elapsed="0.007453"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:08.954558" elapsed="0.003577"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:08.963269" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:08.963414" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:08.963556" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:08.958388" elapsed="0.005205"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:08.968058" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:08.967659" elapsed="0.000439"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:08.968719" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:08.968322" elapsed="0.000437"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:08.968981" elapsed="0.000451"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:08.963990" elapsed="0.005528"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:08.946401" elapsed="0.023191"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:08.945424" elapsed="0.024240"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:08.941863" elapsed="0.027882"/>
</kw>
<arg>pmsi_rsvp_te_p2mp_lsp</arg>
<status status="PASS" start="2026-06-06T03:27:04.813823" elapsed="4.155988"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:04.674664" elapsed="4.295304"/>
</test>
<test id="s1-s13-t64" name="Odl_To_Play_pmsi_mldp_p2mp_lsp" line="222">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:08.975151" elapsed="0.000288"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:08.974780" elapsed="0.000737"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:08.976975" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:08.976805" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:08.976771" elapsed="0.000308"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:08.984052" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:08.983944" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:08.983926" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:08.985133" 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-06-06T03:27:08.984748" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:08.985618" 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-06-06T03:27:08.985323" elapsed="0.000334"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:08.985703" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:27:08.985868" 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-06-06T03:27:08.984351" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:08.991465" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:08.991355" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:08.991336" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:08.993022" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:08.992836" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:08.992816" elapsed="0.000370"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:08.993772" 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-06-06T03:27:08.993342" elapsed="0.000492"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:08.994489" level="INFO">${current_connection_index} = 7</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-06-06T03:27:08.994189" elapsed="0.000360"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:09.030020" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:08.996595" elapsed="0.033564"/>
</kw>
<msg time="2026-06-06T03:27:09.030311" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:09.030406" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:08.994883" elapsed="0.035594"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:09.061639" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "m "l "d "p "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:09.032500" elapsed="0.029308"/>
</kw>
<msg time="2026-06-06T03:27:09.061955" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:09.062051" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:09.030952" elapsed="0.031170"/>
</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-06-06T03:27:09.062877" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.062456" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.062428" elapsed="0.000627"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.063836" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "m "l "d "p "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:09.063214" elapsed="0.000740"/>
</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-06-06T03:27:09.064492" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.064131" elapsed="0.000476"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.064111" elapsed="0.000757"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:09.064911" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:09.068610" elapsed="0.000166"/>
</kw>
<msg time="2026-06-06T03:27:09.068821" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:09.068040" elapsed="0.000851"/>
</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="NOT RUN" start="2026-06-06T03:27:09.069112" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.069331" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:09.067252" elapsed="0.002302"/>
</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-06-06T03:27:09.065231" elapsed="0.004429"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:08.992353" elapsed="0.077488"/>
</kw>
<msg time="2026-06-06T03:27:09.069937" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:09.069982" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:08.991712" elapsed="0.078308"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:09.070448" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:27:09.070098" elapsed="0.000414"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.070079" elapsed="0.000459"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.071033" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.071466" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:09.071540" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:08.991018" elapsed="0.080650"/>
</kw>
<msg time="2026-06-06T03:27:09.071764" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:09.071809" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:08.986294" elapsed="0.085550"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.072181" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.071922" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.071904" elapsed="0.000396"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:08.986132" elapsed="0.086196"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:08.985950" elapsed="0.086411"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:08.983569" elapsed="0.088853"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:08.976370" elapsed="0.096111"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:08.975754" elapsed="0.096772"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:08.971722" elapsed="0.100859"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.077853" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.077987" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:09.078101" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.073066" elapsed="0.005062"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.078321" elapsed="0.002799"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.086694" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.086800" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:09.086902" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.081289" elapsed="0.005640"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:09.091157" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:09.090740" elapsed="0.000457"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:09.091828" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:09.091422" elapsed="0.000445"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.092090" elapsed="0.000449"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.087163" elapsed="0.005463"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:09.072790" elapsed="0.019935"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:08.971049" elapsed="0.121735"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.093871" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.094110" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.093567" elapsed="0.000585"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.094739" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.094921" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.094442" elapsed="0.000519"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.095456" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/announce_pmsi_mldp_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/announce_pmsi_mldp_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.095758" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b...</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.095188" elapsed="0.000610"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:09.096325" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b...</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:09.096028" elapsed="0.000335"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.096754" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/withdraw_pmsi_mldp_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/withdraw_pmsi_mldp_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.096883" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.096544" elapsed="0.000366"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:09.097276" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:09.097072" elapsed="0.000231"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.097731" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;mldp-p2mp-lsp&gt;
                &lt;address-family xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types"&gt;x:ipv4-address-family&lt;/address-family&gt;
                &lt;root-node-address&gt;10.10.10.10&lt;/root-node-address&gt;
                &lt;opaque-value&gt;
                    &lt;opaque-type&gt;1&lt;/opaque-type&gt;
                    &lt;opaque&gt;01:01:01:01:01:01:01&lt;/opaque&gt;
                &lt;/opaque-value&gt;
            &lt;/mldp-p2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.097466" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.098192" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "mldp-p2mp-lsp": {
                            "address-family": "bgp-types:ipv4-address-family",
                            "opaque-value": [
                                {
                                    "opaque": "01:01:01:01:01:01:01",
                                    "opaque-type": 1
                                }
                            ],
                            "root-node-address": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.097951" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.098687" level="INFO">ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.098428" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.099140" level="INFO">ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.098894" elapsed="0.000330"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:09.099391" elapsed="0.002722"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.114372" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1287', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;mldp-p2mp-lsp&gt;
                &lt;address-family xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types"&gt;x:ipv4-address-family&lt;/address-family&gt;
                &lt;root-node-address&gt;10.10.10.10&lt;/root-node-address&gt;
                &lt;opaque-value&gt;
                    &lt;opaque-type&gt;1&lt;/opaque-type&gt;
                    &lt;opaque&gt;01:01:01:01:01:01:01&lt;/opaque&gt;
                &lt;/opaque-value&gt;
            &lt;/mldp-p2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:09.114520" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.114797" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.102332" elapsed="0.012525"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.120834" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.115252" elapsed="0.005680"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.130675" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.131151" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '575'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:09.131259" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.121292" elapsed="0.009994"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.137086" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.131508" elapsed="0.005692"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.146878" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.147305" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '575'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:09.147437" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.139429" elapsed="0.008036"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.150092" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.147658" elapsed="0.002484"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.150330" elapsed="0.003077"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:09.156119" level="INFO">${update} = ffffffffffffffffffffffffffffffff0066020000004f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a0100070101010101...</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:09.153657" elapsed="0.002504"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.156408" elapsed="0.003048"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:09.159530" elapsed="0.000050"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:09.138670" elapsed="0.021070"/>
</kw>
<msg time="2026-06-06T03:27:09.159854" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0066020000004f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a0100070101010101...</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:09.137586" elapsed="0.022305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.160484" level="INFO">ffffffffffffffffffffffffffffffff0066020000004f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.160126" elapsed="0.000436"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.161872" level="INFO">Length is 204.</msg>
<msg time="2026-06-06T03:27:09.161977" level="INFO">${len_1} = 204</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:09.161434" elapsed="0.000576"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.162628" level="INFO">Length is 204.</msg>
<msg time="2026-06-06T03:27:09.162756" level="INFO">${len_2} = 204</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:09.162231" elapsed="0.000558"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.163011" elapsed="0.000428"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:09.163809" level="INFO">${sum_1} = 2584</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:09.163599" elapsed="0.000236"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:09.164175" level="INFO">${sum_2} = 2584</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:09.163989" elapsed="0.000212"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.164355" elapsed="0.000441"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:09.160922" elapsed="0.003934"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:09.165007" elapsed="0.001972"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.172378" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.172540" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '575'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:09.172698" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.167489" elapsed="0.005248"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.176704" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.173030" elapsed="0.003747"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.177001" elapsed="0.003503"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.185568" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.185710" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '575'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:09.185816" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.180756" elapsed="0.005087"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.188438" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.186015" elapsed="0.002473"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.188660" elapsed="0.002490"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:09.193526" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:09.191232" elapsed="0.002338"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.191211" elapsed="0.002383"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.199153" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.199217" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.199356" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.193764" elapsed="0.005629"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:09.167212" elapsed="0.032275"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.205884" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.206034" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:09.206164" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.200848" elapsed="0.005413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.210007" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.206510" elapsed="0.003565"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.210313" elapsed="0.003515"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:09.216237" level="INFO">${update} = ffffffffffffffffffffffffffffffff006002000000494001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:09.214059" elapsed="0.002220"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.216526" elapsed="0.003054"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:09.219669" elapsed="0.000045"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:09.200358" elapsed="0.019493"/>
</kw>
<msg time="2026-06-06T03:27:09.219962" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff006002000000494001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:09.199749" elapsed="0.020250"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.220578" level="INFO">ffffffffffffffffffffffffffffffff006002000000494001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.220234" elapsed="0.000430"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.221894" level="INFO">Length is 192.</msg>
<msg time="2026-06-06T03:27:09.221999" level="INFO">${len_1} = 192</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:09.221499" elapsed="0.000533"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.222619" level="INFO">Length is 192.</msg>
<msg time="2026-06-06T03:27:09.222745" level="INFO">${len_2} = 192</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:09.222265" elapsed="0.000514"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.222999" elapsed="0.000420"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:09.223923" level="INFO">${sum_1} = 2137</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:09.223660" elapsed="0.000298"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:09.224426" level="INFO">${sum_2} = 2137</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:09.224171" elapsed="0.000295"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.224701" elapsed="0.000425"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:09.220989" elapsed="0.004221"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.230731" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.230837" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:09.230928" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.226001" elapsed="0.004953"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.233764" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.231129" elapsed="0.002684"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.233971" elapsed="0.002980"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.241636" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.241814" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:09.241957" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.237183" elapsed="0.004811"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.245747" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.242256" elapsed="0.003559"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.246037" elapsed="0.003005"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:09.251497" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:27:09.249119" elapsed="0.002438"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.249100" elapsed="0.002483"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.251751" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:09.225558" elapsed="0.026284"/>
</kw>
<arg>pmsi_mldp_p2mp_lsp</arg>
<status status="PASS" start="2026-06-06T03:27:09.093150" elapsed="0.158737"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:08.970258" elapsed="0.281742"/>
</test>
<test id="s1-s13-t65" name="Play_To_Odl_pmsi_mldp_p2mp_lsp" line="224">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:09.255821" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:09.255529" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:09.257086" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:09.256974" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.256954" elapsed="0.000202"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:09.262275" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:09.262153" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.262134" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.263363" 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-06-06T03:27:09.262980" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.263868" 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-06-06T03:27:09.263555" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:09.263939" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:09.264093" 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-06-06T03:27:09.262581" elapsed="0.001537"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:09.269991" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:09.269881" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.269862" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:09.271805" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:09.271594" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.271575" elapsed="0.000396"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:09.272535" 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-06-06T03:27:09.272127" elapsed="0.000471"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:09.273236" level="INFO">${current_connection_index} = 7</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-06-06T03:27:09.272971" elapsed="0.000357"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:09.311191" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:09.275260" elapsed="0.036061"/>
</kw>
<msg time="2026-06-06T03:27:09.311458" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:09.311552" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:09.273681" elapsed="0.037943"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:09.342304" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "m "l "d "p "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:09.313586" elapsed="0.028851"/>
</kw>
<msg time="2026-06-06T03:27:09.342567" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:09.342683" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:09.312051" elapsed="0.030707"/>
</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-06-06T03:27:09.343417" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.343056" elapsed="0.000480"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.343034" elapsed="0.000560"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.344322" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "m "l "d "p "_ "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:09.343763" elapsed="0.000677"/>
</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-06-06T03:27:09.344979" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.344613" elapsed="0.000479"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.344593" elapsed="0.000556"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:09.345187" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:09.348682" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:27:09.348867" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:09.348151" elapsed="0.000781"/>
</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="NOT RUN" start="2026-06-06T03:27:09.349151" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.349369" elapsed="0.000021"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:09.347395" elapsed="0.002191"/>
</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-06-06T03:27:09.345455" elapsed="0.004266"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:09.271145" elapsed="0.078754"/>
</kw>
<msg time="2026-06-06T03:27:09.349993" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:09.350037" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:09.270296" elapsed="0.079779"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:09.350280" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:09.350152" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.350132" elapsed="0.000231"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.350869" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.351287" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:09.351361" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:09.269525" elapsed="0.081944"/>
</kw>
<msg time="2026-06-06T03:27:09.351600" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:09.351699" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:09.264506" elapsed="0.087233"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.352075" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.351817" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.351799" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:09.264353" elapsed="0.087824"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:09.264176" elapsed="0.088032"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:09.261791" elapsed="0.090471"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:09.256683" elapsed="0.095633"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:09.256241" elapsed="0.096118"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:09.253284" elapsed="0.099127"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.357890" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.358001" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:09.358094" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.352843" elapsed="0.005277"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:09.358304" elapsed="0.002748"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.365184" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.365329" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:09.365473" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:09.361220" elapsed="0.004290"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:09.369961" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:09.369513" elapsed="0.000487"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:09.370621" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:09.370238" elapsed="0.000443"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.370905" elapsed="0.000448"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:09.365949" elapsed="0.005488"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:09.352554" elapsed="0.018959"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:09.252818" elapsed="0.118797"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.372623" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.372839" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.372344" elapsed="0.000535"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.402813" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp.vanadium/pmsi_mldp_p2mp_lsp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:09.402418" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.403597" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp.vanadium/pmsi_mldp_p2mp_lsp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:09.403353" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp.vanadium/pmsi_mldp_p2mp_lsp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:09.403789" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:09.403010" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.404367" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:09.403982" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.404706" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/pmsi_mldp_p2mp_lsp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.404834" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.404558" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.405262" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "mldp-p2mp-lsp": {
                            "address-family": "bgp-types:ipv4-address-family",
                            "opaque-value": [
                                {
                                    "opaque": "01:01:01:01:01:01:01",
                                    "opaque-type": 1
                                }
                            ],
                            "root-node-address": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.405020" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:09.405719" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:09.405384" elapsed="0.000395"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.406267" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:09.405963" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:09.405804" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:09.405364" elapsed="0.000985"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.406961" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:09.406505" elapsed="0.000485"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:09.407039" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:09.407192" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:09.400011" elapsed="0.007207"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.407612" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/announce_pmsi_mldp_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/announce_pmsi_mldp_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.407754" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b...</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.407416" elapsed="0.000365"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:09.408131" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/withdraw_pmsi_mldp_p2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_p2mp_lsp/withdraw_pmsi_mldp_p2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:09.408253" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:09.407941" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.408698" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;mldp-p2mp-lsp&gt;
                &lt;address-family xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types"&gt;x:ipv4-address-family&lt;/address-family&gt;
                &lt;root-node-address&gt;10.10.10.10&lt;/root-node-address&gt;
                &lt;opaque-value&gt;
                    &lt;opaque-type&gt;1&lt;/opaque-type&gt;
                    &lt;opaque&gt;01:01:01:01:01:01:01&lt;/opaque&gt;
                &lt;/opaque-value&gt;
            &lt;/mldp-p2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.408439" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.409154" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "mldp-p2mp-lsp": {
                            "address-family": "bgp-types:ipv4-address-family",
                            "opaque-value": [
                                {
                                    "opaque": "01:01:01:01:01:01:01",
                                    "opaque-type": 1
                                }
                            ],
                            "root-node-address": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.408916" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.409603" level="INFO">ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.409362" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:09.410055" level="INFO">ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:09.409818" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:09.410278" elapsed="0.002440"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:09.412878" elapsed="0.001837"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:09.419502" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:09.419609" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:09.419753" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:09.415666" elapsed="0.004467">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.420325" elapsed="0.000023"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:09.420568" elapsed="0.000024"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:09.415321" elapsed="0.005393">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:11.431835" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:11.432043" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '575'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:11.432192" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:11.422404" elapsed="0.009826"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:11.432922" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "mldp-p2mp-lsp": {
                            "address-family": "bgp-types:ipv4-address-family",
                            "opaque-value": [
                                {
                                    "opaque": "01:01:01:01:01:01:01",
                                    "opaque-type": 1
                                }
                            ],
                            "root-node-address": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:11.436113" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:11.432496" elapsed="0.003687"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:11.440821" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:11.440060" elapsed="0.000802"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:11.441807" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:11.441084" elapsed="0.000765"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:11.442073" elapsed="0.000455"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:11.436507" elapsed="0.006084"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:11.421387" elapsed="0.021272"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:09.414907" elapsed="2.027865"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:11.442937" elapsed="0.002650"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:11.451172" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:11.451323" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:11.451452" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:11.446562" elapsed="0.004926"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:11.451754" elapsed="0.003873"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:11.460665" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:11.461198" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '723'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"mldp-p2mp-lsp":{"root-node-address":"10.10.10.10","address-family":"bgp-types:ipv4-address-family","opaque-value":[{"opaque":"01:01:01:01:01:01:01","opaque-type":1}]}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:11.461305" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:11.455882" elapsed="0.005450"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:11.464413" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:11.464134" elapsed="0.000307"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:11.465158" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:11.464605" elapsed="0.000581"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:11.465679" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "leaf-information-required": true,
        "mldp-p2mp-lsp": {
         "address-family": "bgp-types:ipv4-address-family",
         "opaque-value": [
          {
           "opaque": "01:01:01:01:01:01:01",
           "opaque-type": 1
          }
         ],
         "root-node-address": "10.10.10.10"
        },
        "mpls-label": 20024
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:11.465945" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,46 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "leaf-information-required": true,
+        "mldp-p2mp-lsp": {
+         "address-family": "bgp-types:ipv4-address-family",
+         "opaque-value": [
+          {
+           "opaque": "01:01:01:01:01:01:01",
+           "opaque-type": 1
+          }
+         ],
+         "root-node-address": "10.10.10.10"
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:11.465348" elapsed="0.000717">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,46 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "root-node-address": "10.10.10.10"
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:11.461565" elapsed="0.004673">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,46 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "root-node-address": "10.10.10.10"
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:11.446279" elapsed="0.020109">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,46 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "root-node-address": "10.10.10.10"
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.476779" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.477071" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.477233" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.467990" elapsed="0.009280"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.477546" elapsed="0.003668"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.486456" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.486607" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:13.486780" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.481469" elapsed="0.005347"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.491141" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.490720" elapsed="0.000460"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.491796" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.491401" elapsed="0.000433"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.492057" elapsed="0.000554"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.487146" elapsed="0.005576"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.467105" elapsed="0.025694"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:11.445821" elapsed="2.047033"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:13.493624" elapsed="0.003087"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.501776" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.501889" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.501993" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.497916" elapsed="0.004103"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.502189" elapsed="0.002542"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.509272" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.509440" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:13.509588" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.504940" elapsed="0.004685"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.514025" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.513607" elapsed="0.000457"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.514679" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.514287" elapsed="0.000432"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.514940" elapsed="0.000449"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.509982" elapsed="0.005493"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.497368" elapsed="0.018182"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:13.496894" elapsed="0.018849"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:13.493114" elapsed="0.022711"/>
</kw>
<arg>pmsi_mldp_p2mp_lsp</arg>
<status status="PASS" start="2026-06-06T03:27:09.371926" elapsed="4.143966"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:09.252320" elapsed="4.263728"/>
</test>
<test id="s1-s13-t66" name="Odl_To_Play_pmsi_pim_ssm_tree" line="227">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:13.521355" elapsed="0.000319"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:13.520970" elapsed="0.000783"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:13.523184" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.523016" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.522985" elapsed="0.000299"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:13.530591" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.530482" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.530463" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.531738" 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-06-06T03:27:13.531293" elapsed="0.000474"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.532237" 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-06-06T03:27:13.531936" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:13.532309" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:27:13.532476" 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-06-06T03:27:13.530907" elapsed="0.001593"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:13.538191" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.538082" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.538062" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:13.539725" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.539514" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.539495" elapsed="0.000393"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:13.540453" 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-06-06T03:27:13.540043" elapsed="0.000471"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:13.541147" level="INFO">${current_connection_index} = 7</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-06-06T03:27:13.540883" elapsed="0.000325"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:13.574549" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:13.543065" elapsed="0.031653"/>
</kw>
<msg time="2026-06-06T03:27:13.574866" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:13.574959" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:13.541529" elapsed="0.033499"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:13.601853" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "p "i "m "_ "s "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:13.577034" elapsed="0.025092"/>
</kw>
<msg time="2026-06-06T03:27:13.602357" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:13.602455" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:13.575441" elapsed="0.027085"/>
</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-06-06T03:27:13.603410" elapsed="0.000061"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.602914" elapsed="0.000626"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.602869" elapsed="0.000735"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.604465" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "p "i "m "_ "s "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:13.603781" elapsed="0.000808"/>
</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-06-06T03:27:13.605145" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.604785" elapsed="0.000474"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.604763" elapsed="0.000572"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:13.605382" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:13.609157" elapsed="0.000164"/>
</kw>
<msg time="2026-06-06T03:27:13.609440" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:13.608567" elapsed="0.000947"/>
</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="NOT RUN" start="2026-06-06T03:27:13.609752" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.609972" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:13.607793" elapsed="0.002400"/>
</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-06-06T03:27:13.605754" elapsed="0.004527"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:13.539077" elapsed="0.071383"/>
</kw>
<msg time="2026-06-06T03:27:13.610557" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:13.610603" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:13.538416" elapsed="0.072318"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:13.611170" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:27:13.610825" elapsed="0.000410"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.610805" elapsed="0.000455"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.611780" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.612210" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:13.612474" elapsed="0.000020"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:13.537739" elapsed="0.074853"/>
</kw>
<msg time="2026-06-06T03:27:13.612702" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:13.612748" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:13.532912" elapsed="0.079872"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.613129" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.612861" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.612844" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:13.532764" elapsed="0.080465"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:13.532561" elapsed="0.080700"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:13.530115" elapsed="0.083235"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:13.522584" elapsed="0.090824"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:13.521969" elapsed="0.091504"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:13.517930" elapsed="0.095598"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.619487" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.619627" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.619797" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.613981" elapsed="0.005843"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.619997" elapsed="0.003081"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.627748" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.627894" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:13.628035" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.623365" elapsed="0.004706"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.632410" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.631990" elapsed="0.000459"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.633074" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.632695" elapsed="0.000418"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.633366" elapsed="0.000410"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.628393" elapsed="0.005446"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.613701" elapsed="0.020193"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:13.517196" elapsed="0.116739"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.634725" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.634890" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.634506" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.635268" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.635395" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.635078" elapsed="0.000344"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.635786" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/announce_pmsi_pim_ssm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/announce_pmsi_pim_ssm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.635912" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.635580" elapsed="0.000359"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:13.636313" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:13.636101" elapsed="0.000239"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.636708" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/withdraw_pmsi_pim_ssm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/withdraw_pmsi_pim_ssm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.636835" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.636500" elapsed="0.000361"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:13.637217" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:13.637018" elapsed="0.000272"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.637720" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;pim-ssm-tree&gt;
                &lt;p-address&gt;11.12.13.14&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/pim-ssm-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.637455" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.638177" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-ssm-tree": {
                            "p-address": "11.12.13.14",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.637935" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.638630" level="INFO">ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.638384" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.639083" level="INFO">ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.638848" elapsed="0.000279"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:13.639277" elapsed="0.002906"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.653919" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1039', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;pim-ssm-tree&gt;
                &lt;p-address&gt;11.12.13.14&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/pim-ssm-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:13.654063" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.654292" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.642452" elapsed="0.011899"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.660274" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.654777" elapsed="0.005591"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.666367" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.666937" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:13.667043" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.660758" elapsed="0.006311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.669951" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.667239" elapsed="0.002790"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.677299" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.677890" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:13.678031" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.671482" elapsed="0.006585"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.681732" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.678312" elapsed="0.003490"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.682025" elapsed="0.003527"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:13.688480" level="INFO">${update} = ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.685804" elapsed="0.002717"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.688804" elapsed="0.003045"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:13.691923" elapsed="0.000052"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:13.670996" elapsed="0.021121"/>
</kw>
<msg time="2026-06-06T03:27:13.692228" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:13.670302" elapsed="0.021962"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.692870" level="INFO">ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.692500" elapsed="0.000433"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.694179" level="INFO">Length is 180.</msg>
<msg time="2026-06-06T03:27:13.694283" level="INFO">${len_1} = 180</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:13.693817" elapsed="0.000498"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.694905" level="INFO">Length is 180.</msg>
<msg time="2026-06-06T03:27:13.695009" level="INFO">${len_2} = 180</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:13.694532" elapsed="0.000510"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.695261" elapsed="0.000448"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:13.696253" level="INFO">${sum_1} = 2563</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:13.695991" elapsed="0.000298"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:13.696790" level="INFO">${sum_2} = 2563</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:13.696506" elapsed="0.000319"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.697044" elapsed="0.000469"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:13.693273" elapsed="0.004320"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:13.697762" elapsed="0.002015"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.705428" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.705547" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:13.705666" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.700316" elapsed="0.005379"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.708478" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.705873" elapsed="0.002655"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.708709" elapsed="0.003332"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.718271" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.718485" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:13.718727" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.712298" elapsed="0.006472"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.722597" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.719059" elapsed="0.003627"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.722916" elapsed="0.003502"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:13.729808" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.726544" elapsed="0.003312"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.726508" elapsed="0.003372"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.736216" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.736262" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.736362" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.730105" elapsed="0.006283"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:13.700015" elapsed="0.036452"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.746137" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.746288" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.746417" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.737580" elapsed="0.008873"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.752241" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.746819" elapsed="0.005527"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.752730" elapsed="0.005242"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:13.760333" level="INFO">${update} = ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.758140" elapsed="0.002226"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.760525" elapsed="0.002211"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:13.762788" elapsed="0.000038"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:13.737169" elapsed="0.025755"/>
</kw>
<msg time="2026-06-06T03:27:13.763003" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:13.736669" elapsed="0.026360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.763442" level="INFO">ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.763198" elapsed="0.000289"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.764361" level="INFO">Length is 168.</msg>
<msg time="2026-06-06T03:27:13.764436" level="INFO">${len_1} = 168</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:13.764101" elapsed="0.000358"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.764884" level="INFO">Length is 168.</msg>
<msg time="2026-06-06T03:27:13.764959" level="INFO">${len_2} = 168</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:13.764616" elapsed="0.000366"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.765139" elapsed="0.000341"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:13.765852" level="INFO">${sum_1} = 2116</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:13.765665" elapsed="0.000213"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:13.766211" level="INFO">${sum_2} = 2116</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:13.766032" elapsed="0.000205"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.766392" elapsed="0.000319"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:13.763736" elapsed="0.003073"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.773403" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.773511" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.773605" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.767374" elapsed="0.006257"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.776422" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.773829" elapsed="0.002641"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.776628" elapsed="0.003212"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.784991" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.785139" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.785321" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.780072" elapsed="0.005288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.788997" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.785602" elapsed="0.003464"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.789309" elapsed="0.003544"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:13.796215" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:27:13.792963" elapsed="0.003335"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.792935" elapsed="0.003399"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.796549" elapsed="0.000030"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:13.767069" elapsed="0.029624"/>
</kw>
<arg>pmsi_pim_ssm_tree</arg>
<status status="PASS" start="2026-06-06T03:27:13.634207" elapsed="0.162553"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.516521" elapsed="0.280400"/>
</test>
<test id="s1-s13-t67" name="Play_To_Odl_pmsi_pim_ssm_tree" line="229">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:13.800819" elapsed="0.000214"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:13.800517" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:13.802128" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.802014" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.801993" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:13.807270" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.807162" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.807144" elapsed="0.000253"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.808425" 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-06-06T03:27:13.808042" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.808933" 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-06-06T03:27:13.808616" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:13.809005" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:13.809161" 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-06-06T03:27:13.807637" elapsed="0.001549"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:13.815075" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.814967" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.814948" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:13.816610" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:13.816427" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.816407" elapsed="0.000390"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:13.817379" 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-06-06T03:27:13.816952" elapsed="0.000488"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:13.818082" level="INFO">${current_connection_index} = 7</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-06-06T03:27:13.817813" elapsed="0.000329"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:13.849209" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:13.820002" elapsed="0.029365"/>
</kw>
<msg time="2026-06-06T03:27:13.849508" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:13.849603" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:13.818454" elapsed="0.031244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:13.875714" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "p "i "m "_ "s "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:13.851683" elapsed="0.024161"/>
</kw>
<msg time="2026-06-06T03:27:13.875975" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:13.876069" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:13.850104" elapsed="0.026035"/>
</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-06-06T03:27:13.876828" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.876436" elapsed="0.000510"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.876414" elapsed="0.000592"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.877772" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "p "i "m "_ "s "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:13.877159" elapsed="0.000728"/>
</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-06-06T03:27:13.878420" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.878065" elapsed="0.000471"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.878044" elapsed="0.000549"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:13.878631" 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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:13.882154" elapsed="0.000138"/>
</kw>
<msg time="2026-06-06T03:27:13.882336" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:13.881676" elapsed="0.000726"/>
</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="NOT RUN" start="2026-06-06T03:27:13.882762" elapsed="0.000027"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.882996" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:13.880878" elapsed="0.002337"/>
</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-06-06T03:27:13.878932" elapsed="0.004368"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:13.815954" elapsed="0.067522"/>
</kw>
<msg time="2026-06-06T03:27:13.883570" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:13.883616" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:13.815300" elapsed="0.068369"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:13.883858" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:13.883748" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.883729" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.884402" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.884841" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:13.884916" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:13.814613" elapsed="0.070411"/>
</kw>
<msg time="2026-06-06T03:27:13.885116" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:13.885160" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:13.809606" elapsed="0.075589"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.885541" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.885281" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.885263" elapsed="0.000362"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:13.809456" elapsed="0.076210"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:13.809272" elapsed="0.076425"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:13.806802" elapsed="0.078949"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:13.801722" elapsed="0.084084"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:13.801259" elapsed="0.084592"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:13.798295" elapsed="0.087609"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.891301" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.891477" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.891615" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.886325" elapsed="0.005352"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:13.891929" elapsed="0.004365"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.903397" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.903540" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:13.903665" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:13.896616" elapsed="0.007079"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.906811" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.906484" elapsed="0.000356"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:13.907275" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:13.907000" elapsed="0.000303"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.907464" elapsed="0.000348"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:13.903930" elapsed="0.003945"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.886049" elapsed="0.021879"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:13.797830" elapsed="0.110138"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.908867" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.909023" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.908481" elapsed="0.000571"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.937579" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree.vanadium/pmsi_pim_ssm_tree.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:13.937173" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.938374" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree.vanadium/pmsi_pim_ssm_tree.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:13.938135" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree.vanadium/pmsi_pim_ssm_tree.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:13.938546" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:13.937793" elapsed="0.000778"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.939143" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:13.938759" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.939467" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/pmsi_pim_ssm_tree.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.939593" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.939334" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.940042" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-ssm-tree": {
                            "p-address": "11.12.13.14",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.939798" elapsed="0.000329"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:13.940504" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:13.940198" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.941046" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:13.940752" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.940587" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:13.940178" elapsed="0.000951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.941761" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:13.941296" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:13.941841" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:13.941994" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:13.934880" elapsed="0.007140"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.942379" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/announce_pmsi_pim_ssm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/announce_pmsi_pim_ssm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.942503" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.942184" elapsed="0.000346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:13.942896" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/withdraw_pmsi_pim_ssm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_ssm_tree/withdraw_pmsi_pim_ssm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:13.943017" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:13.942705" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.943449" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;pim-ssm-tree&gt;
                &lt;p-address&gt;11.12.13.14&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/pim-ssm-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.943204" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.943950" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-ssm-tree": {
                            "p-address": "11.12.13.14",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.943693" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.944394" level="INFO">ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.944157" elapsed="0.000282"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:13.944848" level="INFO">ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:13.944593" elapsed="0.000299"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:13.945073" elapsed="0.002511"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:13.947788" elapsed="0.001761"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:13.954424" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:13.954532" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:13.954627" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:13.950537" elapsed="0.004476">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.955204" elapsed="0.000023"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:13.955438" elapsed="0.000025"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:13.950211" elapsed="0.005353">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:15.966371" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:15.966574" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:15.966753" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:15.957235" elapsed="0.009557"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:15.967455" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-ssm-tree": {
                            "p-address": "11.12.13.14",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:15.970750" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:15.967056" elapsed="0.003765"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:15.975421" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:15.974733" elapsed="0.000800"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:15.976416" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:15.975793" elapsed="0.000663"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:15.976710" elapsed="0.000482"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:15.971141" elapsed="0.006141"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:15.956248" elapsed="0.021111"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:13.949762" elapsed="2.027663"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:15.977673" elapsed="0.003292"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:15.986362" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:15.986476" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:15.986570" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:15.981915" elapsed="0.004682"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:15.986853" elapsed="0.003902"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:15.998251" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:15.998950" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '632'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-ssm-tree":{"p-address":"11.12.13.14","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:15.999102" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:15.990992" elapsed="0.008147"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:16.003462" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:16.003067" elapsed="0.000434"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:16.004437" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:16.003744" elapsed="0.000733"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:16.005191" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "leaf-information-required": true,
        "mpls-label": 20024,
        "pim-ssm-tree": {
         "p-address": "11.12.13.14",
         "p-multicast-group": "10.10.10.10"
        }
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:16.005565" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "leaf-information-required": true,
+        "mpls-label": 20024,
+        "pim-ssm-tree": {
+         "p-address": "11.12.13.14",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:16.004720" elapsed="0.000974">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p-address": "11.12.13.14",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:15.999463" elapsed="0.006465">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p-address": "11.12.13.14",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:15.981605" elapsed="0.024530">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p-address": "11.12.13.14",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.017029" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.017231" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.017379" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.007845" elapsed="0.009573"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.017696" elapsed="0.003882"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.028704" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.028897" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:18.029076" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.021848" elapsed="0.007276"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.034844" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.034219" elapsed="0.000676"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.035700" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.035189" elapsed="0.000566"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.036052" elapsed="0.000636"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.029537" elapsed="0.007269"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.006882" elapsed="0.030027"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:15.981152" elapsed="2.055828"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:18.037969" elapsed="0.003083"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.047982" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.048140" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.048306" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.042861" elapsed="0.005484"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.048587" elapsed="0.003749"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.057999" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.058147" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:18.058293" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.052603" elapsed="0.005728"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.062880" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.062405" elapsed="0.000517"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.063529" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.063149" elapsed="0.000419"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.063814" elapsed="0.000479"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.058674" elapsed="0.005714"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.042051" elapsed="0.022413"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:18.041329" elapsed="0.023189"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:18.037307" elapsed="0.027288"/>
</kw>
<arg>pmsi_pim_ssm_tree</arg>
<status status="PASS" start="2026-06-06T03:27:13.908181" elapsed="4.156502"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:13.797210" elapsed="4.267635"/>
</test>
<test id="s1-s13-t68" name="Odl_To_Play_pmsi_pim_sm_tree" line="232">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:18.071250" elapsed="0.000333"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:18.070808" elapsed="0.000890"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:18.073125" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.072977" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.072951" elapsed="0.000251"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:18.078259" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.078147" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.078127" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.079363" 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-06-06T03:27:18.078970" elapsed="0.000421"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.079882" 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-06-06T03:27:18.079557" elapsed="0.000351"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:18.079954" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:27:18.080119" 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-06-06T03:27:18.078564" elapsed="0.001580"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:18.086283" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.086170" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.086149" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:18.087996" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.087714" elapsed="0.000392"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.087690" elapsed="0.000474"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:18.088789" 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-06-06T03:27:18.088345" elapsed="0.000507"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:18.089477" level="INFO">${current_connection_index} = 7</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-06-06T03:27:18.089208" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:18.121399" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:18.091453" elapsed="0.030100"/>
</kw>
<msg time="2026-06-06T03:27:18.121749" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:18.121872" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:18.089873" elapsed="0.032088"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:18.151172" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "p "i "m "_ "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:18.124001" elapsed="0.027340"/>
</kw>
<msg time="2026-06-06T03:27:18.151494" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:18.151590" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:18.122381" elapsed="0.029310"/>
</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-06-06T03:27:18.152400" elapsed="0.000061"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.152000" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.151976" elapsed="0.000615"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.153382" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "p "i "m "_ "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:18.152766" elapsed="0.000741"/>
</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-06-06T03:27:18.154105" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.153701" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.153680" elapsed="0.000599"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:18.154318" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:18.158055" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:27:18.158241" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:18.157438" elapsed="0.000871"/>
</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="NOT RUN" start="2026-06-06T03:27:18.158528" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.158761" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:18.156660" elapsed="0.002318"/>
</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-06-06T03:27:18.154602" elapsed="0.004461"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:18.087235" elapsed="0.072003"/>
</kw>
<msg time="2026-06-06T03:27:18.159333" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:18.159377" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:18.086514" elapsed="0.072901"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:18.159599" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:18.159491" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.159472" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.160170" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.160701" elapsed="0.000028"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:18.160779" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:18.085806" elapsed="0.075084"/>
</kw>
<msg time="2026-06-06T03:27:18.160985" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:18.161028" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:18.080593" elapsed="0.080472"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.161434" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.161151" elapsed="0.000357"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.161132" elapsed="0.000406"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:18.080435" elapsed="0.081131"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:18.080216" elapsed="0.081382"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:18.077757" elapsed="0.083929"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:18.072628" elapsed="0.089120"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:18.071951" elapsed="0.089844"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:18.066769" elapsed="0.095082"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.168308" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.168437" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.168580" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.162285" elapsed="0.006322"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.169085" elapsed="0.003667"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.178046" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.178193" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:18.178336" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.173011" elapsed="0.005362"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.183205" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.182707" elapsed="0.000551"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.183896" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.183489" elapsed="0.000446"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.184160" elapsed="0.000500"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.178727" elapsed="0.006026"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.162003" elapsed="0.022840"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:18.066026" elapsed="0.118894"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.186046" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.186316" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.185749" elapsed="0.000610"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.186881" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.187063" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.186587" elapsed="0.000518"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.187616" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/announce_pmsi_pim_sm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/announce_pmsi_pim_sm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.187821" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.187344" elapsed="0.000514"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:18.188424" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:18.188083" elapsed="0.000380"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.188927" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/withdraw_pmsi_pim_sm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/withdraw_pmsi_pim_sm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.189058" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.188711" elapsed="0.000403"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:18.189487" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:18.189281" elapsed="0.000234"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.189956" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;pim-sm-tree&gt;
                &lt;p-address&gt;43.43.43.43&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/pim-sm-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.189700" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.190471" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-sm-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.190213" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.190962" level="INFO">ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.190704" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.191446" level="INFO">ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.191186" elapsed="0.000305"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:18.191663" elapsed="0.002472"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.203588" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1037', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;pim-sm-tree&gt;
                &lt;p-address&gt;43.43.43.43&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/pim-sm-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:18.203709" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.203844" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.194314" elapsed="0.009567"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.213053" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.204131" elapsed="0.009021"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.220707" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.221145" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '483'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:18.221254" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.213523" elapsed="0.007758"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.223929" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.221455" elapsed="0.002525"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.230310" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.230712" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '483'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:18.230809" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.224979" elapsed="0.005856"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.233445" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.231009" elapsed="0.002485"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.233673" elapsed="0.002507"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:18.238575" level="INFO">${update} = ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.236375" elapsed="0.002230"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.238790" elapsed="0.002186"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:18.241029" elapsed="0.000037"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:18.224619" elapsed="0.016548"/>
</kw>
<msg time="2026-06-06T03:27:18.241245" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:18.224152" elapsed="0.017119"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.241707" level="INFO">ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.241439" elapsed="0.000317"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.242616" level="INFO">Length is 180.</msg>
<msg time="2026-06-06T03:27:18.242707" level="INFO">${len_1} = 180</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:18.242356" elapsed="0.000376"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.243190" level="INFO">Length is 180.</msg>
<msg time="2026-06-06T03:27:18.243265" level="INFO">${len_2} = 180</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:18.242933" elapsed="0.000355"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.243446" elapsed="0.000329"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:18.244124" level="INFO">${sum_1} = 2686</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:18.243937" elapsed="0.000212"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:18.244533" level="INFO">${sum_2} = 2686</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:18.244349" elapsed="0.000210"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.244736" elapsed="0.000308"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:18.241992" elapsed="0.003112"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:18.245255" elapsed="0.002072"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.252411" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.252731" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '483'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:18.252952" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.247874" elapsed="0.005136"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.258473" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.253402" elapsed="0.005146"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.258807" elapsed="0.003759"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.268057" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.268178" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '483'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:18.268309" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.262834" elapsed="0.005502"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.270936" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.268513" elapsed="0.002473"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.271184" elapsed="0.002520"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:18.276092" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.273791" elapsed="0.002346"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.273768" elapsed="0.002395"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.281983" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.282050" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.282195" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.276352" elapsed="0.005882"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:18.247551" elapsed="0.034785"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.289398" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.289558" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.289724" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.283816" elapsed="0.005948"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.293690" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.290023" elapsed="0.003740"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.293999" elapsed="0.003809"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:18.301156" level="INFO">${update} = ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.298056" elapsed="0.003144"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.301469" elapsed="0.003290"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:18.304837" elapsed="0.000047"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:18.283292" elapsed="0.021737"/>
</kw>
<msg time="2026-06-06T03:27:18.305145" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:18.282587" elapsed="0.022596"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.305821" level="INFO">ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.305435" elapsed="0.000454"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.307191" level="INFO">Length is 168.</msg>
<msg time="2026-06-06T03:27:18.307302" level="INFO">${len_1} = 168</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:18.306805" elapsed="0.000532"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.307971" level="INFO">Length is 168.</msg>
<msg time="2026-06-06T03:27:18.308082" level="INFO">${len_2} = 168</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:18.307569" elapsed="0.000548"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.308366" elapsed="0.000473"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:18.309343" level="INFO">${sum_1} = 2239</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:18.309074" elapsed="0.000307"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:18.309959" level="INFO">${sum_2} = 2239</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:18.309684" elapsed="0.000314"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.310231" elapsed="0.000483"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:18.306230" elapsed="0.004578"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.316226" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.316335" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.316428" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.311630" elapsed="0.004825"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.319263" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.316629" elapsed="0.002683"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.319470" elapsed="0.002529"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.326608" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.326801" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.326953" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.322169" elapsed="0.004822"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.330967" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.327251" elapsed="0.003787"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.331276" elapsed="0.003809"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:18.338717" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:27:18.335199" elapsed="0.003607"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.335170" elapsed="0.003675"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.339073" elapsed="0.000033"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:18.311180" elapsed="0.028023"/>
</kw>
<arg>pmsi_pim_sm_tree</arg>
<status status="PASS" start="2026-06-06T03:27:18.185301" elapsed="0.153970"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.065277" elapsed="0.274154"/>
</test>
<test id="s1-s13-t69" name="Play_To_Odl_pmsi_pim_sm_tree" line="234">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:18.344949" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:18.344675" elapsed="0.000540"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:18.346282" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.346124" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.346104" elapsed="0.000252"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:18.351540" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.351275" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.351256" elapsed="0.000358"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.352691" 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-06-06T03:27:18.352286" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.353186" 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-06-06T03:27:18.352889" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:18.353257" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:18.353412" 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-06-06T03:27:18.351872" elapsed="0.001565"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:18.359236" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.359126" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.359106" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:18.360830" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:18.360621" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.360601" elapsed="0.000393"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:18.361564" 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-06-06T03:27:18.361151" elapsed="0.000475"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:18.362271" level="INFO">${current_connection_index} = 7</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-06-06T03:27:18.362006" elapsed="0.000326"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:18.392423" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:18.364241" elapsed="0.028325"/>
</kw>
<msg time="2026-06-06T03:27:18.392727" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:18.392826" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:18.362658" elapsed="0.030237"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:18.420457" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "p "i "m "_ "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:18.394849" elapsed="0.025739"/>
</kw>
<msg time="2026-06-06T03:27:18.420741" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:18.420835" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:18.393295" elapsed="0.027611"/>
</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-06-06T03:27:18.421563" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.421206" elapsed="0.000492"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.421182" elapsed="0.000581"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.422482" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "p "i "m "_ "s "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:18.421920" elapsed="0.000676"/>
</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-06-06T03:27:18.423141" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.422790" elapsed="0.000464"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.422769" elapsed="0.000545"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:18.423353" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:18.426961" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:27:18.427146" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:18.426411" elapsed="0.000800"/>
</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="NOT RUN" start="2026-06-06T03:27:18.427427" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.427663" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:18.425594" elapsed="0.002287"/>
</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-06-06T03:27:18.423638" elapsed="0.004331"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:18.360136" elapsed="0.068010"/>
</kw>
<msg time="2026-06-06T03:27:18.428258" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:18.428302" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:18.359467" elapsed="0.068871"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:18.428524" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:18.428416" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.428396" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.429086" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.429506" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:18.429579" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:18.358782" elapsed="0.071124"/>
</kw>
<msg time="2026-06-06T03:27:18.430004" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:18.430048" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:18.353844" elapsed="0.076238"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.430416" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.430159" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.430141" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:18.353694" elapsed="0.076823"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:18.353497" elapsed="0.077052"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:18.350904" elapsed="0.079702"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:18.345832" elapsed="0.084849"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:18.345376" elapsed="0.085353"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:18.341317" elapsed="0.089466"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.437816" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.437941" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.438034" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.431208" elapsed="0.006852"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:18.438263" elapsed="0.002833"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.445507" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.445613" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:18.445738" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:18.441266" elapsed="0.004499"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.448881" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.448555" elapsed="0.000354"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:18.449340" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:18.449072" elapsed="0.000295"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.449527" elapsed="0.000348"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:18.445997" elapsed="0.003940"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.430931" elapsed="0.019060"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:18.340589" elapsed="0.109442"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.450768" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.450926" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.450548" elapsed="0.000406"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.476761" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree.vanadium/pmsi_pim_sm_tree.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:18.476365" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.477554" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree.vanadium/pmsi_pim_sm_tree.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:18.477305" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree.vanadium/pmsi_pim_sm_tree.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:18.477746" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:18.476959" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.478330" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:18.477943" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.478671" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/pmsi_pim_sm_tree.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.478810" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.478522" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.479285" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-sm-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.479037" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:18.479748" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:18.479409" elapsed="0.000398"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.480292" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:18.479984" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.479833" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:18.479388" elapsed="0.000986"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.480997" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:18.480527" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:18.481076" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:18.481233" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:18.474045" elapsed="0.007214"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.481616" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/announce_pmsi_pim_sm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/announce_pmsi_pim_sm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.481757" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.481423" elapsed="0.000361"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:18.482132" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/withdraw_pmsi_pim_sm_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_pim_sm_tree/withdraw_pmsi_pim_sm_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:18.482252" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:18.481943" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.482699" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;pim-sm-tree&gt;
                &lt;p-address&gt;43.43.43.43&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/pim-sm-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.482437" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.483153" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-sm-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.482913" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.483634" level="INFO">ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.483393" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:18.484094" level="INFO">ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:18.483853" elapsed="0.000285"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:18.484314" elapsed="0.002355"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:18.486833" elapsed="0.001686"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:18.493967" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:18.494082" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:18.494179" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:18.489485" elapsed="0.005102">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.494800" elapsed="0.000024"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:18.495039" elapsed="0.000024"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:18.489160" elapsed="0.006004">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:20.504891" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:20.505113" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '483'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:20.505270" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:20.496799" elapsed="0.008510"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:20.506029" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "pim-sm-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:20.509572" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:20.505586" elapsed="0.004079"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:20.514565" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:20.513837" elapsed="0.000770"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:20.515514" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:20.514866" elapsed="0.000690"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:20.515857" elapsed="0.000497"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:20.510017" elapsed="0.006429"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:20.495881" elapsed="0.020646"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:18.488732" elapsed="2.027866"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:20.516850" elapsed="0.002945"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:20.528336" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:20.528520" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:20.528688" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:20.520753" elapsed="0.007976"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:20.528987" elapsed="0.004234"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:20.539255" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:20.540016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '631'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"pim-sm-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:20.540179" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:20.533473" elapsed="0.006746"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:20.544866" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:20.544405" elapsed="0.000503"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:20.545912" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:20.545147" elapsed="0.000885"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:20.546789" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "leaf-information-required": true,
        "mpls-label": 20024,
        "pim-sm-tree": {
         "p-address": "43.43.43.43",
         "p-multicast-group": "10.10.10.10"
        }
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:20.547135" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "leaf-information-required": true,
+        "mpls-label": 20024,
+        "pim-sm-tree": {
+         "p-address": "43.43.43.43",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:20.546279" elapsed="0.000968">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p-address": "43.43.43.43",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:20.540573" elapsed="0.006917">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p-address": "43.43.43.43",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:20.520445" elapsed="0.027325">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "p-address": "43.43.43.43",
+         "p-multicast-group": "10.10.10.10"
+        }
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.556992" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.557194" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.557364" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.549250" elapsed="0.008153"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.557686" elapsed="0.003873"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.567872" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.568037" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:22.568142" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.561830" elapsed="0.006338"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.571286" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.570979" elapsed="0.000336"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.571759" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.571472" elapsed="0.000314"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.571946" elapsed="0.000333"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.568407" elapsed="0.003934"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:22.548435" elapsed="0.023961"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:20.519983" elapsed="2.052453"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:22.572988" elapsed="0.002232"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.581844" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.582013" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.582166" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.576957" elapsed="0.005247"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.582454" elapsed="0.003921"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.591092" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.591196" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:22.591297" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.586623" elapsed="0.004700"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.594446" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.594158" elapsed="0.000316"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.594917" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.594632" elapsed="0.000312"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.595100" elapsed="0.000320"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.591553" elapsed="0.003979"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:22.576157" elapsed="0.019429"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:22.575504" elapsed="0.020119"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:22.572624" elapsed="0.023071"/>
</kw>
<arg>pmsi_pim_sm_tree</arg>
<status status="PASS" start="2026-06-06T03:27:18.450249" elapsed="4.145494"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:18.339892" elapsed="4.255967"/>
</test>
<test id="s1-s13-t70" name="Odl_To_Play_pmsi_bidir_pim_tree" line="237">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:22.600443" elapsed="0.000330"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:22.600053" elapsed="0.000802"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:22.602403" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.602226" elapsed="0.000250"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.602193" elapsed="0.000318"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:22.608623" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.608515" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.608496" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.609740" 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-06-06T03:27:22.609322" elapsed="0.000446"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.610230" 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-06-06T03:27:22.609933" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:22.610300" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:27:22.610462" 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-06-06T03:27:22.608940" elapsed="0.001547"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:22.616273" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.616163" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.616143" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:22.618004" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.617816" elapsed="0.000429"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.617797" elapsed="0.000504"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:22.618885" 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-06-06T03:27:22.618456" elapsed="0.000491"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:22.619557" level="INFO">${current_connection_index} = 7</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-06-06T03:27:22.619295" elapsed="0.000322"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:22.654165" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:22.621498" elapsed="0.032793"/>
</kw>
<msg time="2026-06-06T03:27:22.654439" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:22.654533" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:22.619944" elapsed="0.034659"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:22.684452" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "b "i "d "i "r "_ "p "i "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:22.656586" elapsed="0.028129"/>
</kw>
<msg time="2026-06-06T03:27:22.684916" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:22.685013" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:22.655038" elapsed="0.030046"/>
</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-06-06T03:27:22.686104" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:22.685508" elapsed="0.000722"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.685400" elapsed="0.000893"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.687131" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "b "i "d "i "r "_ "p "i "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:22.686449" elapsed="0.000801"/>
</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-06-06T03:27:22.687804" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:22.687429" elapsed="0.000497"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.687408" elapsed="0.000577"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:22.688027" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:22.692449" elapsed="0.000224"/>
</kw>
<msg time="2026-06-06T03:27:22.692737" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:22.691784" elapsed="0.001047"/>
</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="NOT RUN" start="2026-06-06T03:27:22.693133" elapsed="0.000033"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.693451" elapsed="0.000030"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:22.690637" elapsed="0.003161"/>
</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-06-06T03:27:22.688367" elapsed="0.005564"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:22.617332" elapsed="0.076863"/>
</kw>
<msg time="2026-06-06T03:27:22.694340" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:22.694406" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:22.616499" elapsed="0.077961"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:22.694938" elapsed="0.000040"/>
</return>
<status status="PASS" start="2026-06-06T03:27:22.694576" elapsed="0.000452"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.694547" elapsed="0.000517"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.695787" elapsed="0.000039"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.696413" elapsed="0.000037"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:22.696521" elapsed="0.000024"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:22.615822" elapsed="0.080883"/>
</kw>
<msg time="2026-06-06T03:27:22.696852" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:22.696918" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:22.610883" elapsed="0.086089"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.697529" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:22.697084" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.697058" elapsed="0.000630"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:22.610734" elapsed="0.086993"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:22.610544" elapsed="0.087233"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:22.608153" elapsed="0.089695"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:22.601785" elapsed="0.096120"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:22.601081" elapsed="0.096872"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:22.597100" elapsed="0.100909"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.705132" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.705284" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.705406" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.698504" elapsed="0.006959"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.705669" elapsed="0.003840"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.714302" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.714411" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:22.714515" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.709781" elapsed="0.004762"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.717712" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.717358" elapsed="0.000382"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.718170" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.717899" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.718356" elapsed="0.000350"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.714806" elapsed="0.003963"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:22.698212" elapsed="0.020612"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:22.596615" elapsed="0.122252"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:22.719656" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:22.719835" level="INFO">${data_xml} = &lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-d...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:22.719440" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:22.720211" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:22.720339" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:22.720022" elapsed="0.000343"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:22.720727" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/announce_pmsi_bidir_pim_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/announce_pmsi_bidir_pim_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:22.720893" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:22.720522" elapsed="0.000398"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:22.721296" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:22.721083" elapsed="0.000241"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:22.721719" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/withdraw_pmsi_bidir_pim_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/withdraw_pmsi_bidir_pim_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:22.721849" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:22.721513" elapsed="0.000363"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:22.722232" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:22.722033" elapsed="0.000227"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.722686" level="INFO">&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;bidir-pim-tree&gt;
                &lt;p-address&gt;43.43.43.43&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/bidir-pim-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.722422" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.723144" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "bidir-pim-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.722901" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.723591" level="INFO">ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.723352" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.724044" level="INFO">ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.723807" elapsed="0.000281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:22.724240" elapsed="0.002368"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.737719" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1020', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;bidir-pim-tree&gt;
                &lt;p-address&gt;43.43.43.43&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/bidir-pim-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:22.737866" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.738011" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.726799" elapsed="0.011251"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.742545" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.738316" elapsed="0.004292"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.749053" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.749743" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '486'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:22.749932" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.742873" elapsed="0.007096"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.753877" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.750258" elapsed="0.003688"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.761330" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.761788" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '486'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:22.761894" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.755376" elapsed="0.006545"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.764696" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.762247" elapsed="0.002499"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.764907" elapsed="0.003335"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:22.770705" level="INFO">${update} = ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.768488" elapsed="0.002263"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.771020" elapsed="0.003173"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:22.774252" elapsed="0.000044"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:22.754890" elapsed="0.019516"/>
</kw>
<msg time="2026-06-06T03:27:22.774551" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:22.754194" elapsed="0.020383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.775024" level="INFO">ffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.774767" elapsed="0.000303"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.776026" level="INFO">Length is 180.</msg>
<msg time="2026-06-06T03:27:22.776102" level="INFO">${len_1} = 180</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:22.775757" elapsed="0.000369"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.776536" level="INFO">Length is 180.</msg>
<msg time="2026-06-06T03:27:22.776611" level="INFO">${len_2} = 180</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:22.776284" elapsed="0.000350"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.776811" elapsed="0.000312"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:22.777471" level="INFO">${sum_1} = 2687</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:22.777283" elapsed="0.000213"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:22.777880" level="INFO">${sum_2} = 2687</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:22.777692" elapsed="0.000214"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.778060" elapsed="0.000302"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:22.775353" elapsed="0.003068"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:22.778575" elapsed="0.002267"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.786460" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.786690" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '486'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:22.786842" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.781388" elapsed="0.005493"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.791255" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.787151" elapsed="0.004177"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.791566" elapsed="0.003849"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.801967" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.802100" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '486'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:22.802268" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.795684" elapsed="0.006613"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.805048" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.802474" elapsed="0.002627"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.805264" elapsed="0.003604"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:22.812542" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.808996" elapsed="0.003615"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.808961" elapsed="0.003707"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.819096" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.819142" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.819241" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.812902" elapsed="0.006365"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:22.781085" elapsed="0.038252"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.824799" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.824955" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.825083" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.820360" elapsed="0.004760"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.828786" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.825359" elapsed="0.003495"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.829072" elapsed="0.003518"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:22.835186" level="INFO">${update} = ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.832840" elapsed="0.002388"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.835477" elapsed="0.003075"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:22.838623" elapsed="0.000067"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:22.820016" elapsed="0.018814"/>
</kw>
<msg time="2026-06-06T03:27:22.838941" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:22.819509" elapsed="0.019467"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.839554" level="INFO">ffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.839209" elapsed="0.000408"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.840868" level="INFO">Length is 168.</msg>
<msg time="2026-06-06T03:27:22.841202" level="INFO">${len_1} = 168</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:22.840478" elapsed="0.000758"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.841882" level="INFO">Length is 168.</msg>
<msg time="2026-06-06T03:27:22.841987" level="INFO">${len_2} = 168</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:22.841459" elapsed="0.000561"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.842243" elapsed="0.000451"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:22.843177" level="INFO">${sum_1} = 2240</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:22.842918" elapsed="0.000294"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:22.843754" level="INFO">${sum_2} = 2240</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:22.843465" elapsed="0.000326"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.844015" elapsed="0.000428"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:22.839968" elapsed="0.004557"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.849348" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.849457" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.849550" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.845323" elapsed="0.004253"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.853798" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.849785" elapsed="0.004094"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.854105" elapsed="0.003563"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.862744" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.862911" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.863063" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.857910" elapsed="0.005193"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.867047" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:22.863360" elapsed="0.003759"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.867356" elapsed="0.003363"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:22.873149" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:27:22.870806" elapsed="0.002413"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.870782" elapsed="0.002464"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.873422" elapsed="0.000023"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:22.844902" elapsed="0.028793"/>
</kw>
<arg>pmsi_bidir_pim_tree</arg>
<status status="PASS" start="2026-06-06T03:27:22.719144" elapsed="0.154618"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:22.596177" elapsed="0.277722"/>
</test>
<test id="s1-s13-t71" name="Play_To_Odl_pmsi_bidir_pim_tree" line="239">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:22.877832" elapsed="0.000245"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:22.877471" elapsed="0.000672"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:22.879233" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.879095" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.879072" elapsed="0.000234"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:22.884528" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.884398" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.884376" elapsed="0.000234"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.886032" 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-06-06T03:27:22.885359" elapsed="0.000707"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.886578" 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-06-06T03:27:22.886263" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:22.886672" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:27:22.886859" 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-06-06T03:27:22.884905" elapsed="0.001981"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:22.893162" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.893031" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.893006" elapsed="0.000237"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:22.894889" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:22.894693" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.894671" elapsed="0.000385"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:22.895671" 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-06-06T03:27:22.895220" elapsed="0.000516"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:22.896366" level="INFO">${current_connection_index} = 7</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-06-06T03:27:22.896095" elapsed="0.000332"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:22.927837" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:22.898326" elapsed="0.029756"/>
</kw>
<msg time="2026-06-06T03:27:22.928280" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:22.928378" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:22.896758" elapsed="0.031696"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:22.958249" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "b "i "d "i "r "_ "p "i "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:22.930638" elapsed="0.027785"/>
</kw>
<msg time="2026-06-06T03:27:22.958578" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:22.958695" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:22.928966" elapsed="0.029805"/>
</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-06-06T03:27:22.959521" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:22.959099" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.959065" elapsed="0.000658"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:22.960495" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "b "i "d "i "r "_ "p "i "m "_ "t "r "e "e "[K"
[?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-06-06T03:27:22.959886" elapsed="0.000826"/>
</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-06-06T03:27:22.961253" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:22.960896" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.960875" elapsed="0.000554"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:22.961472" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:22.965214" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:27:22.965403" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:22.964726" elapsed="0.000747"/>
</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="NOT RUN" start="2026-06-06T03:27:22.965709" elapsed="0.000043"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.965966" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:22.963893" elapsed="0.002294"/>
</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-06-06T03:27:22.961880" elapsed="0.004393"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:22.894210" elapsed="0.072245"/>
</kw>
<msg time="2026-06-06T03:27:22.966553" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:22.966598" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:22.893419" elapsed="0.073218"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:22.966955" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:27:22.966819" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.966798" elapsed="0.000274"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.967747" elapsed="0.000037"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.968352" elapsed="0.000036"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:22.968455" elapsed="0.000024"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:22.892601" elapsed="0.076011"/>
</kw>
<msg time="2026-06-06T03:27:22.968853" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:22.968917" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:22.887309" elapsed="0.081662"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:22.969438" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:22.969079" elapsed="0.000435"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:22.969054" elapsed="0.000493"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:22.887155" elapsed="0.082425"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:22.886953" elapsed="0.082672"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:22.883944" elapsed="0.086015"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:22.878788" elapsed="0.091252"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:22.878305" elapsed="0.091799"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:22.875152" elapsed="0.095027"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.977860" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.978113" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:22.978253" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.970805" elapsed="0.007485"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:22.978538" elapsed="0.004038"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:22.988926" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:22.989032" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:22.989136" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:22.982832" elapsed="0.006331"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.992328" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.992023" elapsed="0.000333"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:22.992806" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:22.992514" elapsed="0.000320"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.992997" elapsed="0.000328"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:22.989403" elapsed="0.003985"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:22.970389" elapsed="0.023053"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:22.874585" elapsed="0.118898"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:22.994282" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:22.994443" level="INFO">${data_xml} = &lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-d...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:22.994077" elapsed="0.000395"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.022536" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree.vanadium/pmsi_bidir_pim_tree.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:23.022156" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:23.023365" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree.vanadium/pmsi_bidir_pim_tree.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:23.023116" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree.vanadium/pmsi_bidir_pim_tree.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:23.023541" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:23.022754" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.024143" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:23.023753" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:23.024512" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/pmsi_bidir_pim_tree.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:23.024654" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:23.024375" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.025094" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "bidir-pim-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:23.024846" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:23.025540" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:23.025219" elapsed="0.000379"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.026106" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:23.025806" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:23.025624" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:23.025197" elapsed="0.000992"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.026808" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:23.026341" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:23.026888" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:23.027045" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:23.019811" elapsed="0.007261"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:23.027427" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/announce_pmsi_bidir_pim_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/announce_pmsi_bidir_pim_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:23.027553" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:23.027234" elapsed="0.000345"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:23.027942" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/withdraw_pmsi_bidir_pim_tree.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_bidir_pim_tree/withdraw_pmsi_bidir_pim_tree.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:23.028062" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:23.027751" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.028492" level="INFO">&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;true&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;bidir-pim-tree&gt;
                &lt;p-address&gt;43.43.43.43&lt;/p-address&gt;
                &lt;p-multicast-group&gt;10.10.10.10&lt;/p-multicast-group&gt;
            &lt;/bidir-pim-tree&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:23.028248" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.028962" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "bidir-pim-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:23.028718" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.029463" level="INFO">ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:23.029204" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:23.029985" level="INFO">ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:23.029698" elapsed="0.000332"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:23.030185" elapsed="0.002786"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:23.033139" elapsed="0.001796"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:23.040266" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:23.040419" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:23.040552" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:23.035921" elapsed="0.005146">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:23.041335" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:23.041682" elapsed="0.000035"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:23.035557" elapsed="0.006319">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:25.052763" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:25.052978" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '486'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:25.053131" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:25.043537" elapsed="0.009632"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:25.053880" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": true,
                        "mpls-label": 20024,
                        "bidir-pim-tree": {
                            "p-address": "43.43.43.43",
                            "p-multicast-group": "10.10.10.10"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:25.057297" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:25.053437" elapsed="0.003936"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:25.062169" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:25.061347" elapsed="0.000875"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:25.063400" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:25.062519" elapsed="0.000933"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:25.063785" elapsed="0.000637"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:25.057723" elapsed="0.006808"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:25.042543" elapsed="0.022081"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:23.035111" elapsed="2.029627"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:25.065007" elapsed="0.003061"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:25.073864" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:25.074035" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:25.074170" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:25.069083" elapsed="0.005124"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:25.074447" elapsed="0.004006"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:25.085198" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:25.085909" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '634'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":true,"mpls-label":20024,"bidir-pim-tree":{"p-address":"43.43.43.43","p-multicast-group":"10.10.10.10"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:25.086068" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:25.078718" elapsed="0.007388"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:25.090512" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:25.090102" elapsed="0.000449"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:25.091502" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:25.090798" elapsed="0.000797"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:25.092326" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "bidir-pim-tree": {
         "p-address": "43.43.43.43",
         "p-multicast-group": "10.10.10.10"
        },
        "leaf-information-required": true,
        "mpls-label": 20024
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:25.092677" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "bidir-pim-tree": {
+         "p-address": "43.43.43.43",
+         "p-multicast-group": "10.10.10.10"
+        },
+        "leaf-information-required": true,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:25.091851" elapsed="0.000938">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+        },
+        "leaf-information-required": true,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:25.086433" elapsed="0.006589">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+        },
+        "leaf-information-required": true,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:25.068789" elapsed="0.024442">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+        },
+        "leaf-information-required": true,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.103753" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.103945" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.104089" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.095142" elapsed="0.008984"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.104380" elapsed="0.003572"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.113289" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.113558" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:27.113756" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.108189" elapsed="0.005605"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.118232" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.117791" elapsed="0.000478"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.118862" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.118485" elapsed="0.000412"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.119116" elapsed="0.000464"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.114215" elapsed="0.005471"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.094105" elapsed="0.025659"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:25.068263" elapsed="2.051559"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:27.120530" elapsed="0.002498"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.130908" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.131041" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.131154" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.124589" elapsed="0.006593"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.131356" elapsed="0.002666"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.139321" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.139508" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:27.139690" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.134199" elapsed="0.005542"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.144357" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.143892" elapsed="0.000515"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.145129" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.144719" elapsed="0.000451"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.145399" elapsed="0.000484"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.140138" elapsed="0.005931"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.123879" elapsed="0.022287"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:27.123293" elapsed="0.022929"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:27.120070" elapsed="0.026230"/>
</kw>
<arg>pmsi_bidir_pim_tree</arg>
<status status="PASS" start="2026-06-06T03:27:22.993720" elapsed="4.152647"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:22.874121" elapsed="4.272412"/>
</test>
<test id="s1-s13-t72" name="Odl_To_Play_pmsi_ingress_replication" line="242">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:27.151785" elapsed="0.000258"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:27.151490" elapsed="0.000614"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:27.153218" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.153091" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.153067" elapsed="0.000229"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:27.158688" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.158560" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.158541" elapsed="0.000219"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.159808" 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-06-06T03:27:27.159395" elapsed="0.000440"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.160315" 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-06-06T03:27:27.160002" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:27.160386" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:27:27.160551" 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-06-06T03:27:27.158997" elapsed="0.001579"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:27.166860" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.166746" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.166725" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:27.168468" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.168283" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.168263" elapsed="0.000371"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:27.169239" 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-06-06T03:27:27.168809" elapsed="0.000493"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:27.169962" level="INFO">${current_connection_index} = 7</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-06-06T03:27:27.169670" elapsed="0.000363"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:27.202600" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:27.172053" elapsed="0.030715"/>
</kw>
<msg time="2026-06-06T03:27:27.202911" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:27.203006" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:27.170367" elapsed="0.032711"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:27.236903" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "i "n "g "r "e "s "s "_ "r "e "p "l "i "c "a "t "i "o "n "[K"
[?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-06-06T03:27:27.205246" elapsed="0.031872"/>
</kw>
<msg time="2026-06-06T03:27:27.237323" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:27.237464" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:27.203478" elapsed="0.034093"/>
</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-06-06T03:27:27.238756" elapsed="0.000071"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.238171" elapsed="0.000758"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.238134" elapsed="0.000885"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.240134" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "i "n "g "r "e "s "s "_ "r "e "p "l "i "c "a "t "i "o "n "[K"
[?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-06-06T03:27:27.239248" elapsed="0.001066"/>
</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-06-06T03:27:27.241120" elapsed="0.000068"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.240574" elapsed="0.000714"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.240543" elapsed="0.000831"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:27.241430" elapsed="0.000048"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:27.246822" elapsed="0.000213"/>
</kw>
<msg time="2026-06-06T03:27:27.247100" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:27.245988" elapsed="0.001186"/>
</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="NOT RUN" start="2026-06-06T03:27:27.247395" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.247612" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:27.244816" elapsed="0.003032"/>
</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-06-06T03:27:27.241882" elapsed="0.006051"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:27.167819" elapsed="0.080292"/>
</kw>
<msg time="2026-06-06T03:27:27.248205" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:27.248251" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:27.167119" elapsed="0.081170"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:27.248476" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:27.248367" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.248347" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.249063" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.249487" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:27.249561" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:27.166360" elapsed="0.083327"/>
</kw>
<msg time="2026-06-06T03:27:27.249784" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:27.249828" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:27.160997" elapsed="0.088869"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.250216" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.249942" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.249924" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:27.160831" elapsed="0.089486"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:27.160633" elapsed="0.089715"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:27.158190" elapsed="0.092214"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:27.152750" elapsed="0.097711"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:27.152267" elapsed="0.098239"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:27.148507" elapsed="0.102052"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.256913" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.257096" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.257289" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.251039" elapsed="0.006293"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.257617" elapsed="0.003889"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.267144" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.267378" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:27.267602" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.261781" elapsed="0.005919"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.273565" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.273145" elapsed="0.000461"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.274252" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.273854" elapsed="0.000437"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.274515" elapsed="0.000482"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.268228" elapsed="0.006855"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.250761" elapsed="0.024398"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:27.147819" elapsed="0.127398"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.276307" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.276559" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.276027" elapsed="0.000573"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.277116" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.277294" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.276847" elapsed="0.000485"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.277843" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/announce_pmsi_ingress_replication.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/announce_pmsi_ingress_replication.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.278085" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.277553" elapsed="0.000571"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:27.278665" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:27.278350" elapsed="0.000356"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.279209" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/withdraw_pmsi_ingress_replication.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/withdraw_pmsi_ingress_replication.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.279384" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.278935" elapsed="0.000487"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:27.279948" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:27.279662" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.280566" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;false&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;ingress-replication&gt;
                &lt;receiving-endpoint-address&gt;172.12.123.3&lt;/receiving-endpoint-address&gt;
            &lt;/ingress-replication&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.280217" elapsed="0.000449"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.281228" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": false,
                        "mpls-label": 20024,
                        "ingress-replication": {
                            "receiving-endpoint-address": "172.12.123.3"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.280889" elapsed="0.000412"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.281877" level="INFO">ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.281518" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.282560" level="INFO">ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.282218" elapsed="0.000405"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:27.282866" elapsed="0.002688"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.295002" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1022', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;false&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;ingress-replication&gt;
                &lt;receiving-endpoint-address&gt;172.12.123.3&lt;/receiving-endpoint-address&gt;
            &lt;/ingress-replication&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:27.295138" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.295273" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.285739" elapsed="0.009570"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.299356" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.295556" elapsed="0.003863"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.304711" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.305264" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '476'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:27.305411" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.299668" elapsed="0.005780"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.309171" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.305711" elapsed="0.003528"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.316730" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.317287" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '476'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:27.317428" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.310630" elapsed="0.006836"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.321210" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.317746" elapsed="0.003535"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.321508" elapsed="0.005962"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:27.331007" level="INFO">${update} = ffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.327909" elapsed="0.003181"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.331517" elapsed="0.004534"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:27.336125" elapsed="0.000051"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:27.310165" elapsed="0.026153"/>
</kw>
<msg time="2026-06-06T03:27:27.336573" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:27.309482" elapsed="0.027129"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.337229" level="INFO">ffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.336876" elapsed="0.000418"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.338583" level="INFO">Length is 172.</msg>
<msg time="2026-06-06T03:27:27.338711" level="INFO">${len_1} = 172</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:27.338209" elapsed="0.000537"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.339331" level="INFO">Length is 172.</msg>
<msg time="2026-06-06T03:27:27.339435" level="INFO">${len_2} = 172</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:27.338968" elapsed="0.000501"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.339711" elapsed="0.000435"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:27.340630" level="INFO">${sum_1} = 2773</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:27.340369" elapsed="0.000318"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:27.341168" level="INFO">${sum_2} = 2773</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:27.340905" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.341421" elapsed="0.000453"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:27.337628" elapsed="0.004329"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:27.342207" elapsed="0.002255"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.349750" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.350034" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '476'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:27.350283" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.345002" elapsed="0.005340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.357175" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.350769" elapsed="0.006530"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.357723" elapsed="0.003258"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.365822" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.365940" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '476'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:27.366078" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.361155" elapsed="0.004990"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.369433" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.366325" elapsed="0.003178"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.369748" elapsed="0.003575"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:27.376252" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.373437" elapsed="0.002859"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.373407" elapsed="0.002913"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.384614" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.384703" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.384845" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.376476" elapsed="0.008406"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:27.344723" elapsed="0.040255"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.391540" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.391719" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.391851" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.386356" elapsed="0.005532"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.395689" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.392131" elapsed="0.003627"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.395981" elapsed="0.003589"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:27.401747" level="INFO">${update} = ffffffffffffffffffffffffffffffff005002000000394001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.399754" elapsed="0.002022"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.401955" elapsed="0.002169"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:27.404176" elapsed="0.000033"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:27.385865" elapsed="0.018442"/>
</kw>
<msg time="2026-06-06T03:27:27.404386" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff005002000000394001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:27.385215" elapsed="0.019197"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.404851" level="INFO">ffffffffffffffffffffffffffffffff005002000000394001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.404581" elapsed="0.000316"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.405773" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:27:27.405849" level="INFO">${len_1} = 160</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:27.405497" elapsed="0.000412"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.406363" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:27:27.406439" level="INFO">${len_2} = 160</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:27.406071" elapsed="0.000393"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.406624" elapsed="0.000327"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:27.407431" level="INFO">${sum_1} = 2326</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:27.407172" elapsed="0.000295"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:27.407965" level="INFO">${sum_2} = 2326</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:27.407710" elapsed="0.000291"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.408220" elapsed="0.000451"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:27.405129" elapsed="0.003628"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.416048" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.416199" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.416330" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.409532" elapsed="0.006835"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.420304" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.416607" elapsed="0.003764"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.420592" elapsed="0.003559"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.429400" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.429507" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.429609" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.424382" elapsed="0.005254"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.432250" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.429831" elapsed="0.002467"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.432457" elapsed="0.002535"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:27.438340" elapsed="0.000040"/>
</return>
<status status="PASS" start="2026-06-06T03:27:27.435102" elapsed="0.003321"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.435075" elapsed="0.003383"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.438691" elapsed="0.000031"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:27.409108" elapsed="0.029762"/>
</kw>
<arg>pmsi_ingress_replication</arg>
<status status="PASS" start="2026-06-06T03:27:27.275585" elapsed="0.163350"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.147051" elapsed="0.292036"/>
</test>
<test id="s1-s13-t73" name="Play_To_Odl_pmsi_ingress_replication" line="244">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:27.444049" elapsed="0.000206"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:27.443783" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:27.445310" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.445198" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.445178" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:27.450391" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.450285" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.450266" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.451468" 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-06-06T03:27:27.451084" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.451967" 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-06-06T03:27:27.451672" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:27.452036" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:27.452189" 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-06-06T03:27:27.450704" elapsed="0.001510"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:27.457950" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.457841" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.457822" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:27.459521" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:27.459339" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.459320" elapsed="0.000383"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:27.460270" 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-06-06T03:27:27.459859" elapsed="0.000472"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:27.460967" level="INFO">${current_connection_index} = 7</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-06-06T03:27:27.460697" elapsed="0.000331"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:27.494135" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:27.462908" elapsed="0.031399"/>
</kw>
<msg time="2026-06-06T03:27:27.494464" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:27.494560" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:27.461342" elapsed="0.033292"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:27.527759" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "i "n "g "r "e "s "s "_ "r "e "p "l "i "c "a "t "i "o "n "[K"
[?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-06-06T03:27:27.496633" elapsed="0.031269"/>
</kw>
<msg time="2026-06-06T03:27:27.528041" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:27.528137" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:27.495079" elapsed="0.033132"/>
</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-06-06T03:27:27.528949" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.528528" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.528499" elapsed="0.000631"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.529888" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "i "n "g "r "e "s "s "_ "r "e "p "l "i "c "a "t "i "o "n "[K"
[?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-06-06T03:27:27.529287" elapsed="0.000793"/>
</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-06-06T03:27:27.530666" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.530289" elapsed="0.000496"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.530239" elapsed="0.000605"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:27.530885" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:27.534569" elapsed="0.000163"/>
</kw>
<msg time="2026-06-06T03:27:27.534777" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:27.533975" elapsed="0.000871"/>
</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="NOT RUN" start="2026-06-06T03:27:27.535067" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.535287" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:27.533180" elapsed="0.002327"/>
</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-06-06T03:27:27.531208" elapsed="0.004384"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:27.458867" elapsed="0.076925"/>
</kw>
<msg time="2026-06-06T03:27:27.535889" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:27.535934" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:27.458175" elapsed="0.077798"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:27.536159" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:27.536051" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.536032" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.536734" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.537162" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:27.537235" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:27.457487" elapsed="0.079860"/>
</kw>
<msg time="2026-06-06T03:27:27.537444" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:27.537489" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:27.452593" elapsed="0.084934"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.537877" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.537604" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.537586" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:27.452447" elapsed="0.085532"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:27.452271" elapsed="0.085742"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:27.449901" elapsed="0.088174"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:27.444908" elapsed="0.093223"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:27.444463" elapsed="0.093714"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:27.440987" elapsed="0.097246"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.545808" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.545980" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.546086" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.538732" elapsed="0.007381"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:27.546320" elapsed="0.003612"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.554990" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.555137" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:27.555278" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:27.550171" elapsed="0.005144"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.559629" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.559213" elapsed="0.000476"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:27.560294" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:27.559913" elapsed="0.000419"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.560552" elapsed="0.000478"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:27.555634" elapsed="0.005482"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.538409" elapsed="0.022782"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:27.440296" elapsed="0.120950"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.562245" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.562509" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.561967" elapsed="0.000584"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.588385" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication.vanadium/pmsi_ingress_replication.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:27.588009" elapsed="0.000404"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.589205" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication.vanadium/pmsi_ingress_replication.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:27.588948" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication.vanadium/pmsi_ingress_replication.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:27.589373" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:27.588580" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.589972" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:27.589566" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.590357" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/pmsi_ingress_replication.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.590557" level="INFO">${template} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.590207" elapsed="0.000379"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.591026" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": false,
                        "mpls-label": 20024,
                        "ingress-replication": {
                            "receiving-endpoint-address": "172.12.123.3"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.590771" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:27.591454" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:27.591149" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.592004" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:27.591706" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.591539" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:27.591129" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.592698" level="INFO">${final_text} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:27.592240" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:27.592778" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:27.592935" level="INFO">${data_json} = {
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-dist...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:27.585692" elapsed="0.007270"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.593323" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/announce_pmsi_ingress_replication.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/announce_pmsi_ingress_replication.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.593448" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.593128" elapsed="0.000346"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:27.593837" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/withdraw_pmsi_ingress_replication.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_ingress_replication/withdraw_pmsi_ingress_replication.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:27.593956" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:27.593631" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.594409" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;false&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;ingress-replication&gt;
                &lt;receiving-endpoint-address&gt;172.12.123.3&lt;/receiving-endpoint-address&gt;
            &lt;/ingress-replication&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.594139" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.594900" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": false,
                        "mpls-label": 20024,
                        "ingress-replication": {
                            "receiving-endpoint-address": "172.12.123.3"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.594620" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.595384" level="INFO">ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.595143" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:27.595841" level="INFO">ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:27.595582" elapsed="0.000303"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:27.596035" elapsed="0.002230"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:27.598439" elapsed="0.002067"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:27.608812" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:27.608964" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:27.609095" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:27.601470" elapsed="0.008113">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.609874" elapsed="0.000032"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:27.610204" elapsed="0.000033"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:27.601143" elapsed="0.009264">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:29.618876" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:29.619099" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '476'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:29.619252" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:29.611402" elapsed="0.007890"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:29.619996" level="INFO">{
    "odl-bgp-evpn:evpn-routes": {
        "evpn-route": [
            {
                "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
                "path-id": 0,
                "route-distinguisher": "429496729:1",
                "es-route": {
                    "orig-route-ip": "43.43.43.43",
                    "arbitrary": {
                        "arbitrary": "AAAAAAAAAAAA"
                    }
                },
                "attributes": {
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "pmsi-tunnel": {
                        "leaf-information-required": false,
                        "mpls-label": 20024,
                        "ingress-replication": {
                            "receiving-endpoint-address": "172.12.123.3"
                        }
                    },
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    }
                }
            }
        ]
    }
}</msg>
<msg time="2026-06-06T03:27:29.623320" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:29.619558" elapsed="0.003916"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:29.628333" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:29.627545" elapsed="0.000830"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:29.629285" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:29.628606" elapsed="0.000719"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:29.629557" elapsed="0.000502"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:29.623832" elapsed="0.006318"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:29.610874" elapsed="0.019353"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:27.600701" elapsed="2.029593"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:29.630519" elapsed="0.003169"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:29.644782" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:29.645036" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:29.645228" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:29.635911" elapsed="0.009362"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:29.645514" elapsed="0.003998"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:29.655403" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:29.655913" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '624'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"ingress-replication":{"receiving-endpoint-address":"172.12.123.3"}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:29.656023" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:29.649773" elapsed="0.006278"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:29.659326" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:29.658989" elapsed="0.000367"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:29.660074" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:29.659523" elapsed="0.000580"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:29.660724" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "ingress-replication": {
         "receiving-endpoint-address": "172.12.123.3"
        },
        "leaf-information-required": false,
        "mpls-label": 20024
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:29.660965" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "ingress-replication": {
+         "receiving-endpoint-address": "172.12.123.3"
+        },
+        "leaf-information-required": false,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:29.660353" elapsed="0.000694">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+        },
+        "leaf-information-required": false,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:29.656305" elapsed="0.004916">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+        },
+        "leaf-information-required": false,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:29.635237" elapsed="0.026151">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,39 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+        },
+        "leaf-information-required": false,
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.671333" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.671523" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:31.671695" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.662966" elapsed="0.008769"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.671990" elapsed="0.003870"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.681731" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.682004" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:31.682154" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.676099" elapsed="0.006093"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:31.686808" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.686320" elapsed="0.000529"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:31.687463" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.687075" elapsed="0.000428"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.687935" elapsed="0.000506"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.682523" elapsed="0.006009"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:31.662126" elapsed="0.026484"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:29.634174" elapsed="2.054515"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:31.689460" elapsed="0.002753"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.697848" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.697959" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:31.698062" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.693388" elapsed="0.004701"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.698257" elapsed="0.002532"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.705287" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.705432" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:31.705573" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.700955" elapsed="0.004656"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:31.710226" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.709797" elapsed="0.000469"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:31.710884" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.710488" elapsed="0.000435"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.711145" elapsed="0.000450"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.706016" elapsed="0.005739"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:31.692868" elapsed="0.018963"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:31.692394" elapsed="0.019491"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:31.688956" elapsed="0.023004"/>
</kw>
<arg>pmsi_ingress_replication</arg>
<status status="PASS" start="2026-06-06T03:27:27.561532" elapsed="4.150493"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:27.439557" elapsed="4.272618"/>
</test>
<test id="s1-s13-t74" name="Odl_To_Play_pmsi_mldp_mp2mp_lsp" line="247">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:31.716478" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:31.716207" elapsed="0.000554"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:31.717807" elapsed="0.000043"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:31.717682" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.717657" elapsed="0.000259"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:31.722918" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:31.722809" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.722791" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.724003" 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-06-06T03:27:31.723604" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.724491" 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-06-06T03:27:31.724195" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:31.724562" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:27:31.724742" 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-06-06T03:27:31.723223" elapsed="0.001545"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:31.730782" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:31.730659" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.730624" elapsed="0.000230"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:31.732317" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:31.732136" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.732114" elapsed="0.000365"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:31.733066" 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-06-06T03:27:31.732634" elapsed="0.000494"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:31.733769" level="INFO">${current_connection_index} = 7</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-06-06T03:27:31.733484" elapsed="0.000363"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:31.766893" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:31.735757" elapsed="0.031284"/>
</kw>
<msg time="2026-06-06T03:27:31.767179" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:31.767272" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:31.734181" elapsed="0.033161"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:31.812112" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "m "l "d "p "_ "m "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:31.769287" elapsed="0.042994"/>
</kw>
<msg time="2026-06-06T03:27:31.812432" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:31.812525" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:27:31.767766" elapsed="0.044831"/>
</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-06-06T03:27:31.813434" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:31.812949" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.812916" elapsed="0.000698"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.814427" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "p "m "s "i "_ "m "l "d "p "_ "m "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:31.813786" elapsed="0.000763"/>
</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-06-06T03:27:31.815101" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:31.814745" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.814723" elapsed="0.000557"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:31.815322" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:31.819018" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:27:31.819209" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:31.818436" elapsed="0.000986"/>
</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="NOT RUN" start="2026-06-06T03:27:31.819659" elapsed="0.000025"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:31.819882" elapsed="0.000022"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:31.817621" elapsed="0.002481"/>
</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-06-06T03:27:31.815662" elapsed="0.004528"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:31.731689" elapsed="0.088679"/>
</kw>
<msg time="2026-06-06T03:27:31.820465" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:31.820510" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:31.731013" elapsed="0.089537"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:31.820756" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:31.820627" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.820608" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:31.821311" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:31.821771" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:31.821845" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:31.730290" elapsed="0.091683"/>
</kw>
<msg time="2026-06-06T03:27:31.822069" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:31.822114" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:31.725165" elapsed="0.096988"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:31.822488" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:31.822229" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.822211" elapsed="0.000356"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:31.725004" elapsed="0.097587"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:31.724826" elapsed="0.097799"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:31.722430" elapsed="0.100271"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:31.717366" elapsed="0.105394"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:31.716920" elapsed="0.105886"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:31.713959" elapsed="0.108903"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.830166" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.830320" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:31.830456" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.823333" elapsed="0.007150"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.830699" elapsed="0.002983"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.839819" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.839992" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:31.840151" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.833855" elapsed="0.006328"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:31.843842" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.843473" elapsed="0.000400"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:31.844326" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.844039" elapsed="0.000316"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.844527" elapsed="0.000406"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.840555" elapsed="0.004446"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:31.823052" elapsed="0.022010"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:31.713251" elapsed="0.131859"/>
</kw>
<kw name="Odl_To_Play_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:31.846002" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:31.846196" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:31.845736" elapsed="0.000490"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:31.846586" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:31.846734" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.json</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:31.846390" elapsed="0.000371"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:31.847118" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/announce_pmsi_mldp_mp2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/announce_pmsi_mldp_mp2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:31.847359" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:31.846923" elapsed="0.000477"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:31.847988" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:31.847664" elapsed="0.000365"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:31.848561" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/withdraw_pmsi_mldp_mp2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/withdraw_pmsi_mldp_mp2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:31.848772" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:31.848274" elapsed="0.000538"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:27:31.849355" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:27:31.849051" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.850067" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;false&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;mldp-mp2mp-lsp&gt;
                &lt;opaque-type&gt;1&lt;/opaque-type&gt;
                &lt;opaque&gt;01:01:01:01:01:01:01&lt;/opaque&gt;
            &lt;/mldp-mp2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.849663" elapsed="0.000492"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.850779" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          },
          "pmsi-tunnel": {
            "leaf-information-required": false,
            "mpls-label": 20024,
            "mldp-mp2mp-lsp": {
              "opaque-type": 1,
              "opaque": "01:01:01:01:01:01:01"
            }
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.850393" elapsed="0.000461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.851456" level="INFO">ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.851092" elapsed="0.000430"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.852136" level="INFO">ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.851778" elapsed="0.000424"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:31.852429" elapsed="0.002913"/>
</kw>
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.866089" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '1025', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;false&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;mldp-mp2mp-lsp&gt;
                &lt;opaque-type&gt;1&lt;/opaque-type&gt;
                &lt;opaque&gt;01:01:01:01:01:01:01&lt;/opaque&gt;
            &lt;/mldp-mp2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
 
 </msg>
<msg time="2026-06-06T03:27:31.866302" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes/evpn-route=BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw%3D%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.866520" level="INFO">${resp} = &lt;Response [201]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>data=${data_xml}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=201</arg>
<doc>Sends a POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.855519" elapsed="0.011058"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.872452" level="INFO"/>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.867016" elapsed="0.005501"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.878048" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.878696" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '475'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:31.878862" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS_XML}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.872783" elapsed="0.006118"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.882951" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.879161" elapsed="0.003864"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.888951" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.889365" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '475'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:31.889469" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.884562" elapsed="0.004934"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.892189" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.889705" elapsed="0.002535"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.892405" elapsed="0.002904"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:31.898201" level="INFO">${update} = ffffffffffffffffffffffffffffffff005c02000000454001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.895534" elapsed="0.002714"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.898521" elapsed="0.003408"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:31.902030" elapsed="0.000061"/>
</return>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:31.884037" elapsed="0.018223"/>
</kw>
<msg time="2026-06-06T03:27:31.902473" level="INFO">${aupdate} = ffffffffffffffffffffffffffffffff005c02000000454001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101</msg>
<var>${aupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${ALLOWED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:31.883297" elapsed="0.019217"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.903173" level="INFO">ffffffffffffffffffffffffffffffff005c02000000454001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101</msg>
<arg>${aupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.902795" elapsed="0.000446"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.904629" level="INFO">Length is 184.</msg>
<msg time="2026-06-06T03:27:31.904765" level="INFO">${len_1} = 184</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:31.904230" elapsed="0.000571"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.905422" level="INFO">Length is 184.</msg>
<msg time="2026-06-06T03:27:31.905534" level="INFO">${len_2} = 184</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:31.905039" elapsed="0.000530"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.905827" elapsed="0.000493"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:31.906867" level="INFO">${sum_1} = 2497</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:31.906559" elapsed="0.000347"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:31.907323" level="INFO">${sum_2} = 2497</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:31.907131" elapsed="0.000223"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.907512" elapsed="0.000331"/>
</kw>
<arg>${aupdate}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:31.903622" elapsed="0.004281"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:31.908058" elapsed="0.002210"/>
</kw>
<kw name="Remove_Configured_Routes">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.914954" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.915119" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '475'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:31.915270" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.910839" elapsed="0.004470"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.919758" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.915582" elapsed="0.004251"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.920071" elapsed="0.003557"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.927901" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.928034" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '475'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:31.928207" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.923813" elapsed="0.004422"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.930963" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","path-id":0,"es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.928418" elapsed="0.002596"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.931217" elapsed="0.004000"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:31.938961" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:31.935355" elapsed="0.003677"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:31.935316" elapsed="0.003753"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.950808" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.950920" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.951163" level="INFO">${resp} = &lt;Response [204]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.939279" elapsed="0.011924"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:31.910525" elapsed="0.040772"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Content">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.956948" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.957134" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:31.957273" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS_XML}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.952525" elapsed="0.004787"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.961310" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.957572" elapsed="0.003808"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${expected_status_codes}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.961618" elapsed="0.003810"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:31.968118" level="INFO">${update} = ffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:27:31.965695" elapsed="0.002467"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.968432" elapsed="0.003284"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:27:31.971795" elapsed="0.000056"/>
</return>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Gets received data from odl's peer</doc>
<status status="PASS" start="2026-06-06T03:27:31.952147" elapsed="0.019854"/>
</kw>
<msg time="2026-06-06T03:27:31.972119" level="INFO">${wupdate} = ffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101</msg>
<var>${wupdate}</var>
<arg>4x</arg>
<arg>2s</arg>
<arg>Get_Update_Content</arg>
<arg>${DELETED_STATUS_CODES}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:31.951521" elapsed="0.020640"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.972797" level="INFO">ffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101</msg>
<arg>${wupdate}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.972410" elapsed="0.000457"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.974211" level="INFO">Length is 172.</msg>
<msg time="2026-06-06T03:27:31.974404" level="INFO">${len_1} = 172</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:31.973799" elapsed="0.000642"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.975095" level="INFO">Length is 172.</msg>
<msg time="2026-06-06T03:27:31.975206" level="INFO">${len_2} = 172</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:31.974706" elapsed="0.000535"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.975566" elapsed="0.000492"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:31.976581" level="INFO">${sum_1} = 2050</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:31.976303" elapsed="0.000317"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:27:31.977145" level="INFO">${sum_2} = 2050</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:27:31.976873" elapsed="0.000312"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:31.977415" elapsed="0.000470"/>
</kw>
<arg>${wupdate}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:27:31.973221" elapsed="0.004752"/>
</kw>
<kw name="Remove_Configured_Routes" type="TEARDOWN">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.984743" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.984876" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:31.984970" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.978877" elapsed="0.006119"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:31.988347" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.985173" elapsed="0.003246"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:31.988678" elapsed="0.003780"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:31.997564" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:31.997694" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:31.997799" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>headers=${HEADERS}</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:31.992730" elapsed="0.005095"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.000444" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${resp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:31.998001" elapsed="0.002491"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${ALLOWED_DELETE_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:32.000663" elapsed="0.002544"/>
</kw>
<if>
<branch type="IF" condition="${resp.status_code} in ${DELETED_STATUS_CODES}">
<return>
<status status="PASS" start="2026-06-06T03:27:32.006854" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:27:32.003332" elapsed="0.003620"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.003296" elapsed="0.003694"/>
</if>
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}</arg>
<arg>expected_status=204</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.007222" elapsed="0.000032"/>
</kw>
<doc>Removes the route if present. First GET is for debug purposes.</doc>
<status status="PASS" start="2026-06-06T03:27:31.978406" elapsed="0.029015"/>
</kw>
<arg>pmsi_mldp_mp2mp_lsp</arg>
<status status="PASS" start="2026-06-06T03:27:31.845404" elapsed="0.162091"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:31.712590" elapsed="0.295093"/>
</test>
<test id="s1-s13-t75" name="Play_To_Odl_pmsi_mldp_mp2mp_lsp" line="249">
<kw name="Run Keywords" owner="BuiltIn" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:32.012694" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:32.012408" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:32.013993" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:32.013875" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.013854" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:32.019186" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:32.019078" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.019059" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.020279" 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-06-06T03:27:32.019888" elapsed="0.000418"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.020785" 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-06-06T03:27:32.020472" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:32.020855" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:32.021011" 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-06-06T03:27:32.019489" elapsed="0.001546"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:32.026871" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:32.026761" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.026741" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:32.028420" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:32.028229" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.028209" elapsed="0.000383"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:32.029185" 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-06-06T03:27:32.028767" elapsed="0.000480"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:32.029889" level="INFO">${current_connection_index} = 7</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-06-06T03:27:32.029601" elapsed="0.000352"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:32.063197" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:32.032033" elapsed="0.031326"/>
</kw>
<msg time="2026-06-06T03:27:32.063515" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:32.063612" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:32.030279" elapsed="0.033432"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:32.096320" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "m "l "d "p "_ "m "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:32.065785" elapsed="0.030743"/>
</kw>
<msg time="2026-06-06T03:27:32.096761" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:32.096901" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:27:32.064166" elapsed="0.032843"/>
</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-06-06T03:27:32.098031" elapsed="0.000068"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:32.097461" elapsed="0.000768"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.097424" elapsed="0.000893"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.099442" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "p "m "s "i "_ "m "l "d "p "_ "m "p "2 "m "p "_ "l "s "p "[K"
[?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-06-06T03:27:32.098547" elapsed="0.001167"/>
</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-06-06T03:27:32.100462" elapsed="0.000066"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:32.099966" elapsed="0.000657"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.099936" elapsed="0.000796"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:32.100788" elapsed="0.000049"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:32.105504" elapsed="0.000172"/>
</kw>
<msg time="2026-06-06T03:27:32.105725" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:32.104912" elapsed="0.000892"/>
</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="NOT RUN" start="2026-06-06T03:27:32.106029" elapsed="0.000023"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.106273" elapsed="0.000023"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:32.104088" elapsed="0.002409"/>
</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-06-06T03:27:32.101208" elapsed="0.005377"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:32.027782" elapsed="0.079009"/>
</kw>
<msg time="2026-06-06T03:27:32.106894" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:32.106940" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:32.027099" elapsed="0.079880"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:32.107174" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:32.107061" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.107040" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.107766" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.108203" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:32.108278" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:32.026403" elapsed="0.081990"/>
</kw>
<msg time="2026-06-06T03:27:32.108490" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:32.108534" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:32.021427" elapsed="0.087146"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.108927" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:32.108667" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.108633" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:32.021278" elapsed="0.087751"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:32.021097" elapsed="0.087967"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:32.018714" elapsed="0.090410"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:32.013561" elapsed="0.095620"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:32.013119" elapsed="0.096108"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:32.009695" elapsed="0.099589"/>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:32.114742" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:32.114938" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:32.115037" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:32.109777" elapsed="0.005286"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:32.115241" elapsed="0.002887"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:32.123002" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:32.123149" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:32.123291" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:32.118332" elapsed="0.004996"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:32.127718" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:32.127262" elapsed="0.000497"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:32.128367" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:32.127986" elapsed="0.000420"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:32.128632" elapsed="0.000478"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:32.123673" elapsed="0.005522"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:32.109438" elapsed="0.019832"/>
</kw>
<arg>SetupUtils.Setup_Test_With_Logging_And_Without_Fast_Failing</arg>
<arg>AND</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Executes all the given keywords in a sequence.</doc>
<status status="PASS" start="2026-06-06T03:27:32.008930" elapsed="0.120397"/>
</kw>
<kw name="Play_To_Odl_Template">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:32.130370" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:32.130582" level="INFO">${data_xml} = &lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguish...</msg>
<var>${data_xml}</var>
<arg>${EVPN_DIR}/${totest}/${totest}.xml</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:32.130073" elapsed="0.000549"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.157779" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp.vanadium/pmsi_mldp_mp2mp_lsp.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:32.157383" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:32.158603" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp.vanadium/pmsi_mldp_mp2mp_lsp.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:32.158358" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp.vanadium/pmsi_mldp_mp2mp_lsp.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:32.158794" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:32.157978" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.159377" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:32.158991" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:32.159762" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/pmsi_mldp_mp2mp_lsp.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:32.159890" level="INFO">${template} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:32.159606" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.160326" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          },
          "pmsi-tunnel": {
            "leaf-information-required": false,
            "mpls-label": 20024,
            "mldp-mp2mp-lsp": {
              "opaque-type": 1,
              "opaque": "01:01:01:01:01:01:01"
            }
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:32.160080" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:32.160768" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:32.160445" elapsed="0.000382"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.161295" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:32.161003" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:32.160853" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:32.160426" elapsed="0.000952"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.161993" level="INFO">${final_text} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:32.161529" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:32.162073" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:32.162246" level="INFO">${data_json} = {
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "...</msg>
<var>${data_json}</var>
<arg>${EVPN_DIR}/${totest}</arg>
<arg>${totest}.json</arg>
<doc>Check if ${folder}.vanadium/${file_name} exists. If yes read and Log contents of file ${folder}.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default ${folder}/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:32.155088" elapsed="0.007185"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:32.162632" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/announce_pmsi_mldp_mp2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/announce_pmsi_mldp_mp2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:32.162789" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${announce_hex}</var>
<arg>${EVPN_DIR}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:32.162438" elapsed="0.000386"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:32.163192" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/withdraw_pmsi_mldp_mp2mp_lsp.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l2vpn_evpn/pmsi_mldp_mp2mp_lsp/withdraw_pmsi_mldp_mp2mp_lsp.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:32.163314" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<var>${withdraw_hex}</var>
<arg>${EVPN_DIR}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:32.162984" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.163768" level="INFO">&lt;?xml version="1.0" ?&gt;
&lt;evpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-evpn"&gt;
    &lt;route-key&gt;BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-distinguisher&gt;429496729:1&lt;/route-distinguisher&gt;
    &lt;es-route&gt;
        &lt;orig-route-ip&gt;43.43.43.43&lt;/orig-route-ip&gt;
        &lt;arbitrary&gt;
            &lt;arbitrary&gt;AAAAAAAAAAAA&lt;/arbitrary&gt;
        &lt;/arbitrary&gt;
    &lt;/es-route&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pmsi-tunnel&gt;
            &lt;leaf-information-required&gt;false&lt;/leaf-information-required&gt;
            &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;mldp-mp2mp-lsp&gt;
                &lt;opaque-type&gt;1&lt;/opaque-type&gt;
                &lt;opaque&gt;01:01:01:01:01:01:01&lt;/opaque&gt;
            &lt;/mldp-mp2mp-lsp&gt;
        &lt;/pmsi-tunnel&gt;
    &lt;/attributes&gt;
&lt;/evpn-route&gt;
</msg>
<arg>${data_xml}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:32.163502" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.164218" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          },
          "pmsi-tunnel": {
            "leaf-information-required": false,
            "mpls-label": 20024,
            "mldp-mp2mp-lsp": {
              "opaque-type": 1,
              "opaque": "01:01:01:01:01:01:01"
            }
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          }
        }
      }
    ]
  }
}</msg>
<arg>${data_json}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:32.163981" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.164716" level="INFO">ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${announce_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:32.164455" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:32.165155" level="INFO">ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
</msg>
<arg>${withdraw_hex}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:32.164916" elapsed="0.000284"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:27:32.165351" elapsed="0.002511"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:32.168025" elapsed="0.002180"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:32.175206" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:32.175378" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:32.175508" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:27:32.171182" elapsed="0.004850">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Log Many" owner="BuiltIn">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.176306" elapsed="0.000031"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:32.176635" elapsed="0.000054"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="FAIL" start="2026-06-06T03:27:32.170851" elapsed="0.005980">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig</status>
</kw>
<kw name="Loc_Rib_Presence">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:34.187472" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:34.187772" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '475'} 
 body={"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}} 
 </msg>
<msg time="2026-06-06T03:27:34.187958" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:34.178442" elapsed="0.009563"/>
</kw>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:27:34.188817" level="INFO">{
  "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
      {
        "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==",
        "path-id": 0,
        "route-distinguisher": "429496729:1",
        "es-route": {
          "orig-route-ip": "43.43.43.43",
          "arbitrary": {
            "arbitrary": "AAAAAAAAAAAA"
          }
        },
        "attributes": {
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          },
          "pmsi-tunnel": {
            "leaf-information-required": false,
            "mpls-label": 20024,
            "mldp-mp2mp-lsp": {
              "opaque-type": 1,
              "opaque": "01:01:01:01:01:01:01"
            }
          },
          "ipv4-next-hop": {
            "global": "199.20.166.41"
          }
        }
      }
    ]
  }
}</msg>
<msg time="2026-06-06T03:27:34.192339" level="INFO">{"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}</msg>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:27:34.188337" elapsed="0.004154"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:34.197481" level="INFO">${expected_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:34.196736" elapsed="0.000788"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:34.198446" level="INFO">${actual_normalized} = {
 "odl-bgp-evpn:evpn-routes": {
  "evpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "local-pref": {
      "pref": 100
     },
     "origin"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:34.197788" elapsed="0.000700"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:34.198751" elapsed="0.000530"/>
</kw>
<arg>${exp_content}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:34.192886" elapsed="0.006489"/>
</kw>
<arg>${data_json}</arg>
<doc>Verifies if loc-rib contains expected data</doc>
<status status="PASS" start="2026-06-06T03:27:34.177501" elapsed="0.021956"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Loc_Rib_Presence</arg>
<arg>${data_json}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:32.170383" elapsed="2.029144"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:34.199895" elapsed="0.002811"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:34.213163" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:34.213440" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:34.213717" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:34.203664" elapsed="0.010115"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:34.214180" elapsed="0.005948"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:34.225190" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:34.225713" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '623'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false},"odl-bgp-evpn:evpn-routes":{"evpn-route":[{"path-id":0,"route-key":"BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw==","es-route":{"orig-route-ip":"43.43.43.43","arbitrary":{"arbitrary":"AAAAAAAAAAAA"}},"attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"pmsi-tunnel":{"leaf-information-required":false,"mpls-label":20024,"mldp-mp2mp-lsp":{"opaque":"01:01:01:01:01:01:01","opaque-type":1}},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"429496729:1"}]}}]} 
 </msg>
<msg time="2026-06-06T03:27:34.225831" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:34.220383" elapsed="0.005475"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:34.229479" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:34.229034" elapsed="0.000487"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:34.230540" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:34.229782" elapsed="0.000801"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:27:34.231345" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "odl-bgp-evpn:evpn-routes": {
    "evpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       },
       "pmsi-tunnel": {
        "leaf-information-required": false,
        "mldp-mp2mp-lsp": {
         "opaque": "01:01:01:01:01:01:01",
         "opaque-type": 1
        },
        "mpls-label": 20024
       }
      },
      "es-route": {
       "arbitrary": {
        "arbitrary": "AAAAAAAAAAAA"
       },
       "orig-route-ip": "43.43.43.43"
      },
      "path-id": 0,
      "route-distinguisher": "429496729:1",
      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
     }
    ]
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:27:34.231812" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
+       "pmsi-tunnel": {
+        "leaf-information-required": false,
+        "mldp-mp2mp-lsp": {
+         "opaque": "01:01:01:01:01:01:01",
+         "opaque-type": 1
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:27:34.230848" elapsed="0.001078">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "opaque-type": 1
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:27:34.226116" elapsed="0.006056">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "opaque-type": 1
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:27:34.203357" elapsed="0.029040">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": false
    },
+   "odl-bgp-evpn:evpn-routes": {
+    "evpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       },
    [ Message content over the limit has been removed. ]
+         "opaque-type": 1
+        },
+        "mpls-label": 20024
+       }
+      },
+      "es-route": {
+       "arbitrary": {
+        "arbitrary": "AAAAAAAAAAAA"
+       },
+       "orig-route-ip": "43.43.43.43"
+      },
+      "path-id": 0,
+      "route-distinguisher": "429496729:1",
+      "route-key": "BBcAAhmZmZkAAQAAAAAAAAAAAAAgKysrKw=="
+     }
+    ]
+   },
    "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.242699" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.242905" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:36.243059" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:36.233887" elapsed="0.009211"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:36.243370" elapsed="0.004084"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.253246" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.253384" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:36.253522" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:36.247739" elapsed="0.005815"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:36.256928" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.256588" elapsed="0.000434"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:36.257483" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.257204" elapsed="0.000307"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:36.257687" elapsed="0.000338"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:36.253920" elapsed="0.004168"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.233057" elapsed="0.025087"/>
</kw>
<arg>4x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:34.202908" elapsed="2.055278"/>
</kw>
<kw name="Withdraw_Route_And_Verify" type="TEARDOWN">
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:27:36.258752" elapsed="0.002675"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_Test_Preconditions">
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.268784" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.268942" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family/odl-bgp-evpn:evpn-routes?content=config 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:36.269094" level="INFO">${resp} = &lt;Response [409]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_CONF_URL}?content=config</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:36.262661" elapsed="0.006499"/>
</kw>
<kw name="Should Contain" owner="BuiltIn">
<arg>${DELETED_STATUS_CODES}</arg>
<arg>${resp.status_code}</arg>
<doc>Fails if ``container`` does not contain ``item`` one or more times.</doc>
<status status="PASS" start="2026-06-06T03:27:36.269413" elapsed="0.003759"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.277901" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.278005" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=odl-bgp-evpn%3Al2vpn-address-family,odl-bgp-evpn%3Aevpn-subsequent-address-family?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '149'} 
 body={"bgp-rib:tables":[{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:27:36.278106" level="INFO">${resp} = &lt;Response [200]&gt;</msg>
<var>${resp}</var>
<arg>${CONFIG_SESSION}</arg>
<arg>url=${EVPN_FAMILY_LOC_RIB}</arg>
<arg>headers=${HEADERS}</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:36.273422" elapsed="0.004711"/>
</kw>
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:36.281311" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.280988" elapsed="0.000352"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:27:36.281785" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "odl-bgp-evpn:l2vpn-address-family",
   "attributes": {
    "uptodate": false
   },
   "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.281499" elapsed="0.000314"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:27:36.281973" elapsed="0.000326"/>
</kw>
<arg>${EMPTY_ROUTES}</arg>
<arg>${resp.content}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:27:36.278392" elapsed="0.003969"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.262332" elapsed="0.020084"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>Verify_Test_Preconditions</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:27:36.261629" elapsed="0.020825"/>
</kw>
<arg>${withdraw_hex}</arg>
<doc>Sends withdraw update message from exabgp and verifies route removal from odl's rib</doc>
<status status="PASS" start="2026-06-06T03:27:36.258383" elapsed="0.024126"/>
</kw>
<arg>pmsi_mldp_mp2mp_lsp</arg>
<status status="PASS" start="2026-06-06T03:27:32.129631" elapsed="4.152925"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:32.008128" elapsed="4.274556"/>
</test>
<test id="s1-s13-t76" name="Kill_Talking_BGP_Speaker" line="252">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:36.286783" elapsed="0.000319"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:36.286360" elapsed="0.000825"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.288694" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.288496" elapsed="0.000273"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.288464" elapsed="0.000340"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.295775" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.295665" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.295633" elapsed="0.000212"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.296868" 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-06-06T03:27:36.296462" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.297396" 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-06-06T03:27:36.297061" elapsed="0.000361"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:36.297468" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:27:36.297632" 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-06-06T03:27:36.296079" elapsed="0.001594"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:36.303507" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.303394" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.303374" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:36.304825" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.304715" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.304695" elapsed="0.000201"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:36.305374" 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-06-06T03:27:36.305046" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.305800" level="INFO">${current_connection_index} = 7</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-06-06T03:27:36.305566" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.340628" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:36.306357" elapsed="0.034386"/>
</kw>
<msg time="2026-06-06T03:27:36.340908" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:36.340954" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:36.306005" elapsed="0.034983"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.371475" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:27:36.341549" elapsed="0.030029"/>
</kw>
<msg time="2026-06-06T03:27:36.371757" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:36.371803" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "K "i "l "l "_ "T "a "l "k "i...</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-06-06T03:27:36.341164" elapsed="0.030674"/>
</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-06-06T03:27:36.372147" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.371916" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.371895" elapsed="0.000329"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.372686" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:27:36.372372" elapsed="0.000381"/>
</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-06-06T03:27:36.373042" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.372820" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.372801" elapsed="0.000363"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:36.373229" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:36.375870" elapsed="0.000145"/>
</kw>
<msg time="2026-06-06T03:27:36.376076" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:36.374732" elapsed="0.001478"/>
</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="NOT RUN" start="2026-06-06T03:27:36.376498" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.376863" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:36.374093" elapsed="0.003095"/>
</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-06-06T03:27:36.373525" elapsed="0.003757"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:36.304374" elapsed="0.073027"/>
</kw>
<msg time="2026-06-06T03:27:36.377495" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.377540" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "K "i "l "l "_ "T "a "l "k "i...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.303754" elapsed="0.073822"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:36.377781" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:36.377669" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.377634" elapsed="0.000232"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.378271" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.378611" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.378701" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:36.303047" elapsed="0.075765"/>
</kw>
<msg time="2026-06-06T03:27:36.378904" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.378948" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "K "i "l "l "_ "T "a "l "k "i...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:36.298056" elapsed="0.080928"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.379315" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.379060" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.379042" elapsed="0.000351"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:36.297909" elapsed="0.081507"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:36.297731" elapsed="0.081716"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:36.295163" elapsed="0.084339"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:36.288066" elapsed="0.091492"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.287421" elapsed="0.092182"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:36.283689" elapsed="0.095984"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.380884" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:36.380545" elapsed="0.000367"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:36.381070" elapsed="0.000436"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:27:36.380272" elapsed="0.001305"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.400502" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:36.382094" elapsed="0.018467"/>
</kw>
<msg time="2026-06-06T03:27:36.400713" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.400758" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.381756" elapsed="0.019028"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.401444" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:27:36.413702" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:36.413862" level="INFO">${output_log} = 2026-06-06 03:24:43,746 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:43,746 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:43,746 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:36.401298" elapsed="0.012604"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.414547" level="INFO">2026-06-06 03:24:43,746 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:43,746 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:43,746 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:24:43,747 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:24:43,747 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:24:43,748 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:24:43,750 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:24:43,750 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400010080010400190046400200b44700
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:24:43,751 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:24:43,752 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:24:43,752 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Length=53 (0x0035)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=24 (0x18)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400190046020641040000fbf0
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400190046020641040000fbf0'
2026-06-06 03:24:43,753 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400190046020641040000fbf0
2026-06-06 03:24:43,754 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:43,756 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:43,756 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:43,756 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:43,761 INFO BGP-Thread-1 (job): ... idle for 0.006s
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.006s
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): ... idle for 0.000s
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.006s
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:43,763 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:43,763 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:43,763 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:43,763 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:43,763 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:44,764 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:44,764 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.007s
2026-06-06 03:24:44,764 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:44,765 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:44,765 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:45,766 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:45,766 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.008s
2026-06-06 03:24:45,766 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:45,767 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:45,767 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.009s
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.010s
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:48,771 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.010s
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:49,773 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.012s
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:49] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:49] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:49,888 INFO BGP-Thread-1 (job): ... idle for 0.113s
2026-06-06 03:24:49,888 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.125s
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:49,888 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:49,889 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:49,889 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.126s
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.127s
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:51,966 INFO BGP-Thread-1 (job): ... idle for 0.074s
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.201s
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:52] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:52] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:52,968 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:52,968 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.202s
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:53,970 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:53,970 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.203s
2026-06-06 03:24:53,970 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:53,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:53,971 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:54] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.204s
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:54,973 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.206s
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:56,424 INFO BGP-Thread-1 (job): ... idle for 0.450s
2026-06-06 03:24:56,425 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.656s
2026-06-06 03:24:56,425 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:56,425 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:56,426 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:56,426 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:56,502 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:24:56,502 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.732s
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:56,503 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:56,503 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:56,503 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.733s
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:58,507 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:58,507 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.734s
2026-06-06 03:24:58,508 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:58,508 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:58,508 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:58] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:59,509 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:59,509 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.735s
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.736s
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:00,512 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:00,947 INFO BGP-Thread-1 (job): ... idle for 0.435s
2026-06-06 03:25:00,947 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.171s
2026-06-06 03:25:00,947 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:00,948 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:00,948 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:00,948 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.247s
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:01,025 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:01] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:01] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:01] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:02,026 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:02,026 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.248s
2026-06-06 03:25:02,026 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:02,027 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:02,027 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:02,027 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:03,028 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 19.249s
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:03] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:04,030 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:04,031 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.250s
2026-06-06 03:25:04,031 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:04,033 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:04,033 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:04,033 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.251s
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:05,035 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:05,511 INFO BGP-Thread-1 (job): ... idle for 0.476s
2026-06-06 03:25:05,511 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.727s
2026-06-06 03:25:05,512 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:05,512 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:05,512 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:05,513 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:05,598 INFO BGP-Thread-1 (job): ... idle for 0.085s
2026-06-06 03:25:05,598 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.812s
2026-06-06 03:25:05,598 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:05,599 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:05,599 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:05,599 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:06,601 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:06,601 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 22.813s
2026-06-06 03:25:06,601 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:06,602 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:06,602 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:06,602 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:07,603 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:07,603 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 23.814s
2026-06-06 03:25:07,604 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:07,604 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:07,604 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:07] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:08,605 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:08,605 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.816s
2026-06-06 03:25:08,605 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:08,606 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:08,606 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:08,606 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:09,607 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:09,607 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 25.817s
2026-06-06 03:25:09,608 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:09,608 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:09,608 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:10,063 INFO BGP-Thread-1 (job): ... idle for 0.455s
2026-06-06 03:25:10,063 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.272s
2026-06-06 03:25:10,063 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:10,063 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:10,063 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:10,064 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:10,064 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:10,064 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:10,143 INFO BGP-Thread-1 (job): ... idle for 0.079s
2026-06-06 03:25:10,143 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.350s
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:10,144 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:10,144 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:10,144 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:11,145 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:11,145 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 27.351s
2026-06-06 03:25:11,145 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:11,146 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:11,146 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:11,146 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 28.352s
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:12] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.353s
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:13,150 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.354s
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:14,602 INFO BGP-Thread-1 (job): ... idle for 0.450s
2026-06-06 03:25:14,602 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.805s
2026-06-06 03:25:14,602 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:14,602 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:14,602 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:14,602 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:14,603 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:14,603 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:14,603 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:14,603 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:14,603 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:14,603 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:14,677 INFO BGP-Thread-1 (job): ... idle for 0.074s
2026-06-06 03:25:14,677 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.879s
2026-06-06 03:25:14,677 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:14,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:14,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:14,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:15,679 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 31.880s
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 32.881s
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:16] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 33.882s
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 34.883s
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:19,199 INFO BGP-Thread-1 (job): ... idle for 0.512s
2026-06-06 03:25:19,199 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.395s
2026-06-06 03:25:19,199 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:19,200 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:19,200 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:19,200 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:19,200 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:19,267 INFO BGP-Thread-1 (job): ... idle for 0.067s
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.463s
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 36.464s
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 37.465s
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:21] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:22,274 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:22,274 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 38.466s
2026-06-06 03:25:22,274 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:22,275 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:22,275 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:22,275 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:23,276 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 39.467s
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:23,725 INFO BGP-Thread-1 (job): ... idle for 0.448s
2026-06-06 03:25:23,725 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 39.915s
2026-06-06 03:25:23,725 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:23,726 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:23,726 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:23,726 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:23,814 INFO BGP-Thread-1 (job): ... idle for 0.087s
2026-06-06 03:25:23,814 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.003s
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:23,815 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:23,815 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:23,815 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:24] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:24] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:24,816 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:24,816 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 41.004s
2026-06-06 03:25:24,816 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:24,817 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:24,817 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:24,817 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 42.005s
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:25,819 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 43.006s
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.007s
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:28,286 INFO BGP-Thread-1 (job): ... idle for 0.464s
2026-06-06 03:25:28,286 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.471s
2026-06-06 03:25:28,286 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:28,287 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:28,287 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:28,287 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:28,287 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:28,287 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:28,368 INFO BGP-Thread-1 (job): ... idle for 0.081s
2026-06-06 03:25:28,368 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.552s
2026-06-06 03:25:28,368 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:28,368 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:28,368 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:28,369 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:28,369 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:28,369 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:28,369 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:28,369 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:28,369 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:29,370 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 45.553s
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:30,372 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 46.554s
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:31,374 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:31,375 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 47.555s
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:32,377 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 48.556s
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:32,846 INFO BGP-Thread-1 (job): ... idle for 0.468s
2026-06-06 03:25:32,846 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.024s
2026-06-06 03:25:32,846 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:32,846 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:32,847 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:32,847 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:32,847 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:32,920 INFO BGP-Thread-1 (job): ... idle for 0.073s
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.097s
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:33] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:33] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 50.098s
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 51.100s
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:35] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:35,926 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 52.101s
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.102s
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:37,403 INFO BGP-Thread-1 (job): ... idle for 0.474s
2026-06-06 03:25:37,403 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.575s
2026-06-06 03:25:37,403 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:37,404 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:37,404 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:37,404 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:37,482 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:25:37,482 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.653s
2026-06-06 03:25:37,482 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:37,482 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:37,482 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:37,483 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:37,483 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:37,483 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:37,483 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:37,483 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:37,483 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:38,484 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:38,484 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 54.654s
2026-06-06 03:25:38,484 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:38,485 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:38,485 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:38,485 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:39,486 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:39,486 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 55.655s
2026-06-06 03:25:39,487 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:39,487 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:39,487 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:39] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 56.657s
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:40,489 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:40,489 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 57.657s
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:41] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:41,984 INFO BGP-Thread-1 (job): ... idle for 0.494s
2026-06-06 03:25:41,984 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 58.151s
2026-06-06 03:25:41,984 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:41,984 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:41,985 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:41,985 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:41,985 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): ... idle for 0.071s
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 58.223s
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:42,058 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 59.224s
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 60.225s
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:44] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 61.226s
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.227s
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:46,541 INFO BGP-Thread-1 (job): ... idle for 0.475s
2026-06-06 03:25:46,541 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.702s
2026-06-06 03:25:46,541 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:46,542 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:46,542 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:46,542 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:46,610 INFO BGP-Thread-1 (job): ... idle for 0.068s
2026-06-06 03:25:46,610 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.771s
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:46,611 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:46,611 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:46,611 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:47,612 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:47,613 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 63.772s
2026-06-06 03:25:47,613 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:47,614 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:47,615 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:47,615 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 64.773s
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 65.774s
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 66.775s
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:50,621 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:51,078 INFO BGP-Thread-1 (job): ... idle for 0.458s
2026-06-06 03:25:51,078 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.232s
2026-06-06 03:25:51,079 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:51,079 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:51,080 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:51,080 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:51,139 INFO BGP-Thread-1 (job): ... idle for 0.060s
2026-06-06 03:25:51,140 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.292s
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:51,141 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:51,141 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:51,141 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:52,142 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:52,142 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 68.293s
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:53,144 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 69.294s
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:54,146 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 70.295s
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:55,148 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.297s
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:55,575 INFO BGP-Thread-1 (job): ... idle for 0.426s
2026-06-06 03:25:55,575 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.722s
2026-06-06 03:25:55,575 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:55,575 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:55,576 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:55,576 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:55,576 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:55,645 INFO BGP-Thread-1 (job): ... idle for 0.068s
2026-06-06 03:25:55,645 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.791s
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:55,646 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:55,646 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:55,646 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 72.792s
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:56,648 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:57,649 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:57,649 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 73.793s
2026-06-06 03:25:57,662 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:57,662 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:57,662 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:58] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:58,663 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:58,663 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 74.794s
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:59,665 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:59,665 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 75.795s
2026-06-06 03:25:59,665 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:59,666 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:59,666 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.796s
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:00,668 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:00,710 INFO BGP-Thread-1 (job): ... idle for 0.043s
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.839s
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:00,794 INFO BGP-Thread-1 (job): ... idle for 0.083s
2026-06-06 03:26:00,794 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.922s
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:00,795 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:00,795 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:00,795 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:01] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:01] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:01,796 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 77.923s
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:02,799 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:02,799 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 78.924s
2026-06-06 03:26:02,799 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:02,800 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:02,800 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:03] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:03,801 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:03,804 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 79.925s
2026-06-06 03:26:03,804 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:03,804 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:03,805 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:03,805 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:04,806 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:04,806 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 80.926s
2026-06-06 03:26:04,806 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:04,807 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:04,807 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:05,279 INFO BGP-Thread-1 (job): ... idle for 0.473s
2026-06-06 03:26:05,280 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 81.399s
2026-06-06 03:26:05,280 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:05,281 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:05,281 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:05,281 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:05,359 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:26:05,359 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 81.477s
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:05,360 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:05,360 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:05,360 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:05,360 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 82.478s
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:06,362 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:06,362 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 83.479s
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:07] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 84.480s
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:09,366 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:09,367 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 85.481s
2026-06-06 03:26:09,369 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:09,370 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:09,370 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:09,851 INFO BGP-Thread-1 (job): ... idle for 0.481s
2026-06-06 03:26:09,851 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 85.962s
2026-06-06 03:26:09,851 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:09,852 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:09,852 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:09,852 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:09,917 INFO BGP-Thread-1 (job): ... idle for 0.065s
2026-06-06 03:26:09,917 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 86.027s
2026-06-06 03:26:09,917 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:09,917 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:09,917 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:09,918 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:09,918 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:09,918 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:09,918 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:09,918 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:09,918 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:10,919 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:10,919 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 87.028s
2026-06-06 03:26:10,919 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:10,920 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:10,920 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:10,920 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 88.029s
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:11,922 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:12] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:12,922 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:26:12,922 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 89.030s
2026-06-06 03:26:12,922 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:12,923 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:12,923 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:12,923 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:13,924 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:13,924 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.031s
2026-06-06 03:26:13,924 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:13,925 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:13,925 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:14,417 INFO BGP-Thread-1 (job): ... idle for 0.492s
2026-06-06 03:26:14,417 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.523s
2026-06-06 03:26:14,417 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:14,417 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:14,417 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:14,417 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:14,418 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:14,418 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:14,418 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:14,418 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:14,418 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:14,418 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:14,497 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:26:14,497 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.601s
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:14,497 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:14,498 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:14,498 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:15,499 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:15,499 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 91.603s
2026-06-06 03:26:15,499 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:15,500 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:15,500 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:15,500 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 92.604s
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:16] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:17,502 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:17,502 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 93.604s
2026-06-06 03:26:17,502 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:17,503 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:17,503 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:17,503 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:18,503 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 94.605s
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:18,965 INFO BGP-Thread-1 (job): ... idle for 0.461s
2026-06-06 03:26:18,965 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 95.066s
2026-06-06 03:26:18,965 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:18,965 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:18,965 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:18,965 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:18,966 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:18,966 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:18,966 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:18,966 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:18,966 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:18,966 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:19,050 INFO BGP-Thread-1 (job): ... idle for 0.084s
2026-06-06 03:26:19,050 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 95.149s
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:19,050 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:19,051 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:19,051 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 96.151s
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:20,053 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 97.152s
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:21,055 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:21] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 98.153s
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 99.154s
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:23,506 INFO BGP-Thread-1 (job): ... idle for 0.448s
2026-06-06 03:26:23,506 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 99.602s
2026-06-06 03:26:23,506 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:23,507 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:23,507 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:23,507 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:23,507 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:23,593 INFO BGP-Thread-1 (job): ... idle for 0.086s
2026-06-06 03:26:23,593 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 99.687s
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:23,594 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:23,594 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:23,594 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:23,594 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:23,594 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:24,595 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:24,595 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 100.689s
2026-06-06 03:26:24,595 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:24,596 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:24,596 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:24,596 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 101.690s
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 102.691s
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:27,600 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 103.692s
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:28,055 INFO BGP-Thread-1 (job): ... idle for 0.454s
2026-06-06 03:26:28,055 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 104.146s
2026-06-06 03:26:28,055 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:28,055 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:28,056 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:28,056 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:28,056 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:28,133 INFO BGP-Thread-1 (job): ... idle for 0.077s
2026-06-06 03:26:28,133 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 104.223s
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:28,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:28,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:28,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:29,135 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 105.224s
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:30,137 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 106.225s
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:31,139 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:31,142 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 107.226s
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:32,144 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:32,144 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 108.227s
2026-06-06 03:26:32,144 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:32,145 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:32,145 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:32,589 INFO BGP-Thread-1 (job): ... idle for 0.445s
2026-06-06 03:26:32,590 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 108.672s
2026-06-06 03:26:32,590 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:32,590 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:32,591 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:32,591 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:32,675 INFO BGP-Thread-1 (job): ... idle for 0.084s
2026-06-06 03:26:32,675 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 108.756s
2026-06-06 03:26:32,675 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:32,676 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:32,676 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:32,676 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 109.758s
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 110.759s
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:34,681 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 111.760s
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:35,683 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:35,683 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 112.761s
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:37,156 INFO BGP-Thread-1 (job): ... idle for 0.472s
2026-06-06 03:26:37,157 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 113.233s
2026-06-06 03:26:37,157 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:37,157 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:37,158 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:37,158 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): ... idle for 0.082s
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 113.315s
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:37,241 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 114.316s
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 115.318s
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:39] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:40,245 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 116.319s
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:41,247 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:41,247 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 117.320s
2026-06-06 03:26:41,247 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:41,248 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:41,248 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:41,752 INFO BGP-Thread-1 (job): ... idle for 0.505s
2026-06-06 03:26:41,752 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 117.824s
2026-06-06 03:26:41,752 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:41,753 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:41,753 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:41,753 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): ... idle for 0.082s
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 117.906s
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 118.907s
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 119.908s
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:44] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:44,841 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 120.910s
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:45,843 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 121.911s
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:46,324 INFO BGP-Thread-1 (job): ... idle for 0.480s
2026-06-06 03:26:46,324 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 122.391s
2026-06-06 03:26:46,324 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:46,324 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:46,325 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:46,325 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:46,325 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:46,402 INFO BGP-Thread-1 (job): ... idle for 0.077s
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 122.468s
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:47,404 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 123.469s
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 124.470s
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:49,408 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:49,408 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 125.471s
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 126.472s
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): ... idle for 0.482s
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 126.955s
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:50,975 INFO BGP-Thread-1 (job): ... idle for 0.082s
2026-06-06 03:26:50,976 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 127.037s
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:50,977 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:50,977 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:50,977 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:50,977 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:51,978 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:51,978 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 128.038s
2026-06-06 03:26:51,978 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:51,979 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:51,979 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:51,979 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:52,980 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:52,980 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 129.039s
2026-06-06 03:26:52,981 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:52,981 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:52,981 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:53,982 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:53,982 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 130.040s
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:54,984 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 131.041s
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:55,445 INFO BGP-Thread-1 (job): ... idle for 0.460s
2026-06-06 03:26:55,446 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 131.502s
2026-06-06 03:26:55,446 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:55,446 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:55,447 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:55,447 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:55,525 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:26:55,525 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 131.580s
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:55,526 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:55,526 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:55,526 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:56,527 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 132.581s
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:57,529 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:57,530 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 133.582s
2026-06-06 03:26:57,530 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:57,530 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:57,531 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:57] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:58,532 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:58,532 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 134.583s
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:59,536 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 135.584s
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:59] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:59] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:00,009 INFO BGP-Thread-1 (job): ... idle for 0.472s
2026-06-06 03:27:00,009 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 136.056s
2026-06-06 03:27:00,009 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:00,010 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:00,010 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:00,010 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:00,081 INFO BGP-Thread-1 (job): ... idle for 0.071s
2026-06-06 03:27:00,081 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 136.127s
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:00,082 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:00,082 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:00,082 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:00,082 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 137.128s
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 138.129s
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:02] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 139.130s
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:04,088 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:04,089 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 140.131s
2026-06-06 03:27:04,093 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:04,093 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:04,093 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:04,570 INFO BGP-Thread-1 (job): ... idle for 0.477s
2026-06-06 03:27:04,570 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 140.608s
2026-06-06 03:27:04,570 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:04,570 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005e02000000474001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005e' (94)
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:04,571 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:04,571 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:04,571 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:04,635 INFO BGP-Thread-1 (job): ... idle for 0.064s
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 140.672s
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005802000000414001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0058' (88)
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 141.674s
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 142.675s
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:06] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:07,641 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 143.676s
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 144.677s
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:08,644 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:09,148 INFO BGP-Thread-1 (job): ... idle for 0.504s
2026-06-06 03:27:09,148 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 145.181s
2026-06-06 03:27:09,148 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0066020000004f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0066' (102)
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:09,149 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:09,149 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:09,149 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:09,215 INFO BGP-Thread-1 (job): ... idle for 0.066s
2026-06-06 03:27:09,215 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 145.247s
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff006002000000494001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0060' (96)
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:09,216 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:09,216 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:09,216 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:09,216 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:10,217 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:10,217 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 146.248s
2026-06-06 03:27:10,217 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:10,218 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:10,218 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:10,218 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 147.249s
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:11,220 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:11] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:12,223 INFO BGP-Thread-1 (job): ... idle for 1.004s
2026-06-06 03:27:12,223 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 148.253s
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): ... idle for 1.003s
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 149.256s
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:13,228 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:13,675 INFO BGP-Thread-1 (job): ... idle for 0.447s
2026-06-06 03:27:13,675 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 149.703s
2026-06-06 03:27:13,675 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005a' (90)
2026-06-06 03:27:13,676 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:13,676 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:13,676 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:13,676 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:13,676 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:13,752 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:27:13,752 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 149.779s
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0054' (84)
2026-06-06 03:27:13,753 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:13,753 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:13,753 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:13,753 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:13,753 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 150.780s
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:15,757 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:15,757 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 151.782s
2026-06-06 03:27:15,757 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:15,758 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:15,758 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:15] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 152.784s
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 153.785s
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:18,228 INFO BGP-Thread-1 (job): ... idle for 0.466s
2026-06-06 03:27:18,228 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 154.251s
2026-06-06 03:27:18,229 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005a' (90)
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:18,229 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:18,229 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:18,230 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:18,298 INFO BGP-Thread-1 (job): ... idle for 0.068s
2026-06-06 03:27:18,298 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 154.319s
2026-06-06 03:27:18,298 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:18,298 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:18,298 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:18,299 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0054' (84)
2026-06-06 03:27:18,299 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:18,299 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:18,299 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:18,299 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:18,299 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:19,301 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:19,301 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 155.320s
2026-06-06 03:27:19,301 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:19,302 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:19,302 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:19,302 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:20,303 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 156.321s
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 157.323s
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:21,307 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 158.324s
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:22,309 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:22,758 INFO BGP-Thread-1 (job): ... idle for 0.449s
2026-06-06 03:27:22,758 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 158.774s
2026-06-06 03:27:22,758 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005a' (90)
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:22,759 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:22,759 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:22,759 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:22,759 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:22,835 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:27:22,835 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 158.850s
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0054' (84)
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:22,836 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:22,836 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:22,836 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 159.852s
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:23,839 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:23,839 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 160.853s
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:24,841 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:25,841 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 161.854s
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 162.856s
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:27,317 INFO BGP-Thread-1 (job): ... idle for 0.472s
2026-06-06 03:27:27,317 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 163.328s
2026-06-06 03:27:27,317 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:27,317 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03
2026-06-06 03:27:27,317 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0056' (86)
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:27,318 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:27,318 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:27,318 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:27,401 INFO BGP-Thread-1 (job): ... idle for 0.083s
2026-06-06 03:27:27,401 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 163.411s
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005002000000394001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:27,402 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:27,402 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:27,402 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 164.412s
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 165.414s
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:29] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:30,407 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 166.415s
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:31,409 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:31,410 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 167.416s
2026-06-06 03:27:31,411 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:31,411 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:31,411 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:31,890 INFO BGP-Thread-1 (job): ... idle for 0.479s
2026-06-06 03:27:31,890 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 167.895s
2026-06-06 03:27:31,890 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:31,890 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005c02000000454001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005c' (92)
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:31,891 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:31,891 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:31,891 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:31,967 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:27:31,967 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 167.971s
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0056' (86)
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:31,968 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:31,968 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:31,968 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:32,969 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 168.972s
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:33,971 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 169.973s
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:34,973 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:34,973 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 170.974s
2026-06-06 03:27:34,973 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:34,974 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:34,974 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:34,974 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:35,975 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:35,975 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 171.976s
2026-06-06 03:27:35,976 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:35,976 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:35,976 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:36] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.414155" elapsed="0.003640"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:27:36.400990" elapsed="0.016897"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:27:36.418163" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:27:36.417987" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.417957" elapsed="0.000331"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.418516" elapsed="0.000033"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.418794" elapsed="0.000031"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:27:36.379951" elapsed="0.038959"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.431755" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:27:36.465611" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:36.465875" level="INFO">${output_log} = 2026-06-06 03:24:43,746 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:43,746 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:43,746 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:36.431598" elapsed="0.034337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.466942" level="INFO">2026-06-06 03:24:43,746 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:24:43,746 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:24:43,746 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:24:43,747 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:24:43,747 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:24:43,748 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:24:43,750 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:24:43,750 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00410104fbf000b4c000020224022241040000fbf006000200010400010001010400010080010400190046400200b44700
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:24:43,751 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:24:43,751 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:24:43,752 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:24:43,752 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Length=53 (0x0035)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=24 (0x18)
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400190046020641040000fbf0
2026-06-06 03:24:43,752 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400190046020641040000fbf0'
2026-06-06 03:24:43,753 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400190046020641040000fbf0
2026-06-06 03:24:43,754 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:43,755 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:24:43,756 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:43,756 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:43,756 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:43,761 INFO BGP-Thread-1 (job): ... idle for 0.006s
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.006s
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): ... idle for 0.000s
2026-06-06 03:24:43,762 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.006s
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:43,762 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:24:43,763 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:43,763 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:43,763 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:43,763 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:43,763 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:44,764 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:44,764 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.007s
2026-06-06 03:24:44,764 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:44,765 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:44,765 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:45,766 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:45,766 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.008s
2026-06-06 03:24:45,766 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:45,767 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:45,767 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.009s
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:46,768 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.010s
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:47,770 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:48,771 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.010s
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:48,772 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:49,773 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.012s
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:49,774 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:49] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:49] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:49,888 INFO BGP-Thread-1 (job): ... idle for 0.113s
2026-06-06 03:24:49,888 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.125s
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:49,888 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:49,888 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:49,889 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:49,889 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.126s
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:50,890 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.127s
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:51,892 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:51,966 INFO BGP-Thread-1 (job): ... idle for 0.074s
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.201s
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:51,967 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:51,967 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:52] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:52] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:52,968 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:52,968 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.202s
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:52,969 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:53,970 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:53,970 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.203s
2026-06-06 03:24:53,970 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:53,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:53,971 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:54] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.204s
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:54,972 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:54,973 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.206s
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:55,974 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:56,424 INFO BGP-Thread-1 (job): ... idle for 0.450s
2026-06-06 03:24:56,425 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.656s
2026-06-06 03:24:56,425 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:56,425 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:56,425 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:56,426 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:56,426 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:56,502 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:24:56,502 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.732s
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:24:56,503 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:24:56,503 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:56,503 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:56,503 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:24:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.733s
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a62900041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:57,505 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:24:58,507 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:58,507 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.734s
2026-06-06 03:24:58,508 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:58,508 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:58,508 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:24:58] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:24:59,509 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:24:59,509 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.735s
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:24:59,510 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.736s
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:00,511 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:00,512 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:00,947 INFO BGP-Thread-1 (job): ... idle for 0.435s
2026-06-06 03:25:00,947 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.171s
2026-06-06 03:25:00,947 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c001946041700021999999900010501010101000007d000202b2b2b2b
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:00,947 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:00,948 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:00,948 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:00,948 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.247s
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:01,024 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:01,024 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:01,025 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:01] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:01] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:01] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:02,026 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:02,026 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.248s
2026-06-06 03:25:02,026 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:02,027 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:02,027 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:02,027 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:03,028 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 19.249s
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:03,029 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:03] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:04,030 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:04,031 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.250s
2026-06-06 03:25:04,031 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:04,033 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:04,033 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:04,033 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.251s
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:05,034 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:05,035 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:05,511 INFO BGP-Thread-1 (job): ... idle for 0.476s
2026-06-06 03:25:05,511 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.727s
2026-06-06 03:25:05,512 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000101f20cdd809ff7001600202b2b2b2b
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:05,512 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:05,512 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:05,512 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:05,513 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:05,598 INFO BGP-Thread-1 (job): ... idle for 0.085s
2026-06-06 03:25:05,598 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.812s
2026-06-06 03:25:05,598 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:05,599 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:05,599 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:05,599 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:05,599 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:06,601 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:06,601 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 22.813s
2026-06-06 03:25:06,601 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:06,602 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:06,602 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:06,602 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:07,603 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:07,603 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 23.814s
2026-06-06 03:25:07,604 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:07,604 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:07,604 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:07] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:08,605 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:08,605 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.816s
2026-06-06 03:25:08,605 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:08,606 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:08,606 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:08,606 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:09,607 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:09,607 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 25.817s
2026-06-06 03:25:09,608 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:09,608 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:09,608 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:10,063 INFO BGP-Thread-1 (job): ... idle for 0.455s
2026-06-06 03:25:10,063 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.272s
2026-06-06 03:25:10,063 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000102f20cdd809ff7001400202b2b2b2b
2026-06-06 03:25:10,063 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:10,063 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:10,064 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:10,064 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:10,064 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:10,064 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:10,143 INFO BGP-Thread-1 (job): ... idle for 0.079s
2026-06-06 03:25:10,143 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.350s
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:10,143 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:10,144 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:10,144 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:10,144 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:11,145 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:11,145 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 27.351s
2026-06-06 03:25:11,145 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a629000417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:11,146 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:11,146 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:11,146 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 28.352s
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:12,147 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:12] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.353s
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:13,149 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:13,150 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.354s
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:14,151 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:14,602 INFO BGP-Thread-1 (job): ... idle for 0.450s
2026-06-06 03:25:14,602 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.805s
2026-06-06 03:25:14,602 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c0019460417000219999999000103f20cdd809ff70007d0202b2b2b2b
2026-06-06 03:25:14,602 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:14,602 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:14,602 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:14,603 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:25:14,603 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:14,603 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:14,603 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:14,603 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:14,603 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:14,677 INFO BGP-Thread-1 (job): ... idle for 0.074s
2026-06-06 03:25:14,677 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.879s
2026-06-06 03:25:14,677 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:14,678 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:14,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:14,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:14,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:15,679 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 31.880s
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a02000000334001010040020040050400000064800e2200194604c714a6290004170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:15,680 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 32.881s
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:16,682 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:16] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 33.882s
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:17,684 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 34.883s
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:18,686 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:19,199 INFO BGP-Thread-1 (job): ... idle for 0.512s
2026-06-06 03:25:19,199 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.395s
2026-06-06 03:25:19,199 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800f1c00194604170002199999990001042b2b2b2b000007d000202b2b2b2b
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:19,199 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:19,200 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:19,200 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:19,200 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:19,200 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:19,267 INFO BGP-Thread-1 (job): ... idle for 0.067s
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.463s
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:19,268 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:19,268 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 36.464s
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:20,270 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 37.465s
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:21,272 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:21] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:22,274 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:22,274 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 38.466s
2026-06-06 03:25:22,274 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:22,275 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:22,275 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:22,275 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:23,276 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 39.467s
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:23,277 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:23,725 INFO BGP-Thread-1 (job): ... idle for 0.448s
2026-06-06 03:25:23,725 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 39.915s
2026-06-06 03:25:23,725 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001000000000000000000000000000a05dc10
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:23,726 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:23,726 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:23,726 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:23,726 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:23,814 INFO BGP-Thread-1 (job): ... idle for 0.087s
2026-06-06 03:25:23,814 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.003s
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:23,814 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:23,815 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:23,815 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:23,815 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:24] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:24] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:24,816 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:24,816 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 41.004s
2026-06-06 03:25:24,816 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a62900011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:24,817 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:24,817 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:24,817 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 42.005s
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:25,818 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:25,819 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 43.006s
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:26,820 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.007s
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:27,822 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:28,286 INFO BGP-Thread-1 (job): ... idle for 0.464s
2026-06-06 03:25:28,286 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.471s
2026-06-06 03:25:28,286 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e001946011900021999999900010501010101000007d0000000000a05dc10
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:28,286 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:28,287 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:28,287 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:28,287 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:28,287 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:28,287 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:28,368 INFO BGP-Thread-1 (job): ... idle for 0.081s
2026-06-06 03:25:28,368 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.552s
2026-06-06 03:25:28,368 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:28,368 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:28,368 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:28,369 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:28,369 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:28,369 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:28,369 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:28,369 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:28,369 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:29,370 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 45.553s
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:29,371 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:30,372 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 46.554s
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:30,373 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:31,374 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:31,375 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 47.555s
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:31,376 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:32,377 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 48.556s
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:32,378 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:32,846 INFO BGP-Thread-1 (job): ... idle for 0.468s
2026-06-06 03:25:32,846 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.024s
2026-06-06 03:25:32,846 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10
2026-06-06 03:25:32,846 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:32,847 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:32,847 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:32,847 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:32,847 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:32,920 INFO BGP-Thread-1 (job): ... idle for 0.073s
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.097s
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:32,921 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:32,921 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:33] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:33] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 50.098s
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:33,923 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 51.100s
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:34,925 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:35] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:35,926 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 52.101s
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:35,927 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.102s
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:36,929 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:37,403 INFO BGP-Thread-1 (job): ... idle for 0.474s
2026-06-06 03:25:37,403 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.575s
2026-06-06 03:25:37,403 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008030d000000000000
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:37,404 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:37,404 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:37,404 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:37,404 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:37,482 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:25:37,482 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.653s
2026-06-06 03:25:37,482 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:37,482 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:37,482 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:37,483 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:37,483 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:37,483 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:37,483 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:37,483 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:37,483 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:38,484 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:38,484 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 54.654s
2026-06-06 03:25:38,484 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:38,485 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:38,485 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:38,485 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:39,486 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:39,486 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 55.655s
2026-06-06 03:25:39,487 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:39,487 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:39,487 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:39] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 56.657s
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:40,488 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:40,489 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:40,489 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 57.657s
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:41,490 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:41] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:41,984 INFO BGP-Thread-1 (job): ... idle for 0.494s
2026-06-06 03:25:41,984 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 58.151s
2026-06-06 03:25:41,984 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c01008060101000005dc10
2026-06-06 03:25:41,984 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:41,985 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:41,985 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:41,985 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:41,985 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): ... idle for 0.071s
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 58.223s
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:42,057 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:42,057 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:42,058 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 59.224s
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:43,059 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 60.225s
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:44,061 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:44] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 61.226s
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:45,063 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.227s
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:46,065 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:46,541 INFO BGP-Thread-1 (job): ... idle for 0.475s
2026-06-06 03:25:46,541 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.702s
2026-06-06 03:25:46,541 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010080602f20cdd809ff8
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:46,541 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:46,542 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:46,542 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:46,542 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:46,610 INFO BGP-Thread-1 (job): ... idle for 0.068s
2026-06-06 03:25:46,610 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.771s
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:46,611 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:46,611 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:46,611 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:46,611 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:47,612 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:47,613 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 63.772s
2026-06-06 03:25:47,613 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:47,614 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:47,615 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:47,615 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 64.773s
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:48,616 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 65.774s
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:49,618 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 66.775s
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:50,620 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:50,621 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:51,078 INFO BGP-Thread-1 (job): ... idle for 0.458s
2026-06-06 03:25:51,078 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.232s
2026-06-06 03:25:51,079 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c010084604000700c80000
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:51,079 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:51,079 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:51,080 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:51,080 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:51,139 INFO BGP-Thread-1 (job): ... idle for 0.060s
2026-06-06 03:25:51,140 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.292s
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:51,140 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:51,141 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:51,141 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:51,141 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:52,142 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:52,142 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 68.293s
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005702000000404001010040020040050400000064800e2400194604c714a629000119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:52,143 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:53,144 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 69.294s
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:53,145 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:54,146 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 70.295s
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:54,147 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:55,148 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.297s
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:55,149 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:55,575 INFO BGP-Thread-1 (job): ... idle for 0.426s
2026-06-06 03:25:55,575 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.722s
2026-06-06 03:25:55,575 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a4001010040020040050400000064800f1e0019460119000219999999000101f20cdd809ff70016000000000a05dc10c0100806000100000000c8
2026-06-06 03:25:55,575 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:55,576 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:55,576 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:55,576 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:55,576 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:55,645 INFO BGP-Thread-1 (job): ... idle for 0.068s
2026-06-06 03:25:55,645 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.791s
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:25:55,645 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:25:55,646 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:55,646 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:55,646 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:25:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 72.792s
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:56,647 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:56,648 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:57,649 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:57,649 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 73.793s
2026-06-06 03:25:57,662 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:57,662 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:57,662 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:25:58] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:25:58,663 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:58,663 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 74.794s
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:58,664 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:25:59,665 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:25:59,665 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 75.795s
2026-06-06 03:25:59,665 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:25:59,666 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:25:59,666 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.796s
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000102f20cdd809ff70014000000000a05dc10
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:00,667 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:00,668 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:00,710 INFO BGP-Thread-1 (job): ... idle for 0.043s
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.839s
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:00,711 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:00,711 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:00,794 INFO BGP-Thread-1 (job): ... idle for 0.083s
2026-06-06 03:26:00,794 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.922s
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:00,795 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:00,795 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:00,795 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:00,795 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:01] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:01] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:01,796 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 77.923s
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a629000119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:01,797 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:02,799 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:02,799 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 78.924s
2026-06-06 03:26:02,799 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:02,800 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:02,800 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:03] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:03,801 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:03,804 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 79.925s
2026-06-06 03:26:03,804 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:03,804 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:03,805 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:03,805 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:04,806 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:04,806 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 80.926s
2026-06-06 03:26:04,806 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:04,807 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:04,807 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:05,279 INFO BGP-Thread-1 (job): ... idle for 0.473s
2026-06-06 03:26:05,280 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 81.399s
2026-06-06 03:26:05,280 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e0019460119000219999999000103f20cdd809ff70007d00000000a05dc10
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:05,280 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:05,281 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:05,281 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:05,281 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:05,359 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:26:05,359 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 81.477s
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:26:05,359 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:05,360 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:05,360 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:05,360 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:05,360 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 82.478s
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c02000000354001010040020040050400000064800e2400194604c714a6290001190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:06,361 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:06,362 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:06,362 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 83.479s
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:07,363 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:07] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 84.480s
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:08,365 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:09,366 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:09,367 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 85.481s
2026-06-06 03:26:09,369 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:09,370 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:09,370 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:09,851 INFO BGP-Thread-1 (job): ... idle for 0.481s
2026-06-06 03:26:09,851 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 85.962s
2026-06-06 03:26:09,851 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f4001010040020040050400000064800f1e00194601190002199999990001042b2b2b2b000007d0000000000a05dc10
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:09,851 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:09,852 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:09,852 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:09,852 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:09,917 INFO BGP-Thread-1 (job): ... idle for 0.065s
2026-06-06 03:26:09,917 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 86.027s
2026-06-06 03:26:09,917 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:09,917 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:09,917 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:09,918 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:09,918 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:09,918 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:09,918 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:09,918 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:09,918 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:10] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:10] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:10,919 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:10,919 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 87.028s
2026-06-06 03:26:10,919 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:10,920 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:10,920 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:10,920 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 88.029s
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:11,921 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:11,922 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:12] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:12,922 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:26:12,922 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 89.030s
2026-06-06 03:26:12,922 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:12,923 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:12,923 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:12,923 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:13,924 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:13,924 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.031s
2026-06-06 03:26:13,924 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:13,925 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:13,925 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:14,417 INFO BGP-Thread-1 (job): ... idle for 0.492s
2026-06-06 03:26:14,417 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.523s
2026-06-06 03:26:14,417 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:14,417 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:14,417 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:14,417 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:14,418 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:14,418 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:14,418 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:14,418 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:14,418 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:14,418 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:14,497 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:26:14,497 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 90.601s
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:14,497 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:14,497 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:14,498 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:14,498 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:15,499 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:15,499 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 91.603s
2026-06-06 03:26:15,499 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:15,500 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:15,500 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:15,500 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 92.604s
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:16,501 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:16] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:17,502 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:17,502 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 93.604s
2026-06-06 03:26:17,502 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:17,503 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:17,503 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:17,503 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:18,503 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 94.605s
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:18,504 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:18,965 INFO BGP-Thread-1 (job): ... idle for 0.461s
2026-06-06 03:26:18,965 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 95.066s
2026-06-06 03:26:18,965 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:18,965 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:18,965 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:18,965 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:18,966 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:18,966 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:18,966 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:18,966 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:18,966 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:18,966 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:19,050 INFO BGP-Thread-1 (job): ... idle for 0.084s
2026-06-06 03:26:19,050 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 95.149s
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:19,050 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:19,050 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:19,051 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:19,051 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 96.151s
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:20,052 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:20,053 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 97.152s
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:21,054 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:21,055 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:21] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 98.153s
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:22,056 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 99.154s
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:23,058 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:23,506 INFO BGP-Thread-1 (job): ... idle for 0.448s
2026-06-06 03:26:23,506 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 99.602s
2026-06-06 03:26:23,506 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:23,506 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:23,507 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:23,507 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:23,507 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:23,507 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:23,593 INFO BGP-Thread-1 (job): ... idle for 0.086s
2026-06-06 03:26:23,593 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 99.687s
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:23,593 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:23,594 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:23,594 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:23,594 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:23,594 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:23,594 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:24,595 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:24,595 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 100.689s
2026-06-06 03:26:24,595 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:24,596 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:24,596 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:24,596 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 101.690s
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:25,597 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 102.691s
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:26,599 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:27,600 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 103.692s
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:27,601 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:28,055 INFO BGP-Thread-1 (job): ... idle for 0.454s
2026-06-06 03:26:28,055 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 104.146s
2026-06-06 03:26:28,055 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:28,055 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:28,056 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:28,056 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:28,056 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:28,056 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:28,133 INFO BGP-Thread-1 (job): ... idle for 0.077s
2026-06-06 03:26:28,133 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 104.223s
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:28,134 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:28,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:28,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:28,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:29,135 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 105.224s
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:29,136 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:30,137 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 106.225s
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:30,138 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:31,139 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:31,142 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 107.226s
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:31,143 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:32,144 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:32,144 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 108.227s
2026-06-06 03:26:32,144 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:32,145 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:32,145 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:32,589 INFO BGP-Thread-1 (job): ... idle for 0.445s
2026-06-06 03:26:32,590 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 108.672s
2026-06-06 03:26:32,590 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0044' (68)
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:32,590 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:32,590 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:32,591 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:32,591 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:32,675 INFO BGP-Thread-1 (job): ... idle for 0.084s
2026-06-06 03:26:32,675 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 108.756s
2026-06-06 03:26:32,675 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:32,676 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:32,676 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:32,676 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:32,676 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 109.758s
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0044020000002d4001010040020040050400000064800e1c00194604c714a62900031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:33,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 110.759s
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:34,680 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:34,681 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 111.760s
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:35,682 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:35,683 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:35,683 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 112.761s
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:36,684 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:37,156 INFO BGP-Thread-1 (job): ... idle for 0.472s
2026-06-06 03:26:37,157 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 113.233s
2026-06-06 03:26:37,157 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800f16001946031100021999999900010000000a202b2b2b2b
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:37,157 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:37,157 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:37,158 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:37,158 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): ... idle for 0.082s
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 113.315s
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:37,240 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:37,240 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:37,241 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 114.316s
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:38,242 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 115.318s
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:39,244 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:39] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:40,245 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 116.319s
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:40,246 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:41,247 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:41,247 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 117.320s
2026-06-06 03:26:41,247 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:41,248 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:41,248 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:41,752 INFO BGP-Thread-1 (job): ... idle for 0.505s
2026-06-06 03:26:41,752 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 117.824s
2026-06-06 03:26:41,752 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001000000000000000000000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:41,753 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:41,753 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:41,753 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:41,753 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): ... idle for 0.082s
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 117.906s
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:41,836 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:41,836 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:41] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 118.907s
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a62900022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:42,838 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 119.908s
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:43,840 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:44] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:44,841 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 120.910s
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:44,842 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:45,843 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 121.911s
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:45,844 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:46,324 INFO BGP-Thread-1 (job): ... idle for 0.480s
2026-06-06 03:26:46,324 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 122.391s
2026-06-06 03:26:46,324 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d001946022800021999999900010501010101000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:46,324 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:46,325 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:46,325 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:46,325 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:46,325 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:46,402 INFO BGP-Thread-1 (job): ... idle for 0.077s
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 122.468s
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:46,403 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:46,403 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:47,404 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 123.469s
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:47,405 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 124.470s
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:48,407 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:49,408 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:49,408 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 125.471s
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:49,409 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 126.472s
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:50,410 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): ... idle for 0.482s
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 126.955s
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000101f20cdd809ff70016000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:50,893 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:50,893 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:50,975 INFO BGP-Thread-1 (job): ... idle for 0.082s
2026-06-06 03:26:50,976 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 127.037s
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:50,976 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:50,977 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:50,977 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:50,977 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:50,977 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:50] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:51] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:51,978 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:51,978 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 128.038s
2026-06-06 03:26:51,978 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:51,979 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:51,979 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:51,979 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:52,980 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:52,980 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 129.039s
2026-06-06 03:26:52,981 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:52,981 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:52,981 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:53,982 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:53,982 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 130.040s
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:53,983 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:54,984 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 131.041s
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:54,985 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:55,445 INFO BGP-Thread-1 (job): ... idle for 0.460s
2026-06-06 03:26:55,446 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 131.502s
2026-06-06 03:26:55,446 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000102f20cdd809ff70014000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:55,446 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:55,446 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:55,447 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:55,447 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:55,525 INFO BGP-Thread-1 (job): ... idle for 0.078s
2026-06-06 03:26:55,525 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 131.580s
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:26:55,526 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:26:55,526 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:55,526 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:55,526 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:56,527 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 132.581s
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a629000228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:56,528 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:57,529 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:57,530 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 133.582s
2026-06-06 03:26:57,530 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:57,530 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:57,531 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:57] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:26:58,532 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:58,532 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 134.583s
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:58,535 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:26:59,536 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 135.584s
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:26:59,537 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:26:59] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:26:59] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:00,009 INFO BGP-Thread-1 (job): ... idle for 0.472s
2026-06-06 03:27:00,009 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 136.056s
2026-06-06 03:27:00,009 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d0019460228000219999999000103f20cdd809ff70007d00000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005b' (91)
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:00,009 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:00,010 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:00,010 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:00,010 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:00,081 INFO BGP-Thread-1 (job): ... idle for 0.071s
2026-06-06 03:27:00,081 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 136.127s
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0055' (85)
2026-06-06 03:27:00,081 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:00,082 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:00,082 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:00,082 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:00,082 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 137.128s
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005b02000000444001010040020040050400000064800e3300194604c714a6290002280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:01,083 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 138.129s
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:02,085 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:02] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 139.130s
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:03,087 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:04,088 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:04,089 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 140.131s
2026-06-06 03:27:04,093 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:04,093 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:04,093 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:04,570 INFO BGP-Thread-1 (job): ... idle for 0.477s
2026-06-06 03:27:04,570 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 140.608s
2026-06-06 03:27:04,570 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0055020000003e4001010040020040050400000064800f2d00194602280002199999990001042b2b2b2b000007d0000000000a30f20cdd809ff7202b2b2b2b05dc2005dc30
2026-06-06 03:27:04,570 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005e02000000474001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005e' (94)
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:04,571 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:04,571 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:04,571 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:04,571 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:04,635 INFO BGP-Thread-1 (job): ... idle for 0.064s
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 140.672s
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005802000000414001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01611010104e380423a35c700002b670a0a0a0a
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0058' (88)
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:04,636 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:04,636 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:04] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 141.674s
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005e0200000047c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:05,638 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 142.675s
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:06,640 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:06] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:07,641 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 143.676s
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:07,642 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 144.677s
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:08,643 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:08,644 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:09,148 INFO BGP-Thread-1 (job): ... idle for 0.504s
2026-06-06 03:27:09,148 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 145.181s
2026-06-06 03:27:09,148 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00580200000041c01611010104e380423a35c700002b670a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0066020000004f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0066' (102)
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:09,148 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:09,149 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:09,149 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:09,149 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:09,215 INFO BGP-Thread-1 (job): ... idle for 0.066s
2026-06-06 03:27:09,215 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 145.247s
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff006002000000494001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01619010204e380060001040a0a0a0a000a01000701010101010101
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0060' (96)
2026-06-06 03:27:09,215 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:09,216 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:09,216 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:09,216 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:09,216 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:10,217 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:10,217 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 146.248s
2026-06-06 03:27:10,217 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0066020000004fc01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:10,218 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:10,218 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:10,218 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 147.249s
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:11,219 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:11,220 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:11] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:12,223 INFO BGP-Thread-1 (job): ... idle for 1.004s
2026-06-06 03:27:12,223 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 148.253s
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:12,224 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): ... idle for 1.003s
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 149.256s
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:13,227 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:13,228 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:13,675 INFO BGP-Thread-1 (job): ... idle for 0.447s
2026-06-06 03:27:13,675 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 149.703s
2026-06-06 03:27:13,675 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00600200000049c01619010204e380060001040a0a0a0a000a010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:13,675 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005a' (90)
2026-06-06 03:27:13,676 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:13,676 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:13,676 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:13,676 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:13,676 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:13,752 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:27:13,752 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 149.779s
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010304e3800b0c0d0e0a0a0a0a
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:13,752 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0054' (84)
2026-06-06 03:27:13,753 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:13,753 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:13,753 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:13,753 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:13,753 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 150.780s
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005a0200000043c0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:14,755 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:15,757 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:15,757 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 151.782s
2026-06-06 03:27:15,757 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:15,758 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:15,758 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:15] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 152.784s
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:16,760 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 153.785s
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:17,762 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:18,228 INFO BGP-Thread-1 (job): ... idle for 0.466s
2026-06-06 03:27:18,228 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 154.251s
2026-06-06 03:27:18,229 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010304e3800b0c0d0e0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005a' (90)
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:18,229 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:18,229 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:18,229 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:18,230 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:18,298 INFO BGP-Thread-1 (job): ... idle for 0.068s
2026-06-06 03:27:18,298 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 154.319s
2026-06-06 03:27:18,298 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010404e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:18,298 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:18,298 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:18,299 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0054' (84)
2026-06-06 03:27:18,299 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:18,299 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:18,299 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:18,299 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:18,299 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:19,301 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:19,301 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 155.320s
2026-06-06 03:27:19,301 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005a0200000043c0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:19,302 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:19,302 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:19,302 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:20,303 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 156.321s
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:20,304 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 157.323s
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:21,306 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:21,307 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 158.324s
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:22,308 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:22,309 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:22,758 INFO BGP-Thread-1 (job): ... idle for 0.449s
2026-06-06 03:27:22,758 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 158.774s
2026-06-06 03:27:22,758 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010404e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005a02000000434001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005a' (90)
2026-06-06 03:27:22,758 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:22,759 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:22,759 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:22,759 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:22,759 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:22,835 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:27:22,835 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 158.850s
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0054020000003d4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160d010504e3802b2b2b2b0a0a0a0a
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0054' (84)
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:22,836 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:22,836 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:22,836 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:22,836 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:22] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:23] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 159.852s
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005a0200000043c0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:23,838 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:23,839 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:23,839 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 160.853s
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:24,840 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:24,841 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:25,841 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 161.854s
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:25,842 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 162.856s
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:26,844 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:27,317 INFO BGP-Thread-1 (job): ... idle for 0.472s
2026-06-06 03:27:27,317 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 163.328s
2026-06-06 03:27:27,317 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0054020000003dc0160d010504e3802b2b2b2b0a0a0a0a4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:27,317 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03
2026-06-06 03:27:27,317 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0056' (86)
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:27,318 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:27,318 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:27,318 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:27,318 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:27,401 INFO BGP-Thread-1 (job): ... idle for 0.083s
2026-06-06 03:27:27,401 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 163.411s
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005002000000394001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc01609000604e380ac0c7b03
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:27,402 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:27,402 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:27,402 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:27,402 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 164.412s
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0056020000003fc01609000604e380ac0c7b034001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:28,404 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 165.414s
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:29,406 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:29] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:30,407 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 166.415s
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:30,408 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:31,409 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:31,410 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 167.416s
2026-06-06 03:27:31,411 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:31,411 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:31,411 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:31,890 INFO BGP-Thread-1 (job): ... idle for 0.479s
2026-06-06 03:27:31,890 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 167.895s
2026-06-06 03:27:31,890 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039c01609000604e380ac0c7b034001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:31,890 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005c02000000454001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'005c' (92)
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:31,891 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:31,891 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:31,891 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:31,891 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:31,967 INFO BGP-Thread-1 (job): ... idle for 0.076s
2026-06-06 03:27:31,967 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 167.971s
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0056020000003f4001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2bc0160f000704e38001000701010101010101
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0056' (86)
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Evpn True
2026-06-06 03:27:31,968 DEBUG BGP-Thread-1 (job): Skipping update decoding due to evpn data expected
2026-06-06 03:27:31,968 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:31,968 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:31,968 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:27:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:32,969 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 168.972s
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005c0200000045c0160f000704e380010007010101010101014001010040020040050400000064800e2200194604c714a629000417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:32,970 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:33,971 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 169.973s
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:33,972 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:27:34,973 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:34,973 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 170.974s
2026-06-06 03:27:34,973 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0056020000003fc0160f000704e380010007010101010101014001010040020040050400000064800f1c0019460417000219999999000100000000000000000000202b2b2b2b
2026-06-06 03:27:34,974 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:34,974 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:34,974 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:27:35,975 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:27:35,975 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 171.976s
2026-06-06 03:27:35,976 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:27:35,976 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:27:35,976 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:27:36] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.466325" elapsed="0.004917"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:36.472792" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/evpn_play.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/evpn_play.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:27:36.471697" elapsed="0.001224"/>
</kw>
<arg>play.py.out</arg>
<arg>evpn_play.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:36.431260" elapsed="0.041799"/>
</kw>
<doc>Abort the Python speaker</doc>
<status status="PASS" start="2026-06-06T03:27:36.283123" elapsed="0.190241"/>
</test>
<test id="s1-s13-t77" name="Delete_Bgp_Peer_Configuration" line="258">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:36.477291" elapsed="0.000216"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:36.477006" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.478596" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.478478" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.478458" elapsed="0.000226"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.483913" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.483805" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.483786" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.485008" 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-06-06T03:27:36.484606" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.485536" 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-06-06T03:27:36.485202" elapsed="0.000360"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:36.485607" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:27:36.485784" 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-06-06T03:27:36.484218" elapsed="0.001592"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:36.491367" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.491258" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.491239" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:36.492605" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.492497" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.492478" elapsed="0.000220"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:36.493150" 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-06-06T03:27:36.492849" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.493590" level="INFO">${current_connection_index} = 7</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-06-06T03:27:36.493372" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.525450" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:36.494143" elapsed="0.031434"/>
</kw>
<msg time="2026-06-06T03:27:36.525773" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:36.525821" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:36.493798" elapsed="0.032059"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.557178" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:27:36.526412" elapsed="0.030869"/>
</kw>
<msg time="2026-06-06T03:27:36.557463" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:36.557509" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "l "e "t "e "_ "B "g "p...</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-06-06T03:27:36.526053" elapsed="0.031491"/>
</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-06-06T03:27:36.557975" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.557627" elapsed="0.000406"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.557604" elapsed="0.000455"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.558508" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:27:36.558207" elapsed="0.000370"/>
</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-06-06T03:27:36.558887" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.558659" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.558625" elapsed="0.000339"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:36.558999" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:36.561602" elapsed="0.000167"/>
</kw>
<msg time="2026-06-06T03:27:36.561831" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:36.560508" elapsed="0.001456"/>
</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="NOT RUN" start="2026-06-06T03:27:36.562242" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.562586" elapsed="0.000089"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:36.559867" elapsed="0.002921"/>
</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-06-06T03:27:36.559298" elapsed="0.003556"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:36.492195" elapsed="0.070757"/>
</kw>
<msg time="2026-06-06T03:27:36.563046" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.563090" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "l "e "t "e "_ "B "g "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.491591" elapsed="0.071537"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:36.563511" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:27:36.563205" elapsed="0.000378"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.563185" elapsed="0.000424"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.564044" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.564389" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.564462" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:36.490921" elapsed="0.073650"/>
</kw>
<msg time="2026-06-06T03:27:36.564681" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.564727" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "l "e "t "e "_ "B "g "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:36.486187" elapsed="0.078576"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.565096" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.564839" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.564822" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:36.486041" elapsed="0.079157"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:36.485866" elapsed="0.079362"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:36.483424" elapsed="0.081858"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:36.478185" elapsed="0.087183"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.477734" elapsed="0.087682"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:36.474801" elapsed="0.090670"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.566176" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.565709" elapsed="0.000496"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.609710" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:36.609285" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:36.610521" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:36.610254" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:36.610711" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:36.609914" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.611294" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:36.610908" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:36.611793" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:36.611963" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:36.611637" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.612401" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.612152" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.613449" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.613163" elapsed="0.000331"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.613944" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.613675" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.614635" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.614337" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:36.615615" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.615189" elapsed="0.000467"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:36.615710" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:27:36.615866" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:36.614869" elapsed="0.001021"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.616061" elapsed="0.000249"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:27:36.614197" elapsed="0.002155"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.616918" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.616601" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:36.617703" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.617471" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:36.617782" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:36.617932" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:36.617134" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.618116" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:27:36.616464" elapsed="0.001915"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:27:36.614023" elapsed="0.004443"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:27:36.618511" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:36.618687" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:27:36.612836" elapsed="0.005878"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.612518" elapsed="0.006228"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.618924" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.618771" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.612497" elapsed="0.006503"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.619757" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:36.619148" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:36.619834" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:36.608660" elapsed="0.011296"/>
</kw>
<msg time="2026-06-06T03:27:36.620011" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:36.595708" elapsed="0.024350"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.632699" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.648599" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.662426" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.662634" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.662837" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.663216" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.663065" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:36.663050" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.663438" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.663607" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.663790" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:36.663018" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.662914" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.664088" elapsed="0.000029"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.664178" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:27:36.664332" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:36.591281" elapsed="0.073086"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.665945" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.665564" elapsed="0.000450"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.677518" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.677585" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.677759" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:36.668375" elapsed="0.009422"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.666103" elapsed="0.011751"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.678111" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.677891" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.666077" elapsed="0.012148"/>
</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-06-06T03:27:36.683429" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.679624" elapsed="0.003871"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.679309" elapsed="0.004237"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.679283" elapsed="0.004298"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.687235" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.684008" elapsed="0.003285"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.683683" elapsed="0.003650"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.683636" elapsed="0.003731"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.688072" 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-06-06T03:27:36.687604" elapsed="0.000496"/>
</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-06-06T03:27:36.688498" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.688177" elapsed="0.000393"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.689175" 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-06-06T03:27:36.688840" elapsed="0.000369"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.688601" elapsed="0.000650"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.688153" elapsed="0.001126"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.689959" 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-06-06T03:27:36.689516" elapsed="0.000478"/>
</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-06-06T03:27:36.690396" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.690086" elapsed="0.000375"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.691052" 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-06-06T03:27:36.690679" elapsed="0.000407"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.690487" elapsed="0.000687"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.690061" elapsed="0.001143"/>
</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-06-06T03:27:36.691416" elapsed="0.000461"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:27:36.692451" 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-06-06T03:27:36.692097" elapsed="0.000388"/>
</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-06-06T03:27:36.692708" elapsed="0.002874"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:27:36.678741" elapsed="0.016925"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:27:36.695717" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:27:36.698049" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:27:36.664741" elapsed="0.033335"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:36.698131" elapsed="0.000028"/>
</return>
<arg>${BGP_DIR}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:27:36.566434" elapsed="0.131822"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:27:36.474064" elapsed="0.224317"/>
</test>
<test id="s1-s13-t78" name="Deconfigure_App_Peer" line="264">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:36.701806" elapsed="0.000214"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:36.701505" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.703122" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.703004" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.702984" elapsed="0.000224"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.708882" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.708745" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.708720" elapsed="0.000250"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.710368" 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-06-06T03:27:36.709849" elapsed="0.000555"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.711045" 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-06-06T03:27:36.710630" elapsed="0.000448"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:36.711135" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:27:36.711338" 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-06-06T03:27:36.709282" elapsed="0.002088"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:36.718683" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.718549" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.718528" elapsed="0.000227"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:36.720006" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:36.719877" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.719857" elapsed="0.000223"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:36.720590" 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-06-06T03:27:36.720252" elapsed="0.000367"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.721044" level="INFO">${current_connection_index} = 7</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-06-06T03:27:36.720810" elapsed="0.000262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.757407" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:36.721933" elapsed="0.035622"/>
</kw>
<msg time="2026-06-06T03:27:36.757820" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:36.757869" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:36.721245" elapsed="0.036659"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:36.787324" level="INFO">". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:27:36.758486" elapsed="0.029013"/>
</kw>
<msg time="2026-06-06T03:27:36.787758" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:36.787822" level="INFO">${message_wait} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "c "o "n "f "i "g "u "r...</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-06-06T03:27:36.758094" elapsed="0.029778"/>
</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-06-06T03:27:36.788356" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.787998" elapsed="0.000598"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.787962" elapsed="0.000665"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.789260" level="INFO"> ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:27:36.788862" elapsed="0.000490"/>
</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-06-06T03:27:36.789734" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.789439" elapsed="0.000354"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.789415" elapsed="0.000402"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:36.789855" elapsed="0.000048"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:36.792663" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:27:36.792880" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:36.791494" elapsed="0.001534"/>
</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="NOT RUN" start="2026-06-06T03:27:36.793320" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.793722" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:36.790819" elapsed="0.003095"/>
</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-06-06T03:27:36.790218" elapsed="0.003763"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:36.719544" elapsed="0.074548"/>
</kw>
<msg time="2026-06-06T03:27:36.794189" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.794235" level="INFO">${message} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.718917" elapsed="0.075356"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:36.794469" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:36.794355" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.794333" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.795014" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.795374" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.795446" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:36.718194" elapsed="0.077365"/>
</kw>
<msg time="2026-06-06T03:27:36.795678" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:36.795725" level="INFO">${output} =  ". "t "x "t ". "0 "3 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "E "v "p "n ". "D "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:36.711885" elapsed="0.083877"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.796181" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.795895" elapsed="0.000355"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.795874" elapsed="0.000407"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:36.711683" elapsed="0.084630"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:36.711443" elapsed="0.084914"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:36.708258" elapsed="0.088176"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:36.702707" elapsed="0.093805"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:36.702239" elapsed="0.094331"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:36.699230" elapsed="0.097441"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.797559" level="INFO">&amp;{mapping} = { IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.796919" elapsed="0.000676"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.846269" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:36.845857" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:36.847119" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:36.846861" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:36.847293" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:36.846481" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.847892" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:36.847489" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:36.848225" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:36.848387" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:36.848085" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.848840" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.848575" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.849919" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.849628" elapsed="0.000336"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.850395" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.850127" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.851128" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.850807" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:36.851918" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.851696" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:36.851998" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:27:36.852153" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:36.851356" elapsed="0.000821"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.852341" elapsed="0.000271"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:27:36.850664" elapsed="0.002057"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.853277" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:36.852977" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:36.854295" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.853886" elapsed="0.000437"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:36.854375" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:36.854529" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:36.853493" elapsed="0.001061"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:36.854769" elapsed="0.000270"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:27:36.852840" elapsed="0.002242"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:27:36.850474" elapsed="0.004643"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:27:36.855170" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:27:36.855371" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:27:36.849262" elapsed="0.006142"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.848959" elapsed="0.006487"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.855675" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.855477" elapsed="0.000273"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.848938" elapsed="0.006839"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.856695" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:36.855972" elapsed="0.000755"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:36.856779" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:36.845164" elapsed="0.011753"/>
</kw>
<msg time="2026-06-06T03:27:36.856985" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:36.831885" elapsed="0.025159"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.873850" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.887357" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.900191" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.900408" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.900594" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.901072" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.900920" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:36.900903" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.901298" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.901473" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.901681" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:36.900868" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.900754" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.901915" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:36.901992" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:27:36.902134" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:36.827332" elapsed="0.074830"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.903356" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.903065" elapsed="0.000341"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.913199" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01ddgbxul1dmwrys5n73rkzag122.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.913247" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:36.913342" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:36.905561" elapsed="0.007806"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.903472" elapsed="0.009934"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:36.913608" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.913432" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.903454" elapsed="0.010257"/>
</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-06-06T03:27:36.917743" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.914728" elapsed="0.003077"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.914486" elapsed="0.003368"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.914467" elapsed="0.003423"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.921535" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:36.918286" elapsed="0.003347"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.917970" elapsed="0.003732"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.917946" elapsed="0.003792"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.922536" 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-06-06T03:27:36.921988" elapsed="0.000587"/>
</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-06-06T03:27:36.923040" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.922695" elapsed="0.000427"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.923896" 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-06-06T03:27:36.923446" elapsed="0.000489"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.923206" elapsed="0.000780"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.922667" elapsed="0.001349"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.924783" 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-06-06T03:27:36.924246" elapsed="0.000575"/>
</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-06-06T03:27:36.925255" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:36.924919" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:36.926077" 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-06-06T03:27:36.925658" elapsed="0.000456"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:36.925374" elapsed="0.000791"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:36.924893" elapsed="0.001302"/>
</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-06-06T03:27:36.926411" elapsed="0.000510"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:27:36.927557" 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-06-06T03:27:36.927159" elapsed="0.000435"/>
</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-06-06T03:27:36.927840" elapsed="0.003072"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:27:36.914081" elapsed="0.016898"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:27:36.931026" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:27:36.933310" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:27:36.902433" elapsed="0.030903"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:36.933390" elapsed="0.000028"/>
</return>
<arg>${BGP_DIR}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:27:36.798031" elapsed="0.135483"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:27:36.698699" elapsed="0.234966"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:27:36.934623" elapsed="0.000444"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:36.935302" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:27:36.935227" elapsed="0.000158"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:27:36.934400" elapsed="0.001038"/>
</kw>
<doc>Functional test for bgp - evpn

Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests advertising and receiveing routes with evpn content.
It uses play.py and odl as bgp peers. Routes advertized from odl
are configured via application peer. Routes advertised from play.py are
stored in *.hex files. These files are used also as expected data which
is recevied from odl.</doc>
<status status="PASS" start="2026-06-06T03:24:41.321877" elapsed="175.613592"/>
</suite>
<suite id="s1-s14" name="040 Bgp Functional Route Ref" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/040_bgp_functional_route_ref.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.066200" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:27:37.061916" elapsed="0.004337"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:27:37.061682" elapsed="0.004642"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.071118" 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-06-06T03:27:37.067423" elapsed="0.003723"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:37.071357" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:37.071230" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.071207" elapsed="0.000218"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.071953" 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-06-06T03:27:37.071580" elapsed="0.000416"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.072470" 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-06-06T03:27:37.072160" elapsed="0.000336"/>
</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-06-06T03:27:37.073089" elapsed="0.000286"/>
</kw>
<msg time="2026-06-06T03:27:37.073475" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:37.073732" 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-06-06T03:27:37.072742" elapsed="0.001016"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.074308" 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-06-06T03:27:37.073931" elapsed="0.000403"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.075314" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:27:37.075049" elapsed="0.000292"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.075765" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:27:37.075492" elapsed="0.000299"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.076240" 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-06-06T03:27:37.075952" elapsed="0.000315"/>
</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-06-06T03:27:37.079637" elapsed="0.000230"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.080360" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:27:37.080031" elapsed="0.000355"/>
</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-06-06T03:27:37.080541" elapsed="0.000244"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.081568" 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-06-06T03:27:37.081274" elapsed="0.000320"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:27:37.081653" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:27:37.081831" 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-06-06T03:27:37.080980" elapsed="0.000876"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:37.082449" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5de0590&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-06-06T03:27:37.082014" elapsed="0.000574"/>
</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-06-06T03:27:37.082768" elapsed="0.000191"/>
</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-06-06T03:27:37.079078" elapsed="0.003940"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:37.078885" elapsed="0.004177"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:27:37.076322" elapsed="0.006772"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.083677" 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-06-06T03:27:37.083258" elapsed="0.000463"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.084279" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:27:37.083884" elapsed="0.000437"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.084881" 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-06-06T03:27:37.084483" elapsed="0.000441"/>
</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-06-06T03:27:37.074581" elapsed="0.010399"/>
</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-06-06T03:27:37.067078" elapsed="0.017957"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:37.085211" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:37.085100" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.085082" elapsed="0.000195"/>
</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-06-06T03:27:37.088401" 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-06-06T03:27:37.088022" elapsed="0.000445"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.088949" 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-06-06T03:27:37.088633" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:37.089021" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:37.089176" 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-06-06T03:27:37.087691" elapsed="0.001510"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:37.090217" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:27:37.089953" elapsed="0.000291"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.091003" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:27:37.091103" 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-06-06T03:27:37.090837" elapsed="0.000292"/>
</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-06-06T03:27:37.094679" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:37.094086" elapsed="0.000681"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.094065" elapsed="0.000740"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.095447" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:27:37.095007" elapsed="0.000743"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.096719" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:37.096018" elapsed="0.000807"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.098017" 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-06-06T03:27:37.097099" elapsed="0.000969"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.099775" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:27:37.099953" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:37.099404" elapsed="0.000592"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:37.100340" elapsed="0.000543"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.102050" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:27:37.763783" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:27:37 UTC 2026

  System load:  0.0                Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:24:42 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:27:37.101723" elapsed="0.662225"/>
</kw>
<msg time="2026-06-06T03:27:37.764037" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:37.101230" elapsed="0.662979"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:27:37.098506" elapsed="0.665856"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.765313" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:27:37.778467" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:27:37.778961" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:27:37.779195" 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-06-06T03:27:37.764834" elapsed="0.014473"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:27:37.780084" elapsed="0.001159"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.783887" 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-06-06T03:27:37.782592" elapsed="0.001531"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:27:37.785063" elapsed="0.000112"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:37.784484" elapsed="0.000857"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.784428" elapsed="0.000997"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:27:37.786198" elapsed="0.000148"/>
</return>
<status status="PASS" start="2026-06-06T03:27:37.785604" elapsed="0.001105"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.785565" elapsed="0.001239"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:27:37.786939" elapsed="0.000036"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:37.792112" elapsed="0.000662"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:27:37.793167" elapsed="0.000393"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:27:37.793948" elapsed="0.000344"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:37.787834" elapsed="0.006536"/>
</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-06-06T03:27:37.093114" elapsed="0.701431"/>
</kw>
<msg time="2026-06-06T03:27:37.794603" 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-06-06T03:27:37.092467" elapsed="0.702207"/>
</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-06-06T03:27:37.091816" elapsed="0.702940"/>
</kw>
<msg time="2026-06-06T03:27:37.794798" 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-06-06T03:27:37.091289" elapsed="0.703555"/>
</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-06-06T03:27:37.797548" elapsed="0.000335"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:27:37.798053" elapsed="0.000162"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:27:37.798364" elapsed="0.000096"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:37.795136" elapsed="0.003374"/>
</kw>
<msg time="2026-06-06T03:27:37.798602" 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-06-06T03:27:37.090461" elapsed="0.708166"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.799072" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:37.798822" elapsed="0.000291"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:27:37.799155" elapsed="0.000031"/>
</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-06-06T03:27:37.089562" elapsed="0.709719"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:37.089385" elapsed="0.709933"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:37.089253" elapsed="0.710100"/>
</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-06-06T03:27:37.085498" elapsed="0.713911"/>
</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-06-06T03:27:37.799566" elapsed="0.000230"/>
</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-06-06T03:27:37.813539" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:37.813428" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.813408" elapsed="0.000200"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.813916" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:27:37.814019" 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-06-06T03:27:37.813779" elapsed="0.000266"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.814472" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:37.814214" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:37.814928" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:37.814684" elapsed="0.000288"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:37.815743" 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-06-06T03:27:37.815501" elapsed="0.000355">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:27:37.815961" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:27:37.816006" 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-06-06T03:27:37.815133" elapsed="0.000896"/>
</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-06-06T03:27:37.816335" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:37.816105" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:37.816085" elapsed="0.000348"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:37.817185" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:27:37.816923" elapsed="0.000288"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:27:37.817258" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:37.817405" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:27:37.816634" elapsed="0.000795"/>
</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-06-06T03:27:37.817586" elapsed="0.000424"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.818325" level="INFO">index=4
host=10.30.170.38
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-06-06T03:27:37.818424" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:27:37.818218" elapsed="0.000231"/>
</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-06-06T03:27:37.818599" elapsed="0.002368"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:27:37.821396" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:27:38.026853" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:27:37.821134" elapsed="0.205879"/>
</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-06-06T03:27:38.030608" elapsed="0.000426"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:27:38.031210" elapsed="0.000180"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:27:38.031546" elapsed="0.000133"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:38.028228" elapsed="0.003576"/>
</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-06-06T03:27:38.027470" elapsed="0.004384"/>
</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-06-06T03:27:37.813147" elapsed="0.218778"/>
</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-06-06T03:27:37.800577" elapsed="0.231414"/>
</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-06-06T03:27:37.800143" elapsed="0.231907"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:37.800000" elapsed="0.232093"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:27:37.799851" elapsed="0.232280"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:27:37.066619" elapsed="0.965575"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:38.035172" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:38.035022" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.034995" elapsed="0.000275"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:38.040275" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:38.040162" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.040140" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:38.041389" 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-06-06T03:27:38.040958" elapsed="0.000459"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:38.041931" 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-06-06T03:27:38.041588" elapsed="0.000377"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:38.042024" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:27:38.042221" 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-06-06T03:27:38.040594" elapsed="0.001653"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:38.048398" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:38.048282" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.048262" elapsed="0.000208"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:38.049765" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:38.049610" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.049591" elapsed="0.000246"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:38.050354" 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-06-06T03:27:38.049988" elapsed="0.000396"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:38.050817" 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-06-06T03:27:38.050564" elapsed="0.000280"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:38.084413" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:38.051538" elapsed="0.033039"/>
</kw>
<msg time="2026-06-06T03:27:38.084768" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:38.084826" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:27:38.051009" elapsed="0.033856"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:38.158101" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "4 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "r "o "u "t "e "_ "r "e "f ". "r "o "b "o "t "[K"
[?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-06-06T03:27:38.085700" elapsed="0.072671"/>
</kw>
<msg time="2026-06-06T03:27:38.158693" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:38.158744" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:27:38.085077" elapsed="0.073706"/>
</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-06-06T03:27:38.159246" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:38.158897" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.158863" elapsed="0.000583"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:38.160065" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "4 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "r "o "u "t "e "_ "r "e "f ". "r "o "b "o "t "[K"
[?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-06-06T03:27:38.159600" elapsed="0.000555"/>
</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-06-06T03:27:38.160479" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:38.160224" elapsed="0.000409"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.160205" elapsed="0.000474"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:38.160720" elapsed="0.000042"/>
</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-06-06T03:27:38.162967" elapsed="0.000531"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:27:38.163879" elapsed="0.000321"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:27:38.164558" elapsed="0.000550"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:38.162059" elapsed="0.003142"/>
</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-06-06T03:27:38.161055" elapsed="0.004287"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:38.049307" elapsed="0.116151"/>
</kw>
<msg time="2026-06-06T03:27:38.165556" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:38.165601" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:38.048631" elapsed="0.117021"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:38.165846" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:27:38.165736" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.165715" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:38.166383" elapsed="0.000034"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:38.166768" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:38.166841" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:38.047967" elapsed="0.118995"/>
</kw>
<msg time="2026-06-06T03:27:38.167082" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:38.167139" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:38.042691" elapsed="0.124498"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:38.167629" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:38.167293" elapsed="0.000428"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:38.167268" elapsed="0.000484"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:38.042524" elapsed="0.125260"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:38.042337" elapsed="0.125491"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:38.039836" elapsed="0.128069"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:27:38.032855" elapsed="0.135190"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:38.032362" elapsed="0.135745"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:27:37.061337" elapsed="1.106840"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:38.168875" level="INFO">${mininet_conn_id} = 7</msg>
<var>${mininet_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:27:38.168361" elapsed="0.000542"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:38.169438" level="INFO">${mininet_conn_id} = 7</msg>
<arg>${mininet_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:27:38.169079" elapsed="0.000407"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:27:38.171363" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:27:38.171455" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:27:38.171065" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:38.171658" elapsed="0.000571"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:27:38.173551" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:27:38.799552" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:27:38 UTC 2026

  System load:  0.02               Processes:             106
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:24:42 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:27:38.173217" elapsed="0.626594"/>
</kw>
<msg time="2026-06-06T03:27:38.799932" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:38.172433" elapsed="0.627610"/>
</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-06-06T03:27:38.170583" elapsed="0.629620"/>
</kw>
<msg time="2026-06-06T03:27:38.800281" 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-06-06T03:27:38.170085" elapsed="0.630267"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:27:38.169709" elapsed="0.630757"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:27:38.812408" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:27:38.812013" elapsed="0.000427"/>
</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-06-06T03:27:38.814044" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:27:39.080117" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:39.080517" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 105ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:27:39.080627" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:27:39.080770" 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-06-06T03:27:38.813836" elapsed="0.266990"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:27:39.083037" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:27:39.082297" elapsed="0.000851"/>
</kw>
<msg time="2026-06-06T03:27:39.083376" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:27:39.083482" 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-06-06T03:27:39.081362" elapsed="0.002171"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:39.085006" 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-06-06T03:27:39.083962" elapsed="0.001106"/>
</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-06-06T03:27:39.087798" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 105ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:39.087511" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:39.088264" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:39.088012" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:39.088743" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:39.088479" elapsed="0.000310"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:27:39.086156" elapsed="0.002693"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:39.085264" elapsed="0.003624"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:39.085209" elapsed="0.003712"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:27:39.089092" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:39.088981" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:39.088964" elapsed="0.000206"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:27:39.089318" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:27:39.089222" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:39.089207" elapsed="0.000216"/>
</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-06-06T03:27:39.089578" 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-06-06T03:27:38.813221" elapsed="0.276501"/>
</kw>
<msg time="2026-06-06T03:27:39.089784" 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-06-06T03:27:38.812616" elapsed="0.277220"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:27:38.811182" elapsed="0.278770"/>
</kw>
<msg time="2026-06-06T03:27:39.090008" 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-06-06T03:27:38.801989" elapsed="0.288065"/>
</kw>
<arg>virtualenv ${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-06-06T03:27:38.801410" elapsed="0.288750"/>
</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-06-06T03:27:39.097016" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/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-06-06T03:27:39.096677" elapsed="0.000368"/>
</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-06-06T03:27:39.098979" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-06-06T03:27:41.199377" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:41.199902" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
Installing collected packages: pip
  Att...</msg>
<msg time="2026-06-06T03:27:41.200076" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:27:41.200265" 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-06-06T03:27:39.098551" elapsed="2.101802"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:27:41.205434" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:27:41.204446" elapsed="0.001298"/>
</kw>
<msg time="2026-06-06T03:27:41.206083" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:27:41.206243" 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-06-06T03:27:41.201155" elapsed="0.005172"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:41.208903" 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-06-06T03:27:41.206949" elapsed="0.001996"/>
</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-06-06T03:27:41.211499" level="INFO">Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
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.1.2</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:41.211121" elapsed="0.000479"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:41.212438" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:41.211985" elapsed="0.000548"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:41.213506" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:41.212917" elapsed="0.000688"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:27:41.210207" elapsed="0.003536"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:41.209204" elapsed="0.004644"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:41.209175" elapsed="0.004703"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:27:41.214113" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:41.213937" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:41.213919" elapsed="0.000333"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:27:41.214470" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:27:41.214309" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:41.214292" elapsed="0.000343"/>
</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-06-06T03:27:41.214820" 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-06-06T03:27:39.097888" elapsed="2.117117"/>
</kw>
<msg time="2026-06-06T03:27:41.215063" 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-06-06T03:27:39.097211" elapsed="2.117903"/>
</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/defaultvenv/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-06-06T03:27:39.096020" elapsed="2.119174"/>
</kw>
<msg time="2026-06-06T03:27:41.215247" 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-06-06T03:27:39.092160" elapsed="2.123131"/>
</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-06-06T03:27:39.091585" elapsed="2.123784"/>
</kw>
<msg time="2026-06-06T03:27:41.215419" 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-06-06T03:27:39.091192" elapsed="2.124272"/>
</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-06-06T03:27:39.090821" elapsed="2.124718"/>
</kw>
<msg time="2026-06-06T03:27:41.215581" 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-06-06T03:27:39.090331" elapsed="2.125291"/>
</kw>
<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-06-06T03:27:38.800906" elapsed="2.414814"/>
</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-06-06T03:27:41.222876" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:27:41.222531" 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-06-06T03:27:41.224668" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; deactivate'.</msg>
<msg time="2026-06-06T03:27:42.056785" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:42.057294" level="INFO">${stdout} = Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setupt...</msg>
<msg time="2026-06-06T03:27:42.057533" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:27:42.057633" 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-06-06T03:27:41.224302" elapsed="0.833430"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:27:42.062493" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:27:42.061280" elapsed="0.001505"/>
</kw>
<msg time="2026-06-06T03:27:42.063112" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:27:42.063215" 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-06-06T03:27:42.058396" elapsed="0.004871"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:42.065593" 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-06-06T03:27:42.063793" elapsed="0.001827"/>
</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-06-06T03:27:42.067978" level="INFO">Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setuptools
  Attempting uninstall: setuptools
    Found existing installation: setuptools 59.6.0
    Uninstalling setuptools-59.6.0:
      Successfully uninstalled setuptools-59.6.0
Successfully installed setuptools-44.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:42.067469" elapsed="0.000582"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:42.068715" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:42.068352" elapsed="0.000428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:42.069656" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:42.069075" elapsed="0.000652"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:27:42.066557" elapsed="0.003246"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:42.065785" elapsed="0.004115"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:42.065757" elapsed="0.004174"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:27:42.070143" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:42.069993" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:42.069975" elapsed="0.000289"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:27:42.070453" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:27:42.070319" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:42.070302" elapsed="0.000297"/>
</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-06-06T03:27:42.070859" 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-06-06T03:27:41.223678" elapsed="0.847325"/>
</kw>
<msg time="2026-06-06T03:27:42.071061" 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-06-06T03:27:41.223065" elapsed="0.848047"/>
</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/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:27:41.221925" elapsed="0.849281"/>
</kw>
<msg time="2026-06-06T03:27:42.071262" 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-06-06T03:27:41.217945" elapsed="0.853361"/>
</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-06-06T03:27:41.217340" elapsed="0.854053"/>
</kw>
<msg time="2026-06-06T03:27:42.071443" 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-06-06T03:27:41.216962" elapsed="0.854524"/>
</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-06-06T03:27:41.216572" elapsed="0.854998"/>
</kw>
<msg time="2026-06-06T03:27:42.071614" 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-06-06T03:27:41.216196" elapsed="0.855475"/>
</kw>
<arg>setuptools==44.0.0</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-06-06T03:27:41.215922" elapsed="0.855882"/>
</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-06-06T03:27:42.078972" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:27:42.078569" elapsed="0.000432"/>
</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-06-06T03:27:42.080807" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; deactivate'.</msg>
<msg time="2026-06-06T03:27:43.712800" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:43.713320" level="INFO">${stdout} = Collecting exabgp==3.4.16
  Using cached exabgp-3.4.16.tar.gz (240 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to b...</msg>
<msg time="2026-06-06T03:27:43.713475" level="INFO">${stderr} =   error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        ...</msg>
<msg time="2026-06-06T03:27:43.713596" 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-06-06T03:27:42.080394" elapsed="1.633302"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:27:43.718517" level="INFO">Length is 1821.</msg>
<msg time="2026-06-06T03:27:43.719541" level="FAIL">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:27:43.717277" elapsed="0.002790">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</status>
</kw>
<msg time="2026-06-06T03:27:43.720448" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:27:43.720557" level="INFO">${result} = '  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
       ...</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-06-06T03:27:43.714407" elapsed="0.006209"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:43.723025" 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-06-06T03:27:43.721149" elapsed="0.001916"/>
</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-06-06T03:27:43.726401" level="INFO">Collecting exabgp==3.4.16
  Using cached exabgp-3.4.16.tar.gz (240 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 'error'</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:43.725611" elapsed="0.000891"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:43.727558" level="INFO">  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-7vum7ath/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:43.727104" elapsed="0.000597"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:43.728561" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:43.728120" elapsed="0.000556"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:27:43.724350" elapsed="0.004430"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:43.723259" elapsed="0.005653"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:43.723223" elapsed="0.005728"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:27:43.729232" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:43.729032" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:43.729008" elapsed="0.000394"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:27:43.729727" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:27:43.729518" elapsed="0.000367"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:43.729493" elapsed="0.000431"/>
</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-06-06T03:27:43.730133" elapsed="0.000030"/>
</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-06-06T03:27:42.079784" elapsed="1.650544"/>
</kw>
<msg time="2026-06-06T03:27:43.730406" 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-06-06T03:27:42.079162" elapsed="1.651311"/>
</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/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:27:42.077963" elapsed="1.652628"/>
</kw>
<msg time="2026-06-06T03:27:43.730705" 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-06-06T03:27:42.074059" elapsed="1.656695"/>
</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-06-06T03:27:42.073483" elapsed="1.657360"/>
</kw>
<msg time="2026-06-06T03:27:43.730892" 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-06-06T03:27:42.073101" elapsed="1.657834"/>
</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-06-06T03:27:42.072723" elapsed="1.658296"/>
</kw>
<msg time="2026-06-06T03:27:43.731061" 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-06-06T03:27:42.072288" elapsed="1.658814"/>
</kw>
<arg>exabgp==3.4.16</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-06-06T03:27:42.072016" elapsed="1.659166"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:43.731627" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e4718510&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:27:43.731342" elapsed="0.000498"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.760478" level="INFO">[chan 5] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:27:43.769914" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/exa.cfg' -&gt; '/home/jenkins//exa.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${BGP_CFG_NAME}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:27:43.732278" elapsed="0.037775"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.779265" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/exabgp_files/exarpc.py' -&gt; '/home/jenkins//exarpc.py'</msg>
<arg>${EXARPCSCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:27:43.770460" elapsed="0.008887"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.789963" level="INFO">6 files:
bgp-flowspec-redirect.cfg
bgp-flowspec.cfg
bgp-l3vpn-ipv4.cfg
exa-md5.cfg
exa.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:27:43.790126" level="INFO">@{cfgfiles} = [ bgp-flowspec-redirect.cfg | bgp-flowspec.cfg | bgp-l3vpn-ipv4.cfg | exa-md5.cfg | exa.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:27:43.779581" elapsed="0.010581"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.791227" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:27:43.804304" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:43.790851" elapsed="0.013611"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.805346" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:27:43.854330" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:43.804929" elapsed="0.049703"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.855788" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/enable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:27:43.907048" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/enable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:43.855291" elapsed="0.052058"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.908563" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:27:43.958069" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:43.908042" elapsed="0.050229"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:43.959356" level="INFO">Executing command 'cat bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:27:44.012170" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:44.012609" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:43.958877" elapsed="0.053848"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:44.014414" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;

        }
        then {
            redirect 65500:12345;
        }
    }
    route flow2 {
        match {
            source 10.0.0.2/32;
            destination 192.168.0.2/32;

        }
        then {
                redirect 1.2.3.4;
        }
    }
    route flow4 {
        match {
            source 10.0.0.4/32;
            destination 192.168.0.4/32;

        }
        next-hop 127.0.0.1;
        then {
                redirect-to-nexthop;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:44.013404" elapsed="0.001130"/>
</kw>
<var name="${cfgfile}">bgp-flowspec-redirect.cfg</var>
<status status="PASS" start="2026-06-06T03:27:43.790492" elapsed="0.224127"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.015748" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:27:44.066846" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.015327" elapsed="0.051809"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.068405" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:27:44.118495" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.067831" elapsed="0.050927"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.119877" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/enable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:27:44.170268" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/enable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.119379" elapsed="0.051080"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.171430" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:27:44.223140" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.171014" elapsed="0.052451"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.224774" level="INFO">Executing command 'cat bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:27:44.274260" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:44.274517" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.224165" elapsed="0.050610"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:44.276032" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;
            port =80;
            destination-port &gt;8080&amp;&lt;8088;
            source-port &gt;1024;
            protocol tcp;
            packet-length &gt;400&amp;&lt;500;
            fragment =first-fragment;
            icmp-type echo-reply;
            icmp-code network-unreachable;
            tcp-flags =urgent;
            dscp 20;
        }
        then {
            action sample-terminal;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:44.275287" elapsed="0.000867"/>
</kw>
<var name="${cfgfile}">bgp-flowspec.cfg</var>
<status status="PASS" start="2026-06-06T03:27:44.014962" elapsed="0.261272"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.277324" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:27:44.327252" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.276902" elapsed="0.050634"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.328904" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:27:44.378557" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.328249" elapsed="0.050660"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.380083" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/enable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:27:44.430076" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/enable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.379550" elapsed="0.050770"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.431508" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:27:44.482726" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.431015" elapsed="0.052002"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.484211" level="INFO">Executing command 'cat bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:27:44.534519" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:44.534995" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.483724" elapsed="0.051335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:44.536545" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255.254;
      rd 1.2.3.4:1;
      label 24005;
    }
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:44.535753" elapsed="0.000924"/>
</kw>
<var name="${cfgfile}">bgp-l3vpn-ipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:27:44.276538" elapsed="0.260223"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.537833" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:27:44.586620" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.537421" elapsed="0.049541"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.588128" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:27:44.638639" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.587554" elapsed="0.051406"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.640028" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/enable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:27:44.690725" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/enable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.639536" elapsed="0.051466"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.692097" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:27:44.742521" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.691595" elapsed="0.051190"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.743839" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:27:44.794021" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:44.794321" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.743354" elapsed="0.051035"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:44.795806" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:44.795019" elapsed="0.000903"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:27:44.537068" elapsed="0.258939"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.797233" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:27:44.845684" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.796764" elapsed="0.050237"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.848359" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:27:44.898170" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.847719" elapsed="0.050766"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.899780" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/enable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:27:44.949774" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/enable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.899203" elapsed="0.050798"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:44.950855" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:27:45.001809" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:44.950474" elapsed="0.051559"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.002861" level="INFO">Executing command 'cat exa.cfg'.</msg>
<msg time="2026-06-06T03:27:45.064396" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:45.064904" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh enable;
    add-path disable;
  }

  family {
    ipv4 uni...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:45.002493" elapsed="0.062479"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.066540" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh enable;
    add-path disable;
  }

  family {
    ipv4 unicast;
    ipv4 mpls-vpn;
  }

  process exarpcserver {
    run exarpc.py --host 10.30.171.194;
    encoder json;
    receive-routes;
    neighbor-changes;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.065630" elapsed="0.001052"/>
</kw>
<var name="${cfgfile}">exa.cfg</var>
<status status="PASS" start="2026-06-06T03:27:44.796322" elapsed="0.270442"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.067850" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:27:45.110319" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:45.067435" elapsed="0.043170"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.111904" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:27:45.161978" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:45.111279" elapsed="0.051034"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.163434" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/enable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:27:45.214267" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/enable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:45.162947" elapsed="0.051557"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.215453" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:27:45.265816" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:45.215053" elapsed="0.050906"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.266797" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:27:45.317723" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:27:45.317960" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:27:45.266416" elapsed="0.051603"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.319304" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.318587" elapsed="0.000828"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:27:45.067077" elapsed="0.252420"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:27:43.790249" elapsed="1.529329"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:27:43.732056" elapsed="1.587707"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:37.061024" elapsed="8.258861"/>
</kw>
<test id="s1-s14-t1" name="Configure_App_Peer" line="51">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:45.325483" elapsed="0.000327"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:45.325108" elapsed="0.000781"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.327478" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.327283" elapsed="0.000266"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.327249" elapsed="0.000335"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.333728" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.333543" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.333523" elapsed="0.000280"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.334918" 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-06-06T03:27:45.334478" elapsed="0.000468"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.335412" 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-06-06T03:27:45.335112" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:45.335484" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:27:45.335667" 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-06-06T03:27:45.334040" elapsed="0.001655"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:45.341373" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.341255" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.341236" elapsed="0.000207"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:45.342740" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.342605" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.342585" elapsed="0.000225"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:45.343287" 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-06-06T03:27:45.342972" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.343728" level="INFO">${current_connection_index} = 7</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-06-06T03:27:45.343483" elapsed="0.000272"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.376791" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:45.344255" elapsed="0.032643"/>
</kw>
<msg time="2026-06-06T03:27:45.377064" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:45.377111" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:45.343917" elapsed="0.033231"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.405248" level="INFO">". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:27:45.377704" elapsed="0.027654"/>
</kw>
<msg time="2026-06-06T03:27:45.405520" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:45.405566" level="INFO">${message_wait} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "C "o "n "f "...</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-06-06T03:27:45.377325" elapsed="0.028278"/>
</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-06-06T03:27:45.405941" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.405706" elapsed="0.000291"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.405682" elapsed="0.000340"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.406486" level="INFO"> ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:27:45.406170" elapsed="0.000385"/>
</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-06-06T03:27:45.406872" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.406623" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.406605" elapsed="0.000345"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:45.406985" elapsed="0.000030"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:45.409594" elapsed="0.000165"/>
</kw>
<msg time="2026-06-06T03:27:45.409824" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.408469" elapsed="0.001489"/>
</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="NOT RUN" start="2026-06-06T03:27:45.410323" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.410679" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:45.407845" elapsed="0.003023"/>
</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-06-06T03:27:45.407272" elapsed="0.003661"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:45.342252" elapsed="0.068780"/>
</kw>
<msg time="2026-06-06T03:27:45.411127" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:45.411171" level="INFO">${message} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "C "o "n "f "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:45.341607" elapsed="0.069603"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:45.411587" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:27:45.411287" elapsed="0.000391"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.411268" elapsed="0.000436"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.412120" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.412458" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.412531" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:45.340912" elapsed="0.071744"/>
</kw>
<msg time="2026-06-06T03:27:45.412754" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:45.412799" level="INFO">${output} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "C "o "n "f "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:45.336078" elapsed="0.076759"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.413169" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.412912" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.412895" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:45.335932" elapsed="0.077339"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:45.335752" elapsed="0.077550"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:45.333174" elapsed="0.080182"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:45.326853" elapsed="0.086558"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:45.326109" elapsed="0.087348"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:45.321435" elapsed="0.092074"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.414387" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | APP_PEER_NAME=example-bgp-peer-app | RIB_INSTANCE_NAME=example-bgp-rib | APP_PEER_ID=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>APP_PEER_NAME=${APP_PEER_NAME}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>APP_PEER_ID=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.413698" elapsed="0.000718"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.448205" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.447830" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.449010" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.448749" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.449226" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.448400" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.449829" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.449419" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.450162" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:45.450355" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:45.450023" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.450809" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.450544" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.451824" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.451545" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.452293" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.452032" elapsed="0.000287"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.453191" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.452704" elapsed="0.000513"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.453980" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.453751" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.454058" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:45.454213" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.453409" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.454408" elapsed="0.000263"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:27:45.452549" elapsed="0.002165"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.455259" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.454963" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.456016" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.455804" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.456092" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.456241" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.455468" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.456418" elapsed="0.000236"/>
</kw>
<var name="${key}">APP_PEER_NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:27:45.454827" elapsed="0.001869"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.457241" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.456945" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.457997" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.457785" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.458073" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.458222" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.457451" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.458431" elapsed="0.000240"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:27:45.456811" elapsed="0.001902"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.459301" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.459001" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.460064" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.459853" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.460141" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.460291" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.459516" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.460468" elapsed="0.000238"/>
</kw>
<var name="${key}">APP_PEER_ID</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:27:45.458864" elapsed="0.001884"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.461290" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.460995" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.462046" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.461836" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.462124" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.462274" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.461500" elapsed="0.000812"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.462467" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:27:45.460861" elapsed="0.001886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.463288" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.462994" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.464226" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.463834" elapsed="0.000418"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.464303" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:45.464453" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.463499" elapsed="0.000979"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.464631" elapsed="0.000240"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:27:45.462860" elapsed="0.002052"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:27:45.452369" elapsed="0.012579"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:27:45.464991" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:27:45.465150" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10....</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:27:45.451220" elapsed="0.013957"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.450924" elapsed="0.014286"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.465386" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.465235" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.450904" elapsed="0.014558"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.466333" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:45.465607" elapsed="0.000756"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.466415" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:45.447191" elapsed="0.019349"/>
</kw>
<msg time="2026-06-06T03:27:45.466594" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.434337" elapsed="0.032318"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.479075" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.491441" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.503812" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.504021" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.504202" elapsed="0.000038"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.504608" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.504457" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:45.504441" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.504856" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.505026" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.505193" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:45.504410" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.504302" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.505418" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.505494" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:27:45.505624" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:45.430080" elapsed="0.075589"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.532272" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.531884" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.533073" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.532827" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.533244" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.532469" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.533902" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.533496" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.534237" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:45.534424" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:45.534094" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.534901" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.534616" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:45.535327" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.535020" elapsed="0.000367"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.535883" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10....</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.535562" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.535412" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.535000" elapsed="0.000969"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.536818" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:45.536116" elapsed="0.000733"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.536899" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:45.531244" elapsed="0.005786"/>
</kw>
<msg time="2026-06-06T03:27:45.537084" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.518530" elapsed="0.018601"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.549749" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.562159" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.574504" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.574718" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.574937" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.575312" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.575166" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:45.575151" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.575535" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.575720" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.575890" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:45.575122" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.575016" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.576117" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.576192" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:27:45.576312" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:45.515842" elapsed="0.060498"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.577601" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.577362" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.577776" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.577018" elapsed="0.000784"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.578120" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.577872" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.578718" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.578406" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.578201" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.577853" elapsed="0.000948"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.581143" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.578957" elapsed="0.002213"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:27:45.581221" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.581374" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:27:45.576689" elapsed="0.004710"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.582827" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.582557" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.583270" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.583032" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.583730" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.583470" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.584168" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.583927" elapsed="0.000322"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:45.585087" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:27:45.584885" elapsed="0.000228"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:27:45.585446" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:27:45.585271" elapsed="0.000201"/>
</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-06-06T03:27:45.585625" elapsed="0.000227"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.586260" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.586013" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:27:45.586347" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:27:45.586528" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:27:45.584456" elapsed="0.002097"/>
</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-06-06T03:27:45.604979" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:27:45.605037" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:27:45 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:45.605232" 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-06-06T03:27:45.588865" elapsed="0.016395"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.586624" elapsed="0.018682"/>
</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-06-06T03:27:45.605491" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.605333" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.586606" elapsed="0.018978"/>
</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-06-06T03:27:45.608991" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.606629" elapsed="0.002404"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.606402" elapsed="0.002665"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.606353" elapsed="0.002739"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.611668" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.609371" elapsed="0.002345"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.609148" elapsed="0.002603"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.609131" elapsed="0.002644"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.612324" 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-06-06T03:27:45.611942" elapsed="0.000409"/>
</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-06-06T03:27:45.612677" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.612421" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.613221" 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-06-06T03:27:45.612923" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.612760" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.612402" elapsed="0.000901"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.613842" 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-06-06T03:27:45.613464" elapsed="0.000404"/>
</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-06-06T03:27:45.614173" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.613937" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.614817" 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-06-06T03:27:45.614495" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.614302" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.613919" elapsed="0.000982"/>
</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-06-06T03:27:45.615054" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:27:45.615876" 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-06-06T03:27:45.615569" 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-06-06T03:27:45.616061" elapsed="0.002280"/>
</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-06-06T03:27:45.606015" elapsed="0.012403"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:27:45.618594" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:45.618487" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.618467" elapsed="0.000231"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:27:45.618852" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.618921" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:27:45.621255" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:27:45.581746" elapsed="0.039536"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.621347" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:45.621503" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:27:45.419283" elapsed="0.202244"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.621882" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.621626" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.621609" elapsed="0.000366"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.622008" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:27:45.414703" elapsed="0.207433"/>
</kw>
<doc>Configures bgp application peer. Openconfig is used for carbon and above.</doc>
<status status="PASS" start="2026-06-06T03:27:45.320021" elapsed="0.302242"/>
</test>
<test id="s1-s14-t2" name="Reconfigure_ODL_To_Accept_Connection" line="65">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:27:45.625620" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:27:45.625354" elapsed="0.000547"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.626927" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.626817" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.626797" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.632218" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.632110" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.632091" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.633321" 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-06-06T03:27:45.632925" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.633828" 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-06-06T03:27:45.633513" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:27:45.633899" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:45.634057" 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-06-06T03:27:45.632520" elapsed="0.001618"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:27:45.639671" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.639543" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.639523" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:27:45.640963" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:45.640854" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.640835" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:45.641484" 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-06-06T03:27:45.641182" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.641919" level="INFO">${current_connection_index} = 7</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-06-06T03:27:45.641694" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.669848" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:45.642476" elapsed="0.027476"/>
</kw>
<msg time="2026-06-06T03:27:45.670117" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:27:45.670162" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:27:45.642107" elapsed="0.028093"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:27:45.702280" level="INFO">". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:27:45.670773" elapsed="0.031622"/>
</kw>
<msg time="2026-06-06T03:27:45.702590" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:27:45.702635" level="INFO">${message_wait} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "R "e "c "o "...</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-06-06T03:27:45.670375" elapsed="0.032318"/>
</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-06-06T03:27:45.703025" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.702776" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.702753" elapsed="0.000353"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.703561" level="INFO"> ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:27:45.703258" elapsed="0.000378"/>
</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-06-06T03:27:45.703943" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.703723" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.703704" elapsed="0.000317"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:27:45.704055" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:27:45.706727" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:27:45.706937" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.705528" elapsed="0.001543"/>
</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="NOT RUN" start="2026-06-06T03:27:45.707506" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.707880" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:27:45.704906" elapsed="0.003159"/>
</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-06-06T03:27:45.704344" elapsed="0.003786"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:27:45.640499" elapsed="0.067730"/>
</kw>
<msg time="2026-06-06T03:27:45.708379" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:45.708423" level="INFO">${message} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "R "e "c "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:45.639896" elapsed="0.068565"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:27:45.708665" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:27:45.708538" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.708519" elapsed="0.000232"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.709151" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.709487" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.709559" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:27:45.639205" elapsed="0.070481"/>
</kw>
<msg time="2026-06-06T03:27:45.709781" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:27:45.709825" level="INFO">${output} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "R "e "c "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:27:45.634544" elapsed="0.075318"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.710189" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.709937" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.709920" elapsed="0.000347"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:27:45.634395" elapsed="0.075896"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:27:45.634200" elapsed="0.076123"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:27:45.631741" elapsed="0.078637"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:27:45.626503" elapsed="0.083958"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:45.626059" elapsed="0.084451"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:27:45.623227" elapsed="0.087337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.711514" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | RIB_INSTANCE_NAME=example-bgp-rib | BGP_RIB_OPENCONFIG=example-bgp-ri...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.710755" elapsed="0.000790"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.744792" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.744400" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.745576" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.745319" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.745764" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.744984" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.746339" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.745953" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.746713" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:45.746911" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:45.746559" elapsed="0.000379"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.747346" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.747099" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.748358" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.748097" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.749013" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.748565" elapsed="0.000474"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.749734" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.749415" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.750505" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.750272" elapsed="0.000260"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.750587" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.750755" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.749950" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.750935" elapsed="0.000240"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:27:45.749277" elapsed="0.001939"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.751772" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.751462" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.752508" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.752299" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.752583" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:45.752748" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.751981" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.752923" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:27:45.751328" elapsed="0.001855"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.753743" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.753426" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.754507" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.754268" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.754583" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:45.754749" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.753951" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.754928" elapsed="0.000222"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:27:45.753293" elapsed="0.001897"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.755746" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.755433" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.756484" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.756275" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.756558" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.756723" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.755957" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.756944" elapsed="0.000225"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:27:45.755300" elapsed="0.001911"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.757769" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.757457" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.758523" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.758295" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.758598" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.758767" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.757979" elapsed="0.000813"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.758943" elapsed="0.000221"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:27:45.757324" elapsed="0.001881"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.759939" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.759450" elapsed="0.000515"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.760693" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.760468" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.760769" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.760919" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.760151" elapsed="0.000792"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.761095" elapsed="0.000221"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:27:45.759317" elapsed="0.002040"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.761914" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.761602" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.762696" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.762466" elapsed="0.000257"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.762772" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:45.762922" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.762123" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.763100" elapsed="0.000220"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:27:45.761469" elapsed="0.001891"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.763918" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.763605" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.764666" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.764443" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.764742" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:45.764890" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.764127" elapsed="0.000787"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.765066" elapsed="0.000219"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:27:45.763471" elapsed="0.001854"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.765880" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.765568" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.766626" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.766402" elapsed="0.000271"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.766724" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:45.766876" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.766087" elapsed="0.000813"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.767091" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:27:45.765435" elapsed="0.001921"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:27:45.749091" elapsed="0.018299"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:27:45.767433" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:27:45.767594" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'BGP_R...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:27:45.747774" elapsed="0.019846"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.747460" elapsed="0.020211"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.768016" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.767863" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.747440" elapsed="0.020652"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.768988" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:45.768239" elapsed="0.000779"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.769068" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:45.743785" elapsed="0.025407"/>
</kw>
<msg time="2026-06-06T03:27:45.769247" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.731163" elapsed="0.038131"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.781777" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.794294" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.806741" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.806949" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.807131" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.807514" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.807364" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:45.807348" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.807755" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.807926" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.808142" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:45.807317" elapsed="0.000880"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.807211" elapsed="0.001013"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.808375" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.808452" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:27:45.808582" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:45.726969" elapsed="0.081641"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.834840" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.834414" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.835623" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.835375" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.835814" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.835035" elapsed="0.000803"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.836387" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.836003" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.836740" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:45.836926" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:45.836586" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.837362" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.837115" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:45.837808" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.837490" elapsed="0.000378"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.838336" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'BGP_R...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.838038" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.837892" elapsed="0.000506"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.837471" elapsed="0.000948"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.839375" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:45.838580" elapsed="0.000868"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.839502" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:45.833799" elapsed="0.005833"/>
</kw>
<msg time="2026-06-06T03:27:45.839710" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.821238" elapsed="0.018519"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.854132" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.866544" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.878972" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.879176" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.879355" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.879748" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.879585" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:45.879570" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.879976" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.880145" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.880312" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:45.879539" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.879434" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.880539" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.880616" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:27:45.880774" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:45.818594" elapsed="0.062209"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.882166" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.881904" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.882335" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.881520" elapsed="0.000839"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.882729" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.882431" elapsed="0.000357"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.883290" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.882999" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.882813" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.882412" elapsed="0.000962"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.885956" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.883529" elapsed="0.002456"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:27:45.886043" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:27:45.886212" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:27:45.881178" elapsed="0.005059"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.887854" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.887534" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.888318" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.888074" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.888813" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.888537" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.889255" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.889015" elapsed="0.000285"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:45.890158" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:27:45.889951" elapsed="0.000233"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:27:45.890584" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:27:45.890341" elapsed="0.000278"/>
</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-06-06T03:27:45.890806" elapsed="0.000226"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.891440" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.891193" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:27:45.891526" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:45.891700" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:27:45.889509" elapsed="0.002217"/>
</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-06-06T03:27:45.906002" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Content-Length': '1090', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:27:45.906288" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:45.906575" 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-06-06T03:27:45.894112" elapsed="0.012525"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.891805" elapsed="0.014976"/>
</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-06-06T03:27:45.907205" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.906842" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.891784" elapsed="0.015620"/>
</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-06-06T03:27:45.915111" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.909582" elapsed="0.005626"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.909083" elapsed="0.006204"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.909041" elapsed="0.006303"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.918079" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.915813" elapsed="0.002311"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.915469" elapsed="0.002690"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.915432" elapsed="0.002751"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.918830" 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-06-06T03:27:45.918370" elapsed="0.000488"/>
</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-06-06T03:27:45.919176" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.918930" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.919739" 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-06-06T03:27:45.919424" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.919257" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.918911" elapsed="0.000910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.920345" 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-06-06T03:27:45.919985" elapsed="0.000386"/>
</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-06-06T03:27:45.920698" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.920441" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.921234" 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-06-06T03:27:45.920943" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.920781" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.920423" elapsed="0.000892"/>
</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-06-06T03:27:45.921470" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:27:45.922289" 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-06-06T03:27:45.922003" elapsed="0.000312"/>
</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-06-06T03:27:45.922473" elapsed="0.002383"/>
</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-06-06T03:27:45.908238" elapsed="0.016684"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:27:45.925097" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:27:45.924990" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.924970" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:27:45.925337" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:27:45.925405" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:27:45.927688" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:27:45.886624" elapsed="0.041092"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.927819" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:45.927977" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:27:45.716229" elapsed="0.211772"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.928342" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.928101" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.928084" elapsed="0.000351"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.928468" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:27:45.711843" elapsed="0.216748"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:27:45.622633" elapsed="0.306105"/>
</test>
<test id="s1-s14-t3" name="Exa_To_Send_Route_Refresh" line="82">
<kw name="Configure_Routes_And_Start_ExaBgp" type="SETUP">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.930339" level="INFO">${app_rib} = 10.30.170.38</msg>
<var>${app_rib}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.930044" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.931180" level="INFO">&amp;{mapping} = { PREFIX=1.1.1.1/32 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>PREFIX=${prefix}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.930737" elapsed="0.000470"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.964968" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:45.964571" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.965801" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:45.965498" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:45.965978" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:45.965161" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.966581" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:45.966172" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:45.966931" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:45.967091" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes

</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:45.966792" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.967518" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.967276" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.968522" level="INFO">mapping: {'PREFIX': '1.1.1.1/32', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:45.968266" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.969008" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.968745" elapsed="0.000289"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.969953" level="INFO">${value} = 1.1.1.1/32</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.969388" elapsed="0.000592"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.971115" level="INFO">${encoded} = 1.1.1.1/32</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.970630" elapsed="0.000526"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.971311" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:27:45.971540" level="INFO">${encoded_value} = 1.1.1.1/32</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.970169" elapsed="0.001397"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.971739" elapsed="0.000489"/>
</kw>
<var name="${key}">PREFIX</var>
<var name="${value}">1.1.1.1/32</var>
<status status="PASS" start="2026-06-06T03:27:45.969253" elapsed="0.003017"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.973043" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:45.972519" elapsed="0.000550"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:45.974326" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.973866" elapsed="0.000502"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:45.974485" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:27:45.974755" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:45.973256" elapsed="0.001525"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:45.974938" elapsed="0.000485"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:27:45.972384" elapsed="0.003082"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:27:45.969082" elapsed="0.006419"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:27:45.975544" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:45.975718" level="INFO">${mapping_to_use} = {'PREFIX': '1.1.1.1/32', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:27:45.967944" elapsed="0.007800"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:45.967631" elapsed="0.008145"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.975954" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:45.975802" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:45.967611" elapsed="0.008418"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:45.976825" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:45.976173" elapsed="0.000680"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:45.976903" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:45.963954" elapsed="0.013074"/>
</kw>
<msg time="2026-06-06T03:27:45.977083" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:45.951393" elapsed="0.025739"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:45.989748" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.002179" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.014581" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.014864" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.015056" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.015431" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.015282" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:46.015267" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.015668" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.015843" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.016010" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:46.015238" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.015136" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.016236" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.016312" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:27:46.016439" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:45.947086" elapsed="0.069380"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.041164" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.040752" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.041998" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.041735" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:46.042171" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:46.041371" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.042803" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:46.042363" elapsed="0.000468"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.043141" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:46.043341" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;$PREFIX&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;$PREFIX&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;glob...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:46.042997" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.043799" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;$PREFIX&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;$PREFIX&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;199.20.160.41&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.043535" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:46.044281" elapsed="0.000082"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.043935" elapsed="0.000466"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.044895" level="INFO">${mapping_to_use} = {'PREFIX': '1.1.1.1/32', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.044578" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.044428" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.043909" elapsed="0.001071"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.045788" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:46.045130" elapsed="0.000690"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.045875" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:46.040055" elapsed="0.005955"/>
</kw>
<msg time="2026-06-06T03:27:46.046068" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:46.027517" elapsed="0.018599"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.058971" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.071328" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.083678" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.083897" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.084081" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.084490" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.084341" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:46.084323" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.084734" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.084931" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.085103" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:46.084286" elapsed="0.000872"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.084167" elapsed="0.001020"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.085338" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.085473" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:27:46.085619" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:46.026632" elapsed="0.059034"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.087098" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.086809" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:46.087267" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:46.086386" elapsed="0.000906"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.087622" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.087363" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.088209" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.087910" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.087723" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.087344" elapsed="0.000948"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.090688" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:46.088445" elapsed="0.002270"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:27:46.090767" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:46.090922" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:27:46.086015" elapsed="0.004932"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.092488" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.092236" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.092945" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;199.20.160.41&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.092704" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.093394" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.093152" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.093845" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.093588" elapsed="0.000300"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:46.094737" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:27:46.094495" elapsed="0.000268"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:27:46.095212" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:27:46.095037" elapsed="0.000200"/>
</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-06-06T03:27:46.095387" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.096022" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.095775" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:27:46.096107" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:46.096301" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:27:46.094092" elapsed="0.002235"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:46.112407" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;199.20.160.41&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:27:46.112543" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:46.112794" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:46.098679" elapsed="0.014174"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.096398" elapsed="0.016557"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.113366" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.113016" elapsed="0.000499"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.096380" elapsed="0.017183"/>
</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-06-06T03:27:46.119134" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.115832" elapsed="0.003362"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.115443" elapsed="0.003799"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.115400" elapsed="0.003876"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.122899" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.119692" elapsed="0.003270"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.119354" elapsed="0.003656"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.119331" elapsed="0.003713"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.123818" 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-06-06T03:27:46.123280" elapsed="0.000565"/>
</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-06-06T03:27:46.124160" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.123917" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.124720" 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-06-06T03:27:46.124402" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.124241" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.123898" elapsed="0.000904"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.125464" 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-06-06T03:27:46.124963" elapsed="0.000528"/>
</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-06-06T03:27:46.125824" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.125562" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.126367" 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-06-06T03:27:46.126070" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.125906" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.125543" elapsed="0.000906"/>
</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-06-06T03:27:46.126633" elapsed="0.000367"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:27:46.127457" 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-06-06T03:27:46.127172" elapsed="0.000311"/>
</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-06-06T03:27:46.127694" elapsed="0.002288"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:27:46.114387" elapsed="0.015659"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:27:46.130225" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:27:46.130119" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.130100" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:27:46.130462" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.130529" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:27:46.133069" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:27:46.091278" elapsed="0.041823"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.133179" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:27:46.133347" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:27:45.936038" elapsed="0.197334"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.133738" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.133479" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.133461" elapsed="0.000370"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.133863" elapsed="0.000026"/>
</return>
<arg>${BGP_RR_VAR_FOLDER}/route</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:27:45.931466" elapsed="0.202522"/>
</kw>
<var name="${prefix}">1.1.1.1/32</var>
<status status="PASS" start="2026-06-06T03:27:45.930569" elapsed="0.203461"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.134751" level="INFO">&amp;{mapping} = { PREFIX=2.2.2.2/32 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>PREFIX=${prefix}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:46.134275" elapsed="0.000503"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.168513" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.168137" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.169301" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.169061" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:46.169469" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:46.168723" elapsed="0.000771"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.170059" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:46.169676" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.170387" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:46.170543" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes

</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:46.170249" elapsed="0.000418"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.171085" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.170836" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.172094" level="INFO">mapping: {'PREFIX': '2.2.2.2/32', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.171839" elapsed="0.000299"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.172561" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:27:46.172297" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.173508" level="INFO">${value} = 2.2.2.2/32</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:46.172964" elapsed="0.000570"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:46.174713" level="INFO">${encoded} = 2.2.2.2/32</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:46.174203" elapsed="0.000554"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:46.174875" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:27:46.175096" level="INFO">${encoded_value} = 2.2.2.2/32</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:46.173749" elapsed="0.001373"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:46.175277" elapsed="0.000513"/>
</kw>
<var name="${key}">PREFIX</var>
<var name="${value}">2.2.2.2/32</var>
<status status="PASS" start="2026-06-06T03:27:46.172826" elapsed="0.003006"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.176589" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:27:46.176080" elapsed="0.000537"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:27:46.177902" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:27:46.177419" elapsed="0.000525"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:27:46.178062" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:27:46.178284" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:27:46.176824" elapsed="0.001486"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:27:46.178467" elapsed="0.000542"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:27:46.175945" elapsed="0.003105"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:27:46.172637" elapsed="0.006449"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:27:46.179129" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:27:46.179286" level="INFO">${mapping_to_use} = {'PREFIX': '2.2.2.2/32', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:27:46.171497" elapsed="0.007814"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.171197" elapsed="0.008147"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.179519" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.179369" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.171177" elapsed="0.008419"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.180332" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:46.179758" elapsed="0.000603"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.180410" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:46.167501" elapsed="0.013033"/>
</kw>
<msg time="2026-06-06T03:27:46.180588" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:46.154889" elapsed="0.025748"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.193083" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.205448" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.217804" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.218004" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.218183" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.218551" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.218404" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:46.218390" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.218826" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.218999" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.219167" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:46.218361" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.218260" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.219391" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.219466" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:27:46.219584" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:46.150657" elapsed="0.068953"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.244532" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.244116" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.245343" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.245095" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:46.245512" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:46.244751" elapsed="0.000787"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.246108" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:46.245721" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.246449" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:27:46.246698" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;$PREFIX&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;$PREFIX&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;glob...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:27:46.246299" elapsed="0.000430"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.247138" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;$PREFIX&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;$PREFIX&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;199.20.160.41&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.246889" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:27:46.247612" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.247271" elapsed="0.000420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.248161" level="INFO">${mapping_to_use} = {'PREFIX': '2.2.2.2/32', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.247866" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.247718" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.247248" elapsed="0.000996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.249282" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;2.2.2.2/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;2.2.2.2/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:46.248393" elapsed="0.000921"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.249367" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:27:46.243424" elapsed="0.006076"/>
</kw>
<msg time="2026-06-06T03:27:46.249558" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:46.230494" elapsed="0.019117"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.261942" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.274713" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.287899" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.288101" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.288280" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.288732" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.288524" elapsed="0.000267"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:27:46.288508" elapsed="0.000308"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.288961" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.289130" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.289297" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:27:46.288477" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.288364" elapsed="0.001015"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.289525" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.289601" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:27:46.289749" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;2.2.2.2/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;2.2.2.2/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:27:46.229629" elapsed="0.060149"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:27:46.291103" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.290855" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:27:46.291264" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:27:46.290453" elapsed="0.000836"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.291607" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.291360" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.292181" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.291891" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.291707" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.291340" elapsed="0.000923"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.294580" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:46.292417" elapsed="0.002190"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:27:46.294677" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:27:46.294846" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:27:46.290118" elapsed="0.004753"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.296407" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.296157" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.296906" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;2.2.2.2/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;2.2.2.2/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;199.20.160.41&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.296612" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.297372" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.297124" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.297869" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.297606" elapsed="0.000307"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:27:46.298769" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:27:46.298526" elapsed="0.000270"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:27:46.299130" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:27:46.298952" elapsed="0.000203"/>
</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-06-06T03:27:46.299307" elapsed="0.000210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.299938" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.299691" elapsed="0.000292"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:27:46.300026" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:27:46.300181" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:27:46.298119" elapsed="0.002088"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:46.313363" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;2.2.2.2/32&lt;/prefix&gt;
   &lt;path-id&gt;0&lt;/path-id&gt;
   &lt;route-key&gt;2.2.2.2/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;199.20.160.41&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:27:46.313498" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=2.2.2.2%2F32,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:46.313749" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:46.302533" elapsed="0.011277"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.300278" elapsed="0.013636"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.314322" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.313972" elapsed="0.000500"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.300260" elapsed="0.014260"/>
</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-06-06T03:27:46.321226" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.316908" elapsed="0.004378"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.316382" elapsed="0.004953"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.316339" elapsed="0.005030"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.324953" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.321776" elapsed="0.003242"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.321446" elapsed="0.003620"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.321423" elapsed="0.003676"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.325896" 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-06-06T03:27:46.325334" elapsed="0.000600"/>
</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-06-06T03:27:46.326369" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.326034" elapsed="0.000414"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.327181" 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-06-06T03:27:46.326763" elapsed="0.000454"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.326482" elapsed="0.000786"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.326008" elapsed="0.001289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.328046" 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-06-06T03:27:46.327521" elapsed="0.000562"/>
</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-06-06T03:27:46.328566" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.328232" elapsed="0.000434"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.329345" 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-06-06T03:27:46.328932" elapsed="0.000448"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.328702" elapsed="0.000727"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.328205" elapsed="0.001252"/>
</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-06-06T03:27:46.329688" elapsed="0.000485"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:27:46.330856" 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-06-06T03:27:46.330407" elapsed="0.000486"/>
</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-06-06T03:27:46.331115" elapsed="0.002423"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:27:46.315373" elapsed="0.018229"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:27:46.333800" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:27:46.333691" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.333671" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:27:46.334034" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:27:46.334104" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:27:46.336566" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:27:46.295203" elapsed="0.041390"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.336690" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:27:46.336849" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:27:46.139616" elapsed="0.197258"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:27:46.337231" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:27:46.336980" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.336963" elapsed="0.000363"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:27:46.337359" elapsed="0.000029"/>
</return>
<arg>${BGP_RR_VAR_FOLDER}/route</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:27:46.135046" elapsed="0.202452"/>
</kw>
<var name="${prefix}">2.2.2.2/32</var>
<status status="PASS" start="2026-06-06T03:27:46.134128" elapsed="0.203412"/>
</iter>
<var>${prefix}</var>
<value>1.1.1.1/32</value>
<value>2.2.2.2/32</value>
<status status="PASS" start="2026-06-06T03:27:45.930425" elapsed="0.407148"/>
</for>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.340936" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.340598" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.341405" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.341134" elapsed="0.000316"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:46.346365" level="INFO">source /tmp/defaultvenv/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-06-06T03:27:46.342075" elapsed="0.004428"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:46.351056" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:46.351197" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:46.347118" elapsed="0.004175"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.352608" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.351944" elapsed="0.000772"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:46.351401" elapsed="0.001427"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:46.351371" elapsed="0.001524"/>
</if>
<arg>log_output=${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-06-06T03:27:46.341713" elapsed="0.011315"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:46.355258" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:27:46.355420" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:46.353345" elapsed="0.002114"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.356352" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.355956" elapsed="0.000470"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:46.340279" elapsed="0.016244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.359191" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:46.358798" elapsed="0.000421"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.361551" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:46.359395" elapsed="0.002184"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:46.368043" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:46.368242" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:46.368376" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:46.361770" elapsed="0.006642"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.372228" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:46.368694" elapsed="0.003603"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:46.376705" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.372527" elapsed="0.004288">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:46.358205" elapsed="0.018786">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:49.380089" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:49.379148" elapsed="0.001012"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:49.385139" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:49.380553" elapsed="0.004648"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:49.392493" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:49.392628" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:49.392743" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:49.385577" elapsed="0.007193"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:49.395402" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:49.392944" elapsed="0.002508"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:49.399029" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:49.395613" elapsed="0.003514">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:49.377892" elapsed="0.021393">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.402404" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:52.401487" elapsed="0.000987"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.407019" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:52.402901" elapsed="0.004159"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:52.413963" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:52.414145" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:52.414278" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:52.407296" elapsed="0.007018"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.417941" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.414554" elapsed="0.003456"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.421728" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:52.418237" elapsed="0.003590">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:52.400182" elapsed="0.021800">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:27:52.422109" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.357597" elapsed="6.064637">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:27:52.422399" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:27:52.422460" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:46.356805" elapsed="6.065687"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.423601" level="INFO">[?2004l03:27:46 | 3506   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:46 | 3506   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:46 | 3506   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:27:46 | 3506   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:27:46 | 3506   | [01;34minstallation [0m | [1m        [0m
03:27:46 | 3506   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:27:46 | 3506   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:27:46 | 3506   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:27:46 | 3506   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:27:46 | 3506   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:27:46 | 3506   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:27:46 | 3506   | configuration[0m | . local-as         | '64496'[0m
03:27:46 | 3506   | configuration[0m | . peer-as          | '64496'[0m
03:27:46 | 3506   | configuration[0m | &gt; capability       | [0m
03:27:46 | 3506   | configuration[0m | . route-refresh    | 'enable'[0m
03:27:46 | 3506   | configuration[0m | . add-path         | 'disable'[0m
03:27:46 | 3506   | configuration[0m | &lt; capability       | [0m
03:27:46 | 3506   | configuration[0m | &gt; family           | [0m
03:27:46 | 3506   | configuration[0m | . ipv4             | 'unicast'[0m
03:27:46 | 3506   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:27:46 | 3506   | configuration[0m | &lt; family           | [0m
03:27:46 | 3506   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1m        [0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1m        [0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:52.423908" level="INFO">${output} = [?2004l03:27:46 | 3506   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:46 | 3506   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:46 | 3506   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:27:52.423431" elapsed="0.000520"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.424519" level="INFO">[?2004l03:27:46 | 3506   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:46 | 3506   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:46 | 3506   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:27:46 | 3506   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:27:46 | 3506   | [01;34minstallation [0m | [1m        [0m
03:27:46 | 3506   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:27:46 | 3506   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:27:46 | 3506   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:27:46 | 3506   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:27:46 | 3506   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:27:46 | 3506   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:27:46 | 3506   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:27:46 | 3506   | configuration[0m | . local-as         | '64496'[0m
03:27:46 | 3506   | configuration[0m | . peer-as          | '64496'[0m
03:27:46 | 3506   | configuration[0m | &gt; capability       | [0m
03:27:46 | 3506   | configuration[0m | . route-refresh    | 'enable'[0m
03:27:46 | 3506   | configuration[0m | . add-path         | 'disable'[0m
03:27:46 | 3506   | configuration[0m | &lt; capability       | [0m
03:27:46 | 3506   | configuration[0m | &gt; family           | [0m
03:27:46 | 3506   | configuration[0m | . ipv4             | 'unicast'[0m
03:27:46 | 3506   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:27:46 | 3506   | configuration[0m | &lt; family           | [0m
03:27:46 | 3506   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1m        [0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1m        [0m
03:27:46 | 3506   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.424167" elapsed="0.000524"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.425894" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:52.425449" elapsed="0.000474"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:52.426082" elapsed="0.000246"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:27:52.424977" elapsed="0.001411"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.428736" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:52.428828" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:52.426555" elapsed="0.002300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.429281" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.429013" elapsed="0.000317"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.431694" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:52.429978" elapsed="0.001774"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.432538" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:52.432618" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:52.431913" elapsed="0.000748"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.433260" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.432983" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:52.432730" elapsed="0.000612"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:52.432711" elapsed="0.000659"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:27:52.429589" elapsed="0.003827"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:27:52.423047" elapsed="0.010420"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:52.422634" elapsed="0.010860"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:52.422598" elapsed="0.010919"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:52.433704" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:52.433572" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:52.433555" elapsed="0.000216"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:27:46.340102" elapsed="6.093725"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.434864" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:52.434522" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.435292" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.435049" elapsed="0.000287"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.440149" level="INFO">source /tmp/defaultvenv/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-06-06T03:27:52.437538" elapsed="0.002666"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.444339" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:52.444432" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:52.440365" elapsed="0.004093"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.445050" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.444799" elapsed="0.000298"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:52.444527" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:52.444507" elapsed="0.000670"/>
</if>
<arg>log_output=${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-06-06T03:27:52.437129" elapsed="0.008096"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:52.446854" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:27:52.446941" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:52.445383" elapsed="0.001584"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.447368" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.447127" elapsed="0.000286"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:52.434197" elapsed="0.013271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.449374" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:52.448999" elapsed="0.000402"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.451495" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:52.449567" elapsed="0.001955"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:52.456480" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:52.456604" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:52.456727" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:52.451840" elapsed="0.004914"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.459465" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:52.457073" elapsed="0.002439"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:52.462194" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:52.459684" elapsed="0.002578">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:52.448525" elapsed="0.013844">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:55.465446" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:55.464510" elapsed="0.001005"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:55.470698" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:55.465946" elapsed="0.004824"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:55.479065" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:55.479292" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:55.479472" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:55.471089" elapsed="0.008428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:55.484177" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:55.479878" elapsed="0.004386"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:55.487925" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:55.484546" elapsed="0.003465">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:55.463246" elapsed="0.024934">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.491556" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:58.490400" elapsed="0.001235"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.495433" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:58.492082" elapsed="0.003395"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:58.502015" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:58.502409" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:58.502582" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:58.495760" elapsed="0.006863"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.506931" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.502969" elapsed="0.004064"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.511224" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:58.507336" elapsed="0.003992">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:58.489065" elapsed="0.022439">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:27:58.511664" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:27:52.448039" elapsed="6.063764">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:27:58.511980" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:27:58.512026" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:52.447628" elapsed="6.064423"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.512927" level="INFO">[?2004l03:27:52 | 3510   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:52 | 3510   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:52 | 3510   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:27:52 | 3510   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:27:52 | 3510   | [01;34minstallation [0m | [1m        [0m
03:27:52 | 3510   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:27:52 | 3510   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:27:52 | 3510   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:27:52 | 3510   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:27:52 | 3510   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:27:52 | 3510   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:27:52 | 3510   | configuration[0m | . local-as         | '64496'[0m
03:27:52 | 3510   | configuration[0m | . peer-as          | '64496'[0m
03:27:52 | 3510   | configuration[0m | &gt; capability       | [0m
03:27:52 | 3510   | configuration[0m | . route-refresh    | 'enable'[0m
03:27:52 | 3510   | configuration[0m | . add-path         | 'disable'[0m
03:27:52 | 3510   | configuration[0m | &lt; capability       | [0m
03:27:52 | 3510   | configuration[0m | &gt; family           | [0m
03:27:52 | 3510   | configuration[0m | . ipv4             | 'unicast'[0m
03:27:52 | 3510   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:27:52 | 3510   | configuration[0m | &lt; family           | [0m
03:27:52 | 3510   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1m        [0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1m        [0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:58.513152" level="INFO">${output} = [?2004l03:27:52 | 3510   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:52 | 3510   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:52 | 3510   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:27:58.512794" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.513670" level="INFO">[?2004l03:27:52 | 3510   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:52 | 3510   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:52 | 3510   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:27:52 | 3510   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:27:52 | 3510   | [01;34minstallation [0m | [1m        [0m
03:27:52 | 3510   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:27:52 | 3510   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:27:52 | 3510   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:27:52 | 3510   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:27:52 | 3510   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:27:52 | 3510   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:27:52 | 3510   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:27:52 | 3510   | configuration[0m | . local-as         | '64496'[0m
03:27:52 | 3510   | configuration[0m | . peer-as          | '64496'[0m
03:27:52 | 3510   | configuration[0m | &gt; capability       | [0m
03:27:52 | 3510   | configuration[0m | . route-refresh    | 'enable'[0m
03:27:52 | 3510   | configuration[0m | . add-path         | 'disable'[0m
03:27:52 | 3510   | configuration[0m | &lt; capability       | [0m
03:27:52 | 3510   | configuration[0m | &gt; family           | [0m
03:27:52 | 3510   | configuration[0m | . ipv4             | 'unicast'[0m
03:27:52 | 3510   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:27:52 | 3510   | configuration[0m | &lt; family           | [0m
03:27:52 | 3510   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1m        [0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1m        [0m
03:27:52 | 3510   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.513350" elapsed="0.000432"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.514594" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:27:58.514270" elapsed="0.000351"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:58.514793" elapsed="0.000285"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:27:58.513993" elapsed="0.001147"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.517382" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:58.517481" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:58.515312" elapsed="0.002200"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.517957" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.517699" elapsed="0.000308"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.520982" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:58.518667" elapsed="0.002393"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.521920" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:58.522011" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:58.521252" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.522690" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.522402" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:58.522120" elapsed="0.000653"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:58.522093" elapsed="0.000709"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:27:58.518271" elapsed="0.004581"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:27:58.512474" elapsed="0.010433"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:58.512158" elapsed="0.010777"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:58.512131" elapsed="0.010828"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:27:58.523163" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:27:58.523017" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:58.523000" elapsed="0.000233"/>
</if>
<var name="${idx}">1</var>
<status status="PASS" start="2026-06-06T03:27:52.434011" elapsed="6.089308"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.524530" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:58.524187" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.524980" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.524734" elapsed="0.000291"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.527228" level="INFO">source /tmp/defaultvenv/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-06-06T03:27:58.525954" elapsed="0.001331"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.531964" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:27:58.532059" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:27:58.527450" elapsed="0.004635"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.532678" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.532411" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:27:58.532156" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:27:58.532136" elapsed="0.000649"/>
</if>
<arg>log_output=${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-06-06T03:27:58.525553" elapsed="0.007280"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:27:58.534401" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:27:58.534493" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:27:58.532987" elapsed="0.001533"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.534956" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.534705" elapsed="0.000296"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:27:58.523807" elapsed="0.011270"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.537100" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:27:58.536744" elapsed="0.000383"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.539378" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:27:58.537295" elapsed="0.002119"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:27:58.545743" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:27:58.545909" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:27:58.546054" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:27:58.539598" elapsed="0.006485"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.549567" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:27:58.546312" elapsed="0.003392"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:27:58.554123" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:27:58.550071" elapsed="0.004171">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:27:58.536255" elapsed="0.018198">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:01.557638" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:01.556759" elapsed="0.000979"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:01.561869" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:01.558148" elapsed="0.003760"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:01.568204" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:01.568393" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:01.568528" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:01.562149" elapsed="0.006416"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:01.572534" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:01.568836" elapsed="0.003768"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:01.576398" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:01.572853" elapsed="0.003640">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:01.555339" elapsed="0.021342">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.579809" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:04.578898" elapsed="0.000982"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.584798" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:04.580270" elapsed="0.004591"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:04.592472" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:04.592634" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:04.592751" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:04.585240" elapsed="0.007536"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.595332" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:04.592950" elapsed="0.002431"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.598067" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:04.595539" elapsed="0.002599">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:04.577558" elapsed="0.020701">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:04.598351" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:27:58.535736" elapsed="6.062705">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:04.598561" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:04.598605" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:27:58.535255" elapsed="6.063374"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.599444" level="INFO">[?2004l03:27:58 | 3514   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:58 | 3514   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:58 | 3514   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:27:58 | 3514   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:27:58 | 3514   | [01;34minstallation [0m | [1m        [0m
03:27:58 | 3514   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:27:58 | 3514   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:27:58 | 3514   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:27:58 | 3514   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:27:58 | 3514   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:27:58 | 3514   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:27:58 | 3514   | configuration[0m | . local-as         | '64496'[0m
03:27:58 | 3514   | configuration[0m | . peer-as          | '64496'[0m
03:27:58 | 3514   | configuration[0m | &gt; capability       | [0m
03:27:58 | 3514   | configuration[0m | . route-refresh    | 'enable'[0m
03:27:58 | 3514   | configuration[0m | . add-path         | 'disable'[0m
03:27:58 | 3514   | configuration[0m | &lt; capability       | [0m
03:27:58 | 3514   | configuration[0m | &gt; family           | [0m
03:27:58 | 3514   | configuration[0m | . ipv4             | 'unicast'[0m
03:27:58 | 3514   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:27:58 | 3514   | configuration[0m | &lt; family           | [0m
03:27:58 | 3514   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1m        [0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1m        [0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:04.599687" level="INFO">${output} = [?2004l03:27:58 | 3514   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:58 | 3514   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:58 | 3514   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:04.599318" elapsed="0.000401"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.600133" level="INFO">[?2004l03:27:58 | 3514   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:27:58 | 3514   | [01;34mversion      [0m | [1m4.2.17  [0m
03:27:58 | 3514   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:27:58 | 3514   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:27:58 | 3514   | [01;34minstallation [0m | [1m        [0m
03:27:58 | 3514   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:27:58 | 3514   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:27:58 | 3514   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:27:58 | 3514   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:27:58 | 3514   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:27:58 | 3514   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:27:58 | 3514   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:27:58 | 3514   | configuration[0m | . local-as         | '64496'[0m
03:27:58 | 3514   | configuration[0m | . peer-as          | '64496'[0m
03:27:58 | 3514   | configuration[0m | &gt; capability       | [0m
03:27:58 | 3514   | configuration[0m | . route-refresh    | 'enable'[0m
03:27:58 | 3514   | configuration[0m | . add-path         | 'disable'[0m
03:27:58 | 3514   | configuration[0m | &lt; capability       | [0m
03:27:58 | 3514   | configuration[0m | &gt; family           | [0m
03:27:58 | 3514   | configuration[0m | . ipv4             | 'unicast'[0m
03:27:58 | 3514   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:27:58 | 3514   | configuration[0m | &lt; family           | [0m
03:27:58 | 3514   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1m        [0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1m        [0m
03:27:58 | 3514   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:04.599877" elapsed="0.000369"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.601094" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:04.600770" elapsed="0.000352"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:04.601337" elapsed="0.000355"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:04.600450" elapsed="0.001328"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.604696" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:04.604826" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:04.602006" elapsed="0.002860"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.605438" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:04.605085" elapsed="0.000420"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.608342" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:04.606394" elapsed="0.002026"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.609463" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:04.609546" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:04.608700" elapsed="0.000873"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.610157" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:04.609907" elapsed="0.000301"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:04.609655" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:04.609622" elapsed="0.000647"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:04.605879" elapsed="0.004436"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:04.599035" elapsed="0.011332"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:04.598748" elapsed="0.011646"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:04.598721" elapsed="0.011697"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:04.610588" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:04.610473" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:04.610456" elapsed="0.000215"/>
</if>
<var name="${idx}">2</var>
<status status="PASS" start="2026-06-06T03:27:58.523533" elapsed="6.087193"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:27:46.339885" elapsed="18.270878"/>
</for>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.611200" level="FAIL">Unable to connect ExaBgp to ODL</msg>
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:28:04.610922" elapsed="0.000339">Unable to connect ExaBgp to ODL</status>
</kw>
<arg>${cfg_file}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:27:46.337912" elapsed="18.273448">Unable to connect ExaBgp to ODL</status>
</kw>
<kw name="Comment" owner="BuiltIn">
<arg>From neon onwards there are extra BGP End-Of-RIB message per address family</arg>
<doc>Displays the given messages in the log file as keyword arguments.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:04.611565" elapsed="0.000022"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<var>${update_count}</var>
<arg>4</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:04.611759" elapsed="0.000021"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgp_Received_Updates</arg>
<arg>${update_count}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:04.611940" elapsed="0.000021"/>
</kw>
<arg>${BGP_CFG_NAME}</arg>
<doc>Setup keyword for exa to odl test case</doc>
<status status="FAIL" start="2026-06-06T03:27:45.929694" elapsed="18.682362">Unable to connect ExaBgp to ODL</status>
</kw>
<kw name="Deconfigure_Routes_And_Stop_ExaBgp" type="TEARDOWN">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.613387" level="INFO">${output} =  </msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:04.613235" elapsed="0.000178"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.613846" level="INFO"> </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:04.613568" elapsed="0.000323"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.614727" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:04.614398" elapsed="0.000357"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:04.614911" elapsed="0.000199"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:04.614093" elapsed="0.001076"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.616877" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:04.616969" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:04.615331" elapsed="0.001666"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:04.617408" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:04.617154" elapsed="0.000303"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:04.619231" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:04.618113" elapsed="0.001173"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:05.505819" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:05.506122" level="INFO">${output} = [?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:04.619444" elapsed="0.886712"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.507107" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.506743" elapsed="0.000416"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.506318" elapsed="0.000876"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.506276" elapsed="0.000947"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:04.617719" elapsed="0.889565"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:04.612938" elapsed="0.894409"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.507908" level="INFO">${app_rib} = 10.30.170.38</msg>
<var>${app_rib}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:05.507570" elapsed="0.000365"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.508564" level="INFO">&amp;{mapping} = { PREFIX=http://10.30.170.38:8080 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>PREFIX=${prefix}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:05.508110" elapsed="0.000482"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.551407" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:05.551025" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:05.552243" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:05.551963" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:05.552488" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:05.551603" elapsed="0.000910"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.553110" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:05.552719" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:05.553439" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/route_refresh/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:05.553600" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes

</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:05.553301" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.554049" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes

</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.553802" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.555101" level="INFO">mapping: {'PREFIX': 'http://10.30.170.38:8080', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.554841" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.555721" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:05.555308" elapsed="0.000440"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.556420" level="INFO">${value} = http://10.30.170.38:8080</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:05.556118" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:05.557230" level="INFO">${encoded} = http%3A//10.30.170.38%3A8080</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:05.557005" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:05.557311" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:28:05.557617" level="INFO">${encoded_value} = http%3A//10.30.170.38%3A8080</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:05.556629" elapsed="0.001027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:05.557814" elapsed="0.000249"/>
</kw>
<var name="${key}">PREFIX</var>
<var name="${value}">http://10.30.170.38:8080</var>
<status status="PASS" start="2026-06-06T03:28:05.555980" elapsed="0.002123"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.558663" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:05.558350" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:05.559431" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:05.559220" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:05.559507" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:05.559672" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:05.558875" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:05.559851" elapsed="0.000224"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:05.558216" elapsed="0.001900"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:05.555803" elapsed="0.004348"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:05.560195" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:05.560353" level="INFO">${mapping_to_use} = {'PREFIX': 'http%3A//10.30.170.38%3A8080', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:05.554469" elapsed="0.005909"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.554163" elapsed="0.006247"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.560586" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:05.560435" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.554142" elapsed="0.006565"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.561445" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:05.560859" elapsed="0.000614"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:05.561522" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:05.550360" elapsed="0.011303"/>
</kw>
<msg time="2026-06-06T03:28:05.561756" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:05.537430" elapsed="0.024389"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.574481" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.586915" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/route_refresh/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.599448" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.599660" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.599841" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.600210" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:05.600061" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:05.600046" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.600433" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.600602" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.600800" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:05.600018" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:05.599917" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.601030" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:05.601105" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:05.601231" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:05.533096" elapsed="0.068161"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.602397" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.602143" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:05.614681" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:05.614729" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:05.614836" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:05.604602" elapsed="0.010262"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.602550" elapsed="0.012354"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:05.615088" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:05.614932" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.602531" elapsed="0.012641"/>
</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-06-06T03:28:05.622855" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.617516" elapsed="0.005437"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.617017" elapsed="0.006014"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.616975" elapsed="0.006112"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.626870" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.623750" elapsed="0.003165"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.623212" elapsed="0.003737"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.623174" elapsed="0.003800"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.627538" 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-06-06T03:28:05.627151" elapsed="0.000414"/>
</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-06-06T03:28:05.627898" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:05.627636" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.628445" 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-06-06T03:28:05.628144" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.627979" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.627617" elapsed="0.000910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.629082" 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-06-06T03:28:05.628717" elapsed="0.000391"/>
</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-06-06T03:28:05.629418" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:05.629178" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.629968" 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-06-06T03:28:05.629673" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.629497" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.629159" elapsed="0.000890"/>
</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-06-06T03:28:05.630200" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:05.631021" 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-06-06T03:28:05.630734" elapsed="0.000313"/>
</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-06-06T03:28:05.631206" elapsed="0.002491"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:28:05.615977" elapsed="0.017784"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:05.633809" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:28:05.636066" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:28:05.601518" elapsed="0.034575"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:05.636183" elapsed="0.000032"/>
</return>
<arg>${BGP_RR_VAR_FOLDER}/route</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:28:05.508882" elapsed="0.127433"/>
</kw>
<doc>Teardown keyword for exa to odl test case</doc>
<status status="PASS" start="2026-06-06T03:28:04.612337" elapsed="1.024039"/>
</kw>
<doc>Exabgp sends route refresh and count received updates</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:27:45.929132" elapsed="19.707295">Setup failed:
Unable to connect ExaBgp to ODL</status>
</test>
<test id="s1-s14-t4" name="Odl_To_Send_Route_Refresh" line="102">
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib" type="SETUP">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.640527" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:05.640200" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.640991" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.640745" elapsed="0.000291"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:05.643342" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:05.641654" elapsed="0.001744"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:05.647478" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:05.647569" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:05.643559" elapsed="0.004037"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.648187" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.647938" elapsed="0.000300"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:05.647685" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:05.647662" elapsed="0.000635"/>
</if>
<arg>log_output=${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-06-06T03:28:05.641279" elapsed="0.007064"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:05.649777" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:05.649863" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:05.648495" elapsed="0.001393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.650294" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.650050" elapsed="0.000289"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:05.639879" elapsed="0.010515"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.652278" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:05.651931" elapsed="0.000375"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.654564" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:05.652472" elapsed="0.002119"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:05.658864" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:05.659000" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:05.659093" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:05.654771" elapsed="0.004347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.661738" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:05.659289" elapsed="0.002497"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:05.664430" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:05.661946" elapsed="0.002556">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:05.651458" elapsed="0.013154">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:08.667132" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:08.666417" elapsed="0.000887"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:08.670875" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:08.667601" elapsed="0.003318"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:08.677801" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:08.678011" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:08.678161" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:08.671197" elapsed="0.007018"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:08.682220" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:08.678487" elapsed="0.003811"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:08.686246" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:08.682544" elapsed="0.003812">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:08.665368" elapsed="0.021172">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.689766" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:11.688776" elapsed="0.001068"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.693367" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:11.690259" elapsed="0.003149"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:11.700558" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:11.700769" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:11.700905" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:11.693669" elapsed="0.007272"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.704903" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.701184" elapsed="0.003789"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.709289" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:11.705200" elapsed="0.004220">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:11.687420" elapsed="0.022211">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:11.709877" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:05.650970" elapsed="6.059085">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:11.710319" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:11.710412" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:05.650557" elapsed="6.059897"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.711825" level="INFO">[?2004l03:28:05 | 3535   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:05 | 3535   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:05 | 3535   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:05 | 3535   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:05 | 3535   | [01;34minstallation [0m | [1m        [0m
03:28:05 | 3535   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:05 | 3535   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:05 | 3535   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:05 | 3535   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:05 | 3535   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:05 | 3535   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:05 | 3535   | configuration[0m | . local-as         | '64496'[0m
03:28:05 | 3535   | configuration[0m | . peer-as          | '64496'[0m
03:28:05 | 3535   | configuration[0m | &gt; capability       | [0m
03:28:05 | 3535   | configuration[0m | . route-refresh    | 'enable'[0m
03:28:05 | 3535   | configuration[0m | . add-path         | 'disable'[0m
03:28:05 | 3535   | configuration[0m | &lt; capability       | [0m
03:28:05 | 3535   | configuration[0m | &gt; family           | [0m
03:28:05 | 3535   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:05 | 3535   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:05 | 3535   | configuration[0m | &lt; family           | [0m
03:28:05 | 3535   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1m        [0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1m        [0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:11.712044" level="INFO">${output} = [?2004l03:28:05 | 3535   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:05 | 3535   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:05 | 3535   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:11.711615" elapsed="0.000474"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.712698" level="INFO">[?2004l03:28:05 | 3535   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:05 | 3535   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:05 | 3535   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:05 | 3535   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:05 | 3535   | [01;34minstallation [0m | [1m        [0m
03:28:05 | 3535   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:05 | 3535   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:05 | 3535   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:05 | 3535   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:05 | 3535   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:05 | 3535   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:05 | 3535   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:05 | 3535   | configuration[0m | . local-as         | '64496'[0m
03:28:05 | 3535   | configuration[0m | . peer-as          | '64496'[0m
03:28:05 | 3535   | configuration[0m | &gt; capability       | [0m
03:28:05 | 3535   | configuration[0m | . route-refresh    | 'enable'[0m
03:28:05 | 3535   | configuration[0m | . add-path         | 'disable'[0m
03:28:05 | 3535   | configuration[0m | &lt; capability       | [0m
03:28:05 | 3535   | configuration[0m | &gt; family           | [0m
03:28:05 | 3535   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:05 | 3535   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:05 | 3535   | configuration[0m | &lt; family           | [0m
03:28:05 | 3535   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1m        [0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1m        [0m
03:28:05 | 3535   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.712319" elapsed="0.000550"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.714067" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:11.713570" elapsed="0.000569"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:11.714377" elapsed="0.000368"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:11.713168" elapsed="0.001673"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.717138" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:11.717239" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:11.715068" elapsed="0.002199"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.717756" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.717430" elapsed="0.000390"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.719599" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:11.718469" elapsed="0.001204"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.720590" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:11.720692" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:11.719834" elapsed="0.000886"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.721291" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.721041" elapsed="0.000298"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:11.720787" elapsed="0.000585"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:11.720768" elapsed="0.000636"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:11.718094" elapsed="0.003359"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:11.711045" elapsed="0.010458"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:11.710614" elapsed="0.010915"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:11.710574" elapsed="0.010978"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:11.721759" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:11.721608" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:11.721591" elapsed="0.000235"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:28:05.639700" elapsed="6.082150"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.723046" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:11.722718" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.723473" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.723230" elapsed="0.000286"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.725663" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:11.724135" elapsed="0.001619"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.730545" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:11.730636" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:11.725914" elapsed="0.004768"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.731252" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.731002" elapsed="0.000297"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:11.730750" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:11.730731" elapsed="0.000625"/>
</if>
<arg>log_output=${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-06-06T03:28:11.723774" elapsed="0.007628"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:11.733379" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:11.733468" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:11.731553" elapsed="0.001940"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.733978" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.733673" elapsed="0.000352"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:11.722227" elapsed="0.011858"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.736165" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:11.735814" elapsed="0.000379"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.738324" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:11.736358" elapsed="0.001993"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:11.743970" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:11.744088" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:11.744181" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:11.738560" elapsed="0.005647"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.747726" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:11.744375" elapsed="0.003420"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:11.751490" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:11.748015" elapsed="0.003564">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:11.735160" elapsed="0.016588">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:14.754944" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:14.753906" elapsed="0.001113"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:14.760159" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:14.755418" elapsed="0.004804"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:14.767728" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:14.767871" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:14.767970" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:14.760592" elapsed="0.007405"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:14.770628" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:14.768179" elapsed="0.002514"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:14.773354" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:14.770854" elapsed="0.002572">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:14.752626" elapsed="0.020918">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.776583" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:17.775710" elapsed="0.000969"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.781115" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:17.777067" elapsed="0.004088"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:17.788459" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:17.788635" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:17.788910" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:17.781388" elapsed="0.007560"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.792560" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.789204" elapsed="0.003425"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.796538" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:17.792873" elapsed="0.003760">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:17.774380" elapsed="0.022433">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:17.796938" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:11.734663" elapsed="6.062399">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:17.797225" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:17.797287" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:11.734251" elapsed="6.063070"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.798480" level="INFO">[?2004l03:28:11 | 3539   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:11 | 3539   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:11 | 3539   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:11 | 3539   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:11 | 3539   | [01;34minstallation [0m | [1m        [0m
03:28:11 | 3539   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:11 | 3539   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:11 | 3539   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:11 | 3539   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:11 | 3539   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:11 | 3539   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:11 | 3539   | configuration[0m | . local-as         | '64496'[0m
03:28:11 | 3539   | configuration[0m | . peer-as          | '64496'[0m
03:28:11 | 3539   | configuration[0m | &gt; capability       | [0m
03:28:11 | 3539   | configuration[0m | . route-refresh    | 'enable'[0m
03:28:11 | 3539   | configuration[0m | . add-path         | 'disable'[0m
03:28:11 | 3539   | configuration[0m | &lt; capability       | [0m
03:28:11 | 3539   | configuration[0m | &gt; family           | [0m
03:28:11 | 3539   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:11 | 3539   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:11 | 3539   | configuration[0m | &lt; family           | [0m
03:28:11 | 3539   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1m        [0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1m        [0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:17.798716" level="INFO">${output} = [?2004l03:28:11 | 3539   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:11 | 3539   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:11 | 3539   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:17.798271" elapsed="0.000488"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.799322" level="INFO">[?2004l03:28:11 | 3539   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:11 | 3539   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:11 | 3539   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:11 | 3539   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:11 | 3539   | [01;34minstallation [0m | [1m        [0m
03:28:11 | 3539   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:11 | 3539   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:11 | 3539   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:11 | 3539   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:11 | 3539   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:11 | 3539   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:11 | 3539   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:11 | 3539   | configuration[0m | . local-as         | '64496'[0m
03:28:11 | 3539   | configuration[0m | . peer-as          | '64496'[0m
03:28:11 | 3539   | configuration[0m | &gt; capability       | [0m
03:28:11 | 3539   | configuration[0m | . route-refresh    | 'enable'[0m
03:28:11 | 3539   | configuration[0m | . add-path         | 'disable'[0m
03:28:11 | 3539   | configuration[0m | &lt; capability       | [0m
03:28:11 | 3539   | configuration[0m | &gt; family           | [0m
03:28:11 | 3539   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:11 | 3539   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:11 | 3539   | configuration[0m | &lt; family           | [0m
03:28:11 | 3539   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1m        [0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1m        [0m
03:28:11 | 3539   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.798974" elapsed="0.000547"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.800367" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:17.800052" elapsed="0.000342"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:17.800548" elapsed="0.000269"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:17.799777" elapsed="0.001110"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.803267" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:17.803360" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:17.801040" elapsed="0.002347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.803810" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.803544" elapsed="0.000315"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.806120" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:17.804476" elapsed="0.001699"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.807008" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:17.807093" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:17.806333" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.807696" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.807433" elapsed="0.000311"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:17.807186" elapsed="0.000591"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:17.807167" elapsed="0.000635"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:17.804110" elapsed="0.003737"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:17.797882" elapsed="0.010016"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:17.797458" elapsed="0.010467"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:17.797424" elapsed="0.010524"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:17.808117" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:17.808004" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:17.807987" elapsed="0.000194"/>
</if>
<var name="${idx}">1</var>
<status status="PASS" start="2026-06-06T03:28:11.722036" elapsed="6.086168"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.809228" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:17.808905" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.809668" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.809412" elapsed="0.000302"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.812562" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:17.810316" elapsed="0.002300"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.816903" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:17.816993" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:17.812796" elapsed="0.004224"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.817585" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.817336" elapsed="0.000297"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:17.817088" elapsed="0.000595"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:17.817069" elapsed="0.000640"/>
</if>
<arg>log_output=${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-06-06T03:28:17.809955" elapsed="0.007800"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:17.819392" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:17.819479" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:17.817907" elapsed="0.001598"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.819928" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.819682" elapsed="0.000292"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:17.808560" elapsed="0.011468"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.823407" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:17.823054" elapsed="0.000381"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.825575" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:17.823655" elapsed="0.001948"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:17.831006" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:17.831121" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:17.831221" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:17.825788" elapsed="0.005460"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.833790" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:17.831415" elapsed="0.002422"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:17.836879" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:17.833995" elapsed="0.002973">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:17.822573" elapsed="0.014540">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:20.840128" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:20.839235" elapsed="0.000962"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:20.844663" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:20.840586" elapsed="0.004126"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:20.851997" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:20.852185" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:20.852324" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:20.844965" elapsed="0.007398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:20.856247" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:20.852619" elapsed="0.003701"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:20.860360" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:20.856557" elapsed="0.003904">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:20.837975" elapsed="0.022647">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.863927" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:23.862977" elapsed="0.001021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.868875" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:23.864403" elapsed="0.004512"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:23.874975" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:23.875153" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:23.875385" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:23.869156" elapsed="0.006268"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.879065" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:23.875689" elapsed="0.003444"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.882934" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:23.879357" elapsed="0.003682">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:23.861506" elapsed="0.021690">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:23.883321" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:17.820576" elapsed="6.062871">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:23.883610" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:23.883694" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:17.820187" elapsed="6.063543"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.884847" level="INFO">[?2004l03:28:17 | 3543   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:17 | 3543   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:17 | 3543   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:17 | 3543   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:17 | 3543   | [01;34minstallation [0m | [1m        [0m
03:28:17 | 3543   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:17 | 3543   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:17 | 3543   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:17 | 3543   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:17 | 3543   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:17 | 3543   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:17 | 3543   | configuration[0m | . local-as         | '64496'[0m
03:28:17 | 3543   | configuration[0m | . peer-as          | '64496'[0m
03:28:17 | 3543   | configuration[0m | &gt; capability       | [0m
03:28:17 | 3543   | configuration[0m | . route-refresh    | 'enable'[0m
03:28:17 | 3543   | configuration[0m | . add-path         | 'disable'[0m
03:28:17 | 3543   | configuration[0m | &lt; capability       | [0m
03:28:17 | 3543   | configuration[0m | &gt; family           | [0m
03:28:17 | 3543   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:17 | 3543   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:17 | 3543   | configuration[0m | &lt; family           | [0m
03:28:17 | 3543   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1m        [0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1m        [0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:23.885053" level="INFO">${output} = [?2004l03:28:17 | 3543   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:17 | 3543   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:17 | 3543   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:23.884674" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.885683" level="INFO">[?2004l03:28:17 | 3543   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:17 | 3543   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:17 | 3543   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:17 | 3543   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:17 | 3543   | [01;34minstallation [0m | [1m        [0m
03:28:17 | 3543   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:17 | 3543   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:17 | 3543   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:17 | 3543   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:17 | 3543   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:17 | 3543   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:17 | 3543   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:17 | 3543   | configuration[0m | . local-as         | '64496'[0m
03:28:17 | 3543   | configuration[0m | . peer-as          | '64496'[0m
03:28:17 | 3543   | configuration[0m | &gt; capability       | [0m
03:28:17 | 3543   | configuration[0m | . route-refresh    | 'enable'[0m
03:28:17 | 3543   | configuration[0m | . add-path         | 'disable'[0m
03:28:17 | 3543   | configuration[0m | &lt; capability       | [0m
03:28:17 | 3543   | configuration[0m | &gt; family           | [0m
03:28:17 | 3543   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:17 | 3543   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:17 | 3543   | configuration[0m | &lt; family           | [0m
03:28:17 | 3543   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1m        [0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1m        [0m
03:28:17 | 3543   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:23.885313" elapsed="0.000575"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.887074" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:23.886567" elapsed="0.000546"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:23.887332" elapsed="0.000343"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:23.886177" elapsed="0.001595"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.890567" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:23.890681" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:23.887932" elapsed="0.002779"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.891149" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:23.890894" elapsed="0.000304"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.893067" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:23.891845" elapsed="0.001279"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.894067" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:23.894155" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:23.893307" elapsed="0.000875"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.894770" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:23.894502" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:23.894250" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:23.894230" elapsed="0.000665"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:23.891456" elapsed="0.003486"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:23.884265" elapsed="0.010729"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:23.883868" elapsed="0.011155"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:23.883834" elapsed="0.011212"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:23.895218" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:23.895102" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:23.895084" elapsed="0.000200"/>
</if>
<var name="${idx}">2</var>
<status status="PASS" start="2026-06-06T03:28:17.808379" elapsed="6.086929"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:28:05.639467" elapsed="18.255874"/>
</for>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.895797" level="FAIL">Unable to connect ExaBgp to ODL</msg>
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:28:23.895498" elapsed="0.000359">Unable to connect ExaBgp to ODL</status>
</kw>
<arg>${BGP_CFG_NAME}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:28:05.637573" elapsed="18.258381">Unable to connect ExaBgp to ODL</status>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib" type="TEARDOWN">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.896790" level="INFO">${output} =  </msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:23.896621" elapsed="0.000195"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.897231" level="INFO"> </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:23.896970" elapsed="0.000306"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.898214" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:23.897797" elapsed="0.000445"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:23.898396" elapsed="0.000198"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:23.897479" elapsed="0.001199"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.900118" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:23.900210" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:23.898830" elapsed="0.001408"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:23.900678" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:23.900410" elapsed="0.000318"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:23.902551" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:23.901408" elapsed="0.001198"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.021627" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:24.021780" level="INFO">${output} = [?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:23.902790" elapsed="0.119020"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.022579" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.022283" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.021960" elapsed="0.000726"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.021933" elapsed="0.000781"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:23.900975" elapsed="0.121792"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:23.896309" elapsed="0.126514"/>
</kw>
<doc>Sends route refresh request and checks if exabgp receives it</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:28:05.636907" elapsed="18.385977">Setup failed:
Unable to connect ExaBgp to ODL</status>
</test>
<test id="s1-s14-t5" name="Delete_Bgp_Peer_Configuration" line="124">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:28:24.026804" elapsed="0.000241"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:28:24.026506" elapsed="0.000596"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.028210" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.028092" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.028070" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.033268" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.033159" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.033141" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.034373" 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-06-06T03:28:24.033966" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.034960" 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-06-06T03:28:24.034594" elapsed="0.000395"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:24.035035" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:28:24.035200" 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-06-06T03:28:24.033567" elapsed="0.001659"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:28:24.040945" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.040834" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.040814" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:28:24.042262" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.042149" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.042129" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:24.042826" 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-06-06T03:28:24.042481" elapsed="0.000373"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.043274" level="INFO">${current_connection_index} = 7</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-06-06T03:28:24.043052" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.075840" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:24.043823" elapsed="0.032125"/>
</kw>
<msg time="2026-06-06T03:28:24.076129" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:28:24.076176" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:28:24.043463" elapsed="0.032750"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.108954" level="INFO">". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:28:24.076785" elapsed="0.032281"/>
</kw>
<msg time="2026-06-06T03:28:24.109227" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:28:24.109273" level="INFO">${message_wait} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "l "e "...</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-06-06T03:28:24.076397" elapsed="0.032912"/>
</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-06-06T03:28:24.109701" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.109439" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.109416" elapsed="0.000368"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.110234" level="INFO"> ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:28:24.109930" elapsed="0.000378"/>
</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-06-06T03:28:24.110598" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.110376" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.110357" elapsed="0.000338"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:28:24.110731" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:28:24.113380" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:28:24.113589" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.112228" elapsed="0.001515"/>
</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="NOT RUN" start="2026-06-06T03:28:24.114027" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.114363" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:24.111583" elapsed="0.002968"/>
</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-06-06T03:28:24.111041" elapsed="0.003575"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:28:24.041816" elapsed="0.072918"/>
</kw>
<msg time="2026-06-06T03:28:24.114830" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:24.114930" level="INFO">${message} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "l "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:24.041170" elapsed="0.073818"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:28:24.115196" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:28:24.115077" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.115056" elapsed="0.000230"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.115733" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.116083" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.116158" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:28:24.040470" elapsed="0.075801"/>
</kw>
<msg time="2026-06-06T03:28:24.116370" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:24.116417" level="INFO">${output} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "l "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:28:24.035622" elapsed="0.080834"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.116823" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.116536" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.116517" elapsed="0.000388"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:24.035472" elapsed="0.081459"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:24.035291" elapsed="0.081670"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:28:24.032789" elapsed="0.084231"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:28:24.027732" elapsed="0.089346"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:24.027264" elapsed="0.089863"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:28:24.023967" elapsed="0.093255"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.118014" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.117403" elapsed="0.000641"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.160685" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:24.160287" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:24.161458" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:24.161221" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:24.161624" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:24.160883" elapsed="0.000781"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.162226" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:24.161837" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:24.162558" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:24.162728" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:24.162420" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.163181" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.162934" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.164207" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.163941" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.164703" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.164419" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.165402" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.165097" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.166178" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.165954" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.166256" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:24.166428" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.165615" elapsed="0.000840"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.166613" elapsed="0.000283"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:28:24.164960" elapsed="0.001979"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.167488" level="INFO">${value} = example-bgp-peer</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.167189" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.168247" level="INFO">${encoded} = example-bgp-peer</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.168035" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.168323" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:24.168473" level="INFO">${encoded_value} = example-bgp-peer</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.167714" elapsed="0.000784"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.168705" elapsed="0.000392"/>
</kw>
<var name="${key}">BGP_NAME</var>
<var name="${value}">example-bgp-peer</var>
<status status="PASS" start="2026-06-06T03:28:24.167054" elapsed="0.002087"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.169704" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.169390" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.170447" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.170235" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.170523" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:24.170689" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.169916" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.170869" elapsed="0.000238"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:24.169254" elapsed="0.001894"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.171711" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.171396" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.172452" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.172242" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.172528" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:24.172695" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.171924" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.172875" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:24.171260" elapsed="0.001875"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:24.164782" elapsed="0.008388"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:24.173212" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:28:24.173367" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'BGP_NAME': 'example-bgp-peer', 'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:24.163595" elapsed="0.009797"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.163296" elapsed="0.010129"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.173602" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.173450" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.163276" elapsed="0.010419"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.174458" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:24.173843" elapsed="0.000644"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:24.174536" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:24.159665" elapsed="0.015011"/>
</kw>
<msg time="2026-06-06T03:28:24.174732" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.147032" elapsed="0.027747"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.187098" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.199530" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.211970" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.212174" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.212355" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.212742" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.212579" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:24.212564" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.212971" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.213251" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.213425" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:24.212536" elapsed="0.000944"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.212432" elapsed="0.001073"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.213674" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.213753" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:24.213885" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:24.142749" elapsed="0.071163"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.215043" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.214769" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:24.226272" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:24.226321" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:24.226412" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:24.217371" elapsed="0.009068"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.215156" elapsed="0.011324"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.226688" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.226507" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.215138" elapsed="0.011672"/>
</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-06-06T03:28:24.233227" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.227916" elapsed="0.005405"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.227611" elapsed="0.005788"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.227593" elapsed="0.005862"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.237396" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.234219" elapsed="0.003223"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.233578" elapsed="0.003898"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.233540" elapsed="0.003960"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.238083" 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-06-06T03:28:24.237690" elapsed="0.000420"/>
</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-06-06T03:28:24.238423" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.238181" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.239009" 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-06-06T03:28:24.238685" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.238505" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.238163" elapsed="0.000929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.239614" 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-06-06T03:28:24.239255" elapsed="0.000400"/>
</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-06-06T03:28:24.239965" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.239728" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.240495" 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-06-06T03:28:24.240204" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.240044" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.239710" elapsed="0.000870"/>
</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-06-06T03:28:24.240745" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:24.241541" 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-06-06T03:28:24.241263" elapsed="0.000304"/>
</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-06-06T03:28:24.241738" elapsed="0.002284"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:28:24.227205" elapsed="0.016879"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:24.244132" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:24.246384" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:28:24.214175" elapsed="0.032235"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:24.246464" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:28:24.118283" elapsed="0.128304"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:28:24.023334" elapsed="0.223388"/>
</test>
<test id="s1-s14-t6" name="Deconfigure_App_Peer" line="133">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:28:24.250076" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:28:24.249811" elapsed="0.000529"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.251358" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.251249" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.251229" elapsed="0.000196"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.256718" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.256585" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.256564" elapsed="0.000232"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.257913" 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-06-06T03:28:24.257489" elapsed="0.000452"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.258410" 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-06-06T03:28:24.258108" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:24.258482" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:24.258656" 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-06-06T03:28:24.257047" elapsed="0.001636"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:28:24.264168" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.264061" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.264041" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:28:24.265406" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.265299" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.265280" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:24.265947" 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-06-06T03:28:24.265621" elapsed="0.000353"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.266354" level="INFO">${current_connection_index} = 7</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-06-06T03:28:24.266137" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.295982" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:24.266928" elapsed="0.029173"/>
</kw>
<msg time="2026-06-06T03:28:24.296301" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:28:24.296349" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:28:24.266542" elapsed="0.029844"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.323687" level="INFO">". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:28:24.296986" elapsed="0.026817"/>
</kw>
<msg time="2026-06-06T03:28:24.323975" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:28:24.324021" level="INFO">${message_wait} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "c "o "...</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-06-06T03:28:24.296570" elapsed="0.027487"/>
</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-06-06T03:28:24.324395" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.324147" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.324121" elapsed="0.000354"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.324951" level="INFO"> ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:28:24.324621" elapsed="0.000400"/>
</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-06-06T03:28:24.325306" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.325087" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.325069" elapsed="0.000316"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:28:24.325421" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:28:24.328079" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:28:24.328287" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.326956" elapsed="0.001463"/>
</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="NOT RUN" start="2026-06-06T03:28:24.328920" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.329314" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:24.326295" elapsed="0.003208"/>
</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-06-06T03:28:24.325745" elapsed="0.003824"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:28:24.264997" elapsed="0.064696"/>
</kw>
<msg time="2026-06-06T03:28:24.329786" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:24.329830" level="INFO">${message} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "c "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:24.264389" elapsed="0.065478"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:28:24.330053" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:24.329945" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.329925" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.330548" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.330936" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.331010" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:28:24.263718" elapsed="0.067399"/>
</kw>
<msg time="2026-06-06T03:28:24.331210" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:24.331253" level="INFO">${output} =  ". "t "x "t ". "0 "4 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "o "u "t "e "[C "R "e "f ". "D "e "c "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:28:24.259079" elapsed="0.072211"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.331618" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.331366" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.331348" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:24.258931" elapsed="0.072807"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:24.258741" elapsed="0.073029"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:28:24.256180" elapsed="0.075646"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:28:24.250954" elapsed="0.080938"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:24.250492" elapsed="0.081446"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:28:24.247685" elapsed="0.084307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.332763" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | APP_PEER_NAME=example-bgp-peer-app | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>APP_PEER_NAME=${APP_PEER_NAME}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.332169" elapsed="0.000622"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.375251" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:24.374854" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:24.376077" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:24.375807" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:24.376252" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:24.375452" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.376842" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:24.376441" elapsed="0.000473"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:24.377225" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:24.377382" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:24.377084" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.377835" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.377568" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.378853" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.378575" elapsed="0.000349"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.379358" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.379092" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.380066" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.379769" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.381146" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.380790" elapsed="0.000383"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.381223" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:24.381377" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.380280" elapsed="0.001122"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.381559" elapsed="0.000259"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:28:24.379613" elapsed="0.002246"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.382400" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.382105" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.383253" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.383039" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.383330" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:24.383478" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.382618" elapsed="0.000884"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.383670" elapsed="0.000225"/>
</kw>
<var name="${key}">APP_PEER_NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:28:24.381971" elapsed="0.001965"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.384481" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.384180" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.385231" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.385022" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.385307" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:24.385454" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.384706" elapsed="0.000772"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.385630" elapsed="0.000238"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:24.384047" elapsed="0.001864"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.386589" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:24.386295" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:24.387373" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.387163" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:24.387486" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:24.387655" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:24.386821" elapsed="0.000861"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.387838" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:24.386022" elapsed="0.002083"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:24.379436" elapsed="0.008704"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:24.388182" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:24.388340" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:24.378253" elapsed="0.010113"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.377952" elapsed="0.010446"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.388573" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.388423" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.377933" elapsed="0.010732"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.389468" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:24.388822" elapsed="0.000675"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:24.389547" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:24.374220" elapsed="0.015469"/>
</kw>
<msg time="2026-06-06T03:28:24.389745" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.361572" elapsed="0.028220"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.402255" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.414603" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.426871" elapsed="0.000051"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.427103" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.427283" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.427663" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.427503" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:24.427489" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.428008" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.428189" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.428365" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:24.427461" elapsed="0.000958"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.427360" elapsed="0.001085"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.428593" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.428690" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:24.428814" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:24.357238" elapsed="0.071602"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.429937" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.429685" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:24.439129" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0fwets94ac0wa14d6v2di5d9y023.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:24.439177" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:24.439267" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:24.432095" elapsed="0.007199"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.430050" elapsed="0.009284"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:24.439512" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.439360" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.430032" elapsed="0.009562"/>
</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-06-06T03:28:24.442956" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.440595" elapsed="0.002405"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.440373" elapsed="0.002662"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.440354" elapsed="0.002706"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.445724" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.443340" elapsed="0.002431"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.443116" elapsed="0.002710"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.443099" elapsed="0.002762"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.446628" 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-06-06T03:28:24.446099" elapsed="0.000588"/>
</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-06-06T03:28:24.447151" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.446788" elapsed="0.000445"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.447942" 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-06-06T03:28:24.447496" elapsed="0.000483"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.447266" elapsed="0.000762"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.446762" elapsed="0.001295"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.448875" 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-06-06T03:28:24.448333" elapsed="0.000581"/>
</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-06-06T03:28:24.449344" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.449012" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.450118" 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-06-06T03:28:24.449704" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.449458" elapsed="0.000747"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.448987" elapsed="0.001248"/>
</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-06-06T03:28:24.450447" elapsed="0.000524"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:24.451597" 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-06-06T03:28:24.451210" elapsed="0.000425"/>
</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-06-06T03:28:24.451883" elapsed="0.003474"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:28:24.439970" elapsed="0.015477"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:24.455512" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:28:24.457895" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:28:24.429100" elapsed="0.028826"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:24.457989" elapsed="0.000035"/>
</return>
<arg>${BGP_VAR_FOLDER}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:28:24.333025" elapsed="0.125104"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:28:24.247120" elapsed="0.211136"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Virtual_Env_Delete" 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-06-06T03:28:24.464519" level="INFO">${cd_and_command} = cd '.' &amp;&amp; rm -rf /tmp/defaultvenv</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-06-06T03:28:24.464189" elapsed="0.000357"/>
</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-06-06T03:28:24.466020" level="INFO">Executing command 'cd '.' &amp;&amp; rm -rf /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:28:24.499451" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:24.499740" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:28:24.499852" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:28:24.499944" 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-06-06T03:28:24.465821" elapsed="0.034174"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.501835" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:28:24.501204" elapsed="0.000735"/>
</kw>
<msg time="2026-06-06T03:28:24.502152" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:28:24.502249" 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-06-06T03:28:24.500402" elapsed="0.001898"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.503705" 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-06-06T03:28:24.502709" elapsed="0.001058"/>
</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-06-06T03:28:24.506184" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.505599" elapsed="0.000678"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.507242" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.506620" elapsed="0.000713"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.508006" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.507705" elapsed="0.000345"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:28:24.504814" elapsed="0.003290"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:24.504013" elapsed="0.004127"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.503963" elapsed="0.004203"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.508323" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.508222" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.508205" elapsed="0.000247"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:28:24.508599" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:28:24.508508" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.508492" elapsed="0.000211"/>
</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-06-06T03:28:24.508854" 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-06-06T03:28:24.465252" elapsed="0.043721"/>
</kw>
<msg time="2026-06-06T03:28:24.509026" 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-06-06T03:28:24.464726" elapsed="0.044363"/>
</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 rm -rf /tmp/defaultvenv.
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-06-06T03:28:24.463568" elapsed="0.045600"/>
</kw>
<msg time="2026-06-06T03:28:24.509218" 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-06-06T03:28:24.459773" elapsed="0.049501"/>
</kw>
<arg>rm -rf ${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-06-06T03:28:24.459399" elapsed="0.049951"/>
</kw>
<doc>Deletes a directory with virtual env.</doc>
<status status="PASS" start="2026-06-06T03:28:24.459163" elapsed="0.050239"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:28:24.509550" elapsed="0.000400"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:24.510185" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:28:24.510109" elapsed="0.000167"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:28:24.458862" elapsed="0.051466"/>
</kw>
<doc>Functional test for bgp - route refresh

Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests sending and receiveing route refresh message.
It uses odl and exabgp as bgp peers.
Sending route refresh message from odl is initiated via restconf.
If route refresh is received by odl, correct advertising of routes
is verified. Receiving of route refresh by odl is verified by
checking appropriate message counter via odl-bgpcep-bgp-cli and
restconf using BGP neighbor operational state</doc>
<status status="FAIL" start="2026-06-06T03:27:36.936503" elapsed="47.573853"/>
</suite>
<suite id="s1-s15" name="020 Bgp Functional Multipath" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/020_bgp_functional_multipath.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.602566" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:28:24.598108" elapsed="0.004512"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:28:24.597876" elapsed="0.004830"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.607682" 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-06-06T03:28:24.603828" elapsed="0.003884"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:24.607926" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.607798" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.607774" elapsed="0.000222"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.608510" 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-06-06T03:28:24.608153" elapsed="0.000400"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.609049" 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-06-06T03:28:24.608734" elapsed="0.000341"/>
</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-06-06T03:28:24.609591" elapsed="0.000301"/>
</kw>
<msg time="2026-06-06T03:28:24.609990" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:24.610037" 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-06-06T03:28:24.609245" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.610605" 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-06-06T03:28:24.610234" elapsed="0.000397"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.611726" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:28:24.611442" elapsed="0.000312"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.612168" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:28:24.611907" elapsed="0.000287"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.612695" 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-06-06T03:28:24.612379" elapsed="0.000345"/>
</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-06-06T03:28:24.616100" elapsed="0.000210"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.616820" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:28:24.616473" elapsed="0.000374"/>
</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-06-06T03:28:24.617004" elapsed="0.000228"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.618044" 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-06-06T03:28:24.617747" elapsed="0.000323"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:28:24.618116" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:28:24.618274" 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-06-06T03:28:24.617428" elapsed="0.000871"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:24.618918" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e4737b10&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-06-06T03:28:24.618455" elapsed="0.000605"/>
</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-06-06T03:28:24.619225" elapsed="0.000189"/>
</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-06-06T03:28:24.615506" elapsed="0.003966"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:24.615315" elapsed="0.004201"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:28:24.612779" elapsed="0.006768"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.620134" 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-06-06T03:28:24.619731" elapsed="0.000447"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.620757" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:28:24.620342" elapsed="0.000460"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.621354" 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-06-06T03:28:24.620970" elapsed="0.000427"/>
</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-06-06T03:28:24.610984" elapsed="0.010470"/>
</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-06-06T03:28:24.603465" elapsed="0.018043"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.621711" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.621572" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.621553" elapsed="0.000226"/>
</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-06-06T03:28:24.624984" 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-06-06T03:28:24.624585" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.625468" 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-06-06T03:28:24.625174" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:24.625538" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:24.625708" 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-06-06T03:28:24.624231" elapsed="0.001502"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:24.626780" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:28:24.626495" elapsed="0.000315"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.627661" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:28:24.627767" 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-06-06T03:28:24.627480" elapsed="0.000314"/>
</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-06-06T03:28:24.631358" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:24.630762" elapsed="0.000685"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.630742" elapsed="0.000743"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.632140" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:28:24.631703" elapsed="0.000719"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.633371" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.632705" elapsed="0.000770"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.634671" 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-06-06T03:28:24.633766" elapsed="0.000958"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.636441" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:28:24.636619" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:28:24.636091" elapsed="0.000587"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.637019" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.638610" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:28:24.957725" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:27:37 UTC 2026

  System load:  0.0                Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:27:37 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:28:24.638287" elapsed="0.319592"/>
</kw>
<msg time="2026-06-06T03:28:24.957963" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.637839" elapsed="0.320287"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:28:24.635190" elapsed="0.323081"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:24.959177" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:28:24.972159" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:28:24.972524" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:28:24.972795" 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-06-06T03:28:24.958666" elapsed="0.014242"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:28:24.973577" elapsed="0.001166"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.976887" 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-06-06T03:28:24.976026" elapsed="0.001094"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.977761" elapsed="0.000079"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:24.977369" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.977332" elapsed="0.000675"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:28:24.978456" elapsed="0.000091"/>
</return>
<status status="PASS" start="2026-06-06T03:28:24.978125" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:24.978100" elapsed="0.000648"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:28:24.978836" elapsed="0.000025"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.983999" elapsed="0.000692"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.985106" elapsed="0.000412"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:28:24.985928" elapsed="0.000325"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:24.979552" elapsed="0.006802"/>
</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-06-06T03:28:24.629813" elapsed="0.356799"/>
</kw>
<msg time="2026-06-06T03:28:24.986716" 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-06-06T03:28:24.628975" elapsed="0.357821"/>
</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-06-06T03:28:24.628467" elapsed="0.358449"/>
</kw>
<msg time="2026-06-06T03:28:24.987016" 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-06-06T03:28:24.627956" elapsed="0.359129"/>
</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-06-06T03:28:24.990108" elapsed="0.000361"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:28:24.990637" elapsed="0.000166"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:28:24.990972" elapsed="0.000098"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:24.987520" elapsed="0.003600"/>
</kw>
<msg time="2026-06-06T03:28:24.991212" 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-06-06T03:28:24.627096" elapsed="0.364141"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:24.991701" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:24.991420" elapsed="0.000323"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:28:24.991786" elapsed="0.000029"/>
</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-06-06T03:28:24.626140" elapsed="0.365770"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:24.625965" elapsed="0.365982"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:24.625829" elapsed="0.366153"/>
</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-06-06T03:28:24.621999" elapsed="0.370040"/>
</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-06-06T03:28:24.992196" elapsed="0.000211"/>
</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-06-06T03:28:25.006684" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:25.006556" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.006536" elapsed="0.000217"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.007089" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:28:25.007194" 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-06-06T03:28:25.006910" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.007632" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:25.007377" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.008142" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:25.007896" elapsed="0.000291"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:25.009143" 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-06-06T03:28:25.008729" elapsed="0.000524">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:28:25.009360" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:25.009405" 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-06-06T03:28:25.008348" elapsed="0.001080"/>
</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-06-06T03:28:25.009750" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:25.009504" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.009486" elapsed="0.000364"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:25.010629" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:28:25.010366" elapsed="0.000307"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:28:25.010723" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:25.010873" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:28:25.010070" elapsed="0.000827"/>
</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-06-06T03:28:25.011223" elapsed="0.000399"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.011915" level="INFO">index=4
host=10.30.170.38
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-06-06T03:28:25.012015" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:28:25.011809" elapsed="0.000231"/>
</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-06-06T03:28:25.012190" elapsed="0.002393"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.015046" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:28:25.129001" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:28:25.014772" elapsed="0.114349"/>
</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-06-06T03:28:25.132358" elapsed="0.000364"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:28:25.132891" elapsed="0.000155"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:28:25.133195" elapsed="0.000099"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:25.130054" elapsed="0.003293"/>
</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-06-06T03:28:25.129445" elapsed="0.003948"/>
</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-06-06T03:28:25.006275" elapsed="0.127169"/>
</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-06-06T03:28:24.993143" elapsed="0.140347"/>
</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-06-06T03:28:24.992768" elapsed="0.140773"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:24.992610" elapsed="0.141019"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:28:24.992463" elapsed="0.141220"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:28:24.603018" elapsed="0.530725"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:25.136548" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:25.136432" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.136410" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:25.141558" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:25.141451" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.141433" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.142598" 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-06-06T03:28:25.142212" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.143270" 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-06-06T03:28:25.142965" elapsed="0.000331"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:25.143342" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:25.143501" 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-06-06T03:28:25.141876" elapsed="0.001650"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:28:25.149311" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:25.149187" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.149164" elapsed="0.000222"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:28:25.150703" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:25.150549" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.150530" elapsed="0.000244"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:25.151309" 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-06-06T03:28:25.150972" elapsed="0.000365"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.151775" 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-06-06T03:28:25.151526" elapsed="0.000276"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.198262" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:25.152467" elapsed="0.046164"/>
</kw>
<msg time="2026-06-06T03:28:25.199076" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:28:25.199187" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:28:25.151965" elapsed="0.047309"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.272199" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "2 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "m "u "l "t "i "p "a "t "h ". "r "o "b "o "t "[K"
[?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-06-06T03:28:25.200687" elapsed="0.071824"/>
</kw>
<msg time="2026-06-06T03:28:25.272769" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:28:25.272822" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:28:25.199781" elapsed="0.073082"/>
</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-06-06T03:28:25.273437" elapsed="0.000062"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:25.273002" elapsed="0.000600"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.272965" elapsed="0.000669"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.274306" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "2 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "m "u "l "t "i "p "a "t "h ". "r "o "b "o "t "[K"
[?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-06-06T03:28:25.273809" elapsed="0.000690"/>
</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-06-06T03:28:25.274862" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:25.274573" elapsed="0.000498"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.274553" elapsed="0.000549"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:28:25.275145" 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-06-06T03:28:25.277761" elapsed="0.000495"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:28:25.278620" elapsed="0.000445"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:28:25.279443" elapsed="0.000489"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:25.276867" elapsed="0.003172"/>
</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-06-06T03:28:25.275514" elapsed="0.004686"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:28:25.150261" elapsed="0.130055"/>
</kw>
<msg time="2026-06-06T03:28:25.280432" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:25.280487" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:25.149560" elapsed="0.130971"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:28:25.280761" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:28:25.280620" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.280598" elapsed="0.000261"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:25.281300" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:25.281667" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:28:25.281743" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:28:25.148840" elapsed="0.133017"/>
</kw>
<msg time="2026-06-06T03:28:25.281957" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:25.282004" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:28:25.143916" elapsed="0.138128"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:25.282382" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:25.282121" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.282103" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:25.143770" elapsed="0.138714"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:25.143580" elapsed="0.138939"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:28:25.141159" elapsed="0.141422"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:28:25.134342" elapsed="0.148315"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:25.133903" elapsed="0.148804"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:28:24.597543" elapsed="0.685217"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.283312" level="INFO">${tools_system_conn_id} = 7</msg>
<var>${tools_system_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:28:25.282916" elapsed="0.000422"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.283870" level="INFO">${tools_system_conn_id} = 7</msg>
<arg>${tools_system_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:28:25.283512" elapsed="0.000404"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:28:25.285692" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:28:25.285770" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:28:25.285392" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:25.286017" elapsed="0.000578"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:28:25.287546" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:28:25.619852" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:27:38 UTC 2026

  System load:  0.02               Processes:             106
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:27:38 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:28:25.287219" elapsed="0.332848"/>
</kw>
<msg time="2026-06-06T03:28:25.620185" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:25.286792" elapsed="0.333494"/>
</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-06-06T03:28:25.284945" elapsed="0.335497"/>
</kw>
<msg time="2026-06-06T03:28:25.620517" 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-06-06T03:28:25.284487" elapsed="0.336094"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:28:25.284114" elapsed="0.336594"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:28:25.627804" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:28:25.627447" elapsed="0.000384"/>
</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-06-06T03:28:25.629285" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:28:25.904838" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:25.905205" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 126ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:28:25.905312" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:28:25.905404" 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-06-06T03:28:25.629098" elapsed="0.276359"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.907546" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:28:25.906896" elapsed="0.000789"/>
</kw>
<msg time="2026-06-06T03:28:25.907905" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:28:25.908007" 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-06-06T03:28:25.906004" elapsed="0.002055"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.909454" 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-06-06T03:28:25.908445" elapsed="0.001069"/>
</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-06-06T03:28:25.912506" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 126ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:25.911937" elapsed="0.000681"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.913555" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:25.913007" elapsed="0.000672"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:25.914574" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:25.914032" elapsed="0.000673"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:28:25.910537" elapsed="0.004295"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:25.909731" elapsed="0.005186"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.909678" elapsed="0.005397"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:28:25.915507" elapsed="0.000040"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:25.915259" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.915215" elapsed="0.000640"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:28:25.916009" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:28:25.915913" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:25.915896" elapsed="0.000205"/>
</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-06-06T03:28:25.916253" 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-06-06T03:28:25.628525" elapsed="0.287850"/>
</kw>
<msg time="2026-06-06T03:28:25.916433" 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-06-06T03:28:25.627995" elapsed="0.288488"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:28:25.626797" elapsed="0.289796"/>
</kw>
<msg time="2026-06-06T03:28:25.916664" 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-06-06T03:28:25.622130" elapsed="0.294579"/>
</kw>
<arg>virtualenv ${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-06-06T03:28:25.621585" elapsed="0.295229"/>
</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-06-06T03:28:25.923568" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/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-06-06T03:28:25.923239" elapsed="0.000357"/>
</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-06-06T03:28:25.925431" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install --upgrade pip; deactivate'.</msg>
<msg time="2026-06-06T03:28:28.081701" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:28.082086" level="INFO">${stdout} = Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
Installing collected packages: pip
  Att...</msg>
<msg time="2026-06-06T03:28:28.082194" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:28:28.082292" 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-06-06T03:28:25.925083" elapsed="2.157264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.085773" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:28:28.085135" elapsed="0.000794"/>
</kw>
<msg time="2026-06-06T03:28:28.086139" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:28:28.086238" 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-06-06T03:28:28.082893" elapsed="0.003397"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.088245" 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-06-06T03:28:28.086675" elapsed="0.001628"/>
</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-06-06T03:28:28.091749" level="INFO">Requirement already satisfied: pip in /tmp/defaultvenv/lib/python3.10/site-packages (22.0.2)
Collecting pip
  Using cached pip-26.1.2-py3-none-any.whl (1.8 MB)
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.1.2</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:28.091126" elapsed="0.000768"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.092937" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:28.092404" elapsed="0.000665"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.094099" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:28.093574" elapsed="0.000658"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:28:28.089845" elapsed="0.004517"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:28.088556" elapsed="0.005948"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:28.088519" elapsed="0.006025"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:28:28.094973" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:28.094626" elapsed="0.000615"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:28.094601" elapsed="0.000693"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:28:28.095629" elapsed="0.000203"/>
</return>
<status status="PASS" start="2026-06-06T03:28:28.095383" elapsed="0.000583"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:28.095357" elapsed="0.000639"/>
</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-06-06T03:28:28.096154" 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-06-06T03:28:25.924415" elapsed="2.171930"/>
</kw>
<msg time="2026-06-06T03:28:28.096405" 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-06-06T03:28:25.923777" elapsed="2.172684"/>
</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/defaultvenv/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-06-06T03:28:25.922585" elapsed="2.173960"/>
</kw>
<msg time="2026-06-06T03:28:28.096599" 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-06-06T03:28:25.918734" elapsed="2.177926"/>
</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-06-06T03:28:25.918167" elapsed="2.178860"/>
</kw>
<msg time="2026-06-06T03:28:28.097082" 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-06-06T03:28:25.917781" elapsed="2.179349"/>
</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-06-06T03:28:25.917423" elapsed="2.179785"/>
</kw>
<msg time="2026-06-06T03:28:28.097251" 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-06-06T03:28:25.916975" elapsed="2.180320"/>
</kw>
<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-06-06T03:28:25.621124" elapsed="2.476245"/>
</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-06-06T03:28:28.105726" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:28:28.104956" elapsed="0.000837"/>
</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-06-06T03:28:28.108769" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install setuptools==44.0.0; deactivate'.</msg>
<msg time="2026-06-06T03:28:28.964181" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:28.964765" level="INFO">${stdout} = Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setupt...</msg>
<msg time="2026-06-06T03:28:28.964879" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:28:28.964976" 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-06-06T03:28:28.108399" elapsed="0.856634"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.969886" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:28:28.968633" elapsed="0.001500"/>
</kw>
<msg time="2026-06-06T03:28:28.970460" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:28:28.970558" 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-06-06T03:28:28.965740" elapsed="0.004869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.973088" 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-06-06T03:28:28.971178" elapsed="0.001970"/>
</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-06-06T03:28:28.976924" level="INFO">Collecting setuptools==44.0.0
  Using cached setuptools-44.0.0-py2.py3-none-any.whl.metadata (3.7 kB)
Using cached setuptools-44.0.0-py2.py3-none-any.whl (583 kB)
Installing collected packages: setuptools
  Attempting uninstall: setuptools
    Found existing installation: setuptools 59.6.0
    Uninstalling setuptools-59.6.0:
      Successfully uninstalled setuptools-59.6.0
Successfully installed setuptools-44.0.0</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:28.976577" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.977613" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:28.977297" elapsed="0.000477"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:28.978395" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:28.978081" elapsed="0.000382"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:28:28.975383" elapsed="0.003152"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:28.973566" elapsed="0.005063"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:28.973510" elapsed="0.005163"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:28:28.978877" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:28.978733" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:28.978715" elapsed="0.000300"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:28:28.979225" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:28:28.979074" elapsed="0.000268"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:28.979057" elapsed="0.000314"/>
</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-06-06T03:28:28.979521" 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-06-06T03:28:28.107578" elapsed="0.872099"/>
</kw>
<msg time="2026-06-06T03:28:28.979735" 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-06-06T03:28:28.106157" elapsed="0.873632"/>
</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/defaultvenv/bin/activate; pip install setuptools==44.0.0; 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-06-06T03:28:28.103766" elapsed="0.876119"/>
</kw>
<msg time="2026-06-06T03:28:28.979940" 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-06-06T03:28:28.099740" elapsed="0.880246"/>
</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-06-06T03:28:28.099036" elapsed="0.881041"/>
</kw>
<msg time="2026-06-06T03:28:28.980127" 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-06-06T03:28:28.098627" elapsed="0.881544"/>
</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-06-06T03:28:28.098238" elapsed="0.882022"/>
</kw>
<msg time="2026-06-06T03:28:28.980304" 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-06-06T03:28:28.097854" elapsed="0.882492"/>
</kw>
<arg>setuptools==44.0.0</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-06-06T03:28:28.097572" elapsed="0.882855"/>
</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-06-06T03:28:28.988189" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:28:28.987855" elapsed="0.000363"/>
</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-06-06T03:28:28.990028" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==3.4.16; deactivate'.</msg>
<msg time="2026-06-06T03:28:30.543697" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:30.544284" level="INFO">${stdout} = Collecting exabgp==3.4.16
  Using cached exabgp-3.4.16.tar.gz (240 kB)
  Installing build dependencies: started
  Installing build dependencies: finished with status 'done'
  Getting requirements to b...</msg>
<msg time="2026-06-06T03:28:30.544535" level="INFO">${stderr} =   error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        ...</msg>
<msg time="2026-06-06T03:28:30.544694" 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-06-06T03:28:28.989612" elapsed="1.555143"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:28:30.549072" level="INFO">Length is 1821.</msg>
<msg time="2026-06-06T03:28:30.549782" level="FAIL">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:28:30.548243" elapsed="0.001870">'  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel' should be empty.</status>
</kw>
<msg time="2026-06-06T03:28:30.550385" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:28:30.550461" level="INFO">${result} = '  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
       ...</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-06-06T03:28:30.545437" elapsed="0.005067"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:30.552443" 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-06-06T03:28:30.550901" elapsed="0.001583"/>
</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-06-06T03:28:30.556116" level="INFO">Collecting exabgp==3.4.16
  Using cached exabgp-3.4.16.tar.gz (240 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 'error'</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:30.555558" elapsed="0.000669"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:30.557175" level="INFO">  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─&gt; [19 lines of output]
      Traceback (most recent call last):
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 389, in &lt;module&gt;
          main()
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 373, in main
          json_out["return_val"] = hook(**hook_input["kwargs"])
        File "/tmp/defaultvenv/lib/python3.10/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 143, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 333, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 301, in _get_build_requires
          self.run_setup()
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 520, in run_setup
          super().run_setup(setup_script=setup_script)
        File "/tmp/pip-build-env-2afx537q/overlay/lib/python3.10/site-packages/setuptools/build_meta.py", line 317, in run_setup
          exec(code, locals())
        File "&lt;string&gt;", line 40
          print """\
          ^^^^^^^^^
      SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?
      [end of output]
  
  note: This error originates from a subprocess, and is likely not a problem with pip.
ERROR: Failed to build 'exabgp' when getting requirements to build wheel</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:30.556694" elapsed="0.000747"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:30.558419" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:30.557939" elapsed="0.000582"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:28:30.553932" elapsed="0.004696"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:30.552721" elapsed="0.006207"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:30.552680" elapsed="0.006298"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:28:30.559385" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:30.559078" elapsed="0.000452"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:30.559049" elapsed="0.000520"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:28:30.559871" elapsed="0.000050"/>
</return>
<status status="PASS" start="2026-06-06T03:28:30.559672" elapsed="0.000357"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:30.559627" elapsed="0.000430"/>
</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-06-06T03:28:30.560214" 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-06-06T03:28:28.989000" elapsed="1.571363"/>
</kw>
<msg time="2026-06-06T03:28:30.560424" 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-06-06T03:28:28.988381" elapsed="1.572100"/>
</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/defaultvenv/bin/activate; pip install exabgp==3.4.16; 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-06-06T03:28:28.987226" elapsed="1.573353"/>
</kw>
<msg time="2026-06-06T03:28:30.560636" 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-06-06T03:28:28.983151" elapsed="1.577551"/>
</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-06-06T03:28:28.982505" elapsed="1.578290"/>
</kw>
<msg time="2026-06-06T03:28:30.560846" 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-06-06T03:28:28.982067" elapsed="1.578824"/>
</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-06-06T03:28:28.981605" elapsed="1.579373"/>
</kw>
<msg time="2026-06-06T03:28:30.561022" 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-06-06T03:28:28.981171" elapsed="1.579896"/>
</kw>
<arg>exabgp==3.4.16</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-06-06T03:28:28.980627" elapsed="1.580521"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:30.561625" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5a26350&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:28:30.561316" elapsed="0.002300"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.586914" level="INFO">[chan 5] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:28:30.596895" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/exa.cfg' -&gt; '/home/jenkins//exa.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${DEFAUTL_RPC_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:28:30.564176" elapsed="0.032838"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.603505" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/exabgp_files/exarpc.py' -&gt; '/home/jenkins//exarpc.py'</msg>
<arg>${EXARPCSCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:28:30.597359" elapsed="0.006236"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.611663" level="INFO">6 files:
bgp-flowspec-redirect.cfg
bgp-flowspec.cfg
bgp-l3vpn-ipv4.cfg
exa-md5.cfg
exa.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:28:30.611869" level="INFO">@{cfgfiles} = [ bgp-flowspec-redirect.cfg | bgp-flowspec.cfg | bgp-l3vpn-ipv4.cfg | exa-md5.cfg | exa.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:28:30.603880" elapsed="0.008029"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.612894" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:30.624736" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.612614" elapsed="0.012256"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.625765" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:30.673013" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.625309" elapsed="0.047904"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.674135" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:30.721145" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.673737" elapsed="0.047572"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.722262" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:30.769485" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.721811" elapsed="0.047912"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.770601" level="INFO">Executing command 'cat bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:30.817099" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:30.817350" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.770218" elapsed="0.047223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:30.818713" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;

        }
        then {
            redirect 65500:12345;
        }
    }
    route flow2 {
        match {
            source 10.0.0.2/32;
            destination 192.168.0.2/32;

        }
        then {
                redirect 1.2.3.4;
        }
    }
    route flow4 {
        match {
            source 10.0.0.4/32;
            destination 192.168.0.4/32;

        }
        next-hop 127.0.0.1;
        then {
                redirect-to-nexthop;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:30.817991" elapsed="0.000847"/>
</kw>
<var name="${cfgfile}">bgp-flowspec-redirect.cfg</var>
<status status="PASS" start="2026-06-06T03:28:30.612393" elapsed="0.206531"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.820063" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:30.864932" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.819625" elapsed="0.045447"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.865921" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:30.913160" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.865473" elapsed="0.047878"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.914243" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:30.961306" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.913858" elapsed="0.047649"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:30.962483" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:31.009892" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:30.962029" elapsed="0.048025"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.010724" level="INFO">Executing command 'cat bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:31.057476" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:31.057832" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.010414" elapsed="0.047480"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:31.059124" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;
            port =80;
            destination-port &gt;8080&amp;&lt;8088;
            source-port &gt;1024;
            protocol tcp;
            packet-length &gt;400&amp;&lt;500;
            fragment =first-fragment;
            icmp-type echo-reply;
            icmp-code network-unreachable;
            tcp-flags =urgent;
            dscp 20;
        }
        then {
            action sample-terminal;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:31.058409" elapsed="0.000968"/>
</kw>
<var name="${cfgfile}">bgp-flowspec.cfg</var>
<status status="PASS" start="2026-06-06T03:28:30.819273" elapsed="0.240191"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.061029" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:31.106048" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.060584" elapsed="0.045685"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.107405" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:31.157427" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.106792" elapsed="0.050835"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.158564" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:31.209118" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.158164" elapsed="0.051089"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.210052" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:31.257201" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.209636" elapsed="0.047700"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.258066" level="INFO">Executing command 'cat bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:31.305234" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:31.305455" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.257755" elapsed="0.047759"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:31.306629" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255.254;
      rd 1.2.3.4:1;
      label 24005;
    }
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:31.306005" elapsed="0.000759"/>
</kw>
<var name="${cfgfile}">bgp-l3vpn-ipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:28:31.060243" elapsed="0.246598"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.307857" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:31.353078" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.307460" elapsed="0.045746"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.353988" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:31.401683" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.353574" elapsed="0.048250"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.402525" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:31.449832" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.402206" elapsed="0.047769"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.450783" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:31.497620" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.450358" elapsed="0.047449"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.498560" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:31.545709" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:31.545940" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.498232" elapsed="0.047772"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:31.547075" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:31.546439" elapsed="0.000769"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:28:31.307116" elapsed="0.240170"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.548270" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:31.593299" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.547896" elapsed="0.045544"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.594261" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:31.641821" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.593867" elapsed="0.048095"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.642724" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:31.694315" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.642355" elapsed="0.052101"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.695304" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:31.745525" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.694886" elapsed="0.050814"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.746419" level="INFO">Executing command 'cat exa.cfg'.</msg>
<msg time="2026-06-06T03:28:31.797264" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:31.797495" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 un...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.746099" elapsed="0.051456"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:31.798608" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
    ipv4 mpls-vpn;
  }

  process exarpcserver {
    run exarpc.py --host 10.30.171.194;
    encoder json;
    receive-routes;
    neighbor-changes;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:31.798020" elapsed="0.000736"/>
</kw>
<var name="${cfgfile}">exa.cfg</var>
<status status="PASS" start="2026-06-06T03:28:31.547550" elapsed="0.251282"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.799840" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:31.845761" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.799431" elapsed="0.046470"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.846708" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:31.893325" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.846287" elapsed="0.047176"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.894211" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:31.941368" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.893887" elapsed="0.047622"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.942319" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:31.993931" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.941935" elapsed="0.052143"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:31.994835" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:32.046395" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:32.046742" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:31.994467" elapsed="0.052340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.048034" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.047344" elapsed="0.000800"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:28:31.799090" elapsed="0.249134"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:28:30.612122" elapsed="1.436178"/>
</for>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:28:30.563890" elapsed="1.484550"/>
</kw>
<kw name="Store_Rib_Configuration">
<kw name="Get_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.103041" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.102656" elapsed="0.000414"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.103902" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.103608" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.104075" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.103266" elapsed="0.000833"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.104664" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.104266" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.104994" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:32.105170" level="INFO">${template} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:32.104856" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.105665" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.105405" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.106636" level="INFO">mapping: {'ODLIP': '10.30.170.38', 'EXAIP': '10.30.171.194', 'NPATHS': '2'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.106376" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.107133" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.106859" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.108025" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.107542" elapsed="0.000511"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.109041" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.108601" elapsed="0.000550"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.109435" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:28:32.109622" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.108241" elapsed="0.001422"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.109824" elapsed="0.000466"/>
</kw>
<var name="${key}">ODLIP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:32.107403" elapsed="0.002929"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.111018" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.110580" elapsed="0.000463"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.112227" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.111813" elapsed="0.000524"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.112608" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:28:32.112805" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.111443" elapsed="0.001388"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.112986" elapsed="0.000426"/>
</kw>
<var name="${key}">EXAIP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:32.110445" elapsed="0.003009"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.114138" level="INFO">${value} = 2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.113719" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.115502" level="INFO">${encoded} = 2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.114876" elapsed="0.000736"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.115901" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:28:32.116078" level="INFO">${encoded_value} = 2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.114348" elapsed="0.001756"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.116258" elapsed="0.000497"/>
</kw>
<var name="${key}">NPATHS</var>
<var name="${value}">2</var>
<status status="PASS" start="2026-06-06T03:28:32.113569" elapsed="0.003228"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.107224" elapsed="0.009608"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.116874" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:32.117032" level="INFO">${mapping_to_use} = {'ODLIP': '10.30.170.38', 'EXAIP': '10.30.171.194', 'NPATHS': '2'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:32.106100" elapsed="0.010958"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.105790" elapsed="0.011299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.117266" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.117114" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.105768" elapsed="0.011574"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.117967" level="INFO">${final_text} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:32.117488" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.118045" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:32.102070" elapsed="0.016099"/>
</kw>
<msg time="2026-06-06T03:28:32.118261" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.089102" elapsed="0.029207"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.131228" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.143964" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.156762" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.156987" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.157176" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.157569" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.157419" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:32.157403" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.157813" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.157984" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.158151" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:32.157369" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.157256" elapsed="0.000975"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.158379" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.158456" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:32.158588" level="INFO">${uri} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.084563" elapsed="0.074053"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.160021" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.159687" elapsed="0.000410">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.160191" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.159301" elapsed="0.000914"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.160543" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.160285" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.161123" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.160827" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.160624" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.160267" elapsed="0.000939"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.163566" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.161360" elapsed="0.002233"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:32.163659" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.163817" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:32.158968" elapsed="0.004874"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.165025" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.164785" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_config/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.165183" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.164430" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:28:32.165413" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:28:32.165277" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.165259" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.165659" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.165837" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.165902" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:32.168088" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_config/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:32.164152" elapsed="0.003962"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.169471" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.169220" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.169941" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.169691" elapsed="0.000294"/>
</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-06-06T03:28:32.201724" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:32.203652" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib?content=config 
 status=200, reason=OK 
 headers={'Set-Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:28:32 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Cache-Control': 'no-cache', 'Content-Type': 'application/xml', 'Transfer-Encoding': 'chunked'} 
 body=&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;&lt;peer-groups&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;internal-neighbor&lt;/peer-group-name&gt;&lt;route-reflector&gt;&lt;config&gt;&lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;&lt;/config&gt;&lt;/route-reflector&gt;&lt;timers&gt;&lt;config&gt;&lt;hold-time&gt;180.0&lt;/hold-time&gt;&lt;connect-retry&gt;10.0&lt;/connect-retry&gt;&lt;/config&gt;&lt;/timers&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;64496&lt;/peer-as&gt;&lt;/config&gt;&lt;/peer-group&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;external-neighbor&lt;/peer-group-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;65000&lt;/peer-as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/peer-group&gt;&lt;/peer-groups&gt;&lt;global&gt;&lt;apply-policy&gt;&lt;config&gt;&lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;&lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;&lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;&lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;&lt;/config&gt;&lt;/apply-policy&gt;&lt;config&gt;&lt;router-id&gt;192.0.2.2&lt;/router-id&gt;&lt;as&gt;64496&lt;/as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/global&gt;&lt;neighbors&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.1&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.5&lt;/neighbor-address&gt;&lt;config&gt;&lt;local-as&gt;65001&lt;/local-as&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="external-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.6&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;application-peers&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;/neighbors&gt;&lt;/bgp&gt;&lt;/protocol&gt; 
 </msg>
<msg time="2026-06-06T03:28:32.204048" 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-06-06T03:28:32.172163" elapsed="0.031950"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.170052" elapsed="0.034157"/>
</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-06-06T03:28:32.204748" elapsed="0.000065"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.204268" elapsed="0.000647"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.170033" elapsed="0.034931"/>
</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-06-06T03:28:32.212774" level="INFO">&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;&lt;peer-groups&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;internal-neighbor&lt;/peer-group-name&gt;&lt;route-reflector&gt;&lt;config&gt;&lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;&lt;/config&gt;&lt;/route-reflector&gt;&lt;timers&gt;&lt;config&gt;&lt;hold-time&gt;180.0&lt;/hold-time&gt;&lt;connect-retry&gt;10.0&lt;/connect-retry&gt;&lt;/config&gt;&lt;/timers&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;64496&lt;/peer-as&gt;&lt;/config&gt;&lt;/peer-group&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;external-neighbor&lt;/peer-group-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;65000&lt;/peer-as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/peer-group&gt;&lt;/peer-groups&gt;&lt;global&gt;&lt;apply-policy&gt;&lt;config&gt;&lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;&lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;&lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;&lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;&lt;/config&gt;&lt;/apply-policy&gt;&lt;config&gt;&lt;router-id&gt;192.0.2.2&lt;/router-id&gt;&lt;as&gt;64496&lt;/as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/global&gt;&lt;neighbors&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.1&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.5&lt;/neighbor-address&gt;&lt;config&gt;&lt;local-as&gt;65001&lt;/local-as&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="external-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.6&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;application-peers&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;/neighbors&gt;&lt;/bgp&gt;&lt;/protocol&gt;</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.207317" elapsed="0.005658"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.206790" elapsed="0.006222"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.206746" elapsed="0.006292"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.215788" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.213321" elapsed="0.002515"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.213095" elapsed="0.002776"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.213078" elapsed="0.002818"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.216475" 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-06-06T03:28:32.216072" elapsed="0.000431"/>
</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-06-06T03:28:32.216833" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.216573" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.217376" 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-06-06T03:28:32.217077" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.216915" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.216555" elapsed="0.000903"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.217995" 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-06-06T03:28:32.217619" elapsed="0.000403"/>
</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-06-06T03:28:32.218325" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.218092" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.218876" 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-06-06T03:28:32.218565" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.218405" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.218073" elapsed="0.000885"/>
</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-06-06T03:28:32.219109" elapsed="0.000383"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:32.220052" 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-06-06T03:28:32.219753" elapsed="0.000326"/>
</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-06-06T03:28:32.220234" elapsed="0.002348"/>
</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-06-06T03:28:32.205916" elapsed="0.016743"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:32.222839" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:32.222731" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.222712" elapsed="0.000213"/>
</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-06-06T03:28:32.223077" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.223147" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:32.225844" level="INFO">${response_text} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:p...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:28:32.168429" elapsed="0.057446"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.225940" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:32.226103" level="INFO">${response_text} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:p...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:32.058323" elapsed="0.167809"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.226451" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.226213" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.226195" elapsed="0.000397"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.226626" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:28:32.226804" level="INFO">${rib_old} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:p...</msg>
<var>${rib_old}</var>
<arg>${MULT_VAR_FOLDER}/rib_config</arg>
<arg>mapping=${DEFAULT_MAPPING}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Get_Templated response text.
Optionally, verification against XML data (may be iterated) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:32.049567" elapsed="0.177265"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.227361" level="INFO">${rib_old} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:p...</msg>
<arg>${rib_old}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:28:32.227005" elapsed="0.000403"/>
</kw>
<doc>Stores rib configuration</doc>
<status status="PASS" start="2026-06-06T03:28:32.048786" elapsed="0.178679"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:24.597218" elapsed="7.630297"/>
</kw>
<test id="s1-s15-t1" name="Reconfigure_ODL_To_Accept_Connection" line="58">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:28:32.230858" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:28:32.230569" elapsed="0.000560"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.232170" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.232061" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.232039" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.237291" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.237183" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.237165" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.238365" 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-06-06T03:28:32.237983" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.238874" 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-06-06T03:28:32.238556" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:32.238944" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:32.239097" 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-06-06T03:28:32.237586" elapsed="0.001536"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:28:32.244753" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.244629" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.244609" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:28:32.246003" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.245895" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.245876" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:32.246515" 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-06-06T03:28:32.246216" elapsed="0.000326"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:32.246951" level="INFO">${current_connection_index} = 7</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-06-06T03:28:32.246721" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:32.285146" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:32.247496" elapsed="0.037765"/>
</kw>
<msg time="2026-06-06T03:28:32.285439" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:28:32.285486" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:28:32.247140" elapsed="0.038382"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:28:32.320449" level="INFO">". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:28:32.286103" elapsed="0.034505"/>
</kw>
<msg time="2026-06-06T03:28:32.320804" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:28:32.320861" level="INFO">${message_wait} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "R "e "c "o "n...</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-06-06T03:28:32.285736" elapsed="0.035165"/>
</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-06-06T03:28:32.321223" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.320984" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.320962" elapsed="0.000342"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.321774" level="INFO"> ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:28:32.321449" elapsed="0.000401"/>
</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-06-06T03:28:32.322195" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.321941" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.321912" elapsed="0.000366"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:28:32.322312" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:28:32.324918" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:28:32.325123" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.323844" elapsed="0.001411"/>
</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="NOT RUN" start="2026-06-06T03:28:32.325534" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.325901" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:32.323200" elapsed="0.002891"/>
</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-06-06T03:28:32.322596" elapsed="0.003560"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:28:32.245569" elapsed="0.080684"/>
</kw>
<msg time="2026-06-06T03:28:32.326345" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:32.326389" level="INFO">${message} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "R "e "c "o "n...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:32.244974" elapsed="0.081453"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:28:32.326611" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:28:32.326504" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.326484" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.327124" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.327847" elapsed="0.000030"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.327927" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:28:32.244293" elapsed="0.083745"/>
</kw>
<msg time="2026-06-06T03:28:32.328131" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:32.328174" level="INFO">${output} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "R "e "c "o "n...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:28:32.239513" elapsed="0.088698"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.328538" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.328285" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.328268" elapsed="0.000347"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:32.239366" elapsed="0.089303"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:32.239189" elapsed="0.089514"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:28:32.236823" elapsed="0.091934"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:28:32.231768" elapsed="0.097084"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:32.231315" elapsed="0.097583"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:28:32.228181" elapsed="0.100769"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.329901" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | RIB_INSTANCE_NAME=example-bgp-rib | BGP_RIB_OPENCONFIG=example-bgp-ri...</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.329123" elapsed="0.000808"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:28:32.227581" elapsed="0.102485"/>
</test>
<test id="s1-s15-t2" name="Odl Allpaths Exa SendReceived" line="71">
<kw name="Configure_Path_Selection_And_App_Peer_And_Connect_Peer" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:28:32.333769" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:28:32.333490" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.335026" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.334913" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.334893" elapsed="0.000205"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.340426" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.340318" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.340298" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.341504" 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-06-06T03:28:32.341123" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.342006" 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-06-06T03:28:32.341709" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:32.342077" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:32.342230" 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-06-06T03:28:32.340741" elapsed="0.001513"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:28:32.347886" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.347777" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.347758" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:28:32.349248" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:32.349097" elapsed="0.000266"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.349078" elapsed="0.000312"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:32.349962" 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-06-06T03:28:32.349540" elapsed="0.000448"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:32.350423" level="INFO">${current_connection_index} = 7</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-06-06T03:28:32.350189" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:32.392792" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:32.351937" elapsed="0.041263"/>
</kw>
<msg time="2026-06-06T03:28:32.393585" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:28:32.393726" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:28:32.350655" elapsed="0.043155"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:28:32.422582" level="INFO">". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "A "l "l "p "a "t "h "s "[C "E "x "a "[C "S "e "n "d "R "e "c "e "i "v "e "d "[K"
[?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-06-06T03:28:32.397452" elapsed="0.025418"/>
</kw>
<msg time="2026-06-06T03:28:32.423869" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:28:32.423928" level="INFO">${message_wait} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "...</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-06-06T03:28:32.394397" elapsed="0.029580"/>
</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-06-06T03:28:32.424583" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.424171" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.424134" elapsed="0.000679"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.425595" level="INFO"> ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "A "l "l "p "a "t "h "s "[C "E "x "a "[C "S "e "n "d "R "e "c "e "i "v "e "d "[K"
[?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-06-06T03:28:32.424965" elapsed="0.000767"/>
</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-06-06T03:28:32.426111" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.425821" elapsed="0.000470"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.425799" elapsed="0.000521"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:28:32.426362" elapsed="0.000050"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:28:32.429073" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:28:32.429268" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.428566" elapsed="0.000775"/>
</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="NOT RUN" start="2026-06-06T03:28:32.429566" elapsed="0.000250"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.430026" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:32.427664" elapsed="0.002516"/>
</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-06-06T03:28:32.426728" elapsed="0.003546"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:28:32.348742" elapsed="0.081631"/>
</kw>
<msg time="2026-06-06T03:28:32.430466" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:32.430511" level="INFO">${message} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:32.348114" elapsed="0.082434"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:28:32.430752" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:32.430626" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.430607" elapsed="0.000230"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.431320" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.431754" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.431828" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:28:32.347424" elapsed="0.084512"/>
</kw>
<msg time="2026-06-06T03:28:32.432031" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:32.432075" level="INFO">${output} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:28:32.342624" elapsed="0.089488"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.432441" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.432187" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.432170" elapsed="0.000347"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:32.342480" elapsed="0.090060"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:32.342307" elapsed="0.090268"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:28:32.339947" elapsed="0.092685"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:28:32.334606" elapsed="0.098169"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:32.334184" elapsed="0.098640"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:28:32.331135" elapsed="0.101743"/>
</kw>
<kw name="Configure_Odl_Peer_With_Path_Selection_Mode">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.433746" level="INFO">${npaths} = 0</msg>
<var>${npaths}</var>
<arg>"${psm}"=="${ALLPATHS_SELM}"</arg>
<arg>0</arg>
<arg>${N_PATHS_VALUE}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.433361" elapsed="0.000412"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.434583" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | MULTIPATH=0 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>MULTIPATH=${npaths}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.433945" elapsed="0.000668"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.469614" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.469238" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.470464" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.470161" elapsed="0.000389">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.470659" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.469824" elapsed="0.000862"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.471279" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.470853" elapsed="0.000453"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.471612" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:32.471820" level="INFO">${template} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:32.471473" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.472254" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.472007" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.473521" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '0', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.473228" elapsed="0.000341"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.474020" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.473752" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.474952" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.474422" elapsed="0.000556"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.476155" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.475653" elapsed="0.000544"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.476313" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:32.476573" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.475165" elapsed="0.001440"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.476785" elapsed="0.000513"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:32.474283" elapsed="0.003058"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.478124" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.477591" elapsed="0.000595"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.479390" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.478871" elapsed="0.000560"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.479548" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:28:32.479820" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.478379" elapsed="0.001477"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.480021" elapsed="0.000481"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:28:32.477455" elapsed="0.003088"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.481314" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.480807" elapsed="0.000533"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.482466" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.481985" elapsed="0.000522"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.482623" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:28:32.482871" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.481526" elapsed="0.001370"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.483049" elapsed="0.000508"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:28:32.480672" elapsed="0.002927"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.484388" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.483891" elapsed="0.000523"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.485556" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.485076" elapsed="0.000521"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.485740" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:32.485970" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.484597" elapsed="0.001398"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.486148" elapsed="0.000480"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:28:32.483755" elapsed="0.002931"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.487450" level="INFO">${value} = 0</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.486936" elapsed="0.000540"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.488702" level="INFO">${encoded} = 0</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.488205" elapsed="0.000539"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.488860" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.489084" level="INFO">${encoded_value} = 0</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.487764" elapsed="0.001346"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.489263" elapsed="0.000662"/>
</kw>
<var name="${key}">MULTIPATH</var>
<var name="${value}">0</var>
<status status="PASS" start="2026-06-06T03:28:32.486801" elapsed="0.003168"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.490734" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.490217" elapsed="0.000543"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.491999" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.491421" elapsed="0.000619"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.492154" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:32.492379" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.490947" elapsed="0.001458"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.492557" elapsed="0.000493"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:32.490081" elapsed="0.003011"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.474100" elapsed="0.019027"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.493170" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:32.493366" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '0', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:32.472701" elapsed="0.020692"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.472365" elapsed="0.021060"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.493600" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.493450" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.472346" elapsed="0.021348"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.494320" level="INFO">${final_text} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:32.493841" elapsed="0.000507"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.494398" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:32.468604" elapsed="0.025916"/>
</kw>
<msg time="2026-06-06T03:28:32.494574" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.455428" elapsed="0.039193"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.507693" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.520600" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.533522" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.533734" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.533917" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.534286" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.534138" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:32.534124" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.534509" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.534693" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.534863" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:32.534095" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.533993" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.535135" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.535448" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:28:32.535575" level="INFO">${uri} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.451027" elapsed="0.084575"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.563566" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.563059" elapsed="0.000539"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.564408" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.564150" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.564587" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.563796" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.565187" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.564800" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.565521" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:32.565738" level="INFO">${template} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:32.565379" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.566181" level="INFO">&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
        &lt;global&gt;
            &lt;config&gt;
                &lt;router-id&gt;192.0.2.2&lt;/router-id&gt;
                &lt;as&gt;64496&lt;/as&gt;
            &lt;/config&gt;
            &lt;apply-policy&gt;
                &lt;config&gt;
                    &lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;
                    &lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;
                    &lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;
                    &lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;
                &lt;/config&gt;
            &lt;/apply-policy&gt;
            &lt;afi-safis&gt;
                &lt;afi-safi&gt;
                    &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
                    &lt;receive&gt;true&lt;/receive&gt;
                    &lt;send-max&gt;$MULTIPATH&lt;/send-max&gt;
                &lt;/afi-safi&gt;
            &lt;/afi-safis&gt;
        &lt;/global&gt;
    &lt;/bgp&gt;
&lt;/protocol&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.565930" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:32.566673" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.566320" elapsed="0.000414"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.567382" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '0', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.566908" elapsed="0.000503"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.566760" elapsed="0.000688"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.566296" elapsed="0.001173"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.568365" level="INFO">${final_text} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:32.567617" elapsed="0.000778"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.568447" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:32.562211" elapsed="0.006444"/>
</kw>
<msg time="2026-06-06T03:28:32.568720" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.548763" elapsed="0.020008"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.581718" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.594568" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.607476" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.607689" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.607867" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.608248" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.608102" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:32.608087" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.608470" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.608638" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.608822" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:32.608058" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.607948" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.609047" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.609121" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:32.609257" level="INFO">${data} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.546048" elapsed="0.063239"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.610610" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.610353" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.610791" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.610010" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.611138" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.610886" elapsed="0.000360"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.611783" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.611465" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.611275" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.610868" elapsed="0.000999"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.616327" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.612023" elapsed="0.004331"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:32.616406" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:32.616561" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:32.609678" elapsed="0.006908"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.617995" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.617743" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.618435" level="INFO">&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
        &lt;global&gt;
            &lt;config&gt;
                &lt;router-id&gt;192.0.2.2&lt;/router-id&gt;
                &lt;as&gt;64496&lt;/as&gt;
            &lt;/config&gt;
            &lt;apply-policy&gt;
                &lt;config&gt;
                    &lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;
                    &lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;
                    &lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;
                    &lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;
                &lt;/config&gt;
            &lt;/apply-policy&gt;
            &lt;afi-safis&gt;
                &lt;afi-safi&gt;
                    &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
                    &lt;receive&gt;true&lt;/receive&gt;
                    &lt;send-max&gt;0&lt;/send-max&gt;
                &lt;/afi-safi&gt;
            &lt;/afi-safis&gt;
        &lt;/global&gt;
    &lt;/bgp&gt;
&lt;/protocol&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.618196" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.618912" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.618663" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.619369" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.619113" elapsed="0.000299"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:32.620243" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:32.620041" elapsed="0.000228"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:32.620602" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:32.620425" elapsed="0.000203"/>
</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-06-06T03:28:32.620795" elapsed="0.000212"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.621410" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.621163" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:32.621496" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:32.621665" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:32.619616" elapsed="0.002076"/>
</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-06-06T03:28:32.637320" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '1165', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
        &lt;global&gt;
            &lt;config&gt;
                &lt;router-id&gt;192.0.2.2&lt;/router-id&gt;
                &lt;as&gt;64496&lt;/as&gt;
            &lt;/config&gt;
            &lt;apply-policy&gt;
                &lt;config&gt;
                    &lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;
                    &lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;
                    &lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;
                    &lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;
                &lt;/config&gt;
            &lt;/apply-policy&gt;
            &lt;afi-safis&gt;
                &lt;afi-safi&gt;
                    &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
                    &lt;receive&gt;true&lt;/receive&gt;
                    &lt;send-max&gt;0&lt;/send-max&gt;
                &lt;/afi-safi&gt;
            &lt;/afi-safis&gt;
        &lt;/global&gt;
    &lt;/bgp&gt;
&lt;/protocol&gt; 
 </msg>
<msg time="2026-06-06T03:28:32.637467" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:32.637620" level="INFO">${response} = &lt;Response [204]&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-06-06T03:28:32.623903" elapsed="0.013781"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.621764" elapsed="0.015986"/>
</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-06-06T03:28:32.638004" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.637786" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.621746" elapsed="0.016389"/>
</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-06-06T03:28:32.643078" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.639567" elapsed="0.003571"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.639257" elapsed="0.003968"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.639228" elapsed="0.004042"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.647392" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.643691" elapsed="0.003769"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.643352" elapsed="0.004160"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.643328" elapsed="0.004221"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.648374" 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-06-06T03:28:32.647817" elapsed="0.000598"/>
</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-06-06T03:28:32.648899" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.648520" elapsed="0.000466"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.649727" 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-06-06T03:28:32.649264" elapsed="0.000503"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.649022" elapsed="0.000798"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.648493" elapsed="0.001358"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.650624" 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-06-06T03:28:32.650091" elapsed="0.000593"/>
</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-06-06T03:28:32.651140" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.650791" elapsed="0.000449"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.651972" 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-06-06T03:28:32.651515" elapsed="0.000495"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.651275" elapsed="0.000786"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.650764" elapsed="0.001327"/>
</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-06-06T03:28:32.652312" elapsed="0.000527"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:32.653483" 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-06-06T03:28:32.653089" elapsed="0.000430"/>
</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-06-06T03:28:32.653756" elapsed="0.003033"/>
</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-06-06T03:28:32.638706" elapsed="0.018146"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:32.657024" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:32.656918" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.656900" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:32.657258" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.657325" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:28:32.659710" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:28:32.616932" elapsed="0.042805"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.659801" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:32.659991" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:32.439498" elapsed="0.220518"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.660350" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.660115" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.660097" elapsed="0.000345"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.660474" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/rib_policies</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:32.434896" elapsed="0.225700"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.694953" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.694559" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.695738" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.695502" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.695898" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.695147" elapsed="0.000776"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.696470" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.696089" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.696810" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:32.696947" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:32.696674" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.697368" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.697129" elapsed="0.000284"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.698524" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '0', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.698262" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.699021" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.698748" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.700003" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.699434" elapsed="0.000596"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.701187" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.700685" elapsed="0.000545"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.701348" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:32.701580" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.700220" elapsed="0.001387"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.701780" elapsed="0.000488"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:32.699296" elapsed="0.003015"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.703122" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.702558" elapsed="0.000591"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.704308" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.703825" elapsed="0.000524"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.704466" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.704716" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.703365" elapsed="0.001377"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.704897" elapsed="0.000479"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:28:32.702424" elapsed="0.002993"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.706186" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.705679" elapsed="0.000533"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.707371" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.706854" elapsed="0.000560"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.707532" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.707775" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.706397" elapsed="0.001404"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.707955" elapsed="0.000482"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:28:32.705529" elapsed="0.002950"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.709301" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.708796" elapsed="0.000531"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.710457" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.709972" elapsed="0.000527"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.710616" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:28:32.710863" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.709515" elapsed="0.001373"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.711044" elapsed="0.000498"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:28:32.708592" elapsed="0.002994"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.712360" level="INFO">${value} = 0</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.711854" elapsed="0.000533"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.713799" level="INFO">${encoded} = 0</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.713120" elapsed="0.000721"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.713958" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.714321" level="INFO">${encoded_value} = 0</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.712573" elapsed="0.001774"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.714502" elapsed="0.000491"/>
</kw>
<var name="${key}">MULTIPATH</var>
<var name="${value}">0</var>
<status status="PASS" start="2026-06-06T03:28:32.711718" elapsed="0.003318"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.716026" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.715313" elapsed="0.000740"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.717258" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.716773" elapsed="0.000526"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.717417" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.717658" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.716242" elapsed="0.001443"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.717842" elapsed="0.000479"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:32.715154" elapsed="0.003211"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.699101" elapsed="0.019299"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.718478" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:32.718656" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '0', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:32.697782" elapsed="0.020902"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.697478" elapsed="0.021238"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.718893" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.718741" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.697460" elapsed="0.021510"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.719786" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:32.719115" elapsed="0.000700"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.719865" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:32.693944" elapsed="0.026045"/>
</kw>
<msg time="2026-06-06T03:28:32.720044" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.680822" elapsed="0.039270"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.733341" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.746262" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.759170" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.759380" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.759561" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.759945" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.759797" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:32.759781" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.760168" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.760337" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.760505" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:32.759753" elapsed="0.000804"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.759636" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.760782" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.760861" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:32.760982" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.676463" elapsed="0.084546"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.788669" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.788263" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.789454" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.789210" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.789622" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.788870" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.790222" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.789833" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.790555" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:32.790739" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:32.790414" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.791201" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
             &lt;receive&gt;true&lt;/receive&gt;
             &lt;send-max&gt;$MULTIPATH&lt;/send-max&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.790929" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:32.791637" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.791338" elapsed="0.000374"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.792423" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '0', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.791885" elapsed="0.000566"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.791738" elapsed="0.000749"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.791315" elapsed="0.001194"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.793392" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:32.792673" elapsed="0.000751"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.793476" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:32.787621" elapsed="0.005986"/>
</kw>
<msg time="2026-06-06T03:28:32.793724" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.774369" elapsed="0.019407"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.806740" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.819691" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.832679" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.832878" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.833056" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.833433" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.833286" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:32.833271" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.833670" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.833845" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.834015" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:32.833241" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.833135" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.834242" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.834318" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:32.834445" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.771506" elapsed="0.062967"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.835875" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.835518" elapsed="0.000423">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.836035" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.835150" elapsed="0.000946"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.836423" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.836173" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.837005" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.836707" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.836505" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.836154" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.839536" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.837248" elapsed="0.002323"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:32.839628" elapsed="0.000054"/>
</return>
<msg time="2026-06-06T03:28:32.839839" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:32.834822" elapsed="0.005049"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.841300" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.841052" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.841758" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
             &lt;receive&gt;true&lt;/receive&gt;
             &lt;send-max&gt;0&lt;/send-max&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.841502" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.842214" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.841971" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.842664" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.842408" elapsed="0.000301"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:32.843537" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:32.843337" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:32.843916" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:32.843738" elapsed="0.000204"/>
</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-06-06T03:28:32.844093" elapsed="0.000212"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.844910" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.844465" elapsed="0.000490"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:32.844999" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:32.845160" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:32.842912" elapsed="0.002274"/>
</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-06-06T03:28:32.860357" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '871', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
             &lt;receive&gt;true&lt;/receive&gt;
             &lt;send-max&gt;0&lt;/send-max&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:28:32.860475" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:32.860569" 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-06-06T03:28:32.847438" elapsed="0.013157"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.845256" elapsed="0.015404"/>
</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-06-06T03:28:32.860846" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.860689" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.845238" elapsed="0.015697"/>
</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-06-06T03:28:32.864509" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.861895" elapsed="0.002674"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.861673" elapsed="0.002946"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.861652" elapsed="0.003022"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.868392" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.865067" elapsed="0.003389"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.864756" elapsed="0.003749"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.864731" elapsed="0.003808"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.869316" 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-06-06T03:28:32.868790" elapsed="0.000565"/>
</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-06-06T03:28:32.869811" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.869454" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.870574" 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-06-06T03:28:32.870156" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.869927" elapsed="0.000753"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.869427" elapsed="0.001283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.871484" 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-06-06T03:28:32.870939" elapsed="0.000583"/>
</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-06-06T03:28:32.871979" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.871619" elapsed="0.000441"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.872560" 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-06-06T03:28:32.872264" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.872094" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.871593" elapsed="0.001064"/>
</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-06-06T03:28:32.872812" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:32.873604" 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-06-06T03:28:32.873325" elapsed="0.000305"/>
</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-06-06T03:28:32.873802" elapsed="0.002365"/>
</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-06-06T03:28:32.861302" elapsed="0.014928"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:32.876404" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:28:32.876297" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.876278" elapsed="0.000210"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:32.876636" elapsed="0.000038"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.876721" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:32.879063" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:28:32.840237" elapsed="0.038855"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.879209" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:32.879369" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:32.665256" elapsed="0.214139"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.879748" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.879494" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.879477" elapsed="0.000365"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.879875" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:32.660869" elapsed="0.219130"/>
</kw>
<arg>${odl_path_sel_mode}</arg>
<doc>Configures odl peer with path selection mode</doc>
<status status="PASS" start="2026-06-06T03:28:32.433026" elapsed="0.447037"/>
</kw>
<kw name="Configure_App_Peer_With_Routes">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.880836" level="INFO">${app_rib} = 10.30.170.38</msg>
<var>${app_rib}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.880523" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.881695" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | APP_PEER_NAME=example-bgp-peer-app | RIB_INSTANCE_NAME=example-bgp-rib | APP_PEER_ID=10.30.170.38 | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>APP_PEER_NAME=${APP_PEER_NAME}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>APP_PEER_ID=${ODL_SYSTEM_IP}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.881029" elapsed="0.000696"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.916337" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:32.915959" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.917109" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.916884" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:32.917270" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:32.916528" elapsed="0.000766"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.917861" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:32.917462" elapsed="0.000426"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:32.918198" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:32.918348" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:32.918061" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.918799" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.918537" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.919826" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:32.919549" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.920294" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.920034" elapsed="0.000285"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.921228" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.920697" elapsed="0.000557"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.922453" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.921958" elapsed="0.000538"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.922612" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:28:32.922862" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.921480" elapsed="0.001407"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.923044" elapsed="0.000718"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:28:32.920546" elapsed="0.003260"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.924567" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.924052" elapsed="0.000542"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.925894" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.925388" elapsed="0.000548"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.926054" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.926284" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.924800" elapsed="0.001510"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.926467" elapsed="0.000517"/>
</kw>
<var name="${key}">APP_PEER_NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:28:32.923917" elapsed="0.003110"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.927820" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.927294" elapsed="0.000553"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.929166" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.928679" elapsed="0.000529"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.929326" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:32.929550" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.928036" elapsed="0.001540"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.929746" elapsed="0.000490"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:32.927145" elapsed="0.003134"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.931113" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.930523" elapsed="0.000617"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.932325" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.931832" elapsed="0.000535"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.932482" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:32.932726" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.931372" elapsed="0.001380"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.932906" elapsed="0.000478"/>
</kw>
<var name="${key}">APP_PEER_ID</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:32.930390" elapsed="0.003035"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.934189" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.933688" elapsed="0.000528"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.935441" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.934933" elapsed="0.000549"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.935595" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:32.935837" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.934401" elapsed="0.001461"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.936023" elapsed="0.000483"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:32.933538" elapsed="0.003010"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.937315" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:32.936811" elapsed="0.000531"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:32.938533" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.938043" elapsed="0.000532"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:32.938765" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:32.938994" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:32.937577" elapsed="0.001443"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:32.939173" elapsed="0.000511"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:32.936676" elapsed="0.003051"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.920369" elapsed="0.019394"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:32.939805" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:32.939965" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'exampl...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:32.919226" elapsed="0.020765"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:32.918913" elapsed="0.021110"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.940203" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.940048" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:32.918894" elapsed="0.021385"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:32.941075" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:32.940424" elapsed="0.000679"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:32.941152" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:32.915328" elapsed="0.025947"/>
</kw>
<msg time="2026-06-06T03:28:32.941329" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.902261" elapsed="0.039117"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.954762" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.967737" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.980656" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.980894" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.981077" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.981548" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:32.981326" elapsed="0.000280"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:32.981310" elapsed="0.000321"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.981793" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.981965" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.982133" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:32.981275" elapsed="0.000911"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.981160" elapsed="0.001052"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:32.982360" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:32.982436" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:32.982574" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.897912" elapsed="0.084689"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.009865" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.009467" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.010634" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.010392" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.010817" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.010057" elapsed="0.000785"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.011420" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.011005" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.011768" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.011916" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.011612" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.012345" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.012102" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:33.012770" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.012460" elapsed="0.000369"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.013294" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'exampl...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.013000" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.012854" elapsed="0.000502"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.012441" elapsed="0.000936"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.014187" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.013522" elapsed="0.000726"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.014301" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.008852" elapsed="0.005576"/>
</kw>
<msg time="2026-06-06T03:28:33.014481" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:32.995776" elapsed="0.018753"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.027589" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.040439" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.053419" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.053617" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.053810" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.054171" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.054026" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.054011" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.054391" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.054558" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.054739" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.053984" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.053884" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.054965" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.055038" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:33.055159" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:32.993011" elapsed="0.062201"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.056566" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.056330" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.056740" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.055984" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.057081" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.056835" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.057632" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.057342" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.057162" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.056816" elapsed="0.000914"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.060147" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.057885" elapsed="0.002288"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:33.060223" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:33.060375" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:33.055636" elapsed="0.004763"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.061811" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.061544" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.062248" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.062010" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.062705" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.062447" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.063138" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.062900" elapsed="0.000280"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:33.064011" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:33.063816" elapsed="0.000221"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:33.064365" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:33.064190" elapsed="0.000200"/>
</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-06-06T03:28:33.064539" elapsed="0.000219"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.065165" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.064919" elapsed="0.000289"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:33.065249" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:33.065403" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:33.063394" elapsed="0.002033"/>
</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-06-06T03:28:33.077323" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:28:33.077379" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:33.077513" 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-06-06T03:28:33.067832" elapsed="0.009707"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.065497" elapsed="0.012088"/>
</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-06-06T03:28:33.077790" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.077611" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.065479" elapsed="0.012401"/>
</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-06-06T03:28:33.085707" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.079785" elapsed="0.006023"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.079258" elapsed="0.006628"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.079215" elapsed="0.006727"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.089793" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.086569" elapsed="0.003269"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.086069" elapsed="0.003803"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.086031" elapsed="0.003865"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.090441" 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-06-06T03:28:33.090065" elapsed="0.000403"/>
</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-06-06T03:28:33.090795" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.090538" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.091375" 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-06-06T03:28:33.091040" elapsed="0.000361"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.090877" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.090519" elapsed="0.000939"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.092003" 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-06-06T03:28:33.091619" elapsed="0.000412"/>
</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-06-06T03:28:33.092335" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.092101" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.092890" 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-06-06T03:28:33.092578" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.092416" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.092082" elapsed="0.000890"/>
</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-06-06T03:28:33.093123" elapsed="0.000342"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:33.093928" 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-06-06T03:28:33.093633" elapsed="0.000321"/>
</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-06-06T03:28:33.094110" elapsed="0.004249"/>
</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-06-06T03:28:33.078398" elapsed="0.020106"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:33.098929" elapsed="0.000061"/>
</return>
<status status="PASS" start="2026-06-06T03:28:33.098684" elapsed="0.000381"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.098612" elapsed="0.000509"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:33.099488" elapsed="0.000049"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.099664" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:28:33.104994" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:28:33.060751" elapsed="0.044302"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.105198" elapsed="0.000060"/>
</return>
<msg time="2026-06-06T03:28:33.105532" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:32.886794" elapsed="0.218793"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.106435" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.105914" elapsed="0.000669"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.105873" elapsed="0.000763"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.106741" elapsed="0.000059"/>
</return>
<arg>${BGP_VAR_FOLDER}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:32.881993" elapsed="0.225021"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.108562" level="INFO">&amp;{route_mapping} = { NEXTHOP=100.100.100.1 | LOCALPREF=100 | PATHID=1 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{route_mapping}</var>
<arg>NEXTHOP=${NEXT_HOP_PREF}${pathid}</arg>
<arg>LOCALPREF=${pathid}00</arg>
<arg>PATHID=${pathid}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.107839" elapsed="0.000751"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.143248" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.142858" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.144125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.143791" elapsed="0.000400">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.144285" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.143440" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.144884" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.144473" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.145206" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.145339" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.145071" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.145783" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.145522" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.146996" level="INFO">mapping: {'NEXTHOP': '100.100.100.1', 'LOCALPREF': '100', 'PATHID': '1', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.146506" elapsed="0.000547"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.147657" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.147251" elapsed="0.000434"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.148739" level="INFO">${value} = 100.100.100.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.148073" elapsed="0.000707"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.150483" level="INFO">${encoded} = 100.100.100.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.150057" elapsed="0.000463"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.150597" elapsed="0.000093"/>
</return>
<msg time="2026-06-06T03:28:33.150957" level="INFO">${encoded_value} = 100.100.100.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.149248" elapsed="0.001750"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.151247" elapsed="0.000527"/>
</kw>
<var name="${key}">NEXTHOP</var>
<var name="${value}">100.100.100.1</var>
<status status="PASS" start="2026-06-06T03:28:33.147905" elapsed="0.003969"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.152883" level="INFO">${value} = 100</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.152208" elapsed="0.000717"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.155871" level="INFO">${encoded} = 100</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.155438" elapsed="0.000470"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.155986" elapsed="0.000076"/>
</return>
<msg time="2026-06-06T03:28:33.156333" level="INFO">${encoded_value} = 100</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.154624" elapsed="0.001749"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.156603" elapsed="0.000643"/>
</kw>
<var name="${key}">LOCALPREF</var>
<var name="${value}">100</var>
<status status="PASS" start="2026-06-06T03:28:33.152036" elapsed="0.005315"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.158398" level="INFO">${value} = 1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.157635" elapsed="0.000805"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.160165" level="INFO">${encoded} = 1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.159744" elapsed="0.000457"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.160279" elapsed="0.000074"/>
</return>
<msg time="2026-06-06T03:28:33.160614" level="INFO">${encoded_value} = 1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.158919" elapsed="0.001751"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.160900" elapsed="0.000507"/>
</kw>
<var name="${key}">PATHID</var>
<var name="${value}">1</var>
<status status="PASS" start="2026-06-06T03:28:33.157469" elapsed="0.004038"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.162528" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.161889" elapsed="0.000681"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.164266" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.163854" elapsed="0.000449"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.164382" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:28:33.164740" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.163047" elapsed="0.001733"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.165007" elapsed="0.000496"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:33.161625" elapsed="0.003976"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:33.147733" elapsed="0.018008"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:33.165789" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:33.165948" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.1', 'LOCALPREF': '100', 'PATHID': '1', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:33.146185" elapsed="0.019788"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.145894" elapsed="0.020111"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.166180" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.166030" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.145875" elapsed="0.020381"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.167006" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.166398" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.167085" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.142228" elapsed="0.025005"/>
</kw>
<msg time="2026-06-06T03:28:33.167294" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:33.129087" elapsed="0.038255"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.180534" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.193466" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.206589" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.206800" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.206977" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.207369" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.207221" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.207203" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.207591" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.207778" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.207947" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.207154" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.207053" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.208173" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.208249" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:33.208367" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:33.124754" elapsed="0.083639"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.234073" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.233695" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.234900" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.234599" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.235059" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.234267" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.235711" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.235299" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.236040" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.236176" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.235904" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.236608" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;$NEXTHOP&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;$LOCALPREF&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.236364" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:33.237040" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.236749" elapsed="0.000349"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.237564" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.1', 'LOCALPREF': '100', 'PATHID': '1', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.237270" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.237123" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.236729" elapsed="0.000933"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.238450" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.237813" elapsed="0.000668"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.238530" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.232992" elapsed="0.005679"/>
</kw>
<msg time="2026-06-06T03:28:33.238728" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:33.219832" elapsed="0.018944"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.251944" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.264903" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.277705" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.277936" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.278116" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.278497" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.278351" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.278336" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.278739" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.278911" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.279083" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.278308" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.278205" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.279335" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.279412" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:33.279537" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:33.218864" elapsed="0.060702"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.280861" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.280588" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.281021" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.280243" elapsed="0.000802"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.281364" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.281115" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.281923" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.281613" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.281444" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.281096" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.284407" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.282162" elapsed="0.002271"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:33.284484" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:33.284636" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:33.279916" elapsed="0.004760"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.286211" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.285956" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.286664" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.1&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.286413" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.287163" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.286916" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.287632" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.287389" elapsed="0.000304"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:33.288512" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:33.288317" elapsed="0.000221"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:33.288918" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:33.288726" elapsed="0.000219"/>
</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-06-06T03:28:33.289098" elapsed="0.000203"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.289725" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.289458" elapsed="0.000311"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:33.289812" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:33.289966" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:33.287895" elapsed="0.002096"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:33.301889" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.1&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:28:33.301952" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,1', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:33.302053" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:33.292400" elapsed="0.009683"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.290061" elapsed="0.012068"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.302309" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.302155" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.290043" elapsed="0.012354"/>
</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-06-06T03:28:33.308203" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.303461" elapsed="0.004837"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.303236" elapsed="0.005138"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.303215" elapsed="0.005214"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.314383" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.309072" elapsed="0.005412"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.308550" elapsed="0.006011"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.308514" elapsed="0.006102"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.315947" 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-06-06T03:28:33.315014" elapsed="0.000994"/>
</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-06-06T03:28:33.316399" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.316159" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.316959" 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-06-06T03:28:33.316659" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.316481" elapsed="0.000580"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.316126" elapsed="0.000960"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.317617" 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-06-06T03:28:33.317251" elapsed="0.000409"/>
</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-06-06T03:28:33.317971" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.317733" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.318509" 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-06-06T03:28:33.318215" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.318053" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.317713" elapsed="0.000878"/>
</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-06-06T03:28:33.318758" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:33.319559" 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-06-06T03:28:33.319284" elapsed="0.000301"/>
</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-06-06T03:28:33.319757" elapsed="0.002339"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:28:33.302768" elapsed="0.019390"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:33.322339" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:33.322232" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.322213" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:33.322573" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.322656" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:33.325022" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:28:33.285006" elapsed="0.040042"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.325117" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:33.325267" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:33.113476" elapsed="0.211816"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.325625" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.325394" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.325377" elapsed="0.000357"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.325766" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:33.108870" elapsed="0.217017"/>
</kw>
<var name="${pathid}">1</var>
<status status="PASS" start="2026-06-06T03:28:33.107491" elapsed="0.218434"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.326759" level="INFO">&amp;{route_mapping} = { NEXTHOP=100.100.100.2 | LOCALPREF=200 | PATHID=2 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{route_mapping}</var>
<arg>NEXTHOP=${NEXT_HOP_PREF}${pathid}</arg>
<arg>LOCALPREF=${pathid}00</arg>
<arg>PATHID=${pathid}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.326158" elapsed="0.000630"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.361685" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.361275" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.362568" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.362271" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.362765" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.361923" elapsed="0.000868"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.363434" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.362972" elapsed="0.000491"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.363807" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.363955" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.363658" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.364415" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.364151" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.365728" level="INFO">mapping: {'NEXTHOP': '100.100.100.2', 'LOCALPREF': '200', 'PATHID': '2', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.365210" elapsed="0.000568"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.366364" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.365949" elapsed="0.000444"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.367525" level="INFO">${value} = 100.100.100.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.366828" elapsed="0.000740"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.369452" level="INFO">${encoded} = 100.100.100.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.368884" elapsed="0.000607"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.369570" elapsed="0.000091"/>
</return>
<msg time="2026-06-06T03:28:33.369934" level="INFO">${encoded_value} = 100.100.100.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.368070" elapsed="0.001907"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.370215" elapsed="0.000529"/>
</kw>
<var name="${key}">NEXTHOP</var>
<var name="${value}">100.100.100.2</var>
<status status="PASS" start="2026-06-06T03:28:33.366627" elapsed="0.004216"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.371835" level="INFO">${value} = 200</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.371133" elapsed="0.000743"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.373809" level="INFO">${encoded} = 200</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.373368" elapsed="0.000480"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.373927" elapsed="0.000076"/>
</return>
<msg time="2026-06-06T03:28:33.374277" level="INFO">${encoded_value} = 200</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.372353" elapsed="0.001966"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.374552" elapsed="0.000527"/>
</kw>
<var name="${key}">LOCALPREF</var>
<var name="${value}">200</var>
<status status="PASS" start="2026-06-06T03:28:33.370964" elapsed="0.004218"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.376171" level="INFO">${value} = 2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.375508" elapsed="0.000704"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.377939" level="INFO">${encoded} = 2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.377518" elapsed="0.000457"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.378051" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:28:33.378379" level="INFO">${encoded_value} = 2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.376753" elapsed="0.001666"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.378655" elapsed="0.000551"/>
</kw>
<var name="${key}">PATHID</var>
<var name="${value}">2</var>
<status status="PASS" start="2026-06-06T03:28:33.375338" elapsed="0.003973"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.380244" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.379595" elapsed="0.000689"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.382017" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.381596" elapsed="0.000457"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.382130" elapsed="0.000071"/>
</return>
<msg time="2026-06-06T03:28:33.382459" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.380839" elapsed="0.001660"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.382738" elapsed="0.000527"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:33.379428" elapsed="0.003936"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:33.366443" elapsed="0.016959"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:33.383444" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:33.383604" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.2', 'LOCALPREF': '200', 'PATHID': '2', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:33.364863" elapsed="0.018767"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.364533" elapsed="0.019145"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.383856" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.383704" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.364513" elapsed="0.019419"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.384800" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.384076" elapsed="0.000754"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.384879" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.360605" elapsed="0.024396"/>
</kw>
<msg time="2026-06-06T03:28:33.385055" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:33.347471" elapsed="0.037633"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.398240" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.411139" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.424205" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.424413" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.424629" elapsed="0.000039"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.425027" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.424880" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.424864" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.425250" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.425421" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.425588" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.424834" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.424725" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.425830" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.425906" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:33.426023" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:33.343089" elapsed="0.082961"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.451509" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.451114" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.452356" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.452054" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.452516" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.451718" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.453125" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.452731" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.453447" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.453577" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.453313" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.454025" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;$NEXTHOP&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;$LOCALPREF&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.453782" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:33.454580" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.454147" elapsed="0.000541"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.455172" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.2', 'LOCALPREF': '200', 'PATHID': '2', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.454874" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.454719" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.454127" elapsed="0.001176"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.456122" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.455456" elapsed="0.000697"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.456204" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.450483" elapsed="0.005845"/>
</kw>
<msg time="2026-06-06T03:28:33.456384" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:33.437271" elapsed="0.019160"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.469576" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.482606" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.495479" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.495692" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.495871" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.496238" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.496092" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.496077" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.496456" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.496624" elapsed="0.000034"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.496808" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.496048" elapsed="0.000813"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.495947" elapsed="0.000939"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.497030" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.497141" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:28:33.497270" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:33.436408" elapsed="0.060890"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.498558" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.498320" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.498732" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.497974" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.499075" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.498828" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.499661" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.499352" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.499155" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.498809" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.502137" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.499898" elapsed="0.002265"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:33.502214" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:33.502365" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:33.497628" elapsed="0.004761"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.503946" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.503697" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.504385" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.2&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;200&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.504147" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.504855" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.504594" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.505288" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.505049" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:33.506142" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:33.505950" elapsed="0.000218"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:33.506501" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:33.506327" elapsed="0.000200"/>
</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-06-06T03:28:33.506692" elapsed="0.000205"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.507328" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.507055" elapsed="0.000317"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:33.507414" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:33.507568" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:33.505529" elapsed="0.002123"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:33.520596" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.2&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;200&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:28:33.520681" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,2', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:33.520776" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:33.510027" elapsed="0.010775"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.507730" elapsed="0.013119"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.521035" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.520876" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.507711" elapsed="0.013506"/>
</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-06-06T03:28:33.529279" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.523580" elapsed="0.005808"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.523042" elapsed="0.006433"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.522999" elapsed="0.006536"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.533674" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.530242" elapsed="0.003480"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.529703" elapsed="0.004055"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.529627" elapsed="0.004156"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.534325" 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-06-06T03:28:33.533950" elapsed="0.000402"/>
</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-06-06T03:28:33.534692" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.534422" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.535256" 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-06-06T03:28:33.534939" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.534776" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.534404" elapsed="0.000936"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.535879" 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-06-06T03:28:33.535500" elapsed="0.000406"/>
</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-06-06T03:28:33.536213" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.535977" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.536763" 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-06-06T03:28:33.536454" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.536294" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.535958" elapsed="0.000887"/>
</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-06-06T03:28:33.536996" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:33.537804" 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-06-06T03:28:33.537508" elapsed="0.000323"/>
</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-06-06T03:28:33.538025" elapsed="0.002375"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:28:33.522038" elapsed="0.018426"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:33.540658" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:28:33.540537" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.540518" elapsed="0.000227"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:33.540894" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.540963" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:28:33.543334" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:28:33.502728" elapsed="0.040633"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.543431" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:33.543584" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:33.331726" elapsed="0.211883"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.543969" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.543730" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.543711" elapsed="0.000349"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.544092" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:33.327048" elapsed="0.217168"/>
</kw>
<var name="${pathid}">2</var>
<status status="PASS" start="2026-06-06T03:28:33.326015" elapsed="0.218242"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.545108" level="INFO">&amp;{route_mapping} = { NEXTHOP=100.100.100.3 | LOCALPREF=300 | PATHID=3 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{route_mapping}</var>
<arg>NEXTHOP=${NEXT_HOP_PREF}${pathid}</arg>
<arg>LOCALPREF=${pathid}00</arg>
<arg>PATHID=${pathid}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.544500" elapsed="0.000636"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.580321" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.579904" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.581444" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.581048" elapsed="0.000481">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.581627" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.580695" elapsed="0.000988"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.582245" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.581856" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.582577" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.582763" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.582435" elapsed="0.000419"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.583292" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.583019" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.584597" level="INFO">mapping: {'NEXTHOP': '100.100.100.3', 'LOCALPREF': '300', 'PATHID': '3', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.584122" elapsed="0.000536"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.585224" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.584823" elapsed="0.000427"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.586336" level="INFO">${value} = 100.100.100.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.585688" elapsed="0.000689"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.588133" level="INFO">${encoded} = 100.100.100.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.587699" elapsed="0.000471"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.588252" elapsed="0.000082"/>
</return>
<msg time="2026-06-06T03:28:33.588608" level="INFO">${encoded_value} = 100.100.100.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.586875" elapsed="0.001789"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.588900" elapsed="0.000532"/>
</kw>
<var name="${key}">NEXTHOP</var>
<var name="${value}">100.100.100.3</var>
<status status="PASS" start="2026-06-06T03:28:33.585500" elapsed="0.004033"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.590479" level="INFO">${value} = 300</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.589835" elapsed="0.000684"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.592479" level="INFO">${encoded} = 300</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.592067" elapsed="0.000450"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.592594" elapsed="0.000089"/>
</return>
<msg time="2026-06-06T03:28:33.592947" level="INFO">${encoded_value} = 300</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.590996" elapsed="0.001992"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.593214" elapsed="0.000527"/>
</kw>
<var name="${key}">LOCALPREF</var>
<var name="${value}">300</var>
<status status="PASS" start="2026-06-06T03:28:33.589668" elapsed="0.004172"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.594774" level="INFO">${value} = 3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.594120" elapsed="0.000697"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.596564" level="INFO">${encoded} = 3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.596159" elapsed="0.000440"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.596693" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:28:33.597021" level="INFO">${encoded_value} = 3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.595292" elapsed="0.001769"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.597287" elapsed="0.000617"/>
</kw>
<var name="${key}">PATHID</var>
<var name="${value}">3</var>
<status status="PASS" start="2026-06-06T03:28:33.593958" elapsed="0.004044"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.598931" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:33.598282" elapsed="0.000689"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:33.600666" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.600236" elapsed="0.000468"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:33.600781" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:28:33.601114" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:33.599459" elapsed="0.001694"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:33.601378" elapsed="0.000660"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:33.598119" elapsed="0.004014"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:33.585310" elapsed="0.016862"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:33.602220" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:33.602444" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.3', 'LOCALPREF': '300', 'PATHID': '3', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:33.583795" elapsed="0.018676"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.583426" elapsed="0.019079"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.602712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.602535" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.583397" elapsed="0.019393"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.603615" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.602938" elapsed="0.000721"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.603710" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.579178" elapsed="0.024657"/>
</kw>
<msg time="2026-06-06T03:28:33.603892" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:33.566009" elapsed="0.037941"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.617051" elapsed="0.000054"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.630195" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.643429" elapsed="0.000058"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.643760" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.643965" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.644440" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.644281" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.644260" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.644690" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.644863" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.645029" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.644212" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.644058" elapsed="0.001059"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.645270" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.645432" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:28:33.645605" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:33.561601" elapsed="0.084033"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.671338" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.670860" elapsed="0.000512"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.672313" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.671924" elapsed="0.000471">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.672491" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.671550" elapsed="0.000966"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.673104" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.672718" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.673438" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:33.673609" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:33.673295" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.674065" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;$NEXTHOP&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;$LOCALPREF&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.673818" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:33.674544" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.674202" elapsed="0.000402"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.675091" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.3', 'LOCALPREF': '300', 'PATHID': '3', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.674796" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.674631" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.674178" elapsed="0.000996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.676019" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:33.675339" elapsed="0.000711"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.676104" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:33.670150" elapsed="0.006089"/>
</kw>
<msg time="2026-06-06T03:28:33.676355" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:33.656995" elapsed="0.019413"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.690951" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.703895" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.716722" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.716952" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.717142" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.717575" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.717419" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:33.717399" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.717825" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.717997" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.718169" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:33.717355" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.717229" elapsed="0.001021"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.718399" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.718478" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:28:33.718659" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:33.656046" elapsed="0.062646"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:33.720218" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:33.719890" elapsed="0.000412">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:33.720398" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:33.719439" elapsed="0.000984"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.720940" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.720660" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.721516" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:33.721216" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.721023" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.720622" elapsed="0.000977"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.724021" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:33.721772" elapsed="0.002276"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:33.724101" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:28:33.724267" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:33.719031" elapsed="0.005261"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.725886" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.725607" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.726329" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.3&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;300&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.726092" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.726799" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.726536" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.727273" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.726995" elapsed="0.000322"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:33.728148" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:33.727944" elapsed="0.000230"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:33.728505" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:33.728329" elapsed="0.000202"/>
</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-06-06T03:28:33.728698" elapsed="0.000219"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.729324" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.729078" elapsed="0.000289"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:33.729410" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:33.729564" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:33.727520" elapsed="0.002069"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:33.742456" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.3&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;300&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:28:33.742520" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,3', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:33.742725" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:33.732044" elapsed="0.010708"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.729676" elapsed="0.013123"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.742983" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.742825" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.729656" elapsed="0.013416"/>
</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-06-06T03:28:33.746605" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.744160" elapsed="0.002505"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.743935" elapsed="0.002767"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.743916" elapsed="0.002811"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.749366" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.747007" elapsed="0.002404"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.746783" elapsed="0.002663"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.746766" elapsed="0.002705"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.750068" 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-06-06T03:28:33.749667" elapsed="0.000428"/>
</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-06-06T03:28:33.750407" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.750165" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.750970" 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-06-06T03:28:33.750668" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.750488" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.750147" elapsed="0.000906"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.751590" 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-06-06T03:28:33.751228" elapsed="0.000389"/>
</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-06-06T03:28:33.751942" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.751705" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.752475" 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-06-06T03:28:33.752183" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:33.752022" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.751686" elapsed="0.000871"/>
</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-06-06T03:28:33.752728" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:33.753536" 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-06-06T03:28:33.753248" elapsed="0.000314"/>
</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-06-06T03:28:33.753736" elapsed="0.002421"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:28:33.743480" elapsed="0.012741"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:33.756403" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:28:33.756294" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.756275" elapsed="0.000218"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:33.756662" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:33.756732" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:33.759109" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:28:33.724625" elapsed="0.034513"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.759231" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:33.759386" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:33.550044" elapsed="0.209417"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:33.759846" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:33.759570" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:33.759552" elapsed="0.000388"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:33.759973" elapsed="0.000027"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:33.545402" elapsed="0.214696"/>
</kw>
<var name="${pathid}">3</var>
<status status="PASS" start="2026-06-06T03:28:33.544355" elapsed="0.215785"/>
</iter>
<var>${pathid}</var>
<value>@{PATH_ID_LIST}</value>
<status status="PASS" start="2026-06-06T03:28:33.107139" elapsed="0.653037"/>
</for>
<doc>Configure bgp application peer and fill it immediately with routes.</doc>
<status status="PASS" start="2026-06-06T03:28:32.880232" elapsed="0.880005"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.768875" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/exa.cfg' -&gt; '/home/jenkins//exa.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${DEFAUTL_RPC_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:28:33.760841" elapsed="0.008101"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.776427" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/exabgp_files/exarpc.py' -&gt; '/home/jenkins//exarpc.py'</msg>
<arg>${EXARPCSCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:28:33.769117" elapsed="0.007373"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.786147" level="INFO">6 files:
bgp-flowspec-redirect.cfg
bgp-flowspec.cfg
bgp-l3vpn-ipv4.cfg
exa-md5.cfg
exa.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:28:33.786295" level="INFO">@{cfgfiles} = [ bgp-flowspec-redirect.cfg | bgp-flowspec.cfg | bgp-l3vpn-ipv4.cfg | exa-md5.cfg | exa.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:28:33.776680" elapsed="0.009642"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.786970" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:33.799798" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:33.786786" elapsed="0.013162"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.800789" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:33.849510" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:33.800350" elapsed="0.049411"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.850703" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:33.897842" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:33.850272" elapsed="0.047781"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.899051" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:33.949321" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:33.898549" elapsed="0.050974"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:33.950513" level="INFO">Executing command 'cat bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:33.997587" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:33.997974" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:33.950091" elapsed="0.047943"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:33.999343" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;

        }
        then {
            redirect 65500:12345;
        }
    }
    route flow2 {
        match {
            source 10.0.0.2/32;
            destination 192.168.0.2/32;

        }
        then {
                redirect 1.2.3.4;
        }
    }
    route flow4 {
        match {
            source 10.0.0.4/32;
            destination 192.168.0.4/32;

        }
        next-hop 127.0.0.1;
        then {
                redirect-to-nexthop;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:33.998583" elapsed="0.000873"/>
</kw>
<var name="${cfgfile}">bgp-flowspec-redirect.cfg</var>
<status status="PASS" start="2026-06-06T03:28:33.786603" elapsed="0.212931"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.000541" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:34.045289" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.000175" elapsed="0.045279"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.046522" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:34.093905" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.046058" elapsed="0.048063"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.095091" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:34.146058" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.094618" elapsed="0.051691"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.147561" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:34.197098" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.146970" elapsed="0.050499"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.198363" level="INFO">Executing command 'cat bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:34.245033" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:34.245307" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.197983" elapsed="0.047384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:34.246570" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;
            port =80;
            destination-port &gt;8080&amp;&lt;8088;
            source-port &gt;1024;
            protocol tcp;
            packet-length &gt;400&amp;&lt;500;
            fragment =first-fragment;
            icmp-type echo-reply;
            icmp-code network-unreachable;
            tcp-flags =urgent;
            dscp 20;
        }
        then {
            action sample-terminal;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:34.245912" elapsed="0.000838"/>
</kw>
<var name="${cfgfile}">bgp-flowspec.cfg</var>
<status status="PASS" start="2026-06-06T03:28:33.999841" elapsed="0.246990"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.247917" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:34.293269" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.247460" elapsed="0.045975"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.294398" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:34.341825" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.293938" elapsed="0.048221"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.343610" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:34.389543" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.342884" elapsed="0.047023"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.391322" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:34.437625" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.390604" elapsed="0.047272"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.438827" level="INFO">Executing command 'cat bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:34.489794" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:34.490155" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.438384" elapsed="0.051840"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:34.492774" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255.254;
      rd 1.2.3.4:1;
      label 24005;
    }
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:34.490912" elapsed="0.002048"/>
</kw>
<var name="${cfgfile}">bgp-l3vpn-ipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:28:34.247105" elapsed="0.245993"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.494616" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:34.537598" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.494086" elapsed="0.043902"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.540301" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:34.589907" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.538832" elapsed="0.051372"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.591427" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:34.641692" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.590885" elapsed="0.051055"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.643192" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:34.689855" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.642691" elapsed="0.047391"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.691045" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:34.741731" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:34.742090" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.690598" elapsed="0.051555"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:34.743514" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:34.742792" elapsed="0.000828"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:28:34.493514" elapsed="0.250214"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.744764" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:34.793999" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.744357" elapsed="0.049886"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.795430" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:34.845815" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.794814" elapsed="0.051239"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.847046" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:34.898083" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.846581" elapsed="0.051721"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.899330" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:34.949818" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.898837" elapsed="0.051212"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:34.951010" level="INFO">Executing command 'cat exa.cfg'.</msg>
<msg time="2026-06-06T03:28:35.001858" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:35.002206" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path send/receive;
  }

  family {
    ip...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:34.950561" elapsed="0.051708"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.003593" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path send/receive;
  }

  family {
    ipv4 unicast;
    ipv4 mpls-vpn;
  }

  process exarpcserver {
    run exarpc.py --host 10.30.171.194;
    encoder json;
    receive-routes;
    neighbor-changes;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:35.002855" elapsed="0.000876"/>
</kw>
<var name="${cfgfile}">exa.cfg</var>
<status status="PASS" start="2026-06-06T03:28:34.744016" elapsed="0.259795"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.004867" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:35.049511" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:35.004455" elapsed="0.045304"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.050752" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:35.101883" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:35.050256" elapsed="0.051852"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.103031" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:35.153789" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:35.102598" elapsed="0.051431"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.155033" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:35.233292" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:35.154535" elapsed="0.078982"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.234513" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:35.281514" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:35.281889" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:35.234089" elapsed="0.047863"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.283402" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:35.282523" elapsed="0.001178"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:28:35.004114" elapsed="0.279673"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:28:33.786401" elapsed="1.497488"/>
</for>
<arg>addpath=${exa_add_path_value}</arg>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:28:33.760438" elapsed="1.523617"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.292591" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:35.291827" elapsed="0.000856"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.293587" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:35.293041" elapsed="0.000677"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.318378" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:35.295109" elapsed="0.023453"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.323429" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:35.323590" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:35.318990" elapsed="0.004640"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.324682" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:35.324215" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:35.323783" elapsed="0.001023"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:35.323739" elapsed="0.001110"/>
</if>
<arg>log_output=${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-06-06T03:28:35.294259" elapsed="0.030672"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:35.327395" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:35.327529" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:35.325170" elapsed="0.002397"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.328185" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:35.327836" elapsed="0.000394"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:35.291040" elapsed="0.037250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.330361" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:35.330003" elapsed="0.000386"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.332942" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:35.330556" elapsed="0.002414"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:35.338792" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:35.339032" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:35.339185" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:35.333139" elapsed="0.006087"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.342279" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:35.339579" elapsed="0.002749"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:35.345242" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:35.342490" elapsed="0.002830">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:35.329478" elapsed="0.015961">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:38.348795" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:38.347815" elapsed="0.001055"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:38.354731" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:38.349439" elapsed="0.005369"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:38.362513" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:38.362688" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:38.362800" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:38.355289" elapsed="0.007540"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:38.365812" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:38.363033" elapsed="0.002837"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:38.369311" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:38.366051" elapsed="0.003367">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:38.346433" elapsed="0.023230">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.372680" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:41.371791" elapsed="0.000960"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.377278" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:41.373138" elapsed="0.004181"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:41.383494" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:41.383714" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:41.383864" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:41.377566" elapsed="0.006337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.388014" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.384159" elapsed="0.003926"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.392475" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:41.388320" elapsed="0.004261">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:41.370501" elapsed="0.022272">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:41.392909" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:35.328894" elapsed="6.064149">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:41.393218" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:41.393283" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:35.328465" elapsed="6.064855"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.394547" level="INFO">[?2004l03:28:35 | 3732   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:35 | 3732   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:35 | 3732   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:35 | 3732   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:35 | 3732   | [01;34minstallation [0m | [1m        [0m
03:28:35 | 3732   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:35 | 3732   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:35 | 3732   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:35 | 3732   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:35 | 3732   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:35 | 3732   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:35 | 3732   | configuration[0m | . local-as         | '64496'[0m
03:28:35 | 3732   | configuration[0m | . peer-as          | '64496'[0m
03:28:35 | 3732   | configuration[0m | &gt; capability       | [0m
03:28:35 | 3732   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:35 | 3732   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:35 | 3732   | configuration[0m | &lt; capability       | [0m
03:28:35 | 3732   | configuration[0m | &gt; family           | [0m
03:28:35 | 3732   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:35 | 3732   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:35 | 3732   | configuration[0m | &lt; family           | [0m
03:28:35 | 3732   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1m        [0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1m        [0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:41.394875" level="INFO">${output} = [?2004l03:28:35 | 3732   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:35 | 3732   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:35 | 3732   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:41.394370" elapsed="0.000550"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.395569" level="INFO">[?2004l03:28:35 | 3732   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:35 | 3732   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:35 | 3732   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:35 | 3732   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:35 | 3732   | [01;34minstallation [0m | [1m        [0m
03:28:35 | 3732   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:35 | 3732   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:35 | 3732   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:35 | 3732   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:35 | 3732   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:35 | 3732   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:35 | 3732   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:35 | 3732   | configuration[0m | . local-as         | '64496'[0m
03:28:35 | 3732   | configuration[0m | . peer-as          | '64496'[0m
03:28:35 | 3732   | configuration[0m | &gt; capability       | [0m
03:28:35 | 3732   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:35 | 3732   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:35 | 3732   | configuration[0m | &lt; capability       | [0m
03:28:35 | 3732   | configuration[0m | &gt; family           | [0m
03:28:35 | 3732   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:35 | 3732   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:35 | 3732   | configuration[0m | &lt; family           | [0m
03:28:35 | 3732   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1m        [0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1m        [0m
03:28:35 | 3732   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.395151" elapsed="0.000604"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.396827" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:41.396419" elapsed="0.000436"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:41.397012" elapsed="0.000258"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:41.396073" elapsed="0.001256"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.399478" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:41.399569" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:41.397492" elapsed="0.002104"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.400016" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.399768" elapsed="0.000295"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.402249" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:41.400702" elapsed="0.001603"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.403111" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:41.403217" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:41.402468" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.403836" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.403572" elapsed="0.000311"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:41.403322" elapsed="0.000593"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:41.403302" elapsed="0.000642"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:41.400318" elapsed="0.003672"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:41.393943" elapsed="0.010097"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:41.393475" elapsed="0.010590"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:41.393437" elapsed="0.010651"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:41.404260" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:41.404143" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:41.404126" elapsed="0.000236"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:28:35.290607" elapsed="6.113783"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.405441" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:41.405112" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.405883" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.405623" elapsed="0.000304"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.409077" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:41.406525" elapsed="0.002612"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.414389" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:41.414485" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:41.409324" elapsed="0.005187"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.415133" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.414875" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:41.414585" elapsed="0.000665"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:41.414563" elapsed="0.000713"/>
</if>
<arg>log_output=${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-06-06T03:28:41.406167" elapsed="0.009157"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:41.417244" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:41.417337" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:41.415479" elapsed="0.001884"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.417815" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.417527" elapsed="0.000336"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:41.404784" elapsed="0.013136"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.420124" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:41.419762" elapsed="0.000390"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.422348" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:41.420318" elapsed="0.002058"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:41.429443" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:41.429583" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:41.429708" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:41.422542" elapsed="0.007196"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.432411" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:41.429911" elapsed="0.002548"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:41.435224" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:41.432617" elapsed="0.002686">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:41.419039" elapsed="0.016381">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:44.438398" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:44.437505" elapsed="0.000961"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:44.443426" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:44.438877" elapsed="0.004582"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:44.449086" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:44.449220" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:44.449315" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:44.443732" elapsed="0.005609"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:44.452304" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:44.449513" elapsed="0.002863"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:44.456470" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:44.452611" elapsed="0.004156">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:44.436257" elapsed="0.020676">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.460100" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:47.459176" elapsed="0.000996"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.464837" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:47.460569" elapsed="0.004308"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:47.472202" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:47.472401" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:47.472564" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:47.465130" elapsed="0.007473"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.476673" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.472946" elapsed="0.003803"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.480706" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:47.476980" elapsed="0.003829">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:47.457844" elapsed="0.023131">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:47.481112" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:41.418497" elapsed="6.062745">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:47.481414" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:47.481475" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:41.418088" elapsed="6.063420"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.482715" level="INFO">[?2004l03:28:41 | 3736   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:41 | 3736   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:41 | 3736   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:41 | 3736   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:41 | 3736   | [01;34minstallation [0m | [1m        [0m
03:28:41 | 3736   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:41 | 3736   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:41 | 3736   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:41 | 3736   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:41 | 3736   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:41 | 3736   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:41 | 3736   | configuration[0m | . local-as         | '64496'[0m
03:28:41 | 3736   | configuration[0m | . peer-as          | '64496'[0m
03:28:41 | 3736   | configuration[0m | &gt; capability       | [0m
03:28:41 | 3736   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:41 | 3736   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:41 | 3736   | configuration[0m | &lt; capability       | [0m
03:28:41 | 3736   | configuration[0m | &gt; family           | [0m
03:28:41 | 3736   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:41 | 3736   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:41 | 3736   | configuration[0m | &lt; family           | [0m
03:28:41 | 3736   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1m        [0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1m        [0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:47.483277" level="INFO">${output} = [?2004l03:28:41 | 3736   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:41 | 3736   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:41 | 3736   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:47.482522" elapsed="0.000870"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.483940" level="INFO">[?2004l03:28:41 | 3736   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:41 | 3736   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:41 | 3736   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:41 | 3736   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:41 | 3736   | [01;34minstallation [0m | [1m        [0m
03:28:41 | 3736   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:41 | 3736   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:41 | 3736   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:41 | 3736   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:41 | 3736   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:41 | 3736   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:41 | 3736   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:41 | 3736   | configuration[0m | . local-as         | '64496'[0m
03:28:41 | 3736   | configuration[0m | . peer-as          | '64496'[0m
03:28:41 | 3736   | configuration[0m | &gt; capability       | [0m
03:28:41 | 3736   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:41 | 3736   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:41 | 3736   | configuration[0m | &lt; capability       | [0m
03:28:41 | 3736   | configuration[0m | &gt; family           | [0m
03:28:41 | 3736   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:41 | 3736   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:41 | 3736   | configuration[0m | &lt; family           | [0m
03:28:41 | 3736   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1m        [0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1m        [0m
03:28:41 | 3736   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.483619" elapsed="0.000436"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.484910" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:47.484557" elapsed="0.000381"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:47.485097" elapsed="0.000321"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:47.484266" elapsed="0.001228"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.487573" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:47.487683" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:47.485666" elapsed="0.002047"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.488137" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.487876" elapsed="0.000311"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.490024" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:47.488854" elapsed="0.001226"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.491009" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:47.491122" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:47.490253" elapsed="0.000901"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.492118" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.491517" elapsed="0.000706"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:47.491238" elapsed="0.001060"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:47.491213" elapsed="0.001143"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:47.488463" elapsed="0.003995"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:47.482107" elapsed="0.010467"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:47.481673" elapsed="0.010960"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:47.481615" elapsed="0.011105"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:47.493101" elapsed="0.000035"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:47.492847" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:47.492809" elapsed="0.000537"/>
</if>
<var name="${idx}">1</var>
<status status="PASS" start="2026-06-06T03:28:41.404579" elapsed="6.088834"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.496394" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:47.495208" elapsed="0.001262"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.497536" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.496969" elapsed="0.000669"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.501600" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:47.499232" elapsed="0.002534"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.506336" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:47.506538" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:47.502131" elapsed="0.004465"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.507755" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.507436" elapsed="0.000367"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:47.506794" elapsed="0.001043"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:47.506741" elapsed="0.001124"/>
</if>
<arg>log_output=${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-06-06T03:28:47.498288" elapsed="0.009628"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:47.509478" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:47.509564" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:47.508067" elapsed="0.001522"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.510014" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.509767" elapsed="0.000294"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:47.494255" elapsed="0.015863"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.512393" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:47.512043" elapsed="0.000377"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.514664" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:47.512585" elapsed="0.002108"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:47.518933" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:47.519097" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:47.519192" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:47.514861" elapsed="0.004358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.521853" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:47.519387" elapsed="0.002515"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:47.524674" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:47.522060" elapsed="0.002691">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:47.511558" elapsed="0.013307">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:50.527919" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:50.527012" elapsed="0.000978"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:50.533190" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:50.528377" elapsed="0.004876"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:50.541832" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:50.542013" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:50.542145" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:50.533894" elapsed="0.008288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:50.545906" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:50.542421" elapsed="0.003553"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:50.549813" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:50.546195" elapsed="0.003716">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:50.525724" elapsed="0.024343">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.552210" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:53.551751" elapsed="0.000496"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.555369" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:53.552434" elapsed="0.002977"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:53.564583" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.565124" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:53.565486" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:53.555676" elapsed="0.009877"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.572071" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.566099" elapsed="0.006048"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.576517" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:53.572396" elapsed="0.004233">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:53.551038" elapsed="0.025802">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:53.576987" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:47.510705" elapsed="6.066440">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:28:53.577329" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:28:53.577394" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:47.510286" elapsed="6.067142"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.578758" level="INFO">[?2004l03:28:47 | 3740   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:47 | 3740   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:47 | 3740   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:47 | 3740   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:47 | 3740   | [01;34minstallation [0m | [1m        [0m
03:28:47 | 3740   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:47 | 3740   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:47 | 3740   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:47 | 3740   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:47 | 3740   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:47 | 3740   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:47 | 3740   | configuration[0m | . local-as         | '64496'[0m
03:28:47 | 3740   | configuration[0m | . peer-as          | '64496'[0m
03:28:47 | 3740   | configuration[0m | &gt; capability       | [0m
03:28:47 | 3740   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:47 | 3740   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:47 | 3740   | configuration[0m | &lt; capability       | [0m
03:28:47 | 3740   | configuration[0m | &gt; family           | [0m
03:28:47 | 3740   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:47 | 3740   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:47 | 3740   | configuration[0m | &lt; family           | [0m
03:28:47 | 3740   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1m        [0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1m        [0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:53.579141" level="INFO">${output} = [?2004l03:28:47 | 3740   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:47 | 3740   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:47 | 3740   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:53.578543" elapsed="0.000647"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.579827" level="INFO">[?2004l03:28:47 | 3740   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:47 | 3740   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:47 | 3740   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:47 | 3740   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:47 | 3740   | [01;34minstallation [0m | [1m        [0m
03:28:47 | 3740   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:47 | 3740   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:47 | 3740   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:47 | 3740   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:47 | 3740   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:47 | 3740   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:47 | 3740   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:47 | 3740   | configuration[0m | . local-as         | '64496'[0m
03:28:47 | 3740   | configuration[0m | . peer-as          | '64496'[0m
03:28:47 | 3740   | configuration[0m | &gt; capability       | [0m
03:28:47 | 3740   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:47 | 3740   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:47 | 3740   | configuration[0m | &lt; capability       | [0m
03:28:47 | 3740   | configuration[0m | &gt; family           | [0m
03:28:47 | 3740   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:47 | 3740   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:47 | 3740   | configuration[0m | &lt; family           | [0m
03:28:47 | 3740   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1m        [0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1m        [0m
03:28:47 | 3740   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.579423" elapsed="0.000570"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.581184" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:53.580717" elapsed="0.000507"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:53.581452" elapsed="0.000423"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:53.580292" elapsed="0.001687"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.584411" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:53.584505" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:53.582208" elapsed="0.002325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.584992" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.584713" elapsed="0.000332"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.586866" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:53.585725" elapsed="0.001198"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.587961" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:53.588049" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:53.587111" elapsed="0.000964"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.588662" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.588398" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.588144" elapsed="0.000605"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.588124" elapsed="0.000656"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:53.585325" elapsed="0.003501"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:53.578094" elapsed="0.010783"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.577589" elapsed="0.011315"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.577544" elapsed="0.011383"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:53.589099" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:53.588982" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.588965" elapsed="0.000236"/>
</if>
<var name="${idx}">2</var>
<status status="PASS" start="2026-06-06T03:28:47.493847" elapsed="6.095384"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:28:35.290116" elapsed="18.299155"/>
</for>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.589740" level="FAIL">Unable to connect ExaBgp to ODL</msg>
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:28:53.589437" elapsed="0.000364">Unable to connect ExaBgp to ODL</status>
</kw>
<arg>${DEFAUTL_RPC_CFG}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>connection_retries=${3}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:28:35.284891" elapsed="18.305015">Unable to connect ExaBgp to ODL</status>
</kw>
<arg>${ALLPATHS_SELM}</arg>
<arg>${ADDPATHCAP_SR}</arg>
<doc>Setup test case keyword. Early after the path selection config the incomming connection
from exabgp towards odl may be rejected by odl due to config process not finished yet. Because of that
we try to start the tool 3 times in case early attempts fail.</doc>
<status status="FAIL" start="2026-06-06T03:28:32.330713" elapsed="21.259296">Unable to connect ExaBgp to ODL</status>
</kw>
<kw name="Remove_Odl_And_App_Peer_Configuration_And_Stop_ExaBgp" type="TEARDOWN">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.591120" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.590604" elapsed="0.000549"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.637430" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:53.636995" elapsed="0.000470"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:53.638309" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:53.638015" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:53.638481" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:53.637663" elapsed="0.000843"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.639091" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:53.638689" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:53.639426" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:53.639602" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:53.639282" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.640063" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.639815" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.641183" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.640926" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.641676" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.641389" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.642376" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.642083" elapsed="0.000318"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.643212" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.642986" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.643293" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:28:53.643462" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.642587" elapsed="0.000900"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.643667" elapsed="0.000263"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:53.641944" elapsed="0.002028"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.644708" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.644381" elapsed="0.000356"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.645670" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.645270" elapsed="0.000428"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.645754" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:53.645904" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.644925" elapsed="0.001004"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.646081" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:53.644244" elapsed="0.002099"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:53.641761" elapsed="0.004616"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:53.646420" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:53.646575" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:53.640548" elapsed="0.006053"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.640193" elapsed="0.006439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.646840" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.646673" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.640164" elapsed="0.006753"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.647690" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:53.647062" elapsed="0.000658"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:53.647768" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:53.636226" elapsed="0.011666"/>
</kw>
<msg time="2026-06-06T03:28:53.647947" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:53.622653" elapsed="0.025356"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.661051" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.673895" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.686731" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.686961" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.687146" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.687658" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.687491" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:53.687473" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.687895" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.688065" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.688232" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:53.687432" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:53.687312" elapsed="0.001000"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.688460" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:53.688538" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:28:53.688715" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:53.617704" elapsed="0.071041"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.689989" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.689687" elapsed="0.000354"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:53.700878" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.700928" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.701027" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:53.692252" elapsed="0.008801"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.690107" elapsed="0.010986"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.701275" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.701119" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.690089" elapsed="0.011268"/>
</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-06-06T03:28:53.709947" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.702429" elapsed="0.007652"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.702201" elapsed="0.007983"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.702182" elapsed="0.008068"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.714562" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.711314" elapsed="0.003345"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.710400" elapsed="0.004323"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.710354" elapsed="0.004410"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.715612" 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-06-06T03:28:53.715083" elapsed="0.000574"/>
</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-06-06T03:28:53.716015" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.715749" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.716730" 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-06-06T03:28:53.716404" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.716226" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.715724" elapsed="0.001089"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.717340" 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-06-06T03:28:53.716974" elapsed="0.000393"/>
</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-06-06T03:28:53.717691" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.717436" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.718233" 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-06-06T03:28:53.717939" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.717775" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.717418" elapsed="0.000897"/>
</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-06-06T03:28:53.718489" elapsed="0.000384"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:53.719356" 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-06-06T03:28:53.719042" elapsed="0.000340"/>
</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-06-06T03:28:53.719542" elapsed="0.002416"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:28:53.701752" elapsed="0.020280"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:53.722090" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:28:53.724545" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:28:53.689019" elapsed="0.035553"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:53.724629" elapsed="0.000044"/>
</return>
<arg>${MULT_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:28:53.591383" elapsed="0.133397"/>
</kw>
<kw name="Deconfigure_App_Peer">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.725616" level="INFO">${app_rib} = 10.30.170.38</msg>
<var>${app_rib}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:53.725322" elapsed="0.000334"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.726288" level="INFO">&amp;{route_mapping} = { APP_RIB=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{route_mapping}</var>
<arg>APP_RIB=${app_rib}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.725827" elapsed="0.000488"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.770922" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:53.770482" elapsed="0.000474"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:53.771802" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:53.771489" elapsed="0.000390">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:53.771975" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:53.771142" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.772555" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:53.772168" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:53.772906" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:53.773102" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:53.772761" elapsed="0.000439"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.773609" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.773362" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.774964" level="INFO">mapping: {'APP_RIB': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.774439" elapsed="0.000570"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.775451" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.775174" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.776186" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.775883" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.777246" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.776766" elapsed="0.000507"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.777326" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:28:53.777488" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.776401" elapsed="0.001112"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.777697" elapsed="0.000241"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:53.775742" elapsed="0.002238"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.778523" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.778225" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.779545" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.779112" elapsed="0.000459"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.779621" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:28:53.779790" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.778751" elapsed="0.001064"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.779967" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:53.778093" elapsed="0.002136"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:53.775533" elapsed="0.004732"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:53.780308" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:53.780462" level="INFO">${mapping_to_use} = {'APP_RIB': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:53.774086" elapsed="0.006401"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.773753" elapsed="0.006766"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.780711" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.780545" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.773728" elapsed="0.007061"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.781531" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:53.780935" elapsed="0.000625"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:53.781609" elapsed="0.000042"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:53.769795" elapsed="0.011976"/>
</kw>
<msg time="2026-06-06T03:28:53.781838" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:53.756464" elapsed="0.025448"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.795526" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.808802" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.822465" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.822752" elapsed="0.000046"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.822982" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.823464" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.823283" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:53.823263" elapsed="0.000296"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.823745" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.823943" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.824118" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:53.823215" elapsed="0.000956"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:53.823074" elapsed="0.001126"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.824350" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:53.824430" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:28:53.824594" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:53.751801" elapsed="0.072822"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.825984" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.825660" elapsed="0.000379"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:53.837533" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.837581" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.837709" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:53.828585" elapsed="0.009152"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.826107" elapsed="0.011694"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.838079" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.837842" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.826088" elapsed="0.012188"/>
</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-06-06T03:28:53.843637" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.839882" elapsed="0.003840"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.839528" elapsed="0.004245"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.839501" elapsed="0.004310"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.847798" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.844220" elapsed="0.003624"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.843892" elapsed="0.003986"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.843868" elapsed="0.004034"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.848484" 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-06-06T03:28:53.848084" elapsed="0.000427"/>
</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-06-06T03:28:53.848842" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.848581" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.849390" 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-06-06T03:28:53.849089" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.848924" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.848562" elapsed="0.000910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.850011" 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-06-06T03:28:53.849632" elapsed="0.000406"/>
</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-06-06T03:28:53.850343" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.850107" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.850916" 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-06-06T03:28:53.850585" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.850423" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.850088" elapsed="0.000910"/>
</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-06-06T03:28:53.851153" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:53.851989" 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-06-06T03:28:53.851686" elapsed="0.000329"/>
</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-06-06T03:28:53.852172" elapsed="0.002382"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:28:53.838868" elapsed="0.015750"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:53.854684" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:28:53.857159" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:28:53.824940" elapsed="0.032247"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:53.857242" elapsed="0.000028"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:28:53.726549" elapsed="0.130819"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.858155" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | APP_PEER_NAME=example-bgp-peer-app | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>APP_PEER_NAME=${APP_PEER_NAME}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.857541" elapsed="0.000643"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.902792" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:53.902368" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:53.903637" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:53.903337" elapsed="0.000397">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:53.903919" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:53.902997" elapsed="0.000948"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.904505" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:53.904115" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:53.904857" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:53.905019" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:53.904713" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.905453" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.905205" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.906514" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.906254" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.907037" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.906736" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.907767" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.907446" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.908858" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.908329" elapsed="0.000556"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.908937" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:53.909094" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.907981" elapsed="0.001137"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.909274" elapsed="0.000235"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:28:53.907307" elapsed="0.002243"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.910113" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.909817" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.911148" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.910680" elapsed="0.000495"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.911225" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:53.911375" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.910321" elapsed="0.001078"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.911551" elapsed="0.000243"/>
</kw>
<var name="${key}">APP_PEER_NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:28:53.909682" elapsed="0.002152"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.912374" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.912079" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.913552" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.913110" elapsed="0.000468"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.913629" elapsed="0.000058"/>
</return>
<msg time="2026-06-06T03:28:53.913816" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.912582" elapsed="0.001260"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.913993" elapsed="0.000221"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:53.911945" elapsed="0.002309"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.914883" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:53.914535" elapsed="0.000374"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:53.915968" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.915499" elapsed="0.000496"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:53.916051" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:53.916209" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:53.915094" elapsed="0.001141"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:53.916388" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:53.914402" elapsed="0.002266"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:53.907119" elapsed="0.009585"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:53.916747" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:53.917078" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:53.905904" elapsed="0.011199"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.905575" elapsed="0.011560"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.917313" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.917161" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.905551" elapsed="0.011838"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.918254" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:53.917534" elapsed="0.000750"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:53.918333" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:53.901715" elapsed="0.016743"/>
</kw>
<msg time="2026-06-06T03:28:53.918513" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:53.888303" elapsed="0.030272"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.931904" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.944809" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.957739" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.957944" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.958129" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.958589" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.958435" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:53.958419" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.958848" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.959020" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.959186" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:53.958384" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:53.958272" elapsed="0.000994"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.959416" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:53.959493" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:53.959631" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:53.883598" elapsed="0.076075"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.960866" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.960578" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:53.971160" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.971209" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:53.971301" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:53.963299" elapsed="0.008028"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.960982" elapsed="0.010387"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:53.971555" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.971395" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.960964" elapsed="0.010673"/>
</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-06-06T03:28:53.975425" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.972694" elapsed="0.002775"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.972454" elapsed="0.003049"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.972436" elapsed="0.003092"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.979173" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.975859" elapsed="0.003378"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.975583" elapsed="0.003702"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.975566" elapsed="0.003753"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.980138" 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-06-06T03:28:53.979568" elapsed="0.000607"/>
</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-06-06T03:28:53.980610" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.980274" elapsed="0.000495"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.981468" 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-06-06T03:28:53.981043" elapsed="0.000462"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.980807" elapsed="0.000749"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.980248" elapsed="0.001337"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.982342" 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-06-06T03:28:53.981834" elapsed="0.000548"/>
</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-06-06T03:28:53.982846" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:53.982479" elapsed="0.000453"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.983761" 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-06-06T03:28:53.983314" elapsed="0.000485"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.983089" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:53.982454" elapsed="0.001428"/>
</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-06-06T03:28:53.984108" elapsed="0.000515"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:53.985321" 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-06-06T03:28:53.984896" elapsed="0.000463"/>
</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-06-06T03:28:53.985594" elapsed="0.003108"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:28:53.972019" elapsed="0.016748"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:53.988815" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:28:53.991190" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:28:53.959941" elapsed="0.031276"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:53.991272" elapsed="0.000027"/>
</return>
<arg>${BGP_VAR_FOLDER}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:28:53.858422" elapsed="0.132975"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:28:53.724975" elapsed="0.266485"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.992191" level="INFO">${output} =  </msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:28:53.992014" elapsed="0.000203"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.992622" level="INFO"> </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.992372" elapsed="0.000310"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.993494" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:53.993183" elapsed="0.000337"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:53.993690" elapsed="0.000319"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:28:53.992885" elapsed="0.001185"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.996404" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:53.996498" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:53.994234" elapsed="0.002291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:53.997031" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:53.996773" elapsed="0.000307"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:53.999073" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:53.997756" elapsed="0.001375"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:54.122831" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:54.123082" level="INFO">${output} = [?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:53.999292" elapsed="0.123825"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.124085" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.123690" elapsed="0.000450"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.123267" elapsed="0.001069"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.123224" elapsed="0.001145"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:28:53.997334" elapsed="0.127101"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:28:53.991705" elapsed="0.132795"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.126123" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.125702" elapsed="0.000485"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.125682" elapsed="0.000530"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.126368" elapsed="0.000359"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.132049" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.131598" elapsed="0.000480"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="NOT RUN" start="2026-06-06T03:28:54.132299" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:54.132152" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.132134" elapsed="0.000230"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.132825" level="INFO">${newline} = 
</msg>
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.132512" elapsed="0.000340"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.133277" level="INFO">${reference} = bgpcep_userfeatures_txt_020_Bgp_Functional_Multipath_Odl_Allpaths_Exa_SendReceived</msg>
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.133011" elapsed="0.000293"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<msg time="2026-06-06T03:28:54.133656" level="INFO">${reference} = bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived</msg>
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="PASS" start="2026-06-06T03:28:54.133464" elapsed="0.000220"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.134181" level="INFO">${msg} = ... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived"
reference somewhere inside)</msg>
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.133841" elapsed="0.000367"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.134684" level="INFO">${bugs} = "https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived&amp;order=bug_status"</msg>
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.134363" elapsed="0.000349"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.135342" level="INFO">Set test message to:
... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived&amp;order=bug_status"

Setup failed:
Unable to connect ExaBgp to ODL</msg>
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="PASS" start="2026-06-06T03:28:54.134880" elapsed="0.000512"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.135858" level="INFO">... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived&amp;order=bug_status"</msg>
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.135547" elapsed="0.000358"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.131287" elapsed="0.004672"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.125452" elapsed="0.010557"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:28:54.124744" elapsed="0.011307"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:53.590286" elapsed="0.545814"/>
</kw>
<doc>all-paths selected policy selected</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:28:32.330276" elapsed="21.805874">... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_allpaths_exa_sendreceived&amp;order=bug_status"

Setup failed:
Unable to connect ExaBgp to ODL</status>
</test>
<test id="s1-s15-t3" name="Odl Npaths Exa SendReceived" line="81">
<kw name="Configure_Path_Selection_And_App_Peer_And_Connect_Peer" type="SETUP">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:28:54.139998" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:28:54.139725" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.141273" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:54.141162" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.141142" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.146588" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:54.146480" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.146462" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.147697" 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-06-06T03:28:54.147296" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.148187" 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-06-06T03:28:54.147893" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:28:54.148257" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:28:54.148419" 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-06-06T03:28:54.146916" elapsed="0.001527"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:28:54.154081" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:54.153971" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.153951" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:28:54.155503" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:28:54.155352" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.155332" elapsed="0.000344"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:54.156239" 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-06-06T03:28:54.155832" elapsed="0.000434"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:28:54.156728" level="INFO">${current_connection_index} = 7</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-06-06T03:28:54.156469" elapsed="0.000286"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:54.190444" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:54.158186" elapsed="0.032494"/>
</kw>
<msg time="2026-06-06T03:28:54.190890" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:28:54.190936" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:28:54.156948" elapsed="0.034026"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:28:54.226022" level="INFO">". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "N "p "a "t "h "s "[C "E "x "a "[C "S "e "n "d "R "e "c "e "i "v "e "d "[K"
[?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-06-06T03:28:54.192557" elapsed="0.033853"/>
</kw>
<msg time="2026-06-06T03:28:54.226868" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:28:54.226979" level="INFO">${message_wait} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "...</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-06-06T03:28:54.191253" elapsed="0.035812"/>
</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-06-06T03:28:54.227947" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.227387" elapsed="0.000729"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.227330" elapsed="0.000818"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.228931" level="INFO"> ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "N "p "a "t "h "s "[C "E "x "a "[C "S "e "n "d "R "e "c "e "i "v "e "d "[K"
[?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-06-06T03:28:54.228301" elapsed="0.000744"/>
</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-06-06T03:28:54.229427" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.229132" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.229111" elapsed="0.000601"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:28:54.229753" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:28:54.232473" elapsed="0.000378"/>
</kw>
<msg time="2026-06-06T03:28:54.232899" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.231985" elapsed="0.000985"/>
</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="NOT RUN" start="2026-06-06T03:28:54.233197" elapsed="0.000024"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.233424" elapsed="0.000024"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:28:54.231032" elapsed="0.002548"/>
</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-06-06T03:28:54.230101" elapsed="0.003642"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:28:54.154995" elapsed="0.078852"/>
</kw>
<msg time="2026-06-06T03:28:54.233941" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:54.233986" level="INFO">${message} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:54.154306" elapsed="0.079719"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:28:54.234214" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:54.234103" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.234083" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.234776" elapsed="0.000031"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.235165" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.235238" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:28:54.153621" elapsed="0.081724"/>
</kw>
<msg time="2026-06-06T03:28:54.235439" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:28:54.235483" level="INFO">${output} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "O "d "l "[C "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:28:54.148849" elapsed="0.086672"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.235882" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.235596" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.235578" elapsed="0.000383"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:28:54.148702" elapsed="0.087283"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:28:54.148505" elapsed="0.087513"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:28:54.146117" elapsed="0.089956"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:28:54.140871" elapsed="0.095263"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:54.140420" elapsed="0.095759"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:28:54.137435" elapsed="0.098799"/>
</kw>
<kw name="Configure_Odl_Peer_With_Path_Selection_Mode">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.237162" level="INFO">${npaths} = 2</msg>
<var>${npaths}</var>
<arg>"${psm}"=="${ALLPATHS_SELM}"</arg>
<arg>0</arg>
<arg>${N_PATHS_VALUE}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.236760" elapsed="0.000428"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.238072" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | HOLDTIME=180 | PEER_PORT=17900 | PASSIVE_MODE=true | MULTIPATH=2 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>MULTIPATH=${npaths}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.237357" elapsed="0.000745"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.272666" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.272261" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.273468" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.273214" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.273654" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.272871" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.274235" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.273850" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.274567" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:54.274766" level="INFO">${template} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.274426" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.275198" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.274953" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.276505" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.276238" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.277008" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.276733" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.277983" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.277415" elapsed="0.000594"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.279179" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.278666" elapsed="0.000554"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.279338" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:28:54.279571" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.278199" elapsed="0.001398"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.279772" elapsed="0.000499"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:54.277274" elapsed="0.003039"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.281084" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.280563" elapsed="0.000547"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.282250" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.281767" elapsed="0.000523"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.282407" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.282635" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.281295" elapsed="0.001387"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.282883" elapsed="0.000483"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:28:54.280428" elapsed="0.002980"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.284187" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.283671" elapsed="0.000542"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.285397" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.284913" elapsed="0.000525"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.285555" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.285824" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.284399" elapsed="0.001451"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.286004" elapsed="0.000483"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:28:54.283520" elapsed="0.003009"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.287389" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.286889" elapsed="0.000527"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.288545" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.288065" elapsed="0.000521"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.288722" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:28:54.288951" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.287602" elapsed="0.001374"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.289129" elapsed="0.000472"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:28:54.286739" elapsed="0.002932"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.290419" level="INFO">${value} = 2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.289921" elapsed="0.000524"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.291693" level="INFO">${encoded} = 2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.291194" elapsed="0.000541"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.291856" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.292085" level="INFO">${encoded_value} = 2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.290630" elapsed="0.001480"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.292264" elapsed="0.000724"/>
</kw>
<var name="${key}">MULTIPATH</var>
<var name="${value}">2</var>
<status status="PASS" start="2026-06-06T03:28:54.289788" elapsed="0.003256"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.293864" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.293305" elapsed="0.000587"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.295168" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.294532" elapsed="0.000679"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.295328" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:54.295562" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.294082" elapsed="0.001506"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.295758" elapsed="0.000489"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:54.293167" elapsed="0.003122"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:54.277089" elapsed="0.019235"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:54.296368" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:54.296530" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:54.275671" elapsed="0.020886"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.275317" elapsed="0.021272"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.296793" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.296616" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.275295" elapsed="0.021576"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.297518" level="INFO">${final_text} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.297017" elapsed="0.000530"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.297595" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:54.271616" elapsed="0.026137"/>
</kw>
<msg time="2026-06-06T03:28:54.297856" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.258445" elapsed="0.039466"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.310944" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.323796" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.336793" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.337002" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.337184" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.337574" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.337426" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:54.337410" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.337815" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.337982" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.338149" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:54.337374" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.337264" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.338375" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.338452" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:54.338582" level="INFO">${uri} = /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.254094" elapsed="0.084515"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.366096" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.365699" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.367018" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.366721" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.367190" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.366359" elapsed="0.000856"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.367785" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.367383" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.368120" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:54.368283" level="INFO">${template} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.367977" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.368735" level="INFO">&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
        &lt;global&gt;
            &lt;config&gt;
                &lt;router-id&gt;192.0.2.2&lt;/router-id&gt;
                &lt;as&gt;64496&lt;/as&gt;
            &lt;/config&gt;
            &lt;apply-policy&gt;
                &lt;config&gt;
                    &lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;
                    &lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;
                    &lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;
                    &lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;
                &lt;/config&gt;
            &lt;/apply-policy&gt;
            &lt;afi-safis&gt;
                &lt;afi-safi&gt;
                    &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
                    &lt;receive&gt;true&lt;/receive&gt;
                    &lt;send-max&gt;$MULTIPATH&lt;/send-max&gt;
                &lt;/afi-safi&gt;
            &lt;/afi-safis&gt;
        &lt;/global&gt;
    &lt;/bgp&gt;
&lt;/protocol&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.368471" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:54.369174" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.368868" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.369712" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.369401" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.369256" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.368847" elapsed="0.000948"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.370685" level="INFO">${final_text} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.369942" elapsed="0.000774"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.370796" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:54.365045" elapsed="0.005886"/>
</kw>
<msg time="2026-06-06T03:28:54.370992" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.351714" elapsed="0.019326"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.384159" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.397624" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.410418" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.410617" elapsed="0.000033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.410821" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.411202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.411055" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:54.411040" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.411422" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.411590" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.411775" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:54.411011" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.410902" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.412002" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.412076" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:54.412211" level="INFO">${data} = &lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.348979" elapsed="0.063261"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.413503" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.413265" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/rib_policies/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.413675" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.412922" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.414026" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.413777" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.414581" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.414291" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.414107" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.413759" elapsed="0.000921"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.419617" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.414871" elapsed="0.004804"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:54.419779" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.419936" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/rib_policies/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:54.412574" elapsed="0.007387"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.421344" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.421094" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.421815" level="INFO">&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
        &lt;global&gt;
            &lt;config&gt;
                &lt;router-id&gt;192.0.2.2&lt;/router-id&gt;
                &lt;as&gt;64496&lt;/as&gt;
            &lt;/config&gt;
            &lt;apply-policy&gt;
                &lt;config&gt;
                    &lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;
                    &lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;
                    &lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;
                    &lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;
                &lt;/config&gt;
            &lt;/apply-policy&gt;
            &lt;afi-safis&gt;
                &lt;afi-safi&gt;
                    &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
                    &lt;receive&gt;true&lt;/receive&gt;
                    &lt;send-max&gt;2&lt;/send-max&gt;
                &lt;/afi-safi&gt;
            &lt;/afi-safis&gt;
        &lt;/global&gt;
    &lt;/bgp&gt;
&lt;/protocol&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.421545" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.422272" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.422028" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.422727" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.422468" elapsed="0.000314"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:54.423593" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:54.423394" elapsed="0.000225"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:54.423973" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:54.423797" elapsed="0.000201"/>
</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-06-06T03:28:54.424149" elapsed="0.000211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.424786" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.424518" elapsed="0.000312"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:54.424872" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:54.425028" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:54.422987" elapsed="0.002066"/>
</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-06-06T03:28:54.441084" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '1165', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;
    &lt;name&gt;example-bgp-rib&lt;/name&gt;
    &lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;
    &lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
        &lt;global&gt;
            &lt;config&gt;
                &lt;router-id&gt;192.0.2.2&lt;/router-id&gt;
                &lt;as&gt;64496&lt;/as&gt;
            &lt;/config&gt;
            &lt;apply-policy&gt;
                &lt;config&gt;
                    &lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;
                    &lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;
                    &lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;
                    &lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;
                &lt;/config&gt;
            &lt;/apply-policy&gt;
            &lt;afi-safis&gt;
                &lt;afi-safi&gt;
                    &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
                    &lt;receive&gt;true&lt;/receive&gt;
                    &lt;send-max&gt;2&lt;/send-max&gt;
                &lt;/afi-safi&gt;
            &lt;/afi-safis&gt;
        &lt;/global&gt;
    &lt;/bgp&gt;
&lt;/protocol&gt; 
 </msg>
<msg time="2026-06-06T03:28:54.441223" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:54.441441" level="INFO">${response} = &lt;Response [204]&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-06-06T03:28:54.427260" elapsed="0.014238"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.425124" elapsed="0.016575"/>
</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-06-06T03:28:54.442120" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.441763" elapsed="0.000506"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.425105" elapsed="0.017213"/>
</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-06-06T03:28:54.450075" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.444488" elapsed="0.005681"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.443991" elapsed="0.006257"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.443949" elapsed="0.006356"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.500387" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.451153" elapsed="0.049303"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.450429" elapsed="0.050077"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.450391" elapsed="0.050149"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.501268" 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-06-06T03:28:54.500781" elapsed="0.000514"/>
</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-06-06T03:28:54.501628" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.501376" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.502198" 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-06-06T03:28:54.501896" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.501728" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.501354" elapsed="0.000926"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.502842" 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-06-06T03:28:54.502444" elapsed="0.000425"/>
</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-06-06T03:28:54.503180" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.502940" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.503734" 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-06-06T03:28:54.503424" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.503261" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.502921" elapsed="0.000895"/>
</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-06-06T03:28:54.503982" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:54.504818" 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-06-06T03:28:54.504499" elapsed="0.000345"/>
</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-06-06T03:28:54.505004" elapsed="0.002427"/>
</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-06-06T03:28:54.443155" elapsed="0.064348"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:54.507700" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:28:54.507573" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.507554" elapsed="0.000242"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:54.507948" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.508017" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:54.510390" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:28:54.420285" elapsed="0.090131"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.510482" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:54.510634" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:54.242920" elapsed="0.267753"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.511136" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.510875" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.510856" elapsed="0.000374"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.511263" elapsed="0.000025"/>
</return>
<arg>${MULT_VAR_FOLDER}/rib_policies</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:54.238407" elapsed="0.272979"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.546357" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.545968" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.547182" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.546929" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.547351" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.546559" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.547949" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.547545" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.548281" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:54.548449" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.548139" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.548908" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.548637" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.549929" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.549669" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.550408" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.550137" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.551412" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.550862" elapsed="0.000576"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.552606" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.552110" elapsed="0.000554"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.552787" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:28:54.553022" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.551626" elapsed="0.001423"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.553207" elapsed="0.000514"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:28:54.550689" elapsed="0.003075"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.554513" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.554014" elapsed="0.000525"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.555720" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.555203" elapsed="0.000612"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.555937" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.556166" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.554756" elapsed="0.001436"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.556346" elapsed="0.000510"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:28:54.553880" elapsed="0.003021"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.557837" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.557148" elapsed="0.000715"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.559078" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.558498" elapsed="0.000622"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.559239" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:54.559467" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.558050" elapsed="0.001443"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.559676" elapsed="0.000486"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:28:54.557014" elapsed="0.003190"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.561067" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.560452" elapsed="0.000642"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.562222" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.561740" elapsed="0.000523"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.562379" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:54.562607" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.561281" elapsed="0.001352"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.562832" elapsed="0.000480"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:28:54.560318" elapsed="0.003036"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.564133" level="INFO">${value} = 2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.563601" elapsed="0.000558"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.565370" level="INFO">${encoded} = 2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.564890" elapsed="0.000521"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.565526" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.565776" level="INFO">${encoded_value} = 2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.564345" elapsed="0.001458"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.565957" elapsed="0.000476"/>
</kw>
<var name="${key}">MULTIPATH</var>
<var name="${value}">2</var>
<status status="PASS" start="2026-06-06T03:28:54.563468" elapsed="0.003006"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.567265" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.566757" elapsed="0.000535"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.568441" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.567954" elapsed="0.000530"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.568603" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.568940" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.567478" elapsed="0.001488"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.569120" elapsed="0.000480"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:54.566588" elapsed="0.003070"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:54.550488" elapsed="0.019208"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:54.569742" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:54.569907" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:54.549331" elapsed="0.020602"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.549028" elapsed="0.020999"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.570215" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.570056" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.549006" elapsed="0.021286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.571159" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.570439" elapsed="0.000749"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.571239" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:54.545330" elapsed="0.026035"/>
</kw>
<msg time="2026-06-06T03:28:54.571423" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.531874" elapsed="0.039604"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.584975" elapsed="0.000056"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.598883" elapsed="0.000064"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.612074" elapsed="0.000058"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.612386" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.612580" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.613053" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.612895" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:54.612872" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.613281" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.613455" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.613624" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:54.612829" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.612683" elapsed="0.001040"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.613876" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.613957" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:28:54.614206" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.527329" elapsed="0.086906"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.642526" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.642084" elapsed="0.000476"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.643401" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.643136" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.643573" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.642778" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.644182" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.643790" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.644520" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:54.644708" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.644376" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.645146" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;$PEER_PORT&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
             &lt;receive&gt;true&lt;/receive&gt;
             &lt;send-max&gt;$MULTIPATH&lt;/send-max&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.644898" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:54.645664" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.645287" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.646204" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'PASSIVE_MODE': 'true', 'MULTIPATH': '2', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.645900" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.645753" elapsed="0.000513"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.645262" elapsed="0.001026"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.647228" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.646436" elapsed="0.000823"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.647313" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:54.641311" elapsed="0.006143"/>
</kw>
<msg time="2026-06-06T03:28:54.647613" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.627782" elapsed="0.019904"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.661086" elapsed="0.000062"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.674252" elapsed="0.000062"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.687529" elapsed="0.000064"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.687873" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.688070" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.688514" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.688360" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:54.688340" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.688757" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.689078" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.689245" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:54.688300" elapsed="0.000998"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.688160" elapsed="0.001164"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.689473" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.689554" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:54.689741" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflec...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.624836" elapsed="0.064938"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.691404" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.691100" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.691580" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.690600" elapsed="0.001100"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.692057" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.691779" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.692635" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.692329" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.692140" elapsed="0.000576"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.691759" elapsed="0.000979"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.695209" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.692898" elapsed="0.002339"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:54.695293" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:28:54.695459" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:54.690224" elapsed="0.005260"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.696963" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.696691" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.697410" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
             &lt;receive&gt;true&lt;/receive&gt;
             &lt;send-max&gt;2&lt;/send-max&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.697169" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.697890" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.697626" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.698332" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.698089" elapsed="0.000287"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:54.699257" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:54.699057" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:54.699619" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:54.699442" elapsed="0.000218"/>
</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-06-06T03:28:54.699814" elapsed="0.000211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.700428" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.700181" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:54.700516" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:28:54.700698" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:54.698586" elapsed="0.002139"/>
</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-06-06T03:28:54.716558" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '871', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;17900&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
             &lt;receive&gt;true&lt;/receive&gt;
             &lt;send-max&gt;2&lt;/send-max&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:28:54.716809" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:54.717006" 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-06-06T03:28:54.703233" elapsed="0.013813"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.700804" elapsed="0.016332"/>
</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-06-06T03:28:54.717494" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.717187" elapsed="0.000435"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.700783" elapsed="0.016910"/>
</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-06-06T03:28:54.723253" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.719355" elapsed="0.003985"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.718994" elapsed="0.004407"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.718961" elapsed="0.004489"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.727521" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.723942" elapsed="0.003646"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.723542" elapsed="0.004119"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.723515" elapsed="0.004185"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.728339" 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-06-06T03:28:54.727930" elapsed="0.000437"/>
</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-06-06T03:28:54.728698" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.728439" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.729257" 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-06-06T03:28:54.728953" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.728783" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.728420" elapsed="0.000921"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.729888" 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-06-06T03:28:54.729503" elapsed="0.000412"/>
</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-06-06T03:28:54.730222" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.729986" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.730796" 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-06-06T03:28:54.730467" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.730305" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.729968" elapsed="0.000911"/>
</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-06-06T03:28:54.731037" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:54.731872" 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-06-06T03:28:54.731559" elapsed="0.000339"/>
</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-06-06T03:28:54.732058" elapsed="0.002366"/>
</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-06-06T03:28:54.718313" elapsed="0.016181"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:54.734693" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:28:54.734565" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.734545" elapsed="0.000259"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:54.734958" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.735027" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:54.737389" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:28:54.695854" elapsed="0.041562"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.737575" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:28:54.737752" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:54.516096" elapsed="0.221682"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.738141" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.737879" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.737862" elapsed="0.000373"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.738268" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:54.511665" elapsed="0.226728"/>
</kw>
<arg>${odl_path_sel_mode}</arg>
<doc>Configures odl peer with path selection mode</doc>
<status status="PASS" start="2026-06-06T03:28:54.236377" elapsed="0.502083"/>
</kw>
<kw name="Configure_App_Peer_With_Routes">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.739293" level="INFO">${app_rib} = 10.30.170.38</msg>
<var>${app_rib}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.738994" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.740163" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | APP_PEER_NAME=example-bgp-peer-app | RIB_INSTANCE_NAME=example-bgp-rib | APP_PEER_ID=10.30.170.38 | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>APP_PEER_NAME=${APP_PEER_NAME}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>APP_PEER_ID=${ODL_SYSTEM_IP}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.739488" elapsed="0.000704"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.775475" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.775051" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.776315" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.776058" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.776486" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.775707" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.777088" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.776697" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.777427" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:54.777593" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.777281" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.778053" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.777805" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.779174" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.778908" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.779674" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.779385" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.780622" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.780077" elapsed="0.000614"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.781927" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.781407" elapsed="0.000562"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.782090" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:28:54.782332" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.780951" elapsed="0.001408"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.782523" elapsed="0.000563"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:28:54.779939" elapsed="0.003191"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.783907" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.783382" elapsed="0.000551"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.785281" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.784789" elapsed="0.000535"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.785443" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.785706" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.784302" elapsed="0.001431"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.785891" elapsed="0.000481"/>
</kw>
<var name="${key}">APP_PEER_NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:28:54.783246" elapsed="0.003170"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.787209" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.786683" elapsed="0.000552"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.788376" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.787886" elapsed="0.000531"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.788534" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:54.788795" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.787424" elapsed="0.001397"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.789155" elapsed="0.000586"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:54.786530" elapsed="0.003260"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.790541" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.790041" elapsed="0.000526"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.791741" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.791245" elapsed="0.000537"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.791896" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.792124" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.790800" elapsed="0.001349"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.792303" elapsed="0.000515"/>
</kw>
<var name="${key}">APP_PEER_ID</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:54.789904" elapsed="0.002957"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.793622" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.793112" elapsed="0.000653"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.794908" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.794400" elapsed="0.000550"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.795065" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:28:54.795291" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.793957" elapsed="0.001359"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.795471" elapsed="0.000494"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:54.792975" elapsed="0.003033"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.796790" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:54.796254" elapsed="0.000563"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:54.798030" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.797514" elapsed="0.000556"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:54.798187" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:28:54.798414" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:54.797069" elapsed="0.001371"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.798595" elapsed="0.000517"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:28:54.796120" elapsed="0.003036"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:54.779755" elapsed="0.019437"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:54.799238" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:54.799402" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'exampl...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:54.778533" elapsed="0.020895"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.778181" elapsed="0.021279"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.799664" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.799490" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.778156" elapsed="0.021587"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.800586" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.799893" elapsed="0.000722"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.800696" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:54.774299" elapsed="0.026525"/>
</kw>
<msg time="2026-06-06T03:28:54.800883" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.760983" elapsed="0.039955"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.814372" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.827612" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.840512" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.840762" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.840955" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.841460" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.841213" elapsed="0.000307"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:54.841195" elapsed="0.000352"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.841709" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.841884" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.842052" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:54.841156" elapsed="0.000949"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.841039" elapsed="0.001094"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.842283" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.842361" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:54.842512" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.756503" elapsed="0.086038"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.879600" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.879177" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.880466" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.880184" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.880665" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.879839" elapsed="0.000853"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.881260" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.880871" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.881596" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:54.881788" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:54.881451" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.882227" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.881980" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:54.882696" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.882360" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.883253" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'exampl...</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.882953" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.882803" elapsed="0.000513"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.882332" elapsed="0.001006"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.884178" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:54.883489" elapsed="0.000793"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.884340" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:54.878513" elapsed="0.005969"/>
</kw>
<msg time="2026-06-06T03:28:54.884538" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.864146" elapsed="0.020442"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.897689" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.910586" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.923467" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.923679" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.923858" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.924249" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.924101" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:54.924086" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.924469" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.924637" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.924826" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:54.924055" elapsed="0.000824"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.923942" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.925058" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.925133" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:54.925251" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.860022" elapsed="0.065258"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:54.926583" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.926348" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:54.926769" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:54.926004" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.927114" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.926866" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.927689" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:54.927382" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.927196" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.926847" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.930158" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:54.927925" elapsed="0.002259"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:54.930235" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:54.930389" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:54.925671" elapsed="0.004742"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.931828" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.931562" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.932264" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.932027" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.932722" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.932464" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.933155" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.932915" elapsed="0.000284"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:54.934024" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:54.933823" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:54.934388" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:54.934205" elapsed="0.000208"/>
</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-06-06T03:28:54.934564" elapsed="0.000258"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.935234" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.934989" elapsed="0.000288"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:54.935319" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:54.935473" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:54.933401" elapsed="0.002097"/>
</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-06-06T03:28:54.949305" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:28:54.949382" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:54.949554" 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-06-06T03:28:54.937886" elapsed="0.011705"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.935569" elapsed="0.014116"/>
</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-06-06T03:28:54.949946" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.949725" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.935550" elapsed="0.014521"/>
</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-06-06T03:28:54.956930" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.951440" elapsed="0.005588"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.951131" elapsed="0.005977"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.951104" elapsed="0.006060"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.962990" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:54.957829" elapsed="0.005208"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.957291" elapsed="0.005781"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.957253" elapsed="0.005843"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.963658" 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-06-06T03:28:54.963262" elapsed="0.000426"/>
</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-06-06T03:28:54.964004" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.963760" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.964551" 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-06-06T03:28:54.964251" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.964087" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.963741" elapsed="0.000892"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.965175" 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-06-06T03:28:54.964812" elapsed="0.000390"/>
</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-06-06T03:28:54.965508" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.965272" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.966065" 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-06-06T03:28:54.965771" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:54.965588" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.965254" elapsed="0.000892"/>
</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-06-06T03:28:54.966297" elapsed="0.000342"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:54.967132" 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-06-06T03:28:54.966852" elapsed="0.000306"/>
</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-06-06T03:28:54.967315" elapsed="0.002376"/>
</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-06-06T03:28:54.950573" elapsed="0.019181"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:54.969928" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:54.969820" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.969801" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:54.970164" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:54.970230" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:54.972607" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:28:54.930773" elapsed="0.041861"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.972720" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:54.972877" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:54.745225" elapsed="0.227677"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:54.973283" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:54.973042" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:54.973023" elapsed="0.000352"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:54.973408" elapsed="0.000026"/>
</return>
<arg>${BGP_VAR_FOLDER}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:54.740465" elapsed="0.233068"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:54.974485" level="INFO">&amp;{route_mapping} = { NEXTHOP=100.100.100.1 | LOCALPREF=100 | PATHID=1 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{route_mapping}</var>
<arg>NEXTHOP=${NEXT_HOP_PREF}${pathid}</arg>
<arg>LOCALPREF=${pathid}00</arg>
<arg>PATHID=${pathid}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:54.973896" elapsed="0.000617"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.009316" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.008944" elapsed="0.000400"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.010174" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.009858" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.010333" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.009507" elapsed="0.000850"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.010946" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.010523" elapsed="0.000449"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.011275" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:55.011406" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:55.011140" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.011849" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.011587" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.013075" level="INFO">mapping: {'NEXTHOP': '100.100.100.1', 'LOCALPREF': '100', 'PATHID': '1', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.012572" elapsed="0.000550"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.013691" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.013282" elapsed="0.000437"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.014798" level="INFO">${value} = 100.100.100.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.014107" elapsed="0.000733"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.016512" level="INFO">${encoded} = 100.100.100.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.016098" elapsed="0.000451"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.016626" elapsed="0.000090"/>
</return>
<msg time="2026-06-06T03:28:55.016982" level="INFO">${encoded_value} = 100.100.100.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.015299" elapsed="0.001723"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.017250" elapsed="0.000526"/>
</kw>
<var name="${key}">NEXTHOP</var>
<var name="${value}">100.100.100.1</var>
<status status="PASS" start="2026-06-06T03:28:55.013936" elapsed="0.003938"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.018878" level="INFO">${value} = 100</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.018195" elapsed="0.000725"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.021896" level="INFO">${encoded} = 100</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.021463" elapsed="0.000471"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.022013" elapsed="0.000074"/>
</return>
<msg time="2026-06-06T03:28:55.022355" level="INFO">${encoded_value} = 100</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.020674" elapsed="0.001721"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.022624" elapsed="0.000542"/>
</kw>
<var name="${key}">LOCALPREF</var>
<var name="${value}">100</var>
<status status="PASS" start="2026-06-06T03:28:55.018027" elapsed="0.005239"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.024306" level="INFO">${value} = 1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.023548" elapsed="0.000800"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.026013" level="INFO">${encoded} = 1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.025585" elapsed="0.000464"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.026129" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:28:55.026462" level="INFO">${encoded_value} = 1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.024818" elapsed="0.001683"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.026767" elapsed="0.000643"/>
</kw>
<var name="${key}">PATHID</var>
<var name="${value}">1</var>
<status status="PASS" start="2026-06-06T03:28:55.023383" elapsed="0.004128"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.028524" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.027896" elapsed="0.000669"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.030221" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.029810" elapsed="0.000448"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.030336" elapsed="0.000073"/>
</return>
<msg time="2026-06-06T03:28:55.030689" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.029032" elapsed="0.001801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.031077" elapsed="0.000508"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:55.027629" elapsed="0.004104"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:55.013765" elapsed="0.018009"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:55.031817" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:28:55.031984" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.1', 'LOCALPREF': '100', 'PATHID': '1', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:55.012251" elapsed="0.019758"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.011959" elapsed="0.020083"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.032219" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.032067" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.011940" elapsed="0.020356"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.033101" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:55.032440" elapsed="0.000689"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.033179" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:55.008311" elapsed="0.024990"/>
</kw>
<msg time="2026-06-06T03:28:55.033354" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:54.995222" elapsed="0.038180"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.046637" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.059680" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.073065" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.073295" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.073482" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.073910" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.073756" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:55.073735" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.074135" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.074304" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.074470" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:55.073696" elapsed="0.000827"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.073567" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.074728" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.074809" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:28:55.074952" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:54.990859" elapsed="0.084120"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.100535" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.100149" elapsed="0.000414"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.101434" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.101081" elapsed="0.000428">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.101604" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.100742" elapsed="0.000887"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.102274" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.101878" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.102608" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:55.102799" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:55.102466" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.103241" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;$NEXTHOP&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;$LOCALPREF&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.102993" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:55.103680" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.103365" elapsed="0.000375"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.104210" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.1', 'LOCALPREF': '100', 'PATHID': '1', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.103915" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.103765" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.103346" elapsed="0.000948"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.105128" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:55.104442" elapsed="0.000717"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.105210" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:55.099522" elapsed="0.005814"/>
</kw>
<msg time="2026-06-06T03:28:55.105392" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:55.086333" elapsed="0.019108"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.118510" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.131483" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.144480" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.144726" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.144908" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.145276" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.145130" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:55.145114" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.145497" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.145681" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.145857" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:55.145085" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.144983" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.146083" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.146158" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:28:55.146283" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:55.085422" elapsed="0.060889"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.147658" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.147397" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.147817" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.147055" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.148158" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.147912" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.148725" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.148419" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.148239" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.147893" elapsed="0.000919"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.151219" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.148965" elapsed="0.002280"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:55.151295" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.151449" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:55.146654" elapsed="0.004820"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.153025" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.152766" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.153466" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.1&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.153227" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.153980" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.153730" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.154419" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.154177" elapsed="0.000285"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:55.155297" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:55.155098" elapsed="0.000225"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:55.155673" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:55.155478" elapsed="0.000223"/>
</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-06-06T03:28:55.155853" elapsed="0.000207"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.156466" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.156219" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:55.156552" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.156723" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:55.154679" elapsed="0.002069"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:55.171375" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;1&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.1&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;100&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:28:55.171513" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,1', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:55.171782" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:55.159200" elapsed="0.012642"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.156819" elapsed="0.015126"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.172354" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.172005" elapsed="0.000499"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.156801" elapsed="0.015751"/>
</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-06-06T03:28:55.180312" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.175015" elapsed="0.005358"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.174446" elapsed="0.005976"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.174403" elapsed="0.006053"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.184164" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.180871" elapsed="0.003356"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.180533" elapsed="0.003743"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.180510" elapsed="0.003801"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.185096" 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-06-06T03:28:55.184541" elapsed="0.000593"/>
</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-06-06T03:28:55.185566" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.185231" elapsed="0.000436"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.186355" 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-06-06T03:28:55.185937" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.185704" elapsed="0.000782"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.185205" elapsed="0.001314"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.187310" 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-06-06T03:28:55.186800" elapsed="0.000548"/>
</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-06-06T03:28:55.187803" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.187446" elapsed="0.000440"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.188557" 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-06-06T03:28:55.188147" elapsed="0.000447"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.187920" elapsed="0.000741"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.187420" elapsed="0.001273"/>
</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-06-06T03:28:55.188906" elapsed="0.000482"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:55.190036" 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-06-06T03:28:55.189624" elapsed="0.000448"/>
</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-06-06T03:28:55.190291" elapsed="0.002817"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:28:55.173404" elapsed="0.019767"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:55.193352" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:28:55.193245" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.193225" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:55.193588" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.193681" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:55.196074" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:28:55.151816" elapsed="0.044284"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.196170" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:55.196322" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:54.979492" elapsed="0.216854"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.196706" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.196452" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.196434" elapsed="0.000365"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.196831" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:54.974807" elapsed="0.222147"/>
</kw>
<var name="${pathid}">1</var>
<status status="PASS" start="2026-06-06T03:28:54.973751" elapsed="0.223243"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.197845" level="INFO">&amp;{route_mapping} = { NEXTHOP=100.100.100.2 | LOCALPREF=200 | PATHID=2 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{route_mapping}</var>
<arg>NEXTHOP=${NEXT_HOP_PREF}${pathid}</arg>
<arg>LOCALPREF=${pathid}00</arg>
<arg>PATHID=${pathid}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.197232" elapsed="0.000640"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.233042" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.232661" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.233931" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.233624" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.234090" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.233281" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.234724" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.234286" elapsed="0.000467"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.235055" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:55.235182" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:55.234919" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.235610" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.235367" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.236838" level="INFO">mapping: {'NEXTHOP': '100.100.100.2', 'LOCALPREF': '200', 'PATHID': '2', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.236358" elapsed="0.000525"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.237424" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.237046" elapsed="0.000405"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.238486" level="INFO">${value} = 100.100.100.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.237857" elapsed="0.000670"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.240224" level="INFO">${encoded} = 100.100.100.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.239805" elapsed="0.000456"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.240338" elapsed="0.000072"/>
</return>
<msg time="2026-06-06T03:28:55.240746" level="INFO">${encoded_value} = 100.100.100.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.239017" elapsed="0.001778"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.241058" elapsed="0.000563"/>
</kw>
<var name="${key}">NEXTHOP</var>
<var name="${value}">100.100.100.2</var>
<status status="PASS" start="2026-06-06T03:28:55.237688" elapsed="0.004074"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.242993" level="INFO">${value} = 200</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.242219" elapsed="0.000821"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.245134" level="INFO">${encoded} = 200</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.244671" elapsed="0.000503"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.245259" elapsed="0.000079"/>
</return>
<msg time="2026-06-06T03:28:55.245662" level="INFO">${encoded_value} = 200</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.243561" elapsed="0.002147"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.245961" elapsed="0.000571"/>
</kw>
<var name="${key}">LOCALPREF</var>
<var name="${value}">200</var>
<status status="PASS" start="2026-06-06T03:28:55.241894" elapsed="0.004764"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.247930" level="INFO">${value} = 2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.247039" elapsed="0.000940"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.249911" level="INFO">${encoded} = 2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.249437" elapsed="0.000511"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.250025" elapsed="0.000072"/>
</return>
<msg time="2026-06-06T03:28:55.250357" level="INFO">${encoded_value} = 2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.248509" elapsed="0.001886"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.250619" elapsed="0.000608"/>
</kw>
<var name="${key}">PATHID</var>
<var name="${value}">2</var>
<status status="PASS" start="2026-06-06T03:28:55.246833" elapsed="0.004493"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.252359" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.251610" elapsed="0.000789"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.254046" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.253622" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.254159" elapsed="0.000072"/>
</return>
<msg time="2026-06-06T03:28:55.254486" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.252866" elapsed="0.001658"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.254791" elapsed="0.000498"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:55.251443" elapsed="0.003944"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:55.237498" elapsed="0.017927"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:55.255468" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.255628" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.2', 'LOCALPREF': '200', 'PATHID': '2', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:55.236033" elapsed="0.019713"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.235744" elapsed="0.020040"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.255965" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.255812" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.235724" elapsed="0.020317"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.256808" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:55.256187" elapsed="0.000650"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.256887" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:55.232021" elapsed="0.024989"/>
</kw>
<msg time="2026-06-06T03:28:55.257066" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:55.218828" elapsed="0.038287"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.270345" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.283344" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.296403" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.296616" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.296874" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.297277" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.297127" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:55.297109" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.297503" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.297689" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.297861" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:55.297072" elapsed="0.000843"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.296959" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.298090" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.298168" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:55.298306" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:55.214420" elapsed="0.083914"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.324939" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.324533" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.325906" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.325479" elapsed="0.000511">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.326087" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.325136" elapsed="0.000976"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.326684" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.326279" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.327042" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:55.327213" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:55.326895" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.327667" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;$NEXTHOP&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;$LOCALPREF&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.327406" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:55.328093" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.327792" elapsed="0.000408"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.328696" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.2', 'LOCALPREF': '200', 'PATHID': '2', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.328380" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.328229" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.327772" elapsed="0.001009"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.329591" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:55.328929" elapsed="0.000693"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.329689" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:55.323918" elapsed="0.005900"/>
</kw>
<msg time="2026-06-06T03:28:55.329875" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:55.310662" elapsed="0.019262"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.342951" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.355800" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.368700" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.368897" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.369074" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.369435" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.369291" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:55.369276" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.369671" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.369848" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.370016" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:55.369248" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.369148" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.370241" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.370358" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:28:55.370485" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:55.309657" elapsed="0.060857"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.371813" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.371550" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.371971" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.371208" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.372314" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.372066" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.372891" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.372580" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.372397" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.372047" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.375380" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.373134" elapsed="0.002273"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:55.375458" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.375612" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:55.370881" elapsed="0.004756"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.377361" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.377105" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.377827" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.2&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;200&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.377563" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.378275" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.378032" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.378738" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.378468" elapsed="0.000318"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:55.379595" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:55.379390" elapsed="0.000231"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:55.379965" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:55.379791" elapsed="0.000200"/>
</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-06-06T03:28:55.380140" elapsed="0.000207"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.380765" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.380503" elapsed="0.000306"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:55.380850" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.381002" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:55.378987" elapsed="0.002074"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:55.393906" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;2&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.2&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;200&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:28:55.393969" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,2', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:55.394060" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:55.383434" elapsed="0.010652"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.381135" elapsed="0.012997"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.394315" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.394159" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.381116" elapsed="0.013289"/>
</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-06-06T03:28:55.397928" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.395464" elapsed="0.002507"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.395242" elapsed="0.002764"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.395223" elapsed="0.002807"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.400658" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.398308" elapsed="0.002398"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.398086" elapsed="0.002654"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.398069" elapsed="0.002695"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.401313" 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-06-06T03:28:55.400936" elapsed="0.000404"/>
</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-06-06T03:28:55.401664" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.401411" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.402208" 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-06-06T03:28:55.401910" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.401747" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.401392" elapsed="0.000898"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.402856" 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-06-06T03:28:55.402450" elapsed="0.000433"/>
</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-06-06T03:28:55.403190" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.402954" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.403741" 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-06-06T03:28:55.403432" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.403271" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.402935" elapsed="0.000890"/>
</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-06-06T03:28:55.403974" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:55.404797" 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-06-06T03:28:55.404489" elapsed="0.000341"/>
</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-06-06T03:28:55.405039" elapsed="0.002406"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:28:55.394804" elapsed="0.012705"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:55.407705" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:28:55.407582" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.407563" elapsed="0.000232"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:55.407946" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.408014" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:55.410375" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:28:55.375984" elapsed="0.034418"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.410472" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:55.410625" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:55.202820" elapsed="0.207845"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.411030" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.410789" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.410769" elapsed="0.000353"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.411154" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:55.198136" elapsed="0.213142"/>
</kw>
<var name="${pathid}">2</var>
<status status="PASS" start="2026-06-06T03:28:55.197086" elapsed="0.214232"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.412166" level="INFO">&amp;{route_mapping} = { NEXTHOP=100.100.100.3 | LOCALPREF=300 | PATHID=3 | APP_RIB=10.30.170.38 }</msg>
<var>&amp;{route_mapping}</var>
<arg>NEXTHOP=${NEXT_HOP_PREF}${pathid}</arg>
<arg>LOCALPREF=${pathid}00</arg>
<arg>PATHID=${pathid}</arg>
<arg>APP_RIB=${app_rib}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.411554" elapsed="0.000641"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.447261" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.446879" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.448095" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.447805" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.448254" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.447455" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.448852" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.448443" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.449174" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:55.449303" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:55.449040" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.449793" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.449522" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.451100" level="INFO">mapping: {'NEXTHOP': '100.100.100.3', 'LOCALPREF': '300', 'PATHID': '3', 'APP_RIB': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.450585" elapsed="0.000576"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.451771" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.451374" elapsed="0.000426"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.452870" level="INFO">${value} = 100.100.100.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.452185" elapsed="0.000725"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.454865" level="INFO">${encoded} = 100.100.100.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.454404" elapsed="0.000508"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.455047" elapsed="0.000077"/>
</return>
<msg time="2026-06-06T03:28:55.455389" level="INFO">${encoded_value} = 100.100.100.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.453502" elapsed="0.001928"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.455676" elapsed="0.000685"/>
</kw>
<var name="${key}">NEXTHOP</var>
<var name="${value}">100.100.100.3</var>
<status status="PASS" start="2026-06-06T03:28:55.452018" elapsed="0.004442"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.457581" level="INFO">${value} = 300</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.456870" elapsed="0.000751"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.459701" level="INFO">${encoded} = 300</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.459183" elapsed="0.000557"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.459853" elapsed="0.000129"/>
</return>
<msg time="2026-06-06T03:28:55.460359" level="INFO">${encoded_value} = 300</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.458273" elapsed="0.002127"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.460629" elapsed="0.000528"/>
</kw>
<var name="${key}">LOCALPREF</var>
<var name="${value}">300</var>
<status status="PASS" start="2026-06-06T03:28:55.456615" elapsed="0.004640"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.462212" level="INFO">${value} = 3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.461541" elapsed="0.000714"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.464337" level="INFO">${encoded} = 3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.463825" elapsed="0.000550"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.464453" elapsed="0.000086"/>
</return>
<msg time="2026-06-06T03:28:55.464830" level="INFO">${encoded_value} = 3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.462906" elapsed="0.001977"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.465130" elapsed="0.000551"/>
</kw>
<var name="${key}">PATHID</var>
<var name="${value}">3</var>
<status status="PASS" start="2026-06-06T03:28:55.461371" elapsed="0.004422"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.467211" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:28:55.466164" elapsed="0.001091"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:28:55.469174" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.468697" elapsed="0.000514"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:28:55.469291" elapsed="0.000165"/>
</return>
<msg time="2026-06-06T03:28:55.469773" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:28:55.467819" elapsed="0.001995"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:28:55.470045" elapsed="0.000579"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:28:55.465919" elapsed="0.004983"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:28:55.451848" elapsed="0.019106"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:28:55.471001" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.471267" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.3', 'LOCALPREF': '300', 'PATHID': '3', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:28:55.450238" elapsed="0.021057"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.449905" elapsed="0.021460"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.471566" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.471404" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.449886" elapsed="0.021774"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.472560" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:55.471814" elapsed="0.000794"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.472711" elapsed="0.000059"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:55.446219" elapsed="0.026659"/>
</kw>
<msg time="2026-06-06T03:28:55.472936" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:55.432870" elapsed="0.040121"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.486344" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.499598" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.512427" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.512626" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.512823" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.513196" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.513050" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:55.513033" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.513416" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.513583" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.513768" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:55.513003" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.512901" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.513998" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.514118" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:28:55.514243" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:55.428492" elapsed="0.085778"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.539742" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.539335" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.540617" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.540296" elapsed="0.000418">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.540809" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.539948" elapsed="0.000886"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.541384" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.541000" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.541728" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:28:55.541894" level="INFO">${template} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:28:55.541574" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.542340" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;$PATHID&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;$NEXTHOP&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;$LOCALPREF&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.542084" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:28:55.542783" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.542461" elapsed="0.000382"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.543315" level="INFO">${mapping_to_use} = {'NEXTHOP': '100.100.100.3', 'LOCALPREF': '300', 'PATHID': '3', 'APP_RIB': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.543022" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.542867" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.542442" elapsed="0.000962"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.544369" level="INFO">${final_text} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:28:55.543550" elapsed="0.000850"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.544463" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:28:55.538681" elapsed="0.005916"/>
</kw>
<msg time="2026-06-06T03:28:55.544700" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:55.525565" elapsed="0.019187"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.559190" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.572063" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.584915" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.585113" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.585296" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.585681" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.585519" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:28:55.585503" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.585906" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.586076" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.586246" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:28:55.585475" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.585373" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.586473" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.586548" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:55.586704" level="INFO">${data} =   &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
    ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:28:55.524707" elapsed="0.062027"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:28:55.588184" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:28:55.587931" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:28:55.588344" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:28:55.587407" elapsed="0.000961"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.588770" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.588485" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.589328" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:55.589035" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.588854" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.588465" elapsed="0.000946"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.591840" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:55.589566" elapsed="0.002301"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:28:55.591920" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:28:55.592073" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:28:55.587076" elapsed="0.005022"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.593795" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.593374" elapsed="0.000468"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.594239" level="INFO">  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.3&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;300&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.594000" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.594722" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.594445" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.595158" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.594918" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:28:55.596016" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:28:55.595820" elapsed="0.000222"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:28:55.596368" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:28:55.596195" elapsed="0.000198"/>
</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-06-06T03:28:55.596542" elapsed="0.000217"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.597160" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.596916" elapsed="0.000287"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:28:55.597245" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:28:55.597396" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:28:55.595400" elapsed="0.002021"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:55.610131" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '625', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=  &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
   &lt;prefix&gt;1.1.1.1/32&lt;/prefix&gt;
   &lt;path-id&gt;3&lt;/path-id&gt;
   &lt;route-key&gt;1.1.1.1/32&lt;/route-key&gt;
   &lt;attributes&gt;
    &lt;ipv4-next-hop&gt;
     &lt;global&gt;100.100.100.3&lt;/global&gt;
    &lt;/ipv4-next-hop&gt;
    &lt;as-path/&gt;
    &lt;multi-exit-disc&gt;
     &lt;med&gt;0&lt;/med&gt;
    &lt;/multi-exit-disc&gt;
    &lt;local-pref&gt;
     &lt;pref&gt;300&lt;/pref&gt;
    &lt;/local-pref&gt;
    &lt;originator-id&gt;
     &lt;originator&gt;41.41.41.41&lt;/originator&gt;
    &lt;/originator-id&gt;
    &lt;origin&gt;
     &lt;value&gt;igp&lt;/value&gt;
    &lt;/origin&gt;
    &lt;cluster-id&gt;
     &lt;cluster&gt;40.40.40.40&lt;/cluster&gt;
    &lt;/cluster-id&gt;
   &lt;/attributes&gt;
  &lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:28:55.610193" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=1.1.1.1%2F32,3', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:55.610327" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:55.599819" elapsed="0.010537"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.597490" elapsed="0.012917"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.610590" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.610433" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.597472" elapsed="0.013261"/>
</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-06-06T03:28:55.617334" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.611825" elapsed="0.005605"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.611544" elapsed="0.005964"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.611525" elapsed="0.006039"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.621438" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.618223" elapsed="0.003260"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.617723" elapsed="0.003795"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.617681" elapsed="0.003862"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.622113" 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-06-06T03:28:55.621726" elapsed="0.000415"/>
</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-06-06T03:28:55.622455" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.622211" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.623027" 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-06-06T03:28:55.622727" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.622536" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.622193" elapsed="0.000917"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.623632" 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-06-06T03:28:55.623273" elapsed="0.000402"/>
</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-06-06T03:28:55.623982" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.623745" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.624520" 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-06-06T03:28:55.624224" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:55.624063" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.623727" elapsed="0.000876"/>
</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-06-06T03:28:55.624768" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:28:55.625564" 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-06-06T03:28:55.625283" elapsed="0.000308"/>
</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-06-06T03:28:55.625761" elapsed="0.002370"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:28:55.611108" elapsed="0.017086"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:28:55.628373" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:28:55.628266" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.628247" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:28:55.628609" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:28:55.628693" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:28:55.631083" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:28:55.592424" elapsed="0.038686"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.631179" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:28:55.631329" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:28:55.417127" elapsed="0.214263"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:28:55.631753" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:28:55.631497" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:55.631479" elapsed="0.000367"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:28:55.631879" elapsed="0.000026"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:28:55.412455" elapsed="0.219546"/>
</kw>
<var name="${pathid}">3</var>
<status status="PASS" start="2026-06-06T03:28:55.411411" elapsed="0.220630"/>
</iter>
<var>${pathid}</var>
<value>@{PATH_ID_LIST}</value>
<status status="PASS" start="2026-06-06T03:28:54.973591" elapsed="0.658481"/>
</for>
<doc>Configure bgp application peer and fill it immediately with routes.</doc>
<status status="PASS" start="2026-06-06T03:28:54.738637" elapsed="0.893490"/>
</kw>
<kw name="Upload_Config_Files">
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.640445" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/exa.cfg' -&gt; '/home/jenkins//exa.cfg'</msg>
<arg>${BGP_VAR_FOLDER}/${DEFAUTL_RPC_CFG}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:28:55.632722" elapsed="0.007806"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.647959" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/exabgp_files/exarpc.py' -&gt; '/home/jenkins//exarpc.py'</msg>
<arg>${EXARPCSCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:28:55.640785" elapsed="0.007255"/>
</kw>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.657034" level="INFO">6 files:
bgp-flowspec-redirect.cfg
bgp-flowspec.cfg
bgp-l3vpn-ipv4.cfg
exa-md5.cfg
exa.cfg
gobgp.cfg</msg>
<msg time="2026-06-06T03:28:55.657191" level="INFO">@{cfgfiles} = [ bgp-flowspec-redirect.cfg | bgp-flowspec.cfg | bgp-l3vpn-ipv4.cfg | exa-md5.cfg | exa.cfg | gobgp.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:28:55.648266" elapsed="0.008962"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.657999" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:55.670049" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.657758" elapsed="0.012429"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.671078" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:55.720348" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.670576" elapsed="0.049907"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.721209" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:55.772734" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.720898" elapsed="0.051965"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.773593" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:55.820986" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.773230" elapsed="0.047899"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.821916" level="INFO">Executing command 'cat bgp-flowspec-redirect.cfg'.</msg>
<msg time="2026-06-06T03:28:55.869295" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:55.869513" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.821542" elapsed="0.048029"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:55.870758" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;

        }
        then {
            redirect 65500:12345;
        }
    }
    route flow2 {
        match {
            source 10.0.0.2/32;
            destination 192.168.0.2/32;

        }
        then {
                redirect 1.2.3.4;
        }
    }
    route flow4 {
        match {
            source 10.0.0.4/32;
            destination 192.168.0.4/32;

        }
        next-hop 127.0.0.1;
        then {
                redirect-to-nexthop;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:55.870071" elapsed="0.000803"/>
</kw>
<var name="${cfgfile}">bgp-flowspec-redirect.cfg</var>
<status status="PASS" start="2026-06-06T03:28:55.657528" elapsed="0.213425"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.872466" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:55.916752" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.871546" elapsed="0.045347"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.917912" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:55.964780" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.917472" elapsed="0.047440"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:55.965598" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:56.013102" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:55.965287" elapsed="0.047948"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.014034" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:56.061979" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.013613" elapsed="0.048511"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.062925" level="INFO">Executing command 'cat bgp-flowspec.cfg'.</msg>
<msg time="2026-06-06T03:28:56.113196" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:56.113476" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0....</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.062522" elapsed="0.051020"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:56.114858" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
family {
  ipv4 flow;
}
flow {
    route flow1 {
        match {
            source 10.0.0.1/32;
            destination 192.168.0.1/32;
            port =80;
            destination-port &gt;8080&amp;&lt;8088;
            source-port &gt;1024;
            protocol tcp;
            packet-length &gt;400&amp;&lt;500;
            fragment =first-fragment;
            icmp-type echo-reply;
            icmp-code network-unreachable;
            tcp-flags =urgent;
            dscp 20;
        }
        then {
            action sample-terminal;
        }
    }
}
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:56.114099" elapsed="0.000886"/>
</kw>
<var name="${cfgfile}">bgp-flowspec.cfg</var>
<status status="PASS" start="2026-06-06T03:28:55.871228" elapsed="0.243836"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.116130" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:56.161564" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.115703" elapsed="0.046031"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.162510" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:56.213514" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.162123" elapsed="0.051576"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.214442" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:56.265789" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.214102" elapsed="0.051833"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.266784" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:56.318051" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.266333" elapsed="0.051938"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.319282" level="INFO">Executing command 'cat bgp-l3vpn-ipv4.cfg'.</msg>
<msg time="2026-06-06T03:28:56.369297" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:56.369569" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.318872" elapsed="0.050759"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:56.370984" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  family {
    ipv4 mpls-vpn;
  }
  static {
    route 1.1.1.0/24 {
      next-hop 10.0.255.254;
      rd 1.2.3.4:1;
      label 24005;
    }
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:56.370196" elapsed="0.000896"/>
</kw>
<var name="${cfgfile}">bgp-l3vpn-ipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:28:56.115343" elapsed="0.255828"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.372245" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:56.417283" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.371831" elapsed="0.045590"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.418276" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:56.465031" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.417868" elapsed="0.047292"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.465872" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:56.514239" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.465530" elapsed="0.048921"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.515762" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:56.566040" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.515235" elapsed="0.050971"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.567123" level="INFO">Executing command 'cat exa-md5.cfg'.</msg>
<msg time="2026-06-06T03:28:56.616943" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:56.617267" level="INFO">${stdout} = neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path d...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.566716" elapsed="0.050613"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:56.618618" level="INFO">neighbor 10.30.170.38 {
  router-id 10.30.171.194;
  local-address 10.30.171.194;
  local-as 64496;
  peer-as 64496;
  md5-password topsecret;

  capability {
    route-refresh disable;
    add-path disable;
  }

  family {
    ipv4 unicast;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:56.617919" elapsed="0.000867"/>
</kw>
<var name="${cfgfile}">exa-md5.cfg</var>
<status status="PASS" start="2026-06-06T03:28:56.371458" elapsed="0.247410"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.619922" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:56.665639" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.619497" elapsed="0.046343"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.666782" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:56.718194" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.666284" elapsed="0.052155"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.719471" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:56.774123" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.719054" elapsed="0.055291"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.775398" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' exa.cfg'.</msg>
<msg time="2026-06-06T03:28:56.826146" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.774903" elapsed="0.051391"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.827107" level="INFO">Executing command 'cat exa.cfg'.</msg>
<msg time="2026-06-06T03:28:56.878267" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:56.878703" level="INFO">${stdout} = neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path send/receive;
  }

  family {
    ip...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.826768" elapsed="0.052003"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:56.880050" level="INFO">neighbor 10.30.170.38 {
router-id 10.30.171.194;
local-address 10.30.171.194;
local-as 64496;
peer-as 64496;
  capability {
    route-refresh disable;
    add-path send/receive;
  }

  family {
    ipv4 unicast;
    ipv4 mpls-vpn;
  }

  process exarpcserver {
    run exarpc.py --host 10.30.171.194;
    encoder json;
    receive-routes;
    neighbor-changes;
  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:56.879319" elapsed="0.000857"/>
</kw>
<var name="${cfgfile}">exa.cfg</var>
<status status="PASS" start="2026-06-06T03:28:56.619162" elapsed="0.261091"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.881295" level="INFO">Executing command 'sed -i -e 's/EXABGPIP/10.30.171.194/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:56.925971" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/EXABGPIP/${TOOLS_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.880914" elapsed="0.045273"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.927263" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:56.973785" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.926736" elapsed="0.047230"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:56.974971" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:57.025800" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:56.974445" elapsed="0.051503"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:57.026897" level="INFO">Executing command 'sed -i -e 's/ADDPATH/send\/receive/g' gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:57.077683" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/${addpath}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:57.026365" elapsed="0.051479"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:28:57.078624" level="INFO">Executing command 'cat gobgp.cfg'.</msg>
<msg time="2026-06-06T03:28:57.129900" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:28:57.130175" level="INFO">${stdout} = [global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:28:57.078269" elapsed="0.051972"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.131552" level="INFO">[global.config]
    as = 64496
    router-id = "10.30.171.194"
    port = 17900
[[neighbors]]
    [neighbors.config]
        peer-as = 64496
        neighbor-address = "10.30.170.38"
        local-as = 64496
    [neighbors.transport.config]
        local-address = "10.30.171.194"
        remote-port = 1790
    [[neighbors.afi-safis]]
        [neighbors.afi-safis.config]
           afi-safi-name = "ipv4-flowspec"
        [neighbors.afi-safis.long-lived-graceful-restart.config]
           enabled = true
           restart-time = 86400</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:57.130829" elapsed="0.001047"/>
</kw>
<var name="${cfgfile}">gobgp.cfg</var>
<status status="PASS" start="2026-06-06T03:28:56.880546" elapsed="0.251420"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:28:55.657308" elapsed="1.474744"/>
</for>
<arg>addpath=${exa_add_path_value}</arg>
<doc>Uploads exabgp config files</doc>
<status status="PASS" start="2026-06-06T03:28:55.632322" elapsed="1.499886"/>
</kw>
<kw name="Start_ExaBgp_And_Verify_Connected" owner="ExaBgpLib">
<for flavor="IN RANGE">
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.140302" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:57.139844" elapsed="0.000497"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.140926" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:57.140561" elapsed="0.000427"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:57.165630" level="INFO">source /tmp/defaultvenv/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-06-06T03:28:57.141852" elapsed="0.023860"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:28:57.170694" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:28:57.170789" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:28:57.165886" elapsed="0.004932"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.171452" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:57.171193" elapsed="0.000306"/>
</kw>
<status status="PASS" start="2026-06-06T03:28:57.170909" elapsed="0.000624"/>
</branch>
<status status="PASS" start="2026-06-06T03:28:57.170882" elapsed="0.000679"/>
</if>
<arg>log_output=${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-06-06T03:28:57.141325" elapsed="0.030283"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:28:57.173384" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:28:57.173475" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:28:57.171780" elapsed="0.001721"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.173945" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:57.173689" elapsed="0.000302"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:28:57.139364" elapsed="0.034682"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.176017" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:28:57.175661" elapsed="0.000383"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.178468" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:28:57.176213" elapsed="0.002283"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:28:57.183826" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:28:57.184020" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:28:57.184157" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:28:57.178697" elapsed="0.005499"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.188358" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:28:57.184443" elapsed="0.003986"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:28:57.192552" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:28:57.188684" elapsed="0.003997">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:28:57.175182" elapsed="0.017668">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:00.196217" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:00.195266" elapsed="0.001027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:00.201714" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:00.196869" elapsed="0.004913"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:00.209795" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:00.210021" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:00.210154" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:00.202171" elapsed="0.008021"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:00.213972" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:00.210453" elapsed="0.003590"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:00.217966" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:00.214276" elapsed="0.003787">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:00.193782" elapsed="0.024436">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.221178" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:03.220281" elapsed="0.000967"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.225272" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:03.221636" elapsed="0.003678"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:03.231858" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:03.232047" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:03.232192" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:03.225567" elapsed="0.006664"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.236400" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.232524" elapsed="0.003950"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.240880" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:03.236732" elapsed="0.004249">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:03.219056" elapsed="0.022091">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:29:03.241280" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:28:57.174664" elapsed="6.066749">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:29:03.241589" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:29:03.241675" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:28:57.174215" elapsed="6.067498"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.242955" level="INFO">[?2004l03:28:57 | 3785   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:57 | 3785   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:57 | 3785   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:57 | 3785   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:57 | 3785   | [01;34minstallation [0m | [1m        [0m
03:28:57 | 3785   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:57 | 3785   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:57 | 3785   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:57 | 3785   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:57 | 3785   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:57 | 3785   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:57 | 3785   | configuration[0m | . local-as         | '64496'[0m
03:28:57 | 3785   | configuration[0m | . peer-as          | '64496'[0m
03:28:57 | 3785   | configuration[0m | &gt; capability       | [0m
03:28:57 | 3785   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:57 | 3785   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:57 | 3785   | configuration[0m | &lt; capability       | [0m
03:28:57 | 3785   | configuration[0m | &gt; family           | [0m
03:28:57 | 3785   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:57 | 3785   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:57 | 3785   | configuration[0m | &lt; family           | [0m
03:28:57 | 3785   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1m        [0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1m        [0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:03.243193" level="INFO">${output} = [?2004l03:28:57 | 3785   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:57 | 3785   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:57 | 3785   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:29:03.242778" elapsed="0.000446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.243653" level="INFO">[?2004l03:28:57 | 3785   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:28:57 | 3785   | [01;34mversion      [0m | [1m4.2.17  [0m
03:28:57 | 3785   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:28:57 | 3785   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:28:57 | 3785   | [01;34minstallation [0m | [1m        [0m
03:28:57 | 3785   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:28:57 | 3785   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:28:57 | 3785   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:28:57 | 3785   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:28:57 | 3785   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:28:57 | 3785   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:28:57 | 3785   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:28:57 | 3785   | configuration[0m | . local-as         | '64496'[0m
03:28:57 | 3785   | configuration[0m | . peer-as          | '64496'[0m
03:28:57 | 3785   | configuration[0m | &gt; capability       | [0m
03:28:57 | 3785   | configuration[0m | . route-refresh    | 'disable'[0m
03:28:57 | 3785   | configuration[0m | . add-path         | 'send/receive'[0m
03:28:57 | 3785   | configuration[0m | &lt; capability       | [0m
03:28:57 | 3785   | configuration[0m | &gt; family           | [0m
03:28:57 | 3785   | configuration[0m | . ipv4             | 'unicast'[0m
03:28:57 | 3785   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:28:57 | 3785   | configuration[0m | &lt; family           | [0m
03:28:57 | 3785   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1m        [0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1m        [0m
03:28:57 | 3785   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.243383" elapsed="0.000384"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.244570" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:03.244250" elapsed="0.000348"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:03.244772" elapsed="0.000279"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:29:03.243973" elapsed="0.001157"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.247824" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:03.247924" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:03.245306" elapsed="0.002646"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.248373" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.248117" elapsed="0.000304"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.250326" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:03.249074" elapsed="0.001309"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.251420" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:03.251507" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:03.250583" elapsed="0.000951"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.252134" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.251878" elapsed="0.000303"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:03.251604" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:03.251583" elapsed="0.000656"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:29:03.248693" elapsed="0.003592"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:29:03.242330" elapsed="0.010006"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:03.241858" elapsed="0.010506"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:03.241823" elapsed="0.010565"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:29:03.252559" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:03.252443" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:03.252426" elapsed="0.000254"/>
</if>
<var name="${idx}">0</var>
<status status="PASS" start="2026-06-06T03:28:57.139112" elapsed="6.113599"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.253759" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:03.253415" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.254190" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.253945" elapsed="0.000319"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.256687" level="INFO">source /tmp/defaultvenv/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-06-06T03:29:03.254899" elapsed="0.001846"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.261705" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:03.261805" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:03.256908" elapsed="0.004923"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.262475" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.262174" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:03.261907" elapsed="0.000649"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:03.261884" elapsed="0.000699"/>
</if>
<arg>log_output=${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-06-06T03:29:03.254512" elapsed="0.008119"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:03.264474" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:29:03.264564" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:03.262802" elapsed="0.001788"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.265015" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.264767" elapsed="0.000294"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:03.253085" elapsed="0.012031"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.267327" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:03.266970" elapsed="0.000385"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.269579" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:03.267523" elapsed="0.002083"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:03.274941" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:03.275097" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:03.275202" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:03.269786" elapsed="0.005442"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.277962" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:03.275414" elapsed="0.002597"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:03.280809" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:03.278177" elapsed="0.002707">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:03.266221" elapsed="0.014783">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:06.284121" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:06.283213" elapsed="0.000978"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:06.288724" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:06.284584" elapsed="0.004182"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:06.294765" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:06.294954" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:06.295089" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:06.289119" elapsed="0.006007"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:06.298894" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:06.295376" elapsed="0.003589"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:06.302881" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:06.299192" elapsed="0.003794">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:06.281875" elapsed="0.021276">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.306223" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:09.305283" elapsed="0.001009"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.311782" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:09.306757" elapsed="0.005088"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:09.318179" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:09.318328" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:09.318455" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:09.312225" elapsed="0.006258"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.321346" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.318738" elapsed="0.002658"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.324233" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:09.321560" elapsed="0.002748">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:09.303984" elapsed="0.020446">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:29:09.324529" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:29:03.265699" elapsed="6.058968">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:29:09.324800" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:29:09.324845" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:03.265282" elapsed="6.059587"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.325772" level="INFO">[?2004l03:29:03 | 3792   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:29:03 | 3792   | [01;34mversion      [0m | [1m4.2.17  [0m
03:29:03 | 3792   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:29:03 | 3792   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:29:03 | 3792   | [01;34minstallation [0m | [1m        [0m
03:29:03 | 3792   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:29:03 | 3792   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:29:03 | 3792   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:29:03 | 3792   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:29:03 | 3792   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:29:03 | 3792   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:29:03 | 3792   | configuration[0m | . local-as         | '64496'[0m
03:29:03 | 3792   | configuration[0m | . peer-as          | '64496'[0m
03:29:03 | 3792   | configuration[0m | &gt; capability       | [0m
03:29:03 | 3792   | configuration[0m | . route-refresh    | 'disable'[0m
03:29:03 | 3792   | configuration[0m | . add-path         | 'send/receive'[0m
03:29:03 | 3792   | configuration[0m | &lt; capability       | [0m
03:29:03 | 3792   | configuration[0m | &gt; family           | [0m
03:29:03 | 3792   | configuration[0m | . ipv4             | 'unicast'[0m
03:29:03 | 3792   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:29:03 | 3792   | configuration[0m | &lt; family           | [0m
03:29:03 | 3792   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1m        [0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1m        [0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:09.326037" level="INFO">${output} = [?2004l03:29:03 | 3792   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:29:03 | 3792   | [01;34mversion      [0m | [1m4.2.17  [0m
03:29:03 | 3792   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:29:09.325628" elapsed="0.000440"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.326634" level="INFO">[?2004l03:29:03 | 3792   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:29:03 | 3792   | [01;34mversion      [0m | [1m4.2.17  [0m
03:29:03 | 3792   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:29:03 | 3792   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:29:03 | 3792   | [01;34minstallation [0m | [1m        [0m
03:29:03 | 3792   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:29:03 | 3792   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:29:03 | 3792   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:29:03 | 3792   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:29:03 | 3792   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:29:03 | 3792   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:29:03 | 3792   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:29:03 | 3792   | configuration[0m | . local-as         | '64496'[0m
03:29:03 | 3792   | configuration[0m | . peer-as          | '64496'[0m
03:29:03 | 3792   | configuration[0m | &gt; capability       | [0m
03:29:03 | 3792   | configuration[0m | . route-refresh    | 'disable'[0m
03:29:03 | 3792   | configuration[0m | . add-path         | 'send/receive'[0m
03:29:03 | 3792   | configuration[0m | &lt; capability       | [0m
03:29:03 | 3792   | configuration[0m | &gt; family           | [0m
03:29:03 | 3792   | configuration[0m | . ipv4             | 'unicast'[0m
03:29:03 | 3792   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:29:03 | 3792   | configuration[0m | &lt; family           | [0m
03:29:03 | 3792   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1m        [0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1m        [0m
03:29:03 | 3792   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.326257" elapsed="0.000567"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.328054" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:09.327544" elapsed="0.000551"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:09.328327" elapsed="0.000415"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:29:09.327130" elapsed="0.001717"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.331752" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:09.331889" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:09.329078" elapsed="0.002853"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.332535" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.332166" elapsed="0.000440"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.335463" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:09.333552" elapsed="0.001973"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.336330" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:09.336413" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:09.335711" elapsed="0.000728"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.337032" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.336781" elapsed="0.000298"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:09.336510" elapsed="0.000602"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:09.336488" elapsed="0.000651"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:29:09.333005" elapsed="0.004181"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:29:09.325331" elapsed="0.011906"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:09.324977" elapsed="0.012287"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:09.324949" elapsed="0.012338"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:29:09.337462" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:09.337345" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:09.337328" elapsed="0.000244"/>
</if>
<var name="${idx}">1</var>
<status status="PASS" start="2026-06-06T03:29:03.252895" elapsed="6.084705"/>
</iter>
<iter>
<kw name="Start_ExaBgp" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.338693" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<var>${start_cmd}</var>
<arg>${CMD} ${cfg_file}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:09.338353" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.339119" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.338878" elapsed="0.000286"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.342289" level="INFO">source /tmp/defaultvenv/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-06-06T03:29:09.339785" elapsed="0.002562"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.346478" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:09.346580" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:09.342515" elapsed="0.004092"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.347254" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.346985" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:09.346710" elapsed="0.000625"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:09.346684" elapsed="0.000677"/>
</if>
<arg>log_output=${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-06-06T03:29:09.339405" elapsed="0.008007"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:09.349489" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exa.cfg</msg>
<msg time="2026-06-06T03:29:09.349578" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:09.347613" elapsed="0.001992"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.350060" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exa.cfg
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.349789" elapsed="0.000318"/>
</kw>
<arg>${cfg_file}</arg>
<doc>Dump the start command into prompt. It assumes that no exabgp is running. For verified
start use Start_ExaBgp_And_Verify_Connected keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:09.338014" elapsed="0.012150"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.352413" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:09.352058" elapsed="0.000383"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.354687" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:09.352607" elapsed="0.002108"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:09.358848" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:09.358993" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:09.359097" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:09.354882" elapsed="0.004243"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.361905" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:09.359315" elapsed="0.002639"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:09.365958" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:09.362116" elapsed="0.003944">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:09.351562" elapsed="0.014669">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:12.369614" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:12.368706" elapsed="0.001009"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:12.374683" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:12.370110" elapsed="0.004637"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:12.382186" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:12.382475" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:12.382723" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:12.375263" elapsed="0.007526"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:12.388965" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:12.383220" elapsed="0.005854"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:12.393409" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:12.389438" elapsed="0.004070">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:12.367346" elapsed="0.026357">200.0 != 409.0</status>
</kw>
<kw name="Verify_ExaBgps_Connection" owner="ExaBgpLib">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.396839" level="INFO">${peer_check_url} = /rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</msg>
<var>${peer_check_url}</var>
<arg>${REST_API}/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.395879" elapsed="0.001032"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.401635" level="INFO">${exp_status_code} = 200</msg>
<var>${exp_status_code}</var>
<arg>${connected}</arg>
<arg>${200}</arg>
<arg>${404}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:15.397336" elapsed="0.004362"/>
</kw>
<kw name="GET On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:15.407998" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.408186" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp:%2F%2F10.30.171.194?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:15.408346" level="INFO">${rsp} = &lt;Response [409]&gt;</msg>
<var>${rsp}</var>
<arg>${session}</arg>
<arg>url=${peer_check_url}${exabgp_ip}?content=nonconfig</arg>
<arg>expected_status=anything</arg>
<doc>Sends a GET request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:15.401973" elapsed="0.006415"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.412545" level="INFO">{
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
}</msg>
<arg>${rsp.content}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.408672" elapsed="0.003948"/>
</kw>
<kw name="Should Be Equal As Numbers" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.416692" level="FAIL">200.0 != 409.0</msg>
<arg>${exp_status_code}</arg>
<arg>${rsp.status_code}</arg>
<doc>Fails if objects are unequal after converting them to real numbers.</doc>
<status status="FAIL" start="2026-06-06T03:29:15.412887" elapsed="0.003913">200.0 != 409.0</status>
</kw>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Checks peer presence in operational datastore</doc>
<status status="FAIL" start="2026-06-06T03:29:15.394545" elapsed="0.022428">200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:29:15.417107" level="FAIL">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:29:09.350755" elapsed="6.066484">Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</status>
</kw>
<msg time="2026-06-06T03:29:15.417493" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:29:15.417567" level="INFO">${value} = Keyword 'Verify_ExaBgps_Connection' failed after retrying 3 times. The last error was: 200.0 != 409.0</msg>
<var>${status}</var>
<var>${value}</var>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>3x</arg>
<arg>3s</arg>
<arg>Verify_ExaBgps_Connection</arg>
<arg>${session}</arg>
<arg>${exabgp_ip}</arg>
<arg>connected=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:09.350338" elapsed="6.067263"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.418750" level="INFO">[?2004l03:29:09 | 3796   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:29:09 | 3796   | [01;34mversion      [0m | [1m4.2.17  [0m
03:29:09 | 3796   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:29:09 | 3796   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:29:09 | 3796   | [01;34minstallation [0m | [1m        [0m
03:29:09 | 3796   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:29:09 | 3796   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:29:09 | 3796   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:29:09 | 3796   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:29:09 | 3796   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:29:09 | 3796   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:29:09 | 3796   | configuration[0m | . local-as         | '64496'[0m
03:29:09 | 3796   | configuration[0m | . peer-as          | '64496'[0m
03:29:09 | 3796   | configuration[0m | &gt; capability       | [0m
03:29:09 | 3796   | configuration[0m | . route-refresh    | 'disable'[0m
03:29:09 | 3796   | configuration[0m | . add-path         | 'send/receive'[0m
03:29:09 | 3796   | configuration[0m | &lt; capability       | [0m
03:29:09 | 3796   | configuration[0m | &gt; family           | [0m
03:29:09 | 3796   | configuration[0m | . ipv4             | 'unicast'[0m
03:29:09 | 3796   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:29:09 | 3796   | configuration[0m | &lt; family           | [0m
03:29:09 | 3796   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1m        [0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1m        [0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:15.418980" level="INFO">${output} = [?2004l03:29:09 | 3796   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:29:09 | 3796   | [01;34mversion      [0m | [1m4.2.17  [0m
03:29:09 | 3796   | [01;34minterpreter  ...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:29:15.418597" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.419432" level="INFO">[?2004l03:29:09 | 3796   | [01;34mwelcome      [0m | [1mThank you for using ExaBGP[0m
03:29:09 | 3796   | [01;34mversion      [0m | [1m4.2.17  [0m
03:29:09 | 3796   | [01;34minterpreter  [0m | [1m3.10.12 (main, Aug 15 2025, 14:32:43) [GCC 11.4.0][0m
03:29:09 | 3796   | [01;34mos           [0m | [1mLinux releng-26932-288-1-mininet-ovs-217-0 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64[0m
03:29:09 | 3796   | [01;34minstallation [0m | [1m        [0m
03:29:09 | 3796   | [01;31mcli          [0m | [1mcould not find the named pipes (exabgp.in and exabgp.out) required for the cli[0m
03:29:09 | 3796   | [01;31mcli          [0m | [1mwe scanned the following folders (the number is your PID):[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/exabgp/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/1001/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m - /var/run/[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1mplease make them in one of the folder with the following commands:[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m&gt; mkfifo /home/jenkins/run/exabgp.{in,out}[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m&gt; chmod 600 /home/jenkins/run/exabgp.{in,out}[0m
03:29:09 | 3796   | [01;31mcli control  [0m | [1m&gt; chown 1001:1001 /home/jenkins/run/exabgp.{in,out}[0m
03:29:09 | 3796   | [01;34mconfiguration[0m | [1mperforming reload of exabgp 4.2.17[0m
03:29:09 | 3796   | configuration[0m | &gt; neighbor         | '10.30.170.38'[0m
03:29:09 | 3796   | configuration[0m | . router-id        | '10.30.171.194'[0m
03:29:09 | 3796   | configuration[0m | . local-address    | '10.30.171.194'[0m
03:29:09 | 3796   | configuration[0m | . local-as         | '64496'[0m
03:29:09 | 3796   | configuration[0m | . peer-as          | '64496'[0m
03:29:09 | 3796   | configuration[0m | &gt; capability       | [0m
03:29:09 | 3796   | configuration[0m | . route-refresh    | 'disable'[0m
03:29:09 | 3796   | configuration[0m | . add-path         | 'send/receive'[0m
03:29:09 | 3796   | configuration[0m | &lt; capability       | [0m
03:29:09 | 3796   | configuration[0m | &gt; family           | [0m
03:29:09 | 3796   | configuration[0m | . ipv4             | 'unicast'[0m
03:29:09 | 3796   | configuration[0m | . ipv4             | 'mpls-vpn'[0m
03:29:09 | 3796   | configuration[0m | &lt; family           | [0m
03:29:09 | 3796   | configuration[0m | &gt; process          | 'exarpcserver'[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1mnot reloaded, no change found in the configuration[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1m        [0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1msyntax error in section neighbor[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1mline 14: process exarpcserver {[0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1m        [0m
03:29:09 | 3796   | [01;31mconfiguration[0m | [1msection process is invalid in neighbor, neighbor[0m
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt; </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.419171" elapsed="0.000373"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.420371" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.420045" elapsed="0.000358"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:15.420558" elapsed="0.000302"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:29:15.419767" elapsed="0.001155"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.423700" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:15.423793" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:15.421088" elapsed="0.002733"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.424229" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h(defaultvenv) [jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.423980" elapsed="0.000297"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.426770" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:15.424928" elapsed="0.001899"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.427617" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:15.427715" level="INFO">${output} = [?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:15.426989" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.428322" level="INFO">[?2004l[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.428071" elapsed="0.000298"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.427815" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.427794" elapsed="0.000639"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:29:15.424537" elapsed="0.003943"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:29:15.418243" elapsed="0.010292"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.417784" elapsed="0.010778"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.417743" elapsed="0.010843"/>
</if>
<if>
<branch type="IF" condition="&quot;${status}&quot; == &quot;PASS&quot;">
<return>
<status status="NOT RUN" start="2026-06-06T03:29:15.428785" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:15.428659" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.428627" elapsed="0.000265"/>
</if>
<var name="${idx}">2</var>
<status status="PASS" start="2026-06-06T03:29:09.337804" elapsed="6.091116"/>
</iter>
<var>${idx}</var>
<value>${connection_retries}</value>
<status status="PASS" start="2026-06-06T03:28:57.138788" elapsed="18.290169"/>
</for>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.429448" level="FAIL">Unable to connect ExaBgp to ODL</msg>
<arg>Unable to connect ExaBgp to ODL</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:29:15.429121" elapsed="0.000391">Unable to connect ExaBgp to ODL</status>
</kw>
<arg>${DEFAUTL_RPC_CFG}</arg>
<arg>${CONFIG_SESSION}</arg>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>connection_retries=${3}</arg>
<doc>Starts the ExaBgp and verifies its connection. The verification is done by checking the presence
of the peer in the bgp rib.</doc>
<status status="FAIL" start="2026-06-06T03:28:57.133058" elapsed="18.296559">Unable to connect ExaBgp to ODL</status>
</kw>
<arg>${NPATHS_SELM}</arg>
<arg>${ADDPATHCAP_SR}</arg>
<doc>Setup test case keyword. Early after the path selection config the incomming connection
from exabgp towards odl may be rejected by odl due to config process not finished yet. Because of that
we try to start the tool 3 times in case early attempts fail.</doc>
<status status="FAIL" start="2026-06-06T03:28:54.137015" elapsed="21.292722">Unable to connect ExaBgp to ODL</status>
</kw>
<kw name="Remove_Odl_And_App_Peer_Configuration_And_Stop_ExaBgp" type="TEARDOWN">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.430821" level="INFO">&amp;{mapping} = { IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.430339" elapsed="0.000510"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.476063" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.475663" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:15.476908" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:15.476619" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:15.477127" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:15.476270" elapsed="0.000890"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.477785" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:15.477353" elapsed="0.000460"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:15.478128" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:15.478329" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:15.477982" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.478799" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.478526" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.479892" level="INFO">mapping: {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.479607" elapsed="0.000331"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.480378" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.480103" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.481102" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.480797" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.481982" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.481755" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.482064" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:15.482248" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.481364" elapsed="0.000910"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.482448" elapsed="0.000262"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:29:15.480653" elapsed="0.002099"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.483393" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.483072" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.484372" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.483998" elapsed="0.000402"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.484453" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:15.484607" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.483612" elapsed="0.001020"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.484808" elapsed="0.000228"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:15.482932" elapsed="0.002145"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:15.480459" elapsed="0.004653"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:15.485156" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:15.485316" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:15.479241" elapsed="0.006118"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.478925" elapsed="0.006467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.485573" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.485418" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.478900" elapsed="0.006767"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.486457" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.485820" elapsed="0.000666"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:15.486536" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:15.474987" elapsed="0.011693"/>
</kw>
<msg time="2026-06-06T03:29:15.486738" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:15.461549" elapsed="0.025249"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.500002" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.513254" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.527608" elapsed="0.000064"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.527940" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.528139" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.528722" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.528530" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:15.528512" elapsed="0.000299"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.528988" elapsed="0.000031"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.529182" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.529387" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:15.528474" elapsed="0.000971"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.528338" elapsed="0.001134"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.529626" elapsed="0.000037"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.529725" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:29:15.529887" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:15.456879" elapsed="0.073036"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.531241" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.530912" elapsed="0.000385"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:15.541302" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.541380" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.541525" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:15.533587" elapsed="0.007977"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.531366" elapsed="0.010258"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.541968" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.541693" elapsed="0.000386"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.531347" elapsed="0.010764"/>
</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-06-06T03:29:15.549542" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.543719" elapsed="0.005887"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.543355" elapsed="0.006323"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.543327" elapsed="0.006388"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.552759" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.550124" elapsed="0.002684"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.549798" elapsed="0.003047"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.549773" elapsed="0.003099"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.553504" 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-06-06T03:29:15.553058" elapsed="0.000473"/>
</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-06-06T03:29:15.554066" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.553814" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.554705" 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-06-06T03:29:15.554375" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.554201" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.553794" elapsed="0.000997"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.555348" 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-06-06T03:29:15.554960" elapsed="0.000415"/>
</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-06-06T03:29:15.555712" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.555449" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.556269" 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-06-06T03:29:15.555965" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.555798" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.555430" elapsed="0.000926"/>
</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-06-06T03:29:15.556517" elapsed="0.000375"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:15.557390" 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-06-06T03:29:15.557064" elapsed="0.000356"/>
</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-06-06T03:29:15.557597" elapsed="0.002656"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:15.542688" elapsed="0.017636"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:15.560375" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:15.562942" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:15.530220" elapsed="0.032757"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:15.563044" elapsed="0.000038"/>
</return>
<arg>${MULT_VAR_FOLDER}/bgp_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:15.431077" elapsed="0.132132"/>
</kw>
<kw name="Deconfigure_App_Peer">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.564056" level="INFO">${app_rib} = 10.30.170.38</msg>
<var>${app_rib}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.563750" elapsed="0.000333"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.564736" level="INFO">&amp;{route_mapping} = { APP_RIB=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{route_mapping}</var>
<arg>APP_RIB=${app_rib}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.564259" elapsed="0.000506"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.610126" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.609730" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:15.610993" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:15.610725" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:15.611171" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:15.610350" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.611810" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:15.611392" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:15.612158" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/multipaths/route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:15.612327" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:15.612009" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.612880" level="INFO">/rests/data/bgp-rib:application-rib=$APP_RIB/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.612572" elapsed="0.000356"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.614226" level="INFO">mapping: {'APP_RIB': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.613751" elapsed="0.000538"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.614772" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.614467" elapsed="0.000333"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.615510" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.615197" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.616599" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.616106" elapsed="0.000521"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.616707" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:15.616872" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.615748" elapsed="0.001150"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.617061" elapsed="0.000249"/>
</kw>
<var name="${key}">APP_RIB</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:15.615041" elapsed="0.002342"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.617965" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.617656" elapsed="0.000335"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.619013" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.618544" elapsed="0.000497"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.619094" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:15.619260" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.618188" elapsed="0.001099"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.619449" elapsed="0.000258"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:15.617502" elapsed="0.002260"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:15.614858" elapsed="0.004948"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:15.619863" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:15.620040" level="INFO">${mapping_to_use} = {'APP_RIB': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:15.613361" elapsed="0.006705"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.613002" elapsed="0.007097"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.620309" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.620127" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.612980" elapsed="0.007409"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.621181" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.620541" elapsed="0.000670"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:15.621262" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:15.608976" elapsed="0.012434"/>
</kw>
<msg time="2026-06-06T03:29:15.621469" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:15.595406" elapsed="0.026131"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.635376" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.648685" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/multipaths/route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.661933" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.662174" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.662377" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.662845" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.662686" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:15.662666" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.663091" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.663270" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.663440" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:15.662606" elapsed="0.000888"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.662470" elapsed="0.001052"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.663690" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.663771" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:15.663914" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:15.590887" elapsed="0.073055"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.665220" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.664900" elapsed="0.000371"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:15.674687" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.674736" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.674829" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:15.667792" elapsed="0.007064"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.665372" elapsed="0.009526"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.675101" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.674925" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.665353" elapsed="0.009896"/>
</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-06-06T03:29:15.679177" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.676413" elapsed="0.002819"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.676150" elapsed="0.003118"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.676131" elapsed="0.003163"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.682016" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.679600" elapsed="0.002462"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.679361" elapsed="0.002736"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.679333" elapsed="0.002789"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.682722" 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-06-06T03:29:15.682304" elapsed="0.000446"/>
</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-06-06T03:29:15.683067" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.682822" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.683616" 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-06-06T03:29:15.683315" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.683149" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.682803" elapsed="0.000914"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.684243" 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-06-06T03:29:15.683878" elapsed="0.000393"/>
</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-06-06T03:29:15.684583" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.684342" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.685146" 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-06-06T03:29:15.684849" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.684682" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.684323" elapsed="0.000919"/>
</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-06-06T03:29:15.685418" elapsed="0.000379"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:15.686261" 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-06-06T03:29:15.685966" elapsed="0.000321"/>
</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-06-06T03:29:15.686445" elapsed="0.002469"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:15.675667" elapsed="0.013320"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:15.689041" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:29:15.691465" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:15.664226" elapsed="0.027266"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:15.691549" elapsed="0.000040"/>
</return>
<arg>${MULT_VAR_FOLDER}/route</arg>
<arg>mapping=${route_mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:15.565033" elapsed="0.126673"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.692526" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | APP_PEER_NAME=example-bgp-peer-app | IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>APP_PEER_NAME=${APP_PEER_NAME}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.691900" elapsed="0.000655"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.739144" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.738546" elapsed="0.000634"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:15.740046" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:15.739766" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:15.740318" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:15.739374" elapsed="0.000970"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.740931" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:15.740517" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:15.741269" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:15.741507" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:15.741123" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.741972" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.741717" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.743418" level="INFO">mapping: {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.743053" elapsed="0.000429"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.744110" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.743731" elapsed="0.000415"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.745143" level="INFO">${value} = controller-config</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.744693" elapsed="0.000487"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.746963" level="INFO">${encoded} = controller-config</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.746262" elapsed="0.000740"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.747080" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:29:15.747308" level="INFO">${encoded_value} = controller-config</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.745720" elapsed="0.001624"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.747585" elapsed="0.000365"/>
</kw>
<var name="${key}">DEVICE_NAME</var>
<var name="${value}">controller-config</var>
<status status="PASS" start="2026-06-06T03:29:15.744477" elapsed="0.003531"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.748834" level="INFO">${value} = example-bgp-peer-app</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.748369" elapsed="0.000502"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.750279" level="INFO">${encoded} = example-bgp-peer-app</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.749672" elapsed="0.000645"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.750390" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:29:15.750602" level="INFO">${encoded_value} = example-bgp-peer-app</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.749133" elapsed="0.001504"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.750875" elapsed="0.000312"/>
</kw>
<var name="${key}">APP_PEER_NAME</var>
<var name="${value}">example-bgp-peer-app</var>
<status status="PASS" start="2026-06-06T03:29:15.748179" elapsed="0.003065"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.752039" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.751584" elapsed="0.000491"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.753784" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.753089" elapsed="0.000740"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.753901" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:29:15.754116" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.752335" elapsed="0.001815"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.754368" elapsed="0.000229"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:15.751398" elapsed="0.003240"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.755259" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:15.754959" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.756281" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.755848" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:15.756359" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:15.756514" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:15.755473" elapsed="0.001066"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.756710" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:15.754822" elapsed="0.002153"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:15.744222" elapsed="0.012788"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:15.757053" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:15.757209" level="INFO">${mapping_to_use} = {'DEVICE_NAME': 'controller-config', 'APP_PEER_NAME': 'example-bgp-peer-app', 'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:15.742533" elapsed="0.014702"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.742108" elapsed="0.015160"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.757461" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.757294" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.742079" elapsed="0.015460"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.758339" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.757700" elapsed="0.000668"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:15.758418" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:15.737624" elapsed="0.020918"/>
</kw>
<msg time="2026-06-06T03:29:15.758598" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:15.723582" elapsed="0.035096"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.771939" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.784962" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.798100" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.798302" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.798484" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.798922" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.798772" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:15.798756" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.799147" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.799318" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.799488" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:15.798725" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.798602" elapsed="0.000967"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.799734" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.799812" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:15.799945" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:15.718487" elapsed="0.081486"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.801170" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.800911" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:15.813108" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.813156" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:15.813248" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:15.803596" elapsed="0.009678"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.801285" elapsed="0.012058"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.813609" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.813378" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.801267" elapsed="0.012491"/>
</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-06-06T03:29:15.818743" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.815216" elapsed="0.003588"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.814902" elapsed="0.003952"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.814876" elapsed="0.004013"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.822546" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.819279" elapsed="0.003312"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.818967" elapsed="0.003659"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.818943" elapsed="0.003722"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.823246" 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-06-06T03:29:15.822852" elapsed="0.000421"/>
</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-06-06T03:29:15.823585" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.823342" elapsed="0.000362"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.824208" 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-06-06T03:29:15.823903" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.823733" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.823324" elapsed="0.000967"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.824839" 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-06-06T03:29:15.824454" elapsed="0.000412"/>
</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-06-06T03:29:15.825175" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.824936" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.825750" 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-06-06T03:29:15.825435" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.825256" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.824918" elapsed="0.000916"/>
</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-06-06T03:29:15.825990" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:15.826823" 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-06-06T03:29:15.826511" elapsed="0.000338"/>
</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-06-06T03:29:15.827009" elapsed="0.002524"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:15.814260" elapsed="0.015351"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:15.829686" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:29:15.832082" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:15.800275" elapsed="0.031834"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:15.832166" elapsed="0.000028"/>
</return>
<arg>${BGP_VAR_FOLDER}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:15.692851" elapsed="0.139443"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:29:15.563378" elapsed="0.268982"/>
</kw>
<kw name="Stop_ExaBgp" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.833157" level="INFO">${output} =  </msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:29:15.832975" elapsed="0.000209"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.833656" level="INFO"> </msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.833357" elapsed="0.000347"/>
</kw>
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.834581" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.834256" elapsed="0.000352"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:15.834785" elapsed="0.000324"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:29:15.833937" elapsed="0.001233"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.837092" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:15.837184" level="INFO">${output} = ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:15.835339" elapsed="0.001872"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.837671" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.837406" elapsed="0.000315"/>
</kw>
<kw name="Virtual_Env_Deactivate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.839898" level="INFO">deactivate</msg>
<arg>deactivate</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:15.838391" elapsed="0.001561"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.962387" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:29:15.962602" level="INFO">${output} = [?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:29:15.840113" elapsed="0.122520"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.963494" level="INFO">[?2004ldeactivate: command not found
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.963156" elapsed="0.000388"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.962788" elapsed="0.000983"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.962744" elapsed="0.001060"/>
</if>
<arg>log_output=${True}</arg>
<doc>Deactivates virtual environment.</doc>
<status status="PASS" start="2026-06-06T03:29:15.837991" elapsed="0.125873"/>
</kw>
<doc>Stops the ExaBgp by sending ctrl+c</doc>
<status status="PASS" start="2026-06-06T03:29:15.832622" elapsed="0.131303"/>
</kw>
<kw name="Teardown_Test_Show_Bugs_If_Test_Failed" owner="SetupUtils">
<kw name="SetupUtils__Report_Bugs_Causing_Failure" owner="SetupUtils">
<if>
<branch type="IF" condition="'${SetupUtils__Known_Bug_ID}' != ''">
<kw name="Report Failure Due To Bug" owner="Utils">
<arg>${SetupUtils__Known_Bug_ID}</arg>
<doc>Report that a test failed due to a known Bugzilla bug whose
number is provided as an argument.
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:15.965591" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:15.965166" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.965147" elapsed="0.000550"/>
</if>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>'${SetupUtils__Known_Bug_ID}' != ''</arg>
<arg>Set_Known_Bug_Id</arg>
<arg>${EMPTY}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:15.965857" elapsed="0.000337"/>
</kw>
<kw name="Report_Failure_And_Point_To_Linked_Bugs" owner="Utils">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.971627" level="INFO">${test_skipped} = False</msg>
<var>${test_skipped}</var>
<arg>len(re.findall('SKIPPED', """${TEST_MESSAGE}""")) &gt; 0</arg>
<arg>modules=re</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.971162" elapsed="0.000513"/>
</kw>
<if>
<branch type="IF" condition="('${TEST_STATUS}' != 'FAIL') or ${test_skipped}">
<return>
<status status="NOT RUN" start="2026-06-06T03:29:15.971907" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:15.971755" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.971735" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.972430" level="INFO">${newline} = 
</msg>
<var>${newline}</var>
<arg>chr(10)</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:15.972127" elapsed="0.000330"/>
</kw>
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:15.972907" level="INFO">${reference} = bgpcep_userfeatures_txt_020_Bgp_Functional_Multipath_Odl_Npaths_Exa_SendReceived</msg>
<var>${reference}</var>
<arg>${SUITE_NAME}_${TEST_NAME}</arg>
<arg>[ /\.-]</arg>
<arg>_</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:15.972619" elapsed="0.000314"/>
</kw>
<kw name="Convert To Lower Case" owner="String">
<msg time="2026-06-06T03:29:15.973273" level="INFO">${reference} = bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived</msg>
<var>${reference}</var>
<arg>${reference}</arg>
<doc>Converts string to lower case.</doc>
<status status="PASS" start="2026-06-06T03:29:15.973097" elapsed="0.000218"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.973872" level="INFO">${msg} = ... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived"
reference somewhere inside)</msg>
<var>${msg}</var>
<arg>... click for list of related bugs or create a new one if needed (with the${newline}"${reference}"${newline}reference somewhere inside)</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.973494" elapsed="0.000405"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.974369" level="INFO">${bugs} = "https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived&amp;order=bug_status"</msg>
<var>${bugs}</var>
<arg>"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=${reference}&amp;order=bug_status"</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:15.974058" elapsed="0.000339"/>
</kw>
<kw name="Set Test Message" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.975050" level="INFO">Set test message to:
... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived&amp;order=bug_status"

Setup failed:
Unable to connect ExaBgp to ODL</msg>
<arg>${msg}${newline}${bugs}${newline}${newline}${TEST_MESSAGE}</arg>
<doc>Sets message for the current test case.</doc>
<status status="PASS" start="2026-06-06T03:29:15.974553" elapsed="0.000559"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.975579" level="INFO">... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived&amp;order=bug_status"</msg>
<arg>${msg}${newline}${bugs}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:15.975274" elapsed="0.000355"/>
</kw>
<doc>Report that a test failed and point to linked Bugzilla bug(s).
Linked bugs must contain the ${reference} inside comments (workaround
becasue of currently missing suitable field for external references and
not correctly working the CONTENT MATCHES filter).
Not FAILED (incl. SKIPPED) test are not reported.
This keyword must be used in the [Teardown] setting of the affected test
or as the first line of the test if FastFail module is not being
used. It reports the URL of the bug on console and also puts it
into the Robot log file.</doc>
<status status="PASS" start="2026-06-06T03:29:15.970849" elapsed="0.004854"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.964921" elapsed="0.010833"/>
</kw>
<doc>Test case teardown. Show linked bugs in case of failure.</doc>
<status status="PASS" start="2026-06-06T03:29:15.964145" elapsed="0.011651"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:15.430017" elapsed="0.545828"/>
</kw>
<doc>n-paths policy selected on odl</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:28:54.136535" elapsed="21.839361">... click for list of related bugs or create a new one if needed (with the
"bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived"
reference somewhere inside)
"https://bugs.opendaylight.org/buglist.cgi?f1=cf_external_ref&amp;o1=substring&amp;v1=bgpcep_userfeatures_txt_020_bgp_functional_multipath_odl_npaths_exa_sendreceived&amp;order=bug_status"

Setup failed:
Unable to connect ExaBgp to ODL</status>
</test>
<test id="s1-s15-t4" name="Delete_Bgp_Peer_Configuration" line="91">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:15.979564" elapsed="0.000283"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:15.979294" elapsed="0.000611"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.981081" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:15.980968" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.980948" elapsed="0.000213"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:15.986598" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:15.986476" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.986457" elapsed="0.000235"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.987757" 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-06-06T03:29:15.987334" elapsed="0.000451"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:15.988277" 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-06-06T03:29:15.987964" elapsed="0.000339"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:15.988349" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:15.988527" 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-06-06T03:29:15.986937" elapsed="0.001616"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:15.994363" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:15.994253" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.994233" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:15.995676" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:15.995542" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:15.995522" elapsed="0.000225"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:15.996246" 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-06-06T03:29:15.995914" elapsed="0.000359"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:15.996702" level="INFO">${current_connection_index} = 7</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-06-06T03:29:15.996438" elapsed="0.000294"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.026056" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:15.997253" elapsed="0.028919"/>
</kw>
<msg time="2026-06-06T03:29:16.026349" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:16.026397" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:15.996901" elapsed="0.029533"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.057273" level="INFO">". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:29:16.027007" elapsed="0.030474"/>
</kw>
<msg time="2026-06-06T03:29:16.057729" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:16.057777" level="INFO">${message_wait} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "D "e "l "e "t...</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-06-06T03:29:16.026610" elapsed="0.031206"/>
</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-06-06T03:29:16.058253" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.057931" elapsed="0.000381"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.057893" elapsed="0.000447"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.058885" level="INFO"> ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:29:16.058492" elapsed="0.000469"/>
</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-06-06T03:29:16.059250" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.059030" elapsed="0.000355"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.059011" elapsed="0.000399"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:16.059451" elapsed="0.000045"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:16.062184" elapsed="0.000353"/>
</kw>
<msg time="2026-06-06T03:29:16.062603" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:16.061083" elapsed="0.001677"/>
</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="NOT RUN" start="2026-06-06T03:29:16.063042" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:16.063384" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:16.060407" elapsed="0.003167"/>
</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-06-06T03:29:16.059810" elapsed="0.003847"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:15.995225" elapsed="0.068534"/>
</kw>
<msg time="2026-06-06T03:29:16.063852" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:16.063897" level="INFO">${message} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "D "e "l "e "t...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:15.994586" elapsed="0.069348"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:16.064121" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:16.064012" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.063993" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:16.064618" elapsed="0.000047"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:16.064988" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:16.065058" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:15.993910" elapsed="0.071255"/>
</kw>
<msg time="2026-06-06T03:29:16.065258" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:16.065314" level="INFO">${output} =  ". "t "x "t ". "0 "2 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "u "l "t "i "p "a "t "h ". "D "e "l "e "t...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:15.988984" elapsed="0.076368"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:16.065703" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.065434" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.065416" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:15.988833" elapsed="0.076973"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:15.988617" elapsed="0.077221"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:15.986090" elapsed="0.079805"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:15.980511" elapsed="0.085443"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:15.980071" elapsed="0.085930"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:15.976790" elapsed="0.089265"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.066844" level="INFO">&amp;{mapping} = { DEVICE_NAME=controller-config | BGP_NAME=example-bgp-peer | IP=10.30.171.194 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>DEVICE_NAME=${DEVICE_NAME}</arg>
<arg>BGP_NAME=${BGP_PEER_NAME}</arg>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${PROTOCOL_OPENCONFIG}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:16.066235" elapsed="0.000638"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:29:15.976185" elapsed="0.090810"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Virtual_Env_Delete" 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-06-06T03:29:16.073470" level="INFO">${cd_and_command} = cd '.' &amp;&amp; rm -rf /tmp/defaultvenv</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-06-06T03:29:16.073117" elapsed="0.000416"/>
</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-06-06T03:29:16.074997" level="INFO">Executing command 'cd '.' &amp;&amp; rm -rf /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:29:16.108153" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:29:16.108294" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:29:16.108338" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:29:16.108379" 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-06-06T03:29:16.074808" elapsed="0.033595"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.109320" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:29:16.109013" elapsed="0.000355"/>
</kw>
<msg time="2026-06-06T03:29:16.109467" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:29:16.109510" 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-06-06T03:29:16.108614" elapsed="0.000919"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.110154" 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-06-06T03:29:16.109724" elapsed="0.000457"/>
</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-06-06T03:29:16.111475" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.110995" elapsed="0.000523"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.111935" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.111691" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.112370" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.112129" elapsed="0.000291"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:29:16.110617" elapsed="0.001859"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:16.110263" elapsed="0.002250"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.110240" elapsed="0.002299"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:29:16.112716" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:16.112597" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.112579" elapsed="0.000205"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:29:16.112925" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:29:16.112835" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.112820" elapsed="0.000191"/>
</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-06-06T03:29:16.113158" 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-06-06T03:29:16.074242" elapsed="0.039035"/>
</kw>
<msg time="2026-06-06T03:29:16.113342" 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-06-06T03:29:16.073719" elapsed="0.039684"/>
</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 rm -rf /tmp/defaultvenv.
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-06-06T03:29:16.072488" elapsed="0.040991"/>
</kw>
<msg time="2026-06-06T03:29:16.113527" 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-06-06T03:29:16.068331" elapsed="0.045249"/>
</kw>
<arg>rm -rf ${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-06-06T03:29:16.067973" elapsed="0.045696"/>
</kw>
<doc>Deletes a directory with virtual env.</doc>
<status status="PASS" start="2026-06-06T03:29:16.067741" elapsed="0.045980"/>
</kw>
<kw name="Put_As_Xml_To_Uri" owner="TemplatedRequests">
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.119240" level="INFO">/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.118991" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.119700" level="INFO">&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;&lt;peer-groups&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;internal-neighbor&lt;/peer-group-name&gt;&lt;route-reflector&gt;&lt;config&gt;&lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;&lt;/config&gt;&lt;/route-reflector&gt;&lt;timers&gt;&lt;config&gt;&lt;hold-time&gt;180.0&lt;/hold-time&gt;&lt;connect-retry&gt;10.0&lt;/connect-retry&gt;&lt;/config&gt;&lt;/timers&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;64496&lt;/peer-as&gt;&lt;/config&gt;&lt;/peer-group&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;external-neighbor&lt;/peer-group-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;65000&lt;/peer-as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/peer-group&gt;&lt;/peer-groups&gt;&lt;global&gt;&lt;apply-policy&gt;&lt;config&gt;&lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;&lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;&lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;&lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;&lt;/config&gt;&lt;/apply-policy&gt;&lt;config&gt;&lt;router-id&gt;192.0.2.2&lt;/router-id&gt;&lt;as&gt;64496&lt;/as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/global&gt;&lt;neighbors&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.1&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.5&lt;/neighbor-address&gt;&lt;config&gt;&lt;local-as&gt;65001&lt;/local-as&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="external-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.6&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;application-peers&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;/neighbors&gt;&lt;/bgp&gt;&lt;/protocol&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.119447" elapsed="0.000485"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.120342" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.120090" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.120804" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.120542" elapsed="0.000307"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:16.121628" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:16.121427" elapsed="0.000243"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:16.122002" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:16.121826" elapsed="0.000202"/>
</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-06-06T03:29:16.122180" elapsed="0.000201"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.122804" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.122537" elapsed="0.000311"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:16.122891" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:16.123047" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:16.121052" elapsed="0.002019"/>
</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-06-06T03:29:16.139192" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node010odff2d7ph5w14jtktxb0e06g24.node0', 'Content-Length': '9528', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;protocol xmlns="http://openconfig.net/yang/network-instance"&gt;&lt;identifier xmlns:x="http://openconfig.net/yang/policy-types"&gt;x:BGP&lt;/identifier&gt;&lt;name&gt;example-bgp-rib&lt;/name&gt;&lt;bgp xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;&lt;peer-groups&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;internal-neighbor&lt;/peer-group-name&gt;&lt;route-reflector&gt;&lt;config&gt;&lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;&lt;/config&gt;&lt;/route-reflector&gt;&lt;timers&gt;&lt;config&gt;&lt;hold-time&gt;180.0&lt;/hold-time&gt;&lt;connect-retry&gt;10.0&lt;/connect-retry&gt;&lt;/config&gt;&lt;/timers&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;64496&lt;/peer-as&gt;&lt;/config&gt;&lt;/peer-group&gt;&lt;peer-group&gt;&lt;peer-group-name&gt;external-neighbor&lt;/peer-group-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;restart-time&gt;60&lt;/restart-time&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;transport&gt;&lt;config&gt;&lt;passive-mode&gt;true&lt;/passive-mode&gt;&lt;remote-port&gt;179&lt;/remote-port&gt;&lt;/config&gt;&lt;/transport&gt;&lt;config&gt;&lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;&lt;peer-as&gt;65000&lt;/peer-as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;graceful-restart&gt;&lt;config&gt;&lt;enabled&gt;true&lt;/enabled&gt;&lt;/config&gt;&lt;/graceful-restart&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/peer-group&gt;&lt;/peer-groups&gt;&lt;global&gt;&lt;apply-policy&gt;&lt;config&gt;&lt;default-export-policy&gt;REJECT-ROUTE&lt;/default-export-policy&gt;&lt;default-import-policy&gt;REJECT-ROUTE&lt;/default-import-policy&gt;&lt;export-policy&gt;default-odl-export-policy&lt;/export-policy&gt;&lt;import-policy&gt;default-odl-import-policy&lt;/import-policy&gt;&lt;/config&gt;&lt;/apply-policy&gt;&lt;config&gt;&lt;router-id&gt;192.0.2.2&lt;/router-id&gt;&lt;as&gt;64496&lt;/as&gt;&lt;/config&gt;&lt;afi-safis&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;ROUTE-TARGET-CONSTRAIN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-MULTICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV6-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;IPV4-MCAST-VPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;afi-safi&gt;&lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;&lt;/afi-safi&gt;&lt;/afi-safis&gt;&lt;/global&gt;&lt;neighbors&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.1&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.5&lt;/neighbor-address&gt;&lt;config&gt;&lt;local-as&gt;65001&lt;/local-as&gt;&lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="external-neighbor"]&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;neighbor&gt;&lt;neighbor-address&gt;192.0.2.6&lt;/neighbor-address&gt;&lt;config&gt;&lt;peer-group&gt;application-peers&lt;/peer-group&gt;&lt;/config&gt;&lt;/neighbor&gt;&lt;/neighbors&gt;&lt;/bgp&gt;&lt;/protocol&gt; 
 </msg>
<msg time="2026-06-06T03:29:16.139427" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:16.139534" level="INFO">${response} = &lt;Response [204]&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-06-06T03:29:16.125245" elapsed="0.014316"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:16.123141" elapsed="0.016469"/>
</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-06-06T03:29:16.139838" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.139661" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.123124" elapsed="0.016805"/>
</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-06-06T03:29:16.143613" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.140892" elapsed="0.002779"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:16.140659" elapsed="0.003048"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.140625" elapsed="0.003108"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.146351" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.144016" elapsed="0.002380"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:16.143790" elapsed="0.002641"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.143773" elapsed="0.002682"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.147054" 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-06-06T03:29:16.146655" elapsed="0.000426"/>
</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-06-06T03:29:16.147394" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.147150" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.147962" 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-06-06T03:29:16.147659" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:16.147479" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.147132" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.148563" 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-06-06T03:29:16.148206" elapsed="0.000384"/>
</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-06-06T03:29:16.148914" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.148676" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.149478" 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-06-06T03:29:16.149155" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:16.148994" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.148656" elapsed="0.000903"/>
</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-06-06T03:29:16.149731" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:16.150550" 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-06-06T03:29:16.150255" elapsed="0.000321"/>
</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-06-06T03:29:16.150751" elapsed="0.002379"/>
</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-06-06T03:29:16.140314" elapsed="0.012878"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:16.153385" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:29:16.153259" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.153240" elapsed="0.000241"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:16.153634" elapsed="0.000037"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:16.153719" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:16.156055" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</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-06-06T03:29:16.116420" elapsed="0.039662"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:16.156144" elapsed="0.000028"/>
</return>
<arg>${OPENCONFIG_RIB_URI}</arg>
<arg>${rib_old}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Specify XML headers and return Put_To_Uri response text.</doc>
<status status="PASS" start="2026-06-06T03:29:16.113928" elapsed="0.042382"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:29:16.156480" elapsed="0.000877"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:16.157597" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:29:16.157520" elapsed="0.000207"/>
</kw>
<doc>Suite teardown keyword with old rib restoration</doc>
<status status="PASS" start="2026-06-06T03:29:16.067462" elapsed="0.090329"/>
</kw>
<doc>Functional test suite for bgp - n-path and all-path selection

Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests n-path and all-path selection policy.
It uses odl and exabgp as bgp peers. Routes advertized from odl
are configured via application peer.</doc>
<status status="FAIL" start="2026-06-06T03:28:24.511030" elapsed="51.646797"/>
</suite>
<suite id="s1-s16" name="060 Bgp Functional Mvpn" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/060_bgp_functional_mvpn.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.247900" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:29:16.243556" elapsed="0.004399"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:29:16.243307" elapsed="0.004720"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.252854" 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-06-06T03:29:16.249154" elapsed="0.003729"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:29:16.253102" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:16.252972" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.252946" elapsed="0.000225"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.253736" 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-06-06T03:29:16.253362" elapsed="0.000419"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.254260" 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-06-06T03:29:16.253949" elapsed="0.000338"/>
</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-06-06T03:29:16.254828" elapsed="0.000287"/>
</kw>
<msg time="2026-06-06T03:29:16.255214" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:16.255260" 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-06-06T03:29:16.254462" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.255845" 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-06-06T03:29:16.255457" elapsed="0.000414"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.256871" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:29:16.256587" elapsed="0.000311"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.257320" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:29:16.257051" elapsed="0.000296"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.257818" 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-06-06T03:29:16.257510" elapsed="0.000335"/>
</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-06-06T03:29:16.260953" elapsed="0.000215"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.261691" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:29:16.261345" elapsed="0.000373"/>
</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-06-06T03:29:16.261874" elapsed="0.000228"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.262909" 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-06-06T03:29:16.262594" elapsed="0.000341"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:29:16.262979" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:16.263139" 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-06-06T03:29:16.262298" elapsed="0.000865"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:16.263926" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e4769a90&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-06-06T03:29:16.263324" elapsed="0.000813"/>
</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-06-06T03:29:16.264307" elapsed="0.000192"/>
</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-06-06T03:29:16.260370" elapsed="0.004189"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:16.260177" elapsed="0.004426"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:29:16.257903" elapsed="0.006731"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.265223" 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-06-06T03:29:16.264818" elapsed="0.000449"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.265884" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:29:16.265466" elapsed="0.000463"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.266491" 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-06-06T03:29:16.266096" elapsed="0.000439"/>
</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-06-06T03:29:16.256134" elapsed="0.010458"/>
</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-06-06T03:29:16.248806" elapsed="0.017859"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:16.266846" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:16.266733" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.266713" elapsed="0.000201"/>
</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-06-06T03:29:16.270039" 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-06-06T03:29:16.269658" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.270521" 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-06-06T03:29:16.270228" elapsed="0.000319"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:16.270591" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:16.270762" 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-06-06T03:29:16.269311" elapsed="0.001475"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:16.271790" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:29:16.271502" elapsed="0.000315"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.272563" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:29:16.272679" 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-06-06T03:29:16.272398" elapsed="0.000308"/>
</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-06-06T03:29:16.276096" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.275499" elapsed="0.000684"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.275479" elapsed="0.000742"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.276879" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:29:16.276427" elapsed="0.000738"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.278128" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.277450" elapsed="0.000831"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.279468" 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-06-06T03:29:16.278558" elapsed="0.000964"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.281608" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:29:16.281804" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:16.281068" elapsed="0.000780"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:16.282191" elapsed="0.000483"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.283902" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:29:16.847695" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:29:16 UTC 2026

  System load:  0.0                Processes:             121
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:28:24 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:29:16.283483" elapsed="0.564372"/>
</kw>
<msg time="2026-06-06T03:29:16.847942" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:16.283027" elapsed="0.565086"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:29:16.280167" elapsed="0.568096"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.849159" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:29:16.861631" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:29:16.862057" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:29:16.862288" 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-06-06T03:29:16.848669" elapsed="0.013729"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:29:16.863128" elapsed="0.001125"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.866920" 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-06-06T03:29:16.865622" elapsed="0.001532"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:29:16.868103" elapsed="0.000114"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:16.867516" elapsed="0.000871"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.867461" elapsed="0.001011"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:29:16.869180" elapsed="0.000193"/>
</return>
<status status="PASS" start="2026-06-06T03:29:16.868678" elapsed="0.000826"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.868610" elapsed="0.000949"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:29:16.869661" elapsed="0.000025"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:16.874216" elapsed="0.000759"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:29:16.875371" elapsed="0.000422"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:29:16.876166" elapsed="0.000314"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:16.870349" elapsed="0.006229"/>
</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-06-06T03:29:16.274545" elapsed="0.602300"/>
</kw>
<msg time="2026-06-06T03:29:16.876923" 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-06-06T03:29:16.273911" elapsed="0.603087"/>
</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-06-06T03:29:16.273408" elapsed="0.603779"/>
</kw>
<msg time="2026-06-06T03:29:16.877262" 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-06-06T03:29:16.272867" elapsed="0.604461"/>
</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-06-06T03:29:16.881144" elapsed="0.000423"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:29:16.881752" elapsed="0.000149"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:29:16.882055" elapsed="0.000098"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:16.877764" elapsed="0.004441"/>
</kw>
<msg time="2026-06-06T03:29:16.882297" 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-06-06T03:29:16.272036" elapsed="0.610286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.882802" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.882513" elapsed="0.000331"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:29:16.882888" elapsed="0.000030"/>
</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-06-06T03:29:16.271142" elapsed="0.611872"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:16.270962" elapsed="0.612091"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:16.270836" elapsed="0.612253"/>
</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-06-06T03:29:16.267138" elapsed="0.616007"/>
</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-06-06T03:29:16.883306" elapsed="0.000210"/>
</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-06-06T03:29:16.897686" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:16.897558" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.897538" elapsed="0.000218"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.898059" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:29:16.898162" 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-06-06T03:29:16.897923" elapsed="0.000266"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.898608" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.898346" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:16.899076" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:16.898831" elapsed="0.000288"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:16.899916" 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-06-06T03:29:16.899679" elapsed="0.000347">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:29:16.900132" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:29:16.900176" 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-06-06T03:29:16.899285" elapsed="0.000915"/>
</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-06-06T03:29:16.900507" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:16.900276" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:16.900256" elapsed="0.000352"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:16.901404" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:29:16.901112" elapsed="0.000321"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:29:16.901485" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:16.901656" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:29:16.900835" elapsed="0.000847"/>
</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-06-06T03:29:16.901845" elapsed="0.000405"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.902585" level="INFO">index=4
host=10.30.170.38
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-06-06T03:29:16.902706" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:29:16.902477" elapsed="0.000257"/>
</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-06-06T03:29:16.902891" elapsed="0.002183"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:29:16.905528" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:29:17.065987" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:29:16.905259" elapsed="0.160887"/>
</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-06-06T03:29:17.070091" elapsed="0.000369"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:29:17.070634" elapsed="0.000197"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:29:17.070988" elapsed="0.000103"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:17.067389" elapsed="0.003757"/>
</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-06-06T03:29:17.066610" elapsed="0.004584"/>
</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-06-06T03:29:16.897275" elapsed="0.173972"/>
</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-06-06T03:29:16.884266" elapsed="0.187031"/>
</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-06-06T03:29:16.883887" elapsed="0.187465"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:16.883741" elapsed="0.187653"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:29:16.883573" elapsed="0.187858"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:29:16.248336" elapsed="0.823159"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.074229" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.074109" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.074085" elapsed="0.000220"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.079310" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.079201" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.079182" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.080362" 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-06-06T03:29:17.079969" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.080877" 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-06-06T03:29:17.080558" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:17.080947" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:17.081110" 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-06-06T03:29:17.079612" elapsed="0.001522"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:17.086604" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.086495" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.086477" elapsed="0.000211"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:17.087918" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.087789" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.087770" elapsed="0.000217"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:17.088460" 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-06-06T03:29:17.088136" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.088904" 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-06-06T03:29:17.088670" elapsed="0.000261"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.123992" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:17.089635" elapsed="0.034495"/>
</kw>
<msg time="2026-06-06T03:29:17.124264" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:17.124310" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:29:17.089097" elapsed="0.035251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.194562" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "6 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "m "v "p "n ". "r "o "b "o "t "[K"
[?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-06-06T03:29:17.125060" elapsed="0.069678"/>
</kw>
<msg time="2026-06-06T03:29:17.194871" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:17.194918" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:29:17.124531" elapsed="0.070424"/>
</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-06-06T03:29:17.195314" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.195042" elapsed="0.000421"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.195019" elapsed="0.000473"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.196124" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "6 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "m "v "p "n ". "r "o "b "o "t "[K"
[?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-06-06T03:29:17.195754" elapsed="0.000456"/>
</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-06-06T03:29:17.196522" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.196279" elapsed="0.000408"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.196260" elapsed="0.000455"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:17.196751" elapsed="0.000037"/>
</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-06-06T03:29:17.199254" elapsed="0.000468"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:29:17.200077" elapsed="0.000304"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:29:17.200736" elapsed="0.000238"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:17.198455" elapsed="0.002609"/>
</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-06-06T03:29:17.197063" elapsed="0.004153"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:17.087476" elapsed="0.113845"/>
</kw>
<msg time="2026-06-06T03:29:17.201416" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:17.201462" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:17.086849" elapsed="0.114652"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:17.202008" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:29:17.201892" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.201869" elapsed="0.000230"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.202529" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.202898" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.202972" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:17.086205" elapsed="0.116877"/>
</kw>
<msg time="2026-06-06T03:29:17.203177" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:17.203222" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:17.081602" elapsed="0.121656"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.203598" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.203337" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.203319" elapsed="0.000375"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:17.081451" elapsed="0.122268"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:17.081269" elapsed="0.122484"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:17.078908" elapsed="0.124900"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:29:17.072130" elapsed="0.131736"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:17.071676" elapsed="0.132234"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:29:16.242986" elapsed="0.960977"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.204492" level="INFO">${mininet_conn_id} = 7</msg>
<var>${mininet_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:29:17.204125" elapsed="0.000393"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.205045" level="INFO">${mininet_conn_id} = 7</msg>
<arg>${mininet_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:29:17.204709" elapsed="0.000378"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:29:17.207054" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:29:17.207131" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:17.206770" elapsed="0.000385"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:17.207318" elapsed="0.000472"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.208667" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:29:17.828130" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:29:17 UTC 2026

  System load:  0.02               Processes:             106
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:28:25 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:29:17.208333" elapsed="0.619953"/>
</kw>
<msg time="2026-06-06T03:29:17.828373" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:17.207969" elapsed="0.620482"/>
</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-06-06T03:29:17.206305" elapsed="0.622256"/>
</kw>
<msg time="2026-06-06T03:29:17.828717" 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-06-06T03:29:17.205911" elapsed="0.622856"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:29:17.205303" elapsed="0.623542"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:17.829469" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e47c8110&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:29:17.829087" elapsed="0.000573"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.837225" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:29:17.852978" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>${PLAY_SCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:29:17.829839" elapsed="0.023234"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.855109" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:29:17.887181" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:29:17.887435" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:29:17.887533" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:29:17.887623" 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-06-06T03:29:17.854840" elapsed="0.032880"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.889698" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:29:17.889021" elapsed="0.000783"/>
</kw>
<msg time="2026-06-06T03:29:17.890017" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:29:17.890116" 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-06-06T03:29:17.888151" elapsed="0.002015"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.891560" 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-06-06T03:29:17.890559" elapsed="0.001061"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.892611" elapsed="0.000084"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.891838" elapsed="0.000949"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.891788" elapsed="0.001058"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:29:17.893213" elapsed="0.000071"/>
</return>
<status status="PASS" start="2026-06-06T03:29:17.892971" elapsed="0.000389"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.892935" elapsed="0.000479"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.893619" elapsed="0.000058"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.893541" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:17.893505" elapsed="0.000288"/>
</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-06-06T03:29:17.894123" elapsed="0.000048"/>
</kw>
<msg time="2026-06-06T03:29:17.894452" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:29:17.854275" elapsed="0.040234"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:29:17.894904" elapsed="0.000059"/>
</return>
<status status="PASS" start="2026-06-06T03:29:17.894695" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.894626" elapsed="0.000456"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.895422" elapsed="0.000047"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:29:17.853564" elapsed="0.042036"/>
</kw>
<doc>Initialize SetupUtils. Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:16.242595" elapsed="1.653161"/>
</kw>
<test id="s1-s16-t1" name="Configure_App_Peer" line="49">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:17.899758" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:17.899470" elapsed="0.000558"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.901032" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.900921" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.900902" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.906249" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.906141" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.906122" elapsed="0.000254"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.907391" 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-06-06T03:29:17.907010" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.907900" 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-06-06T03:29:17.907584" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:17.907971" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:17.908125" 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-06-06T03:29:17.906611" elapsed="0.001540"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:17.913662" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.913539" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.913520" elapsed="0.000213"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:17.914917" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:17.914810" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.914792" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:17.915440" 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-06-06T03:29:17.915137" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.915869" level="INFO">${current_connection_index} = 7</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-06-06T03:29:17.915631" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.945933" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:17.916400" elapsed="0.029635"/>
</kw>
<msg time="2026-06-06T03:29:17.946215" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:17.946261" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:17.916059" elapsed="0.030239"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:17.972622" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:29:17.946849" elapsed="0.025887"/>
</kw>
<msg time="2026-06-06T03:29:17.972896" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:17.972941" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "C "o "n "f "i "g "u "r "e "_...</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-06-06T03:29:17.946476" elapsed="0.026501"/>
</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-06-06T03:29:17.973309" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.973054" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.973034" elapsed="0.000355"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:17.973864" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:29:17.973537" elapsed="0.000395"/>
</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-06-06T03:29:17.974218" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.973999" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.973981" elapsed="0.000315"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:17.974329" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:17.976835" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:29:17.977039" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:17.975798" elapsed="0.001393"/>
</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="NOT RUN" start="2026-06-06T03:29:17.977769" elapsed="0.000084"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.978184" elapsed="0.000087"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:17.975158" elapsed="0.003238"/>
</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-06-06T03:29:17.974609" elapsed="0.003852"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:17.914485" elapsed="0.064074"/>
</kw>
<msg time="2026-06-06T03:29:17.978670" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:17.978716" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "C "o "n "f "i "g "u "r "e "_...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:17.913890" elapsed="0.064864"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:17.978949" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:17.978833" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.978814" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.979441" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.979801" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:17.979873" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:17.913202" elapsed="0.066778"/>
</kw>
<msg time="2026-06-06T03:29:17.980073" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:17.980117" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "C "o "n "f "i "g "u "r "e "_...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:17.908534" elapsed="0.071620"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:17.980494" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:17.980230" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:17.980212" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:17.908382" elapsed="0.072213"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:17.908207" elapsed="0.072417"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:17.905775" elapsed="0.074923"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:17.900615" elapsed="0.080140"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:17.900184" elapsed="0.080615"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:17.896941" elapsed="0.083911"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.014614" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.014229" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.015465" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.015178" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:18.015659" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.014837" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.016240" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:18.015856" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.016615" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:18.016810" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:18.016474" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.017270" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.016999" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.018285" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.018028" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.018780" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.018494" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.019626" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.019165" elapsed="0.000503"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.020408" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.020186" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.020484" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:18.020633" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.019864" elapsed="0.000812"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.020836" elapsed="0.000237"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:18.019026" elapsed="0.002088"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.021691" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.021376" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.022433" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.022224" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.022508" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:18.022672" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.021905" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.022854" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:18.021239" elapsed="0.001876"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:18.018855" elapsed="0.004294"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:18.023191" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:18.023346" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:18.017701" elapsed="0.005670"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.017385" elapsed="0.006018"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.023580" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.023428" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.017365" elapsed="0.006306"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.024404" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:18.023821" elapsed="0.000612"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.024482" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:18.013557" elapsed="0.011047"/>
</kw>
<msg time="2026-06-06T03:29:18.024675" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:18.000887" elapsed="0.023869"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.037188" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.049784" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.062262" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.062468" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.062664" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.063043" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.062893" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:18.062878" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.063268" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.063438" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.063610" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:18.062848" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.062744" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.063857" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.063932" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:18.064061" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:17.996579" elapsed="0.067508"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.090979" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.090569" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.091760" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.091509" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:18.091982" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.091173" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.092563" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:18.092179" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.092915" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:18.093070" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:18.092772" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.093525" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.093277" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:18.093958" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.093657" elapsed="0.000359"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.094491" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.094191" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.094042" elapsed="0.000510"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.093622" elapsed="0.000951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.095319" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:18.094739" elapsed="0.000610"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.095399" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:18.089882" elapsed="0.005643"/>
</kw>
<msg time="2026-06-06T03:29:18.095580" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:18.077161" elapsed="0.018465"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.107969" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.120303" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.134404" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.134637" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.134833" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.135206" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.135056" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:18.135040" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.135435" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.135614" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.135803" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:18.135011" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.134909" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.136034" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.136110" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:18.136231" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:18.074343" elapsed="0.061917"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.137579" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.137325" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:18.137756" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.136940" elapsed="0.000841"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.138103" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.137852" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.138683" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.138368" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.138186" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.137833" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.141138" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:18.138926" elapsed="0.002240"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:18.141220" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:18.141377" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:18.136593" elapsed="0.004810"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.142825" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.142555" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.143276" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.143034" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.143746" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.143483" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.144228" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.143984" elapsed="0.000287"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:18.145105" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:18.144905" elapsed="0.000238"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:18.145478" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:18.145301" elapsed="0.000202"/>
</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-06-06T03:29:18.145671" elapsed="0.000208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.146286" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.146039" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:18.146372" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:18.146528" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:18.144479" elapsed="0.002074"/>
</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-06-06T03:29:18.163379" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:29:18.163438" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:29:18 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:18.163688" 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-06-06T03:29:18.148983" elapsed="0.014769"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.146746" elapsed="0.017108"/>
</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-06-06T03:29:18.164267" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.163913" elapsed="0.000503"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.146605" elapsed="0.017862"/>
</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-06-06T03:29:18.172031" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.166687" elapsed="0.005441"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.166156" elapsed="0.006050"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.166114" elapsed="0.006149"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.175539" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.172921" elapsed="0.002665"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.172388" elapsed="0.003232"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.172351" elapsed="0.003308"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.176212" 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-06-06T03:29:18.175830" elapsed="0.000410"/>
</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-06-06T03:29:18.176559" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.176311" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.177142" 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-06-06T03:29:18.176826" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.176655" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.176292" elapsed="0.000935"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.177773" 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-06-06T03:29:18.177391" elapsed="0.000409"/>
</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-06-06T03:29:18.178160" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.177871" elapsed="0.000348"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.178729" 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-06-06T03:29:18.178413" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.178244" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.177853" elapsed="0.000959"/>
</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-06-06T03:29:18.178966" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:18.179791" 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-06-06T03:29:18.179490" elapsed="0.000327"/>
</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-06-06T03:29:18.179978" elapsed="0.002322"/>
</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-06-06T03:29:18.165319" elapsed="0.017045"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:18.182543" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:18.182431" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.182412" elapsed="0.000218"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:18.182800" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.182869" elapsed="0.001026"/>
</return>
<msg time="2026-06-06T03:29:18.189609" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:29:18.141756" elapsed="0.047949"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.189871" elapsed="0.000067"/>
</return>
<msg time="2026-06-06T03:29:18.190224" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:17.985666" elapsed="0.204613"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.191125" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.190516" elapsed="0.000762"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.190476" elapsed="0.000858"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.191407" elapsed="0.000058"/>
</return>
<arg>${MVPN_DIR}/app_peer</arg>
<arg>mapping=${MVPN_APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:17.981116" elapsed="0.210592"/>
</kw>
<doc>Configures bgp application peer.</doc>
<status status="PASS" start="2026-06-06T03:29:17.895885" elapsed="0.296091"/>
</test>
<test id="s1-s16-t2" name="Reconfigure_ODL_To_Accept_Connection" line="57">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:18.198866" elapsed="0.000329"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:18.198431" elapsed="0.000848"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.200811" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.200623" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.200594" elapsed="0.000320"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.207403" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.207296" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.207278" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.208487" 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-06-06T03:29:18.208103" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.208995" 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-06-06T03:29:18.208695" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:18.209151" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:18.209329" 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-06-06T03:29:18.207718" elapsed="0.001637"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:18.214887" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.214777" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.214757" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:18.216169" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.216062" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.216043" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:18.216713" 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-06-06T03:29:18.216386" elapsed="0.000353"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.217145" level="INFO">${current_connection_index} = 7</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-06-06T03:29:18.216902" elapsed="0.000271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.241438" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:18.218005" elapsed="0.023543"/>
</kw>
<msg time="2026-06-06T03:29:18.241738" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:18.241786" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:18.217341" elapsed="0.024482"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.270492" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:29:18.242360" elapsed="0.028243"/>
</kw>
<msg time="2026-06-06T03:29:18.270784" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:18.270830" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "R "e "c "o "n "f "i "g "u "r...</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-06-06T03:29:18.242006" elapsed="0.028861"/>
</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-06-06T03:29:18.271177" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.270947" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.270926" elapsed="0.000331"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.271734" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:29:18.271404" elapsed="0.000406"/>
</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-06-06T03:29:18.272100" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.271878" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.271859" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:18.272212" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:18.274791" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:29:18.274999" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:18.273697" elapsed="0.001433"/>
</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="NOT RUN" start="2026-06-06T03:29:18.275413" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.275771" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:18.273042" elapsed="0.002916"/>
</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-06-06T03:29:18.272488" elapsed="0.003536"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:18.215756" elapsed="0.060404"/>
</kw>
<msg time="2026-06-06T03:29:18.276252" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:18.276297" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "R "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:18.215114" elapsed="0.061221"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:18.276520" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:18.276412" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.276392" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.277032" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.277394" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.277467" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:18.214414" elapsed="0.063166"/>
</kw>
<msg time="2026-06-06T03:29:18.277690" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:18.277736" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "R "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:18.209749" elapsed="0.068024"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.278106" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.277850" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.277832" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:18.209582" elapsed="0.068627"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:18.209410" elapsed="0.068828"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:18.206929" elapsed="0.071362"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:18.200181" elapsed="0.078165"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:18.199516" elapsed="0.078875"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:18.194909" elapsed="0.083533"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.312738" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.312316" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.313637" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.313377" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:18.313836" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.312949" elapsed="0.000912"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.314424" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:18.314033" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.314786" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:18.314943" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:18.314627" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.315436" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.315182" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.316480" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.316213" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.316988" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.316713" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.317740" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.317417" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.318510" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.318291" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.318586" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:18.318760" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.317961" elapsed="0.000824"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.318943" elapsed="0.000241"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:29:18.317269" elapsed="0.001956"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.319817" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.319481" elapsed="0.000362"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.320560" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.320351" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.320635" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:29:18.320822" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.320032" elapsed="0.000816"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.321018" elapsed="0.000293"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:29:18.319342" elapsed="0.002013"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.321942" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.321619" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.322913" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.322671" elapsed="0.000270"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.322994" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:18.323161" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.322162" elapsed="0.001025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.323348" elapsed="0.000223"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:29:18.321475" elapsed="0.002138"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.324212" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.323886" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.325050" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.324820" elapsed="0.000264"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.325157" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:18.325315" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.324446" elapsed="0.000895"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.325508" elapsed="0.000244"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:29:18.323748" elapsed="0.002063"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.326387" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.326080" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.327213" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.326991" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.327289" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:18.327441" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.326662" elapsed="0.000804"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.327622" elapsed="0.000246"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:18.325931" elapsed="0.001982"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.328490" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:18.328177" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:18.329315" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.329075" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:18.329393" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:18.329545" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:18.328743" elapsed="0.000827"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:18.329747" elapsed="0.000250"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:29:18.328038" elapsed="0.002001"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:18.317066" elapsed="0.013009"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:18.330119" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:18.330279" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:18.315878" elapsed="0.014428"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.315552" elapsed="0.014786"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.330518" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.330364" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.315533" elapsed="0.015062"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.331434" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:18.330763" elapsed="0.000700"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.331514" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:18.311625" elapsed="0.020030"/>
</kw>
<msg time="2026-06-06T03:29:18.331714" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:18.298556" elapsed="0.033207"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.344453" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.356921" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.369420" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.369621" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.369818" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.370184" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.370034" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:18.370019" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.370407" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.370579" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.370764" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:18.369991" elapsed="0.000827"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.369892" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.370994" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.371069" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:18.371190" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:18.294013" elapsed="0.077204"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.397732" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.397333" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.398478" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.398264" elapsed="0.000278">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:18.398634" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.397926" elapsed="0.000749"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.399228" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:18.398843" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.399553" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:18.399786" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:18.399419" elapsed="0.000397"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.400225" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.399980" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:18.400709" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.400384" elapsed="0.000385"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.401259" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.400946" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.400795" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.400365" elapsed="0.000978"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.402323" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:18.401493" elapsed="0.000861"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.402404" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:18.396690" elapsed="0.005838"/>
</kw>
<msg time="2026-06-06T03:29:18.402582" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:18.384054" elapsed="0.018575"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.415403" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.427788" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.440193" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.440391" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.440570" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.440950" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.440804" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:18.440789" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.441197" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.441368" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.441541" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:18.440761" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.440658" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.441820" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.441898" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:18.442019" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:18.381397" elapsed="0.060650"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:18.443314" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.443072" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:18.443471" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.442725" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.443838" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.443571" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.444378" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.444087" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.443919" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.443553" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.446856" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:18.444612" elapsed="0.002271"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:18.446934" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:18.447086" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:18.442380" elapsed="0.004731"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.448491" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.448246" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.448947" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.448709" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.449405" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.449163" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.449857" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.449601" elapsed="0.000299"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:18.450722" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:18.450508" elapsed="0.000241"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:18.451076" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:18.450904" elapsed="0.000198"/>
</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-06-06T03:29:18.451253" elapsed="0.000196"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.451875" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.451609" elapsed="0.000309"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:18.451959" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:18.452113" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:18.450103" elapsed="0.002067"/>
</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-06-06T03:29:18.463472" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '295', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:29:18.463530" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:18.463619" 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-06-06T03:29:18.454515" elapsed="0.009149"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.452244" elapsed="0.011467"/>
</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-06-06T03:29:18.463897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.463738" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.452225" elapsed="0.011760"/>
</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-06-06T03:29:18.469705" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.464959" elapsed="0.004846"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.464734" elapsed="0.005148"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.464716" elapsed="0.005221"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.475741" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.470568" elapsed="0.005276"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.470063" elapsed="0.005856"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.470025" elapsed="0.005949"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.477288" 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-06-06T03:29:18.476348" elapsed="0.001002"/>
</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-06-06T03:29:18.477766" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.477501" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.478313" 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-06-06T03:29:18.478013" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.477849" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.477466" elapsed="0.000930"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.478943" 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-06-06T03:29:18.478564" elapsed="0.000406"/>
</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-06-06T03:29:18.479278" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.479039" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.479835" 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-06-06T03:29:18.479521" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:18.479357" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.479021" elapsed="0.000897"/>
</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-06-06T03:29:18.480166" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:18.480982" 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-06-06T03:29:18.480703" elapsed="0.000305"/>
</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-06-06T03:29:18.481185" elapsed="0.002306"/>
</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-06-06T03:29:18.464359" elapsed="0.019195"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:18.483785" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:18.483675" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.483653" elapsed="0.000217"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:18.484021" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.484089" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:18.486382" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:29:18.447436" elapsed="0.038974"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.486475" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:18.486627" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:18.283068" elapsed="0.203598"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.487003" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.486766" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.486749" elapsed="0.000347"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:18.487129" elapsed="0.000025"/>
</return>
<arg>${MVPN_DIR}/bgp_peer</arg>
<arg>mapping=${MVPN_ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:18.278719" elapsed="0.208531"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:29:18.192872" elapsed="0.294492"/>
</test>
<test id="s1-s16-t3" name="Start_Bgp_Peer" line="65">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:18.491046" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:18.490777" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.492310" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.492200" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.492181" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.497337" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.497229" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.497211" elapsed="0.000192"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.498404" 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-06-06T03:29:18.498025" elapsed="0.000406"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.498906" 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-06-06T03:29:18.498594" elapsed="0.000338"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:18.498976" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:18.499129" 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-06-06T03:29:18.497628" elapsed="0.001525"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:18.504613" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.504505" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.504485" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:18.505950" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:18.505844" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.505825" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:18.506462" 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-06-06T03:29:18.506166" elapsed="0.000323"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.506886" level="INFO">${current_connection_index} = 7</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-06-06T03:29:18.506672" elapsed="0.000274"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.540567" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:18.507454" elapsed="0.033242"/>
</kw>
<msg time="2026-06-06T03:29:18.540869" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:18.540918" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:18.507113" elapsed="0.033843"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.564835" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:29:18.541530" elapsed="0.023411"/>
</kw>
<msg time="2026-06-06T03:29:18.565129" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:18.565179" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "S "t "a "r "t "_ "B "g "p "_...</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-06-06T03:29:18.541168" elapsed="0.024049"/>
</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-06-06T03:29:18.565522" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.565295" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.565275" elapsed="0.000325"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.566070" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:29:18.565774" elapsed="0.000361"/>
</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-06-06T03:29:18.566422" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.566202" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.566184" elapsed="0.000316"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:18.566532" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:18.569041" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:29:18.569258" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:18.567985" elapsed="0.001400"/>
</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="NOT RUN" start="2026-06-06T03:29:18.569682" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.570021" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:18.567342" elapsed="0.002860"/>
</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-06-06T03:29:18.566812" elapsed="0.003455"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:18.505515" elapsed="0.064847"/>
</kw>
<msg time="2026-06-06T03:29:18.570454" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:18.570498" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "S "t "a "r "t "_ "B "g "p "_...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:18.504855" elapsed="0.065680"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:18.570735" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:18.570611" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.570592" elapsed="0.000227"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.571212" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.571548" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:18.571619" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:18.504165" elapsed="0.067578"/>
</kw>
<msg time="2026-06-06T03:29:18.571872" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:18.571916" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "S "t "a "r "t "_ "B "g "p "_...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:18.499517" elapsed="0.072437"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:18.572283" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:18.572028" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:18.572011" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:18.499373" elapsed="0.073011"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:18.499205" elapsed="0.073207"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:18.496834" elapsed="0.075630"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:18.491914" elapsed="0.080610"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:18.491464" elapsed="0.081105"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:18.488444" elapsed="0.084177"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Start_Bgp_Peer">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.574399" level="INFO">${command} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --mvpn --wfr 1 &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:18.574072" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:18.574857" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --mvpn --wfr 1 &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:18.574590" elapsed="0.000314"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:18.578175" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --mvpn --wfr 1 &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:29:18.578268" level="INFO">${output} =  python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --mvpn --wfr 1 &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:18.575059" elapsed="0.003237"/>
</kw>
<arg>--amount 0 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug --mvpn --wfr 1</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:29:18.573619" elapsed="0.004740"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:29:24.580580" level="FAIL">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.579981" elapsed="6.002315">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.582591" elapsed="0.000031"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:29:18.579708" elapsed="6.003055">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:29:18.579290" elapsed="6.003602"/>
</kw>
<msg time="2026-06-06T03:29:24.583006" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:18.578928" elapsed="6.004104"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:29:24.583214" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:29:24.583124" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.583098" elapsed="0.000202"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.583526" elapsed="0.000026"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.583720" elapsed="0.000025"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:29:18.578626" elapsed="6.005181"/>
</kw>
<doc>Starts bgp peer and verifies that the peer runs.</doc>
<status status="PASS" start="2026-06-06T03:29:18.573275" elapsed="6.010579"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>Start Bgp Peer</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:18.572810" elapsed="6.011086"/>
</kw>
<doc>Start Python speaker to connect to ODL. We need to do WUKS until odl really starts to accept incomming bgp connection. The failure happens if the incomming connection comes too quickly after configuring the peer in the previous test case.</doc>
<status status="PASS" start="2026-06-06T03:29:18.487661" elapsed="6.096439"/>
</test>
<test id="s1-s16-t4" name="Odl_To_Play_intra_as_ipmsi_ad" line="70">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:24.587556" elapsed="0.000278"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:24.587281" elapsed="0.000610"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.589137" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:24.589013" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.588993" elapsed="0.000213"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.594177" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:24.594070" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.594051" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.595260" 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-06-06T03:29:24.594872" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.595767" 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-06-06T03:29:24.595452" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:24.595838" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:24.595991" 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-06-06T03:29:24.594474" elapsed="0.001541"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:24.603371" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:24.603252" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.603229" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:24.604754" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:24.604613" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.604593" elapsed="0.000229"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:24.605299" 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-06-06T03:29:24.604972" elapsed="0.000355"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:24.605732" level="INFO">${current_connection_index} = 7</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-06-06T03:29:24.605494" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:24.649640" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:24.606266" elapsed="0.043514"/>
</kw>
<msg time="2026-06-06T03:29:24.649943" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:24.649989" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:24.605923" elapsed="0.044105"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:24.679601" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:24.650561" elapsed="0.029162"/>
</kw>
<msg time="2026-06-06T03:29:24.679883" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:24.679929" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:29:24.650209" elapsed="0.029758"/>
</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-06-06T03:29:24.680280" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.680046" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.680025" elapsed="0.000334"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.680862" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:24.680507" elapsed="0.000486"/>
</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-06-06T03:29:24.681286" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.681062" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.681043" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:24.681399" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:24.684018" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:29:24.684223" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:24.682911" elapsed="0.001444"/>
</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="NOT RUN" start="2026-06-06T03:29:24.684666" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.685010" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:24.682260" elapsed="0.002937"/>
</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-06-06T03:29:24.681713" elapsed="0.003548"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:24.604297" elapsed="0.081063"/>
</kw>
<msg time="2026-06-06T03:29:24.685452" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:24.685498" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:24.603618" elapsed="0.081919"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:24.685747" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:24.685614" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.685595" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.686254" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.686594" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.686683" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:24.602858" elapsed="0.083934"/>
</kw>
<msg time="2026-06-06T03:29:24.686885" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:24.686929" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:24.596393" elapsed="0.090574"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.687298" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.687041" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.687024" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:24.596246" elapsed="0.091152"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:24.596072" elapsed="0.091360"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:24.593710" elapsed="0.093777"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:24.588503" elapsed="0.099039"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:24.588050" elapsed="0.099536"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:24.585029" elapsed="0.102624"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.688700" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/announce_intra_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/announce_intra_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:24.689084" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:24.688461" elapsed="0.000679"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:24.689522" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.689308" elapsed="0.000241"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.689936" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/withdraw_intra_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/withdraw_intra_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:24.690063" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:24.689746" elapsed="0.000343"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:24.690448" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.690248" elapsed="0.000226"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:24.690777" elapsed="0.003314"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.690545" elapsed="0.003596"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.690527" elapsed="0.003645"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.731366" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:24.730981" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.732186" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:24.731923" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:24.732357" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:24.731566" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.732989" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:24.732585" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.733321" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:24.733473" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:24.733182" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.733922" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.733675" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.734980" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.734719" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.735464" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.735194" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.736183" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:24.735885" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:24.737187" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.736753" elapsed="0.000461"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:24.737268" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:24.737426" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:24.736398" elapsed="0.001053"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.737608" elapsed="0.000266"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:24.735743" elapsed="0.002216"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.738682" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:24.738364" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:24.739628" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.739220" elapsed="0.000451"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:24.739723" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:24.739873" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:24.738898" elapsed="0.001000"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.740053" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:24.738075" elapsed="0.002241"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:24.735545" elapsed="0.004805"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:24.740393" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:24.740562" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:24.734337" elapsed="0.006251"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.734039" elapsed="0.006581"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.740815" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.740659" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.734018" elapsed="0.006874"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.741611" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:24.741039" elapsed="0.000615"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:24.741705" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:24.730342" elapsed="0.011487"/>
</kw>
<msg time="2026-06-06T03:29:24.741885" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:24.717659" elapsed="0.024273"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.754474" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.766935" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.779374" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.779614" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.779812" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.780182" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.780033" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:24.780018" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.780406" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.780603" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.780795" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:24.779989" elapsed="0.000860"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.779889" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.781024" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.781100" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:24.781219" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:24.713401" elapsed="0.067845"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.806009" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:24.805620" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.806775" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:24.806541" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:24.806937" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:24.806205" elapsed="0.000758"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.807523" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:24.807132" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.807890" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:24.808067" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:24.807746" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.808505" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.808260" elapsed="0.000333"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:24.809018" elapsed="0.000076"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.808683" elapsed="0.000450"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.809885" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:24.809317" elapsed="0.000595"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.809160" elapsed="0.000789"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.808660" elapsed="0.001311"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.810586" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:24.810124" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:24.810686" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:24.805007" elapsed="0.005813"/>
</kw>
<msg time="2026-06-06T03:29:24.810877" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:24.792308" elapsed="0.018620"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.823473" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.835932" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.848398" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.848611" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.848815" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.849195" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.849046" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:24.849030" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.849418" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.849592" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.849778" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:24.849000" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.848894" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.850010" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.850121" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:24.850254" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:24.791441" elapsed="0.058841"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.851794" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:24.851486" elapsed="0.000573">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:24.852153" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:24.851130" elapsed="0.001048"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.852497" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.852249" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.853117" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:24.852824" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.852610" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.852230" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.855546" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:24.853353" elapsed="0.002220"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:24.855624" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:29:24.855794" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:24.850620" elapsed="0.005199"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.857373" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.857124" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.857835" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.857578" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.858285" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.858043" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.858739" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.858484" elapsed="0.000298"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:24.859590" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:24.859393" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:24.859966" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:24.859789" elapsed="0.000203"/>
</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-06-06T03:29:24.860142" elapsed="0.000208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.860788" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.860510" elapsed="0.000322"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:24.860917" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:24.861079" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:24.858988" elapsed="0.002116"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:24.874185" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '666', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:29:24.874248" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AQwAAQECAwQBAgoKCgo%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:24.874354" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:24.863472" elapsed="0.010908"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.861175" elapsed="0.013251"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.874608" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.874452" elapsed="0.000250"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.861157" elapsed="0.013566"/>
</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-06-06T03:29:24.878131" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.875765" elapsed="0.002409"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.875525" elapsed="0.002684"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.875505" elapsed="0.002728"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.880824" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.878511" elapsed="0.002360"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.878289" elapsed="0.002617"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.878272" elapsed="0.002658"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.881487" 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-06-06T03:29:24.881101" elapsed="0.000413"/>
</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-06-06T03:29:24.881846" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.881585" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.882393" 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-06-06T03:29:24.882094" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.881927" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.881566" elapsed="0.000909"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.883017" 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-06-06T03:29:24.882653" elapsed="0.000391"/>
</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-06-06T03:29:24.883353" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.883114" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.883913" 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-06-06T03:29:24.883602" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.883435" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.883095" elapsed="0.000900"/>
</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-06-06T03:29:24.884149" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:24.885032" 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-06-06T03:29:24.884746" elapsed="0.000312"/>
</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-06-06T03:29:24.885218" elapsed="0.002324"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:29:24.875087" elapsed="0.012521"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:24.887807" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:24.887697" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.887677" elapsed="0.000218"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:24.888047" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.888118" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:24.890462" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:29:24.856150" elapsed="0.034339"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:24.890561" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:24.890737" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:24.699246" elapsed="0.191516"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.891109" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.890868" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.890850" elapsed="0.000350"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:24.891233" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:24.694510" elapsed="0.196846"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:24.894440" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:24.892292" elapsed="0.002178"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:24.894670" elapsed="0.002324"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:24.897044" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:24.892017" elapsed="0.005155"/>
</kw>
<msg time="2026-06-06T03:29:24.897248" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:24.891531" elapsed="0.005742"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.898149" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:24.898225" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:24.897881" elapsed="0.000368"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.898679" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:24.898756" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:24.898408" elapsed="0.000373"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:24.898941" elapsed="0.000310"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:24.899592" level="INFO">${sum_1} = 933</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:24.899411" elapsed="0.000205"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:24.899968" level="INFO">${sum_2} = 933</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:24.899790" elapsed="0.000203"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:24.900188" elapsed="0.000311"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:24.897493" elapsed="0.003080"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:24.900749" elapsed="0.001864"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.946202" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:24.945812" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.947017" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:24.946764" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:24.947185" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:24.946410" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.947783" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:24.947381" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:24.948121" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:24.948280" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:24.947978" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.948744" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.948468" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.950048" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.949505" elapsed="0.000590"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.950544" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.950263" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.951396" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:24.950977" elapsed="0.000446"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:24.952782" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.952244" elapsed="0.000620"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:24.953003" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:24.953235" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:24.951617" elapsed="0.001643"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.953421" elapsed="0.000434"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:24.950837" elapsed="0.003060"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.954561" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:24.954147" elapsed="0.000440"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:24.955710" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.955212" elapsed="0.000581"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:24.955932" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:24.956153" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:24.954790" elapsed="0.001389"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:24.956335" elapsed="0.000428"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:24.954011" elapsed="0.002845"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:24.950627" elapsed="0.006266"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:24.956937" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:24.957098" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:24.949175" elapsed="0.007948"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.948868" elapsed="0.008287"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.957335" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.957180" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.948843" elapsed="0.008568"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.958155" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:24.957557" elapsed="0.000627"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:24.958233" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:24.945170" elapsed="0.013187"/>
</kw>
<msg time="2026-06-06T03:29:24.958412" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:24.932342" elapsed="0.026118"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.971085" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.983556" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.996091" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.996291" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.996471" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.996890" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:24.996738" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:24.996723" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.997116" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.997287" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.997455" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:24.996690" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.996568" elapsed="0.001005"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:24.997747" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:24.997826" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:24.997947" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:24.927941" elapsed="0.070033"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:24.999092" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:24.998839" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:25.008173" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:25.008220" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:25.008309" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:25.001471" elapsed="0.006864"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.999205" elapsed="0.009170"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.008578" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.008402" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:24.999186" elapsed="0.009499"/>
</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-06-06T03:29:25.012076" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.009706" elapsed="0.002414"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.009461" elapsed="0.002695"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.009442" elapsed="0.002739"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.014785" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.012465" elapsed="0.002367"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.012238" elapsed="0.002629"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.012221" elapsed="0.002671"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.015458" 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-06-06T03:29:25.015072" elapsed="0.000414"/>
</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-06-06T03:29:25.015836" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.015560" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.016401" 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-06-06T03:29:25.016093" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.015921" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.015541" elapsed="0.000946"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.017080" 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-06-06T03:29:25.016712" elapsed="0.000395"/>
</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-06-06T03:29:25.017419" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.017178" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.017984" 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-06-06T03:29:25.017687" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.017502" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.017160" elapsed="0.000968"/>
</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-06-06T03:29:25.018292" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:25.019125" 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-06-06T03:29:25.018832" elapsed="0.000319"/>
</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-06-06T03:29:25.019312" elapsed="0.002380"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:25.009047" elapsed="0.012716"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:25.021815" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:25.024095" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:24.998243" elapsed="0.025879"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:25.024178" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:24.903634" elapsed="0.120669"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:24.903210" elapsed="0.121149"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:24.902836" elapsed="0.121584"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:25.027787" level="INFO">${update} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:25.025469" elapsed="0.002348"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:25.028000" elapsed="0.002135"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:25.030186" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:25.025184" elapsed="0.005133"/>
</kw>
<msg time="2026-06-06T03:29:25.030395" level="INFO">${update} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:25.024609" elapsed="0.005811"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.031294" level="INFO">Length is 128.</msg>
<msg time="2026-06-06T03:29:25.031371" level="INFO">${len_1} = 128</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:25.031027" elapsed="0.000368"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.031828" level="INFO">Length is 128.</msg>
<msg time="2026-06-06T03:29:25.031903" level="INFO">${len_2} = 128</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:25.031552" elapsed="0.000375"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:25.032088" elapsed="0.000308"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:25.032767" level="INFO">${sum_1} = 782</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:25.032569" elapsed="0.000224"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:25.033123" level="INFO">${sum_2} = 782</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:25.032947" elapsed="0.000201"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:25.033303" elapsed="0.000304"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:25.030635" elapsed="0.003051"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.078219" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:25.077685" elapsed="0.000565"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.079120" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.078781" elapsed="0.000414">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:25.079290" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:25.078424" elapsed="0.000891"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.080022" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:25.079486" elapsed="0.000564"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.080358" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:25.080511" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:25.080217" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.080976" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.080727" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.082040" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.081781" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.082526" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.082254" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.083493" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:25.082946" elapsed="0.000573"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:25.084707" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.084215" elapsed="0.000535"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:25.084870" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:25.085095" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:25.083734" elapsed="0.001387"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.085287" elapsed="0.000512"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:25.082805" elapsed="0.003037"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.086603" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:25.086097" elapsed="0.000532"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:25.087941" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.087476" elapsed="0.000507"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:25.088100" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:25.088325" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:25.086837" elapsed="0.001514"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.088511" elapsed="0.000541"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:25.085958" elapsed="0.003137"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:25.082608" elapsed="0.006524"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:25.089175" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:25.089335" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:25.081403" elapsed="0.007958"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.081097" elapsed="0.008296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.089572" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.089418" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.081075" elapsed="0.008591"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.090402" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:25.089818" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:25.090518" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:25.077009" elapsed="0.013656"/>
</kw>
<msg time="2026-06-06T03:29:25.090723" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:25.064114" elapsed="0.026671"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.103550" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.116099" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.128649" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.128858" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.129039" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.129408" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.129257" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:25.129242" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.129634" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.129826" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.129998" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:25.129214" elapsed="0.000901"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.129114" elapsed="0.001032"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.130311" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.130386" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:25.130505" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:25.059616" elapsed="0.070916"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.131747" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.131479" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:25.139141" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:25.139509" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:25.139666" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:29:25.139716" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.133931" elapsed="0.006167">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:25.131859" elapsed="0.008319">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.140374" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.140212" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:25.131841" elapsed="0.008619">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:25.144114" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.141546" elapsed="0.002603">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:25.141321" elapsed="0.002892">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:25.141302" elapsed="0.002943">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.146890" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.144579" elapsed="0.002343">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:25.144317" elapsed="0.002667">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:25.144300" elapsed="0.002715">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.147598" 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-06-06T03:29:25.147209" elapsed="0.000416"/>
</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-06-06T03:29:25.147960" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.147714" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.148526" 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-06-06T03:29:25.148211" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.148043" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.147694" elapsed="0.000916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.149154" 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-06-06T03:29:25.148790" elapsed="0.000391"/>
</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-06-06T03:29:25.149489" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.149249" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.150088" 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-06-06T03:29:25.149789" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.149605" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.149231" elapsed="0.000940"/>
</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-06-06T03:29:25.150325" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:25.151139" 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-06-06T03:29:25.150861" elapsed="0.000304"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:29:25.153580" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.151325" elapsed="0.002288">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:29:25.140874" elapsed="0.012890">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:25.153826" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:25.156183" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:29:25.156212" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:29:25.130870" elapsed="0.025372">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:25.156307" elapsed="0.000025"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.034965" elapsed="0.121509">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:25.034316" elapsed="0.122280"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:25.033915" elapsed="0.122780"/>
</kw>
<arg>intra_as_ipmsi_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:24.688087" elapsed="0.468662"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:24.584502" elapsed="0.572369"/>
</test>
<test id="s1-s16-t5" name="Play_To_Odl_intra_as_ipmsi_ad" line="74">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:25.160207" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:25.159937" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.161498" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:25.161387" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.161368" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.166514" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:25.166408" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.166390" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.167593" 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-06-06T03:29:25.167212" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.168098" 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-06-06T03:29:25.167801" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:25.168169" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:25.168325" 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-06-06T03:29:25.166833" elapsed="0.001517"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:25.173912" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:25.173802" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.173782" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:25.175167" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:25.175060" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.175041" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:25.175699" 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-06-06T03:29:25.175384" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:25.176109" level="INFO">${current_connection_index} = 7</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-06-06T03:29:25.175889" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:25.204779" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:25.176671" elapsed="0.028207"/>
</kw>
<msg time="2026-06-06T03:29:25.205040" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:25.205086" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:25.176300" elapsed="0.028820"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:25.238607" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:25.205637" elapsed="0.033123"/>
</kw>
<msg time="2026-06-06T03:29:25.238950" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:25.238997" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:29:25.205294" elapsed="0.033740"/>
</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-06-06T03:29:25.239419" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.239134" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.239104" elapsed="0.000398"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.240036" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:25.239687" elapsed="0.000423"/>
</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-06-06T03:29:25.240401" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.240178" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.240159" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:25.240546" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:25.243267" elapsed="0.000154"/>
</kw>
<msg time="2026-06-06T03:29:25.243483" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:25.242114" elapsed="0.001503"/>
</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="NOT RUN" start="2026-06-06T03:29:25.243931" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.244330" elapsed="0.000080"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:25.241453" elapsed="0.003088"/>
</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-06-06T03:29:25.240885" elapsed="0.003726"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:25.174748" elapsed="0.069982"/>
</kw>
<msg time="2026-06-06T03:29:25.244828" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:25.244876" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:25.174140" elapsed="0.070774"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:25.245157" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:25.245044" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.245023" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.245672" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.246022" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.246095" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:25.173398" elapsed="0.072807"/>
</kw>
<msg time="2026-06-06T03:29:25.246301" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:25.246346" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:25.168761" elapsed="0.077621"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.246753" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.246461" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.246443" elapsed="0.000392"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:25.168599" elapsed="0.078261"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:25.168403" elapsed="0.078490"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:25.166049" elapsed="0.080898"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:25.161099" elapsed="0.085907"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:25.160659" elapsed="0.086393"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:25.157675" elapsed="0.089431"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.248263" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.247785" elapsed="0.000507"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.248988" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.248466" elapsed="0.000552"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.249578" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.249192" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.249997" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/announce_intra_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/announce_intra_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:25.250157" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:25.249789" elapsed="0.000395"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.250539" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/withdraw_intra_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/withdraw_intra_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:25.250679" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:25.250346" elapsed="0.000362"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:25.250871" elapsed="0.002546"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:25.253632" elapsed="0.001797"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.309270" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:25.308886" elapsed="0.000468"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.310146" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.309892" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:25.310318" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:25.309530" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.310918" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:25.310514" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.311252" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:25.311395" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:25.311111" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.311856" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.311585" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.312955" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.312636" elapsed="0.000366"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.313441" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.313170" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.314270" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:25.313859" elapsed="0.000438"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:25.315518" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.314968" elapsed="0.000650"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:25.315721" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:25.316021" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:25.314490" elapsed="0.001558"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.316209" elapsed="0.000400"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:25.313716" elapsed="0.002949"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.317326" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:25.316919" elapsed="0.000434"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:25.318744" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.318186" elapsed="0.000657"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:25.318921" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:25.319212" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:25.317716" elapsed="0.001523"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:25.319396" elapsed="0.000379"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:25.316780" elapsed="0.003039"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:25.313521" elapsed="0.006332"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:25.319897" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:25.320053" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:25.312274" elapsed="0.007805"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.311976" elapsed="0.008136"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.320325" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.320136" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.311954" elapsed="0.008450"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.321182" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:25.320582" elapsed="0.000629"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:25.321260" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:25.308231" elapsed="0.013153"/>
</kw>
<msg time="2026-06-06T03:29:25.321440" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:25.295486" elapsed="0.026002"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.334078" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.346660" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.359107" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.359307" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.359487" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.360005" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.359725" elapsed="0.000336"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:25.359708" elapsed="0.000377"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.360231" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.360402" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.360591" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:25.359675" elapsed="0.000984"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.359561" elapsed="0.001125"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.360838" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.360913" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:25.361033" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:25.291176" elapsed="0.069917"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.362401" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.362122" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:25.362558" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:25.361774" elapsed="0.000809"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.362924" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.362670" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.363488" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:25.363196" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.363007" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.362635" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.366112" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:25.363742" elapsed="0.002396"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:25.366190" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:25.366343" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:25.361426" elapsed="0.004941"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:25.367602" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.367364" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:25.367776" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:25.367024" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:25.368009" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:25.367873" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:25.367853" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.368246" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.368420" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.368485" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:29:25.370446" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:25.366692" elapsed="0.003780"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.371893" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.371622" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:25.372339" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:25.372097" elapsed="0.000286"/>
</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-06-06T03:29:25.380299" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:25.380478" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:25.380613" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:29:25.374562" elapsed="0.006445">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:25.372450" elapsed="0.008642">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:25.381291" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.381127" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:25.372431" elapsed="0.008952">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:29:25.381798" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.381933" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:25.381895" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:25.381877" elapsed="0.000121"/>
</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-06-06T03:29:25.382147" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.382218" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:29:25.370802" elapsed="0.011523">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.382402" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.267992" elapsed="0.114507">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:25.382796" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:25.382595" elapsed="0.000276"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:25.382577" elapsed="0.000318"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:25.382927" elapsed="0.000015"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:25.261840" elapsed="0.121184">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.440349" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.439898" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.441377" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.441111" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.441554" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.440740" elapsed="0.000838"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.442165" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.441767" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.442528" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:27.442712" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:27.442380" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.443157" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.442905" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.444601" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.444168" elapsed="0.000505"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.445126" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.444845" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.445966" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.445537" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:27.447234" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.446661" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:27.447421" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:27.447745" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:27.446186" elapsed="0.001585"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.447933" elapsed="0.000422"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:27.445394" elapsed="0.003004"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.449072" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.448666" elapsed="0.000432"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:27.450506" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.449958" elapsed="0.000652"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:27.450706" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:27.451005" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:27.449471" elapsed="0.001560"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.451188" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:27.448513" elapsed="0.003085"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:27.445210" elapsed="0.006424"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:27.451695" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:27.451853" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:27.443723" elapsed="0.008379"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.443290" elapsed="0.008849"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.452347" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.452166" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.443262" elapsed="0.009169"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.453266" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:27.452632" elapsed="0.000663"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.453345" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:27.439237" elapsed="0.014234"/>
</kw>
<msg time="2026-06-06T03:29:27.453527" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.426435" elapsed="0.027143"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.466259" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.478713" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.491100" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.491343" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.491538" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.491975" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.491820" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:27.491801" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.492207" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.492425" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.492604" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:27.491761" elapsed="0.000914"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.491623" elapsed="0.001081"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.492857" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.492936" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:27.493087" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:27.422119" elapsed="0.070997"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.494621" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.494331" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.494815" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.493925" elapsed="0.000915"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.495179" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.494912" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.495761" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.495448" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.495262" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.494893" elapsed="0.000952"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.498462" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.496004" elapsed="0.002485"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:27.498543" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:27.498718" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:27.493544" elapsed="0.005199"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.499971" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.499736" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.500127" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.499381" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:27.500394" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:27.500222" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.500203" elapsed="0.000275"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.500627" elapsed="0.000037"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.500825" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.500891" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:27.502809" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:27.499053" elapsed="0.003782"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.504236" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.503982" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.504710" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.504451" elapsed="0.000303"/>
</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-06-06T03:29:27.512740" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:27.513093" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '323'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:27.513240" 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-06-06T03:29:27.506902" elapsed="0.006365"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.504820" elapsed="0.008491"/>
</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-06-06T03:29:27.513498" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.513338" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.504801" elapsed="0.008783"/>
</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-06-06T03:29:27.517230" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.514612" elapsed="0.002675"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.514387" elapsed="0.002939"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.514367" elapsed="0.002985"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.519964" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.517658" elapsed="0.002353"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.517411" elapsed="0.002634"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.517393" elapsed="0.002677"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.520709" 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-06-06T03:29:27.520247" elapsed="0.000489"/>
</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-06-06T03:29:27.521191" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.520825" elapsed="0.000452"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.522027" 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-06-06T03:29:27.521558" elapsed="0.000509"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.521312" elapsed="0.000810"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.520794" elapsed="0.001359"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.522955" 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-06-06T03:29:27.522398" elapsed="0.000596"/>
</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-06-06T03:29:27.523451" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.523098" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.524271" 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-06-06T03:29:27.523837" elapsed="0.000501"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.523571" elapsed="0.000829"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.523071" elapsed="0.001360"/>
</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-06-06T03:29:27.524686" elapsed="0.000521"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:27.525922" 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-06-06T03:29:27.525464" elapsed="0.000497"/>
</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-06-06T03:29:27.526199" elapsed="0.003483"/>
</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-06-06T03:29:27.513963" elapsed="0.015817"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.530043" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:27.529886" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.529857" elapsed="0.000284"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.533965" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:27.530363" elapsed="0.003631"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:27.534046" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:27.534208" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:27.503147" elapsed="0.031087"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.534346" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:27.534504" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:27.398766" elapsed="0.135764"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.573295" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.572788" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.574215" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.573890" elapsed="0.000461">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.574531" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.573518" elapsed="0.001038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.575196" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.574752" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.575557" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:27.575777" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:27.575392" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.576240" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.575969" elapsed="0.000335"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:27.576835" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.576389" elapsed="0.000510"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.577584" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.577080" elapsed="0.000531"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.576928" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.576362" elapsed="0.001324"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.578340" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:27.577840" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.578423" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:27.572108" elapsed="0.006451"/>
</kw>
<msg time="2026-06-06T03:29:27.578616" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.556431" elapsed="0.022306"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.591300" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.603828" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.616339" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.616547" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.616745" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.617145" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.616994" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:27.616979" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.617371" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.617543" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.617728" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:27.616948" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.616833" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.617967" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.618042" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:27.618176" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:27.550016" elapsed="0.068186"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.618384" elapsed="0.002392"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.621999" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.621518" elapsed="0.000510"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.622625" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.622223" elapsed="0.000445"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:27.622832" elapsed="0.000333"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:27.621102" elapsed="0.002123"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.620857" elapsed="0.002401"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.623437" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.623284" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.620838" elapsed="0.002674"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:27.535714" elapsed="0.087847"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:27.534886" elapsed="0.088766"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.534615" elapsed="0.089086"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.534598" elapsed="0.089128"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.623761" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:27.391987" elapsed="0.231905"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:25.255788" elapsed="2.368168"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.673753" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.673360" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.674496" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.674288" elapsed="0.000271">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.674672" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.673950" elapsed="0.000749"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.675258" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.674873" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.675585" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:27.675726" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:27.675450" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.676159" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.675915" elapsed="0.000288"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.677387" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.676928" elapsed="0.000505"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.677904" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.677603" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.678748" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.678330" elapsed="0.000447"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:27.679986" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.679423" elapsed="0.000666"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:27.680166" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:27.680513" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:27.678973" elapsed="0.001568"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.680721" elapsed="0.000395"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:27.678190" elapsed="0.002968"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.681826" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.681409" elapsed="0.000443"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:27.683054" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.682495" elapsed="0.000659"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:27.683231" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:27.683522" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:27.682042" elapsed="0.001506"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.683724" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:27.681271" elapsed="0.002862"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:27.678015" elapsed="0.006152"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:27.684210" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:27.684384" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:27.676583" elapsed="0.007826"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.676270" elapsed="0.008172"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.684620" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.684466" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.676251" elapsed="0.008462"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.685434" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:27.684863" elapsed="0.000600"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.685512" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:27.672732" elapsed="0.012904"/>
</kw>
<msg time="2026-06-06T03:29:27.685708" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.659853" elapsed="0.025904"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.698302" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.710708" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.723216" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.723421" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.723602" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.723986" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.723836" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:27.723820" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.724214" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.724424" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.724598" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:27.723791" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.723690" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.724843" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.724919" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:27.725040" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:27.655557" elapsed="0.069509"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.726320" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.726083" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.726477" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.725738" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.726847" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.726572" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.727406" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.727115" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.726930" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.726553" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.730088" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.727658" elapsed="0.002457"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:27.730167" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:27.730321" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:27.725393" elapsed="0.004953"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.731617" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.731376" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.731837" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.731026" elapsed="0.000836"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:27.732074" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:27.731934" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.731914" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.732345" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.732524" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.732590" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:27.734526" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:27.730684" elapsed="0.003869"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.735976" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.735720" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.736440" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.736181" elapsed="0.000302"/>
</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-06-06T03:29:27.743354" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:27.743503" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '323'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:27.743601" 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-06-06T03:29:27.738620" elapsed="0.005007"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.736549" elapsed="0.007142"/>
</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-06-06T03:29:27.743877" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.743719" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.736531" elapsed="0.007430"/>
</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-06-06T03:29:27.748858" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.745033" elapsed="0.004016"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.744807" elapsed="0.004277"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.744785" elapsed="0.004324"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.751707" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.749395" elapsed="0.002360"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.749165" elapsed="0.002629"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.749148" elapsed="0.002672"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.752413" 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-06-06T03:29:27.752000" elapsed="0.000440"/>
</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-06-06T03:29:27.752780" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.752512" elapsed="0.000355"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.753561" 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-06-06T03:29:27.753136" elapsed="0.000463"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.752901" elapsed="0.000887"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.752493" elapsed="0.001329"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.754578" 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-06-06T03:29:27.754060" elapsed="0.000556"/>
</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-06-06T03:29:27.755090" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.754747" elapsed="0.000423"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.755875" 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-06-06T03:29:27.755437" elapsed="0.000475"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.755204" elapsed="0.000757"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.754720" elapsed="0.001271"/>
</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-06-06T03:29:27.756205" elapsed="0.000532"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:27.757376" 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-06-06T03:29:27.756979" elapsed="0.000434"/>
</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-06-06T03:29:27.757634" elapsed="0.003289"/>
</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-06-06T03:29:27.744355" elapsed="0.016657"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.761260" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:27.761111" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.761084" elapsed="0.000269"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.765302" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:27.761564" elapsed="0.003767"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:27.765384" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:27.765540" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:27.734889" elapsed="0.030677"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.765629" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:29:27.765800" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:27.632884" elapsed="0.132943"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.794332" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.793874" elapsed="0.000487"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.795165" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.794904" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.795460" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.794531" elapsed="0.000954"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.796119" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.795675" elapsed="0.000505"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.796534" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:27.796693" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:27.796371" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.797151" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.796882" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:27.797691" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.797267" elapsed="0.000488"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.798430" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.797933" elapsed="0.000524"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.797780" elapsed="0.000713"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.797248" elapsed="0.001266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.799176" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:27.798682" elapsed="0.000524"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.799256" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:27.793237" elapsed="0.006144"/>
</kw>
<msg time="2026-06-06T03:29:27.799439" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.780376" elapsed="0.019112"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.812104" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.824663" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.837142" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.837341" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.837556" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.837952" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.837804" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:27.837789" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.838177" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.838350" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.838521" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:27.837758" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.837637" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.838768" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.838846" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:27.838980" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:27.777704" elapsed="0.061303"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.839188" elapsed="0.002414"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.842791" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.842361" elapsed="0.000462"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.843378" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.842981" elapsed="0.000425"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:27.843566" elapsed="0.000343"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:27.841946" elapsed="0.002023"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.841700" elapsed="0.002304"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.844183" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.844030" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.841679" elapsed="0.002581"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:27.766968" elapsed="0.077360"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:27.766153" elapsed="0.078252"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.765910" elapsed="0.078541"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.765893" elapsed="0.078582"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.844508" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:27.628501" elapsed="0.216133"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:27.624140" elapsed="0.220570"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.894322" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.893945" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.895075" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.894869" elapsed="0.000270">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.895230" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.894516" elapsed="0.000740"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.895820" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.895421" elapsed="0.000426"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.896144" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:27.896290" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:27.896011" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.896735" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.896476" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.897931" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.897461" elapsed="0.000517"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.898420" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.898145" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.899234" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.898833" elapsed="0.000428"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:27.900469" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.899919" elapsed="0.000649"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:27.900660" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:27.900953" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:27.899453" elapsed="0.001526"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.901135" elapsed="0.000366"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:27.898692" elapsed="0.002852"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.902216" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:27.901815" elapsed="0.000427"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:27.903439" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.902903" elapsed="0.000637"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:27.903616" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:29:27.903934" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:27.902432" elapsed="0.001527"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:27.904115" elapsed="0.000417"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:27.901672" elapsed="0.002902"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:27.898494" elapsed="0.006115"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:27.904668" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:27.904866" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:27.897137" elapsed="0.007755"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.896848" elapsed="0.008076"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.905104" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.904949" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.896827" elapsed="0.008353"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.905909" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:27.905327" elapsed="0.000610"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.905987" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:27.893315" elapsed="0.012794"/>
</kw>
<msg time="2026-06-06T03:29:27.906162" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.880658" elapsed="0.025551"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.918797" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.931243" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.943697" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.943910" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.944095" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.944504" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.944350" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:27.944335" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.944746" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.944921" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.945091" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:27.944304" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.944171" elapsed="0.000999"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.945318" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.945433" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:27.945558" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:27.876385" elapsed="0.069201"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.946896" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.946629" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.947055" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.946273" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.947407" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.947151" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.947973" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:27.947681" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.947490" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.947132" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.950678" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:27.948214" elapsed="0.002492"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:27.950760" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:27.950917" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:27.945932" elapsed="0.005011"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:27.952171" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:27.951939" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:27.952371" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:27.951581" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:27.952611" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:27.952474" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.952455" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.952872" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:27.953047" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.953114" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:27.955034" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:27.951248" elapsed="0.003812"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.956468" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.956199" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.956933" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.956690" elapsed="0.000287"/>
</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-06-06T03:29:27.964097" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:27.964297" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '323'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:27.964401" 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-06-06T03:29:27.959140" elapsed="0.005288"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.957043" elapsed="0.007428"/>
</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-06-06T03:29:27.964694" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.964498" elapsed="0.000264"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.957024" elapsed="0.007759"/>
</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-06-06T03:29:27.968426" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.965837" elapsed="0.002638"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.965581" elapsed="0.002930"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.965563" elapsed="0.002973"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.971129" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:27.968841" elapsed="0.002333"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.968594" elapsed="0.002615"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.968576" elapsed="0.002658"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.971803" 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-06-06T03:29:27.971404" elapsed="0.000427"/>
</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-06-06T03:29:27.972146" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.971902" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.972749" 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-06-06T03:29:27.972431" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.972229" elapsed="0.000592"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.971884" elapsed="0.000971"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.973585" 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-06-06T03:29:27.973083" elapsed="0.000538"/>
</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-06-06T03:29:27.974081" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:27.973744" elapsed="0.000415"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:27.974859" 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-06-06T03:29:27.974426" elapsed="0.000469"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.974194" elapsed="0.000750"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.973717" elapsed="0.001256"/>
</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-06-06T03:29:27.975189" elapsed="0.000501"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:27.976333" 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-06-06T03:29:27.975927" elapsed="0.000443"/>
</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-06-06T03:29:27.976592" elapsed="0.003321"/>
</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-06-06T03:29:27.965154" elapsed="0.014848"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:27.980249" elapsed="0.000063"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:27.980101" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.980074" elapsed="0.000383"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:27.983578" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:27.980691" elapsed="0.002917"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:27.983678" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:27.983837" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:27.955372" elapsed="0.028491"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:27.983926" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:27.984077" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:27.853590" elapsed="0.130512"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.012543" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:28.012044" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.013402" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.013123" elapsed="0.000397">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:28.013720" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:28.012770" elapsed="0.000976"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.014358" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:28.013915" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.014726" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:28.014878" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:28.014550" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.015336" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.015068" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:28.015899" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.015456" elapsed="0.000503"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.016708" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:28.016134" elapsed="0.000602"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.015984" elapsed="0.000789"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.015436" elapsed="0.001359"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.017430" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:28.016946" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:28.017551" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:28.011401" elapsed="0.006305"/>
</kw>
<msg time="2026-06-06T03:29:28.017765" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:27.998520" elapsed="0.019294"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.030370" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.042904" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.055435" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.055637" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.055835" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.056223" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.056074" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:28.056059" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.056478" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.056664" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.056843" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:28.056028" elapsed="0.000868"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.055918" elapsed="0.001005"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.057077" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.057153" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:28.057293" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:27.995849" elapsed="0.061471"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:28.057543" elapsed="0.002376"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:28.061145" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.060703" elapsed="0.000470"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:28.061745" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.061332" elapsed="0.000442"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:28.061937" elapsed="0.000328"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:28.060260" elapsed="0.002064"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.060002" elapsed="0.002356"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.062535" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.062383" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.059982" elapsed="0.002628"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:27.985277" elapsed="0.077399"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:27.984455" elapsed="0.078303"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:27.984185" elapsed="0.078620"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:27.984168" elapsed="0.078664"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:28.062869" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:27.849233" elapsed="0.213766"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:27.844934" elapsed="0.218126"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:28.063229" elapsed="0.003366"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.124428" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:28.123984" elapsed="0.000481"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.125356" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.125022" elapsed="0.000417">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:28.125536" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:28.124673" elapsed="0.000888"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.126148" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:28.125751" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.126489" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:28.126694" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:28.126342" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.127221" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.126966" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.128614" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.128292" elapsed="0.000395"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.129145" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:28.128861" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.129990" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.129557" elapsed="0.000460"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:28.131252" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:28.130693" elapsed="0.000660"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:28.131435" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:28.131758" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:28.130212" elapsed="0.001572"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:28.131948" elapsed="0.000399"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:28.129414" elapsed="0.002976"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.133073" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.132664" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:28.134300" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:28.133760" elapsed="0.000642"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:28.134479" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:28.134789" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:28.133289" elapsed="0.001526"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:28.134972" elapsed="0.000363"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:28.132511" elapsed="0.002866"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:28.129230" elapsed="0.006180"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:28.135454" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:28.135609" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:28.127689" elapsed="0.007945"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.127350" elapsed="0.008333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.135868" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.135709" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.127324" elapsed="0.008621"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.136751" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:28.136094" elapsed="0.000685"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:28.136829" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:28.123337" elapsed="0.013615"/>
</kw>
<msg time="2026-06-06T03:29:28.137007" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:28.110459" elapsed="0.026597"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.149596" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.162031" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.174458" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.174671" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.174856" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.175227" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.175078" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:28.175063" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.175452" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.175624" elapsed="0.000034"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.175812" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:28.175035" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.174932" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.176039" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.176113" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:28.176231" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:28.105904" elapsed="0.070367"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.177545" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.177297" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:28.177723" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:28.176955" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.178071" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.177820" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.178856" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:28.178341" elapsed="0.000542"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.178153" elapsed="0.000768"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.177801" elapsed="0.001142"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.181310" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:28.179103" elapsed="0.002233"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:28.181388" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:28.181578" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:28.176605" elapsed="0.004998"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.182808" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:28.182597" elapsed="0.000264"/>
</kw>
<msg time="2026-06-06T03:29:28.182946" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:28.182258" elapsed="0.000711"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.183175" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:28.183039" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.183021" elapsed="0.000220"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.183551" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:28.183699" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:28.183388" elapsed="0.000337"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:28.184117" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.183885" elapsed="0.000258"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:28.184190" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:28.184359" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:28.181928" elapsed="0.002455"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.185804" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.185533" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.186247" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.186006" elapsed="0.000284"/>
</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-06-06T03:29:28.193028" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:28.193460" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '468'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:29:28.193559" 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-06-06T03:29:28.188445" elapsed="0.005140"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.186356" elapsed="0.007272"/>
</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-06-06T03:29:28.193835" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.193676" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.186337" elapsed="0.007586"/>
</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-06-06T03:29:28.197406" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.194972" elapsed="0.002485"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.194740" elapsed="0.002750"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.194721" elapsed="0.002795"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.200313" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.197852" elapsed="0.002509"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.197571" elapsed="0.002825"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.197554" elapsed="0.002866"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.201084" 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-06-06T03:29:28.200594" elapsed="0.000528"/>
</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-06-06T03:29:28.201557" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.201220" elapsed="0.000416"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.202355" 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-06-06T03:29:28.201934" elapsed="0.000457"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.201699" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.201194" elapsed="0.001276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.203313" 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-06-06T03:29:28.202724" elapsed="0.000634"/>
</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-06-06T03:29:28.203912" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.203474" elapsed="0.000529"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.204852" 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-06-06T03:29:28.204342" elapsed="0.000550"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.204041" elapsed="0.000906"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.203443" elapsed="0.001537"/>
</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-06-06T03:29:28.205228" elapsed="0.000607"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:28.206557" 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-06-06T03:29:28.206117" elapsed="0.000482"/>
</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-06-06T03:29:28.206891" elapsed="0.003085"/>
</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-06-06T03:29:28.194303" elapsed="0.015736"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.210215" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:28.210109" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.210090" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:28.213284" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:29:28.210431" elapsed="0.002882"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:28.213365" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:28.213521" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:28.184718" elapsed="0.028829"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:28.213609" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:28.213780" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:28.078375" elapsed="0.135431"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.242235" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:28.241781" elapsed="0.000520"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.243125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.242849" elapsed="0.000396">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:28.243419" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:28.242475" elapsed="0.000969"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.244080" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:28.243614" elapsed="0.000493"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:28.244452" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:28.244592" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:28.244291" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.245065" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:28.244797" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:28.245584" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.245178" elapsed="0.000482"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.246343" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:28.245840" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:28.245687" elapsed="0.000719"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:28.245158" elapsed="0.001268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.247084" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:28.246578" elapsed="0.000535"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:28.247162" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:28.241146" elapsed="0.006141"/>
</kw>
<msg time="2026-06-06T03:29:28.247341" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:28.228361" elapsed="0.019029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.260682" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.273173" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.285850" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.286086" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.286276" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.286717" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.286543" elapsed="0.000233"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:28.286525" elapsed="0.000283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.286958" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.287141" elapsed="0.000030"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.287350" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:28.286486" elapsed="0.000922"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.286364" elapsed="0.001072"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.287592" elapsed="0.000038"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.287705" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:29:28.287853" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:28.225720" elapsed="0.062162"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:28.288104" elapsed="0.003904"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:28.293129" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.292806" elapsed="0.000351"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:28.293932" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:28.293315" elapsed="0.000646"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:29:28.294506" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "intra-as-i-pmsi-a-d": {
       "orig-route-ip": "10.10.10.10",
       "route-distinguisher": "1.2.3.4:258"
      },
      "path-id": 0,
      "route-key": "AQwAAQECAwQBAgoKCgo="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:29:28.294724" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.294121" elapsed="0.000682">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.292352" elapsed="0.002633">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:28.292088" elapsed="0.002975">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:28.295253" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:28.295097" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:28.292069" elapsed="0.003262">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.214956" elapsed="0.080497">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.214135" elapsed="0.081461">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:28.213891" elapsed="0.081810">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:28.213873" elapsed="0.081864">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:28.295785" elapsed="0.000015"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:28.072885" elapsed="0.223043">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.350890" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.350443" elapsed="0.000483"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.351811" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.351514" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.352023" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.351115" elapsed="0.000940"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.352800" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.352274" elapsed="0.000557"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.353255" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.353463" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.353043" elapsed="0.000450"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.353971" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.353678" elapsed="0.000341"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.355251" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.354905" elapsed="0.000396"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.355837" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.355513" elapsed="0.000355"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.356742" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.356300" elapsed="0.000469"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:30.358152" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.357511" elapsed="0.000746"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:30.358343" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:29:30.358670" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:30.356973" elapsed="0.001740"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.358896" elapsed="0.000422"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:30.356131" elapsed="0.003231"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.360119" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.359617" elapsed="0.000550"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:30.361638" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.360989" elapsed="0.000770"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:30.361845" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:29:30.362170" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:30.360394" elapsed="0.001876"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.362436" elapsed="0.000416"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:30.359478" elapsed="0.003431"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:30.355925" elapsed="0.007031"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:30.363006" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:30.363173" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:30.354489" elapsed="0.008711"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.354103" elapsed="0.009131"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.363432" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.363265" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.354077" elapsed="0.009434"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.364327" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:30.363683" elapsed="0.000674"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.364408" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:30.349757" elapsed="0.014785"/>
</kw>
<msg time="2026-06-06T03:29:30.364602" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.336753" elapsed="0.027952"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.378319" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.391695" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.404691" elapsed="0.000054"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.405034" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.405275" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.405767" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.405572" elapsed="0.000268"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:30.405550" elapsed="0.000319"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.406035" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.406224" elapsed="0.000025"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.406542" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:30.405509" elapsed="0.001094"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.405369" elapsed="0.001263"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.406822" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.406911" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:29:30.407085" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:30.332420" elapsed="0.074694"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.408612" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.408313" elapsed="0.000394">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.408806" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.407887" elapsed="0.000945"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.409266" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.408910" elapsed="0.000422"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.409875" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.409556" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.409357" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.408890" elapsed="0.001074"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.412397" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.410121" elapsed="0.002303"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:30.412479" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:30.412659" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:30.407493" elapsed="0.005193"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.414095" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.413872" elapsed="0.000278"/>
</kw>
<msg time="2026-06-06T03:29:30.414236" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.413465" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.414475" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:30.414332" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.414313" elapsed="0.000230"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.414886" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.415051" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.414715" elapsed="0.000362"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:30.415485" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.415240" elapsed="0.000273"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:30.415562" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:30.415740" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:30.413057" elapsed="0.002710"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.417327" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.417010" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.417866" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.417535" elapsed="0.000377"/>
</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-06-06T03:29:30.425830" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:30.426090" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:29:30.426220" 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-06-06T03:29:30.420465" elapsed="0.005784"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.417981" elapsed="0.008319"/>
</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-06-06T03:29:30.426516" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.426333" elapsed="0.000250"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.417962" elapsed="0.008643"/>
</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-06-06T03:29:30.430706" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.427785" elapsed="0.002996"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.427525" elapsed="0.003308"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.427504" elapsed="0.003370"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.434791" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.431300" elapsed="0.003562"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.430958" elapsed="0.003957"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.430933" elapsed="0.004019"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.435864" 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-06-06T03:29:30.435239" elapsed="0.000665"/>
</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-06-06T03:29:30.436374" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.436009" elapsed="0.000450"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.437219" 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-06-06T03:29:30.436769" elapsed="0.000540"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.436495" elapsed="0.000870"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.435981" elapsed="0.001415"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.438107" 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-06-06T03:29:30.437665" elapsed="0.000469"/>
</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-06-06T03:29:30.438446" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.438205" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.439009" 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-06-06T03:29:30.438712" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.438528" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.438185" elapsed="0.000907"/>
</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-06-06T03:29:30.439260" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:30.440117" 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-06-06T03:29:30.439806" elapsed="0.000337"/>
</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-06-06T03:29:30.440307" elapsed="0.002364"/>
</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-06-06T03:29:30.427050" elapsed="0.015775"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.443026" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:30.442908" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.442885" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:30.445989" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:29:30.443252" elapsed="0.002766"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:30.446071" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:29:30.446243" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:30.416148" elapsed="0.030122"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.446336" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:30.446489" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:30.309417" elapsed="0.137098"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.475886" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.475318" elapsed="0.000605"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.476812" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.476478" elapsed="0.000470">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.477128" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.476116" elapsed="0.001038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.477831" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.477325" elapsed="0.000535"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.478200" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.478366" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.478035" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.478850" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.478557" elapsed="0.000342"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:30.479441" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.478980" elapsed="0.000524"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.480395" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.479702" elapsed="0.000720"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.479533" elapsed="0.000924"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.478954" elapsed="0.001524"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.481148" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:30.480632" elapsed="0.000610"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.481297" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:30.474616" elapsed="0.006836"/>
</kw>
<msg time="2026-06-06T03:29:30.481508" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.461694" elapsed="0.019865"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.494731" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.508957" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.521814" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.522051" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.522240" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.522672" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.522502" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:30.522484" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.522903" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.523076" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.523249" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:30.522447" elapsed="0.000857"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.522327" elapsed="0.001004"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.523481" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.523561" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:30.523721" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:30.458878" elapsed="0.064873"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.524007" elapsed="0.002318"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:30.527450" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.527124" elapsed="0.000355"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:30.527930" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.527638" elapsed="0.000320"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.528120" elapsed="0.000339"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.526680" elapsed="0.001840"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.526406" elapsed="0.002149"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.528751" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.528581" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.526386" elapsed="0.002444"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:30.447773" elapsed="0.081106"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:30.446888" elapsed="0.082070"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.446600" elapsed="0.082405"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.446582" elapsed="0.082448"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.529065" elapsed="0.000032"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:30.304279" elapsed="0.224919"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:28.066834" elapsed="2.462425"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:30.529518" elapsed="0.003191"/>
</kw>
<arg>intra_as_ipmsi_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:25.247360" elapsed="5.285409"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:25.157179" elapsed="5.375712"/>
</test>
<test id="s1-s16-t6" name="Odl_To_Play_inter_as_ipmsi_ad" line="78">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:30.536207" elapsed="0.000224"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:30.535907" elapsed="0.000581"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.537572" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:30.537415" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.537394" elapsed="0.000266"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.545311" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:30.545141" elapsed="0.000244"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.545112" elapsed="0.000308"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.548507" 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-06-06T03:29:30.547482" elapsed="0.001094"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.549793" 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-06-06T03:29:30.549014" elapsed="0.000838"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:30.549963" elapsed="0.000079"/>
</return>
<msg time="2026-06-06T03:29:30.550336" 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-06-06T03:29:30.546348" elapsed="0.004042"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:30.560288" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:30.560169" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.560146" elapsed="0.000213"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:30.561596" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:30.561467" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.561448" elapsed="0.000247"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:30.562162" 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-06-06T03:29:30.561851" elapsed="0.000338"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:30.562578" level="INFO">${current_connection_index} = 7</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-06-06T03:29:30.562358" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:30.590449" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:30.563130" elapsed="0.027420"/>
</kw>
<msg time="2026-06-06T03:29:30.590765" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:30.590813" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:30.562788" elapsed="0.028062"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:30.617576" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "e "r "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:30.591374" elapsed="0.026352"/>
</kw>
<msg time="2026-06-06T03:29:30.617905" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:30.617950" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:29:30.591027" elapsed="0.026961"/>
</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-06-06T03:29:30.618333" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.618077" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.618051" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.618903" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "e "r "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:30.618563" elapsed="0.000414"/>
</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-06-06T03:29:30.619267" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.619043" elapsed="0.000284"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.619025" elapsed="0.000325"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:30.619385" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:30.621994" elapsed="0.000336"/>
</kw>
<msg time="2026-06-06T03:29:30.622394" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.620930" elapsed="0.001601"/>
</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="NOT RUN" start="2026-06-06T03:29:30.622955" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.623303" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:30.620282" elapsed="0.003211"/>
</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-06-06T03:29:30.619722" elapsed="0.003836"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:30.561159" elapsed="0.062519"/>
</kw>
<msg time="2026-06-06T03:29:30.623775" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:30.623821" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:30.560517" elapsed="0.063341"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:30.624096" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:30.623986" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.623966" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.624584" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.624945" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.625017" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:30.559813" elapsed="0.065313"/>
</kw>
<msg time="2026-06-06T03:29:30.625221" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:30.625266" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:30.551459" elapsed="0.073844"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.625635" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.625379" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.625362" elapsed="0.000381"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:30.550958" elapsed="0.074809"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:30.550518" elapsed="0.075281"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:30.544543" elapsed="0.081311"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:30.537121" elapsed="0.088792"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:30.536664" elapsed="0.089298"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:30.533707" elapsed="0.092311"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.626913" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/announce_inter_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/announce_inter_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.627079" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.626706" elapsed="0.000400"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:30.627479" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.627266" elapsed="0.000240"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.627893" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/withdraw_inter_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/withdraw_inter_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.628020" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.627697" elapsed="0.000349"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:30.628405" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.628204" elapsed="0.000227"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:30.628737" elapsed="0.002203"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.628502" elapsed="0.002474"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.628483" elapsed="0.002519"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.665304" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.664927" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.666171" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.665927" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.666348" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.665541" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.666949" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.666543" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.667277" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.667407" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.667143" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.667858" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.667593" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.668877" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.668594" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.669357" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.669087" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.670102" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.669764" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:30.671061" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.670639" elapsed="0.000449"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:30.671137" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:30.671288" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:30.670318" elapsed="0.000994"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.671468" elapsed="0.000266"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:30.669607" elapsed="0.002167"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.672321" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.672026" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:30.673269" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.672869" elapsed="0.000426"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:30.673344" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:30.673493" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:30.672532" elapsed="0.000986"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.673689" elapsed="0.000243"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:30.671890" elapsed="0.002082"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:30.669432" elapsed="0.004575"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:30.674048" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:30.674202" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:30.668269" elapsed="0.005957"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.667970" elapsed="0.006288"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.674437" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.674283" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.667951" elapsed="0.006561"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.675250" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:30.674674" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.675362" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:30.664284" elapsed="0.011202"/>
</kw>
<msg time="2026-06-06T03:29:30.675541" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.651396" elapsed="0.024192"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.688304" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.700885" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.713343" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.713544" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.713741" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.714136" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.713982" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:30.713966" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.714360" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.714533" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.714718" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:30.713937" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.713819" elapsed="0.000980"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.714949" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.715024" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:30.715140" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:30.646936" elapsed="0.068230"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.740237" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.739861" elapsed="0.000404"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.740996" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.740781" elapsed="0.000281">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.741155" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.740430" elapsed="0.000750"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.741748" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.741347" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.742234" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.742373" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AgwAAQECAwQBAgAA+/A=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.741941" elapsed="0.000461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.742826" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AgwAAQECAwQBAgAA+/A=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;inter-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;64496&lt;/source-as&gt;
    &lt;/inter-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.742563" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:30.743239" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.742948" elapsed="0.000349"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.743778" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.743470" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.743322" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.742929" elapsed="0.000935"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.744449" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AgwAAQECAwQBAgAA+/A=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:30.744013" elapsed="0.000466"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.744528" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:30.739229" elapsed="0.005438"/>
</kw>
<msg time="2026-06-06T03:29:30.744725" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.726391" elapsed="0.018382"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.757407" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.769995" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.782455" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.782671" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.782854" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.783219" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.783071" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:30.783057" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.783440" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.783609" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.783796" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:30.783029" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.782929" elapsed="0.000945"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.784021" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.784095" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:30.784224" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AgwAAQECAwQBAgAA+/A=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:30.725489" elapsed="0.058765"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.785539" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.785282" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.785714" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.784936" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.786060" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.785810" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.786666" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.786358" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.786170" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.785791" elapsed="0.000960"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.789101" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.786908" elapsed="0.002219"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:30.789220" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:30.789376" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:30.784588" elapsed="0.004813"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.790951" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.790703" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.791392" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AgwAAQECAwQBAgAA+/A=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;inter-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;64496&lt;/source-as&gt;
    &lt;/inter-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.791154" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.791864" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.791600" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.792302" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.792064" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:30.793171" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:30.792975" elapsed="0.000222"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:30.793526" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:30.793352" elapsed="0.000199"/>
</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-06-06T03:29:30.793719" elapsed="0.000200"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.794366" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.794079" elapsed="0.000331"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:30.794452" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:30.794606" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:30.792547" elapsed="0.002084"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:30.807745" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '690', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AgwAAQECAwQBAgAA+/A=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;inter-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;64496&lt;/source-as&gt;
    &lt;/inter-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:29:30.807841" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AgwAAQECAwQBAgAA%2B%2FA%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:30.807992" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:30.796960" elapsed="0.011072"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.794719" elapsed="0.013384"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.808389" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.808144" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.794701" elapsed="0.013871"/>
</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-06-06T03:29:30.813489" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.810128" elapsed="0.003422"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.809801" elapsed="0.003798"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.809774" elapsed="0.003860"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.817269" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.814056" elapsed="0.003277"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.813735" elapsed="0.003646"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.813711" elapsed="0.003705"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.818255" 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-06-06T03:29:30.817682" elapsed="0.000612"/>
</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-06-06T03:29:30.818757" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.818395" elapsed="0.000445"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.819344" 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-06-06T03:29:30.819043" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.818874" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.818368" elapsed="0.001059"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.819974" 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-06-06T03:29:30.819592" elapsed="0.000409"/>
</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-06-06T03:29:30.820309" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.820070" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.820866" 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-06-06T03:29:30.820552" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.820389" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.820052" elapsed="0.000896"/>
</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-06-06T03:29:30.821106" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:30.821926" 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-06-06T03:29:30.821621" elapsed="0.000331"/>
</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-06-06T03:29:30.822114" elapsed="0.002313"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:29:30.809133" elapsed="0.015356"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:30.824688" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:29:30.824563" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.824544" elapsed="0.000235"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:30.824952" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.825021" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:30.827347" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:29:30.789740" elapsed="0.037733"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.827551" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:30.827730" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:30.635854" elapsed="0.191902"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.828103" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.827860" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.827843" elapsed="0.000389"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.828264" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:30.631275" elapsed="0.197114"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:30.831614" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.829356" elapsed="0.002312"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.831850" elapsed="0.003678"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:30.835601" elapsed="0.000059"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:30.829082" elapsed="0.006719"/>
</kw>
<msg time="2026-06-06T03:29:30.835908" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:30.828577" elapsed="0.007367"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.837166" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:30.837272" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:30.836791" elapsed="0.000515"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.837913" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:30.838020" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:30.837529" elapsed="0.000525"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.838299" elapsed="0.000456"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:30.839239" level="INFO">${sum_1} = 1385</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:30.838986" elapsed="0.000289"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:30.839761" level="INFO">${sum_2} = 1385</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:30.839490" elapsed="0.000307"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.840015" elapsed="0.000430"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:30.836244" elapsed="0.004283"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:30.840761" elapsed="0.001853"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.886314" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:30.885936" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.887125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.886886" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:30.887292" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:30.886529" elapsed="0.000788"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.887887" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:30.887485" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:30.888216" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:30.888359" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:30.888080" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.888848" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.888582" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.890063" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.889576" elapsed="0.000533"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.890594" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.890277" elapsed="0.000344"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.891431" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.891015" elapsed="0.000443"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:30.892564" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.892087" elapsed="0.000575"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:30.892803" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:30.893031" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:30.891667" elapsed="0.001391"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.893215" elapsed="0.000402"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:30.890875" elapsed="0.002801"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.894356" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.893929" elapsed="0.000455"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:30.895468" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.895004" elapsed="0.000547"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:30.895710" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:30.895937" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:30.894572" elapsed="0.001391"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:30.896119" elapsed="0.000395"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:30.893792" elapsed="0.002764"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:30.890696" elapsed="0.005894"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:30.896633" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:29:30.896809" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:30.889255" elapsed="0.007579"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.888961" elapsed="0.007907"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.897046" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.896893" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.888941" elapsed="0.008181"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.897852" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:30.897268" elapsed="0.000612"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.897930" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:30.885299" elapsed="0.012757"/>
</kw>
<msg time="2026-06-06T03:29:30.898112" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:30.872503" elapsed="0.025658"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.910922" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.923496" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.936119" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.936318" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.936501" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.936900" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.936744" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:30.936729" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.937127" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.937299" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.937467" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:30.936698" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.936578" elapsed="0.000967"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.937710" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:30.937787" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:30.937905" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:30.868026" elapsed="0.069906"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.939087" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.938823" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:30.948053" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:30.948099" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:30.948200" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:30.941459" elapsed="0.006767"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.939202" elapsed="0.009065"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:30.948450" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.948294" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.939184" elapsed="0.009385"/>
</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-06-06T03:29:30.953246" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.949908" elapsed="0.003399"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.949571" elapsed="0.003785"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.949544" elapsed="0.003847"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.957068" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:30.953805" elapsed="0.003327"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.953469" elapsed="0.003711"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.953445" elapsed="0.003771"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.958020" 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-06-06T03:29:30.957457" elapsed="0.000601"/>
</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-06-06T03:29:30.958534" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.958157" elapsed="0.000472"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.959211" 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-06-06T03:29:30.958909" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.958684" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.958131" elapsed="0.001162"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.959839" 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-06-06T03:29:30.959459" elapsed="0.000407"/>
</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-06-06T03:29:30.960176" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:30.959937" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.960736" 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-06-06T03:29:30.960423" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.960257" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:30.959918" elapsed="0.000899"/>
</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-06-06T03:29:30.960972" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:30.961782" 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-06-06T03:29:30.961485" elapsed="0.000323"/>
</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-06-06T03:29:30.961972" elapsed="0.002308"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:30.948996" elapsed="0.015348"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:30.964392" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:30.966687" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:30.938196" elapsed="0.028519"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:30.966771" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:30.843730" elapsed="0.123165"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:30.843280" elapsed="0.123669"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:30.842907" elapsed="0.124101"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:30.969994" level="INFO">${update} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:30.967932" elapsed="0.002091"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.970201" elapsed="0.002137"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:30.972390" elapsed="0.000028"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:30.967640" elapsed="0.004872"/>
</kw>
<msg time="2026-06-06T03:29:30.972587" level="INFO">${update} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:30.967178" elapsed="0.005434"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.973518" level="INFO">Length is 128.</msg>
<msg time="2026-06-06T03:29:30.973594" level="INFO">${len_1} = 128</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:30.973256" elapsed="0.000362"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:30.974167" level="INFO">Length is 128.</msg>
<msg time="2026-06-06T03:29:30.974240" level="INFO">${len_2} = 128</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:30.973793" elapsed="0.000471"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.974422" elapsed="0.000360"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:30.975234" level="INFO">${sum_1} = 1234</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:30.974987" elapsed="0.000281"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:30.975754" level="INFO">${sum_2} = 1234</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:30.975484" elapsed="0.000305"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:30.976008" elapsed="0.000429"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:30.972887" elapsed="0.003634"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.022762" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:31.022327" elapsed="0.000464"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.023572" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.023313" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:31.023757" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:31.022966" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.024341" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:31.023952" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.024687" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:31.024837" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:31.024534" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.025266" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.025022" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.026337" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.026071" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.026850" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.026547" elapsed="0.000330"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.027803" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:31.027242" elapsed="0.000588"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:31.028974" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.028503" elapsed="0.000513"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:31.029134" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:31.029354" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:31.028025" elapsed="0.001355"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.029583" elapsed="0.000513"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:31.027104" elapsed="0.003034"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.030940" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:31.030389" elapsed="0.000578"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:31.032247" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.031636" elapsed="0.000652"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:31.032405" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:31.032624" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:31.031156" elapsed="0.001522"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.032838" elapsed="0.000499"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:31.030252" elapsed="0.003128"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:31.026930" elapsed="0.006485"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:31.033457" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:31.033614" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:31.025713" elapsed="0.007926"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:31.025382" elapsed="0.008309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.033870" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.033716" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.025362" elapsed="0.008583"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.034689" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:31.034092" elapsed="0.000627"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:31.034768" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:31.021660" elapsed="0.013237"/>
</kw>
<msg time="2026-06-06T03:29:31.034952" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:31.008567" elapsed="0.026445"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.047788" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.060270" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.072787" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.073024" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.073204" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.073575" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.073424" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:31.073409" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.073819" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.073991" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.074159" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:31.073380" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.073278" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.074387" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.074462" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:31.074581" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:31.004147" elapsed="0.070460"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.075791" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.075520" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:31.083497" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:31.083660" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:31.083797" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:29:31.083839" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.077974" elapsed="0.006245">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:31.075904" elapsed="0.008397">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.084492" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.084334" elapsed="0.000220"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:31.075886" elapsed="0.008692">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:31.088380" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.085636" elapsed="0.002838">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:31.085407" elapsed="0.003193">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:31.085388" elapsed="0.003280">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.092336" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.089091" elapsed="0.003290">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:31.088773" elapsed="0.003695">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:31.088748" elapsed="0.003765">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.093331" 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-06-06T03:29:31.092797" elapsed="0.000572"/>
</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-06-06T03:29:31.093834" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.093470" elapsed="0.000452"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.094614" 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-06-06T03:29:31.094193" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:31.093957" elapsed="0.000765"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.093444" elapsed="0.001309"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.095542" 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-06-06T03:29:31.095017" elapsed="0.000563"/>
</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-06-06T03:29:31.096001" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.095702" elapsed="0.000356"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.096541" 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-06-06T03:29:31.096247" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:31.096082" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.095674" elapsed="0.000949"/>
</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-06-06T03:29:31.096793" elapsed="0.000342"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:31.097582" 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-06-06T03:29:31.097305" elapsed="0.000303"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:29:31.100049" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.097784" elapsed="0.002298">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:29:31.084972" elapsed="0.015243">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:31.100276" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:31.102630" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:29:31.102678" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:29:31.074912" elapsed="0.027797">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:31.102776" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:29:30.978014" elapsed="0.124965">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:30.977410" elapsed="0.125632"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:30.976858" elapsed="0.126281"/>
</kw>
<arg>inter_as_ipmsi_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:30.626311" elapsed="0.476881"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:30.533221" elapsed="0.570091"/>
</test>
<test id="s1-s16-t7" name="Play_To_Odl_inter_as_ipmsi_ad" line="82">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:31.106709" elapsed="0.000229"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:31.106421" elapsed="0.000573"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.108007" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:31.107896" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.107877" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.113032" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:31.112925" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.112908" elapsed="0.000191"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.114100" 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-06-06T03:29:31.113718" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.114585" 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-06-06T03:29:31.114290" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:31.114673" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:31.114831" 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-06-06T03:29:31.113325" elapsed="0.001530"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:31.120691" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:31.120565" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.120545" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:31.121933" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:31.121824" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.121805" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:31.122445" 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-06-06T03:29:31.122148" elapsed="0.000323"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:31.122873" level="INFO">${current_connection_index} = 7</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-06-06T03:29:31.122632" elapsed="0.000288"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:31.153911" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:31.123425" elapsed="0.030621"/>
</kw>
<msg time="2026-06-06T03:29:31.154229" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:31.154276" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:31.123084" elapsed="0.031227"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:31.179257" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "e "r "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:31.155145" elapsed="0.024225"/>
</kw>
<msg time="2026-06-06T03:29:31.179538" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:31.179585" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:29:31.154524" elapsed="0.025097"/>
</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-06-06T03:29:31.179993" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.179733" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.179708" elapsed="0.000367"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.180596" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "e "r "_ "a "s "_ "i "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:31.180282" elapsed="0.000402"/>
</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-06-06T03:29:31.180981" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.180755" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.180735" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:31.181095" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:31.183796" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:29:31.184016" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:31.182627" elapsed="0.001522"/>
</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="NOT RUN" start="2026-06-06T03:29:31.184432" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.184796" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:31.181987" elapsed="0.002994"/>
</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-06-06T03:29:31.181407" elapsed="0.003640"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:31.121496" elapsed="0.063649"/>
</kw>
<msg time="2026-06-06T03:29:31.185236" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:31.185280" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:31.120915" elapsed="0.064402"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:31.185502" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:31.185393" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.185374" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.186010" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.186352" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.186422" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:31.120227" elapsed="0.066301"/>
</kw>
<msg time="2026-06-06T03:29:31.186621" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:31.186692" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:31.115567" elapsed="0.071163"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.187096" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.186807" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.186789" elapsed="0.000386"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:31.115415" elapsed="0.071785"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:31.115239" elapsed="0.071992"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:31.112549" elapsed="0.074737"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:31.107586" elapsed="0.079788"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:31.107151" elapsed="0.080271"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:31.104140" elapsed="0.083336"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.188608" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.188138" elapsed="0.000498"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.189320" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.188863" elapsed="0.000484"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.189922" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.189517" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.190323" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/announce_inter_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/announce_inter_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:31.190480" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:31.190113" elapsed="0.000394"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.190961" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/withdraw_inter_as_ipmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/withdraw_inter_as_ipmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:31.191100" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:31.190767" elapsed="0.000359"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:31.191282" elapsed="0.002320"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:31.193784" elapsed="0.001886"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.245669" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:31.245277" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.246446" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.246211" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:31.246613" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:31.245873" elapsed="0.000764"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.247227" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:31.246824" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.247562" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:31.247714" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:31.247424" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.248149" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.247905" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.249194" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.248912" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.249694" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.249404" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.250479" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:31.250081" elapsed="0.000424"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:31.251791" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.251232" elapsed="0.000659"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:31.251969" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:31.252261" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:31.250716" elapsed="0.001571"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.252444" elapsed="0.000398"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:31.249943" elapsed="0.002942"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.253701" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:31.253132" elapsed="0.000596"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:31.254940" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.254373" elapsed="0.000665"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:31.255115" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:31.255429" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:31.253920" elapsed="0.001535"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:31.255612" elapsed="0.000378"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:31.252996" elapsed="0.003037"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:31.249771" elapsed="0.006297"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:31.256110" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:31.256265" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:31.248559" elapsed="0.007731"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:31.248262" elapsed="0.008060"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.256498" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.256346" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.248242" elapsed="0.008331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.257316" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:31.256739" elapsed="0.000606"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:31.257394" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:31.244656" elapsed="0.012861"/>
</kw>
<msg time="2026-06-06T03:29:31.257570" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:31.231927" elapsed="0.025691"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.270152" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.282562" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.295213" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.295439" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.295620" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.296006" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.295853" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:31.295838" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.296229" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.296401" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.296571" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:31.295809" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.295710" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.296824" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.296899" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:31.297018" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:31.227615" elapsed="0.069430"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.298314" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.298073" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:31.298475" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:31.297726" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.298836" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.298570" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.299414" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:31.299088" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:31.298917" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.298552" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.302011" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:31.299664" elapsed="0.002502"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:31.302218" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:31.302372" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:31.297368" elapsed="0.005029"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:31.303632" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.303397" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:31.303839" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:31.303043" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:31.304069" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:29:31.303933" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:31.303915" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.304301" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.304475" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.304540" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:31.306446" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:31.302717" elapsed="0.003755"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.307908" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.307658" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:31.308351" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:31.308111" 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-06-06T03:29:31.315784" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:31.315960" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:31.316056" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:29:31.310550" elapsed="0.005861">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:31.308458" elapsed="0.008036">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:31.316702" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.316528" elapsed="0.000241"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:31.308440" elapsed="0.008352">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:29:31.317165" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.317296" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:31.317259" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:31.317242" elapsed="0.000118"/>
</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-06-06T03:29:31.317506" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.317576" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:29:31.306795" elapsed="0.010901">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.317808" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.204831" elapsed="0.113081">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:31.318191" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:31.318006" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:31.317989" elapsed="0.000297"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:31.318319" elapsed="0.000014"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:31.200424" elapsed="0.117991">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.375150" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.374740" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.375976" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.375715" elapsed="0.000439">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.376249" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.375360" elapsed="0.000913"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.376855" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.376452" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.377213" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:33.377377" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:33.377067" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.377874" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.377583" elapsed="0.000342"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.379032" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.378710" elapsed="0.000368"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.379513" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.379243" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.380394" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.379938" elapsed="0.000482"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:33.381668" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.381098" elapsed="0.000732"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:33.381915" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:33.382214" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:33.380613" elapsed="0.001628"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.382402" elapsed="0.000403"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:33.379797" elapsed="0.003051"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.384984" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.383109" elapsed="0.001902"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:33.386246" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.385686" elapsed="0.000659"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:33.386424" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:33.386754" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:33.385205" elapsed="0.001576"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.386942" elapsed="0.000369"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:33.382962" elapsed="0.004391"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:33.379593" elapsed="0.007795"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:33.387432" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:33.387599" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:33.378346" elapsed="0.009280"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.378019" elapsed="0.009654"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.387855" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.387700" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.377988" elapsed="0.009944"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.388763" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:33.388110" elapsed="0.000683"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.388843" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:33.374071" elapsed="0.014898"/>
</kw>
<msg time="2026-06-06T03:29:33.389024" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.361003" elapsed="0.028070"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.402182" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.415927" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.428845" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.429085" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.429286" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.429730" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.429548" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:33.429531" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.429966" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.430160" elapsed="0.000030"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.430405" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:33.429494" elapsed="0.000985"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.429367" elapsed="0.001148"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.430722" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.430808" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:33.430956" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:33.356594" elapsed="0.074390"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.432491" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.432139" elapsed="0.000433">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.432685" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.431704" elapsed="0.001008"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.433056" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.432787" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.433637" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.433332" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.433140" elapsed="0.000583"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.432767" elapsed="0.000978"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.486801" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.433905" elapsed="0.052937"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:33.486928" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:29:33.487120" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:33.431327" elapsed="0.055819"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.488688" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.488386" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.488933" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.487928" elapsed="0.001030"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:33.489202" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:33.489036" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.489014" elapsed="0.000274"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.489443" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.489622" elapsed="0.000038"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.489709" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:33.491655" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:33.487522" elapsed="0.004162"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.493132" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.492870" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.493586" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.493340" elapsed="0.000290"/>
</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-06-06T03:29:33.502774" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:33.503128" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '311'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:29:33.503239" 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-06-06T03:29:33.495820" elapsed="0.007446"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.493715" elapsed="0.009595"/>
</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-06-06T03:29:33.503497" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.503337" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.493696" elapsed="0.009888"/>
</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-06-06T03:29:33.508303" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.504743" elapsed="0.003633"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.504490" elapsed="0.003936"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.504468" elapsed="0.003994"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.512100" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.508888" elapsed="0.003277"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.508543" elapsed="0.003670"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.508518" elapsed="0.003731"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.513071" 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-06-06T03:29:33.512542" elapsed="0.000556"/>
</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-06-06T03:29:33.513418" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.513171" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.513990" 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-06-06T03:29:33.513686" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.513501" elapsed="0.000595"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.513152" elapsed="0.000967"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.514670" 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-06-06T03:29:33.514288" elapsed="0.000411"/>
</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-06-06T03:29:33.515016" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.514772" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.515560" 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-06-06T03:29:33.515264" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.515098" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.514753" elapsed="0.000905"/>
</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-06-06T03:29:33.515818" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:33.516663" 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-06-06T03:29:33.516357" 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-06-06T03:29:33.516852" elapsed="0.002307"/>
</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-06-06T03:29:33.503970" elapsed="0.015253"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.519400" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:33.519294" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.519275" elapsed="0.000191"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.522427" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:33.519617" elapsed="0.002839"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:33.522509" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:33.522695" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:33.492006" elapsed="0.030718"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.522787" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:33.522940" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:33.333721" elapsed="0.189249"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.559892" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.559334" elapsed="0.000596"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.560868" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.560507" elapsed="0.000509">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.561204" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.560130" elapsed="0.001099"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.561885" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.561409" elapsed="0.000583"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.562351" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:33.562531" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:33.562176" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.563036" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "inter-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "source-as": 64496
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.562743" elapsed="0.000345"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:33.563616" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.563174" elapsed="0.000526"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.564472" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.563884" elapsed="0.000630"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.563730" elapsed="0.000823"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.563145" elapsed="0.001430"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.565293" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:33.564760" elapsed="0.000563"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.565377" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:33.558611" elapsed="0.006906"/>
</kw>
<msg time="2026-06-06T03:29:33.565576" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.543808" elapsed="0.021818"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.578457" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.591167" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.608738" elapsed="0.000078"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.609246" elapsed="0.000051"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.609788" elapsed="0.000050"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.610717" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.610349" elapsed="0.000496"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:33.610311" elapsed="0.000589"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.611229" elapsed="0.000046"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.611614" elapsed="0.000070"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.612027" elapsed="0.000046"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:33.610237" elapsed="0.001910"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.609977" elapsed="0.002229"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.612592" elapsed="0.000050"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.612801" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:33.613065" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:33.538544" elapsed="0.074550"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.613282" elapsed="0.002437"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.617234" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.616749" elapsed="0.000514"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.617844" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.617423" elapsed="0.000449"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:33.618038" elapsed="0.000359"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:33.616228" elapsed="0.002237"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.615833" elapsed="0.002670"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.618703" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.618531" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.615805" elapsed="0.002977"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:33.524109" elapsed="0.094723"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:33.523295" elapsed="0.095620"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.523053" elapsed="0.095913"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.523035" elapsed="0.095957"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.619029" elapsed="0.000040"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:33.329048" elapsed="0.290128"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:31.195846" elapsed="2.423397"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.669231" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.668855" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.670045" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.669786" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.670219" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.669430" elapsed="0.000814"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.670824" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.670415" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.671158" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:33.671322" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:33.671019" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.671776" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.671513" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.672931" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.672526" elapsed="0.000454"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.673436" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.673153" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.674270" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.673864" elapsed="0.000432"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:33.675538" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.674987" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:33.675735" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:33.676027" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:33.674502" elapsed="0.001552"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.676215" elapsed="0.000389"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:33.673722" elapsed="0.002964"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.677347" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.676946" elapsed="0.000427"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:33.678580" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.678037" elapsed="0.000665"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:33.678779" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:33.679072" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:33.677560" elapsed="0.001538"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.679255" elapsed="0.000358"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:33.676806" elapsed="0.002866"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:33.673516" elapsed="0.006192"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:33.679787" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:33.679947" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:33.672196" elapsed="0.007777"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.671888" elapsed="0.008123"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.680188" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.680035" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.671868" elapsed="0.008395"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.681218" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:33.680407" elapsed="0.000841"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.681300" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:33.668188" elapsed="0.013235"/>
</kw>
<msg time="2026-06-06T03:29:33.681479" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.655429" elapsed="0.026098"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.694282" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.706678" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.719198" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.719396" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.719576" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.719961" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.719812" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:33.719797" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.720187" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.720358" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.720527" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:33.719768" elapsed="0.000811"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.719665" elapsed="0.000939"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.720826" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.720904" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:33.721038" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:33.650926" elapsed="0.070138"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.722329" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.722093" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.722488" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.721746" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.722854" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.722583" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.723416" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.723127" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.722937" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.722564" elapsed="0.000933"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.725894" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.723668" elapsed="0.002252"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:33.725972" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:33.726125" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:33.721395" elapsed="0.004754"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.727378" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.727145" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.727534" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.726806" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:33.727782" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:33.727629" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.727610" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.728025" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.728204" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.728270" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:29:33.730366" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:33.726460" elapsed="0.003933"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.731823" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.731554" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.732270" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.732029" elapsed="0.000285"/>
</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-06-06T03:29:33.741298" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:33.741568" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '311'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:29:33.741796" 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-06-06T03:29:33.734561" elapsed="0.007287"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.732418" elapsed="0.009514"/>
</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-06-06T03:29:33.742208" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.741973" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.732398" elapsed="0.009939"/>
</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-06-06T03:29:33.747524" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.743888" elapsed="0.003708"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.743529" elapsed="0.004138"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.743501" elapsed="0.004206"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.751052" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.748127" elapsed="0.002971"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.747790" elapsed="0.003342"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.747766" elapsed="0.003391"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.751731" 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-06-06T03:29:33.751331" elapsed="0.000427"/>
</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-06-06T03:29:33.752075" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.751829" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.752622" 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-06-06T03:29:33.752324" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.752156" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.751810" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.753265" 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-06-06T03:29:33.752903" elapsed="0.000389"/>
</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-06-06T03:29:33.753603" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.753361" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.754171" 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-06-06T03:29:33.753870" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.753703" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.753343" elapsed="0.000912"/>
</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-06-06T03:29:33.754410" elapsed="0.000370"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:33.755237" 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-06-06T03:29:33.754951" elapsed="0.000312"/>
</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-06-06T03:29:33.755425" elapsed="0.002464"/>
</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-06-06T03:29:33.742907" elapsed="0.015046"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.758177" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:33.758067" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.758046" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.761209" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:33.758398" elapsed="0.002840"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:33.761293" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:33.761455" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:33.730730" elapsed="0.030752"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.761546" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:33.761713" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:33.628343" elapsed="0.133397"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.790189" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.789723" elapsed="0.000495"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.791152" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.790751" elapsed="0.000531">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.791457" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.790387" elapsed="0.001096"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.792121" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.791676" elapsed="0.000472"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.792480" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:33.792655" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:33.792317" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.793138" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "inter-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "source-as": 64496
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.792850" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:33.793681" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.793256" elapsed="0.000487"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.794425" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.793918" elapsed="0.000535"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.793769" elapsed="0.000720"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.793236" elapsed="0.001273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.795172" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:33.794673" elapsed="0.000565"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.795292" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:33.789085" elapsed="0.006336"/>
</kw>
<msg time="2026-06-06T03:29:33.795479" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.776212" elapsed="0.019316"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.808302" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.820823" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.833302" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.833502" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.833696" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.834082" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.833934" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:33.833919" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.834306" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.834479" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.834664" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:33.833889" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.833781" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.834897" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.834973" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:33.835105" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:33.773539" elapsed="0.061593"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.835347" elapsed="0.002215"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.838882" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.838452" elapsed="0.000459"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.839465" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.839071" elapsed="0.000422"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:33.839669" elapsed="0.000329"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:33.837903" elapsed="0.002155"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.837657" elapsed="0.002435"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.840270" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.840117" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.837624" elapsed="0.002721"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:33.762905" elapsed="0.077487"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:33.762078" elapsed="0.078388"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.761824" elapsed="0.078686"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.761806" elapsed="0.078728"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.840568" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:33.623919" elapsed="0.216793"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:33.619492" elapsed="0.221283"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.890354" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.889980" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.891114" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.890904" elapsed="0.000276">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.891273" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.890549" elapsed="0.000749"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.891864" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.891466" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.892194" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:33.892431" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:33.892060" elapsed="0.000399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.892887" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.892621" elapsed="0.000349"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.894005" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.893719" elapsed="0.000331"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.894490" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.894217" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.895299" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.894900" elapsed="0.000425"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:33.896540" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.895997" elapsed="0.000658"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:33.896737" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:33.897032" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:33.895524" elapsed="0.001534"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.897233" elapsed="0.000380"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:33.894760" elapsed="0.002911"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.898327" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:33.897922" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:33.899558" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.899014" elapsed="0.000666"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:33.899760" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:33.900056" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:33.898541" elapsed="0.001542"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:33.900240" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:33.897786" elapsed="0.002879"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:33.894563" elapsed="0.006139"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:33.900746" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:33.900904" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:33.893377" elapsed="0.007552"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.893039" elapsed="0.007922"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.901162" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.900986" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.893020" elapsed="0.008223"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.902153" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:33.901392" elapsed="0.000790"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.902232" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:33.889347" elapsed="0.013010"/>
</kw>
<msg time="2026-06-06T03:29:33.902410" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:33.876628" elapsed="0.025829"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.915010" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.932473" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.944812" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.945012" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.945192" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.945588" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.945439" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:33.945424" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.945833" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.946004" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.946171" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:33.945396" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.945294" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.946397" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.946471" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:33.946590" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:33.872327" elapsed="0.074290"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.947896" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.947657" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.948054" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.947293" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.948401" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.948150" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.948976" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:33.948679" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.948483" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.948130" elapsed="0.000930"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.951409" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:33.949214" elapsed="0.002222"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:33.951521" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:33.951696" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:33.946963" elapsed="0.004759"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:33.952957" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:33.952724" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:33.953114" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:33.952362" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:33.953374" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:33.953210" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.953191" elapsed="0.000268"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.953608" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:33.953802" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.953868" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:33.955967" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:33.952036" elapsed="0.003957"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.957403" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.957140" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.957862" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.957605" elapsed="0.000300"/>
</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-06-06T03:29:33.966119" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:33.966250" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '311'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:29:33.966347" 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-06-06T03:29:33.960036" elapsed="0.006345"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.957971" elapsed="0.008453"/>
</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-06-06T03:29:33.966608" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.966451" elapsed="0.000244"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.957953" elapsed="0.008764"/>
</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-06-06T03:29:33.970454" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.967746" elapsed="0.002781"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.967503" elapsed="0.003075"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.967484" elapsed="0.003130"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.974486" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:33.971056" elapsed="0.003497"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.970720" elapsed="0.003882"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.970693" elapsed="0.003946"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.975459" 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-06-06T03:29:33.974911" elapsed="0.000587"/>
</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-06-06T03:29:33.976039" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.975671" elapsed="0.000452"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.976866" 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-06-06T03:29:33.976405" elapsed="0.000500"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.976159" elapsed="0.000798"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.975622" elapsed="0.001366"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.977977" 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-06-06T03:29:33.977420" elapsed="0.000591"/>
</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-06-06T03:29:33.978325" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:33.978084" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:33.978885" 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-06-06T03:29:33.978571" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.978405" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.978066" elapsed="0.000903"/>
</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-06-06T03:29:33.979124" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:33.979932" 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-06-06T03:29:33.979640" elapsed="0.000318"/>
</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-06-06T03:29:33.980121" elapsed="0.003444"/>
</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-06-06T03:29:33.967087" elapsed="0.016541"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:33.983823" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:33.983717" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.983697" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:33.986842" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:33.984038" elapsed="0.002833"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:33.986924" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:33.987085" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:33.956311" elapsed="0.030800"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:33.987172" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:33.987320" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:33.849588" elapsed="0.137758"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.016068" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:34.015585" elapsed="0.000513"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.016895" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.016609" elapsed="0.000405">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:34.017237" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:34.016269" elapsed="0.000994"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.017949" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:34.017471" elapsed="0.000505"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.018298" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:34.018434" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:34.018142" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.018911" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "inter-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "source-as": 64496
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.018620" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:34.019443" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.019032" elapsed="0.000472"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.020207" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:34.019698" elapsed="0.000536"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.019529" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.019009" elapsed="0.001283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.020941" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:34.020443" elapsed="0.000527"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:34.021019" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:34.014912" elapsed="0.006232"/>
</kw>
<msg time="2026-06-06T03:29:34.021201" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:34.002157" elapsed="0.019091"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.034088" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.046632" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/inter_as_ipmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.059908" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.060175" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.060363" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.060785" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.060613" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:34.060598" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.061016" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.061191" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.061363" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:34.060565" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.060449" elapsed="0.000996"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.061638" elapsed="0.000038"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.061736" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:34.061882" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AgwAAQECAwQBAgAA+/A=",
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:33.999467" elapsed="0.062444"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:34.062095" elapsed="0.002234"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:34.065580" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.065106" elapsed="0.000504"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:34.066205" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.065793" elapsed="0.000442"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:34.066398" elapsed="0.000352"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:34.064678" elapsed="0.002134"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.064411" elapsed="0.002435"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.067026" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.066872" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.064391" elapsed="0.002712"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:33.988475" elapsed="0.078677"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:33.987682" elapsed="0.079549"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:33.987426" elapsed="0.079852"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:33.987409" elapsed="0.079895"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:34.067338" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:33.845261" elapsed="0.222207"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:33.840959" elapsed="0.226610"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:34.067760" elapsed="0.003345"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.125391" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:34.125009" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.126217" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.125975" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:34.126387" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:34.125591" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.126993" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:34.126583" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.127324" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:34.127474" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:34.127188" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.127932" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.127683" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.128981" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.128687" elapsed="0.000339"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.129468" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:34.129194" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.130317" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.129913" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:34.131563" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:34.131013" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:34.131762" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:34.132055" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:34.130537" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:34.132238" elapsed="0.000505"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:34.129769" elapsed="0.003019"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.133448" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.133043" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:34.134712" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:34.134148" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:34.134893" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:34.135182" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:34.133689" elapsed="0.001519"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:34.135366" elapsed="0.000383"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:34.132900" elapsed="0.002927"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:34.129544" elapsed="0.006322"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:34.135909" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:34.136072" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:34.128343" elapsed="0.007755"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.128047" elapsed="0.008084"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.136311" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.136156" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.128028" elapsed="0.008361"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.137298" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:34.136536" elapsed="0.000792"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:34.137379" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:34.124364" elapsed="0.013141"/>
</kw>
<msg time="2026-06-06T03:29:34.137561" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:34.111257" elapsed="0.026351"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.150274" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.162736" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.175182" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.175389" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.175572" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.175957" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.175806" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:34.175791" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.176182" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.176355" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.176526" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:34.175763" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.175662" elapsed="0.000989"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.176812" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.176888" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:34.177005" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:34.106853" elapsed="0.070179"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.178324" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.178087" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:34.178483" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:34.177708" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.178848" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.178581" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.179401" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:34.179110" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.178932" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.178562" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.182009" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:34.179638" elapsed="0.002398"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:34.182087" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:34.182239" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:34.177359" elapsed="0.004905"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.183442" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:34.183258" elapsed="0.000237"/>
</kw>
<msg time="2026-06-06T03:29:34.183578" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:34.182913" elapsed="0.000688"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.183825" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:34.183688" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.183668" elapsed="0.000224"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.184208" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:34.184332" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:34.184043" elapsed="0.000314"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:34.184769" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.184520" elapsed="0.000275"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:34.184842" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:34.184994" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:34.182568" elapsed="0.002452"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.186439" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.186193" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.186945" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.186700" elapsed="0.000289"/>
</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-06-06T03:29:34.196067" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:34.196634" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '456'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}}]} 
 </msg>
<msg time="2026-06-06T03:29:34.196797" 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-06-06T03:29:34.189344" elapsed="0.007490"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.187056" elapsed="0.009839"/>
</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-06-06T03:29:34.197157" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.196932" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.187037" elapsed="0.010240"/>
</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-06-06T03:29:34.202346" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AgwAAQECAwQBAgAA+/A=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":64496}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.198908" elapsed="0.003509"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.198408" elapsed="0.004059"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.198382" elapsed="0.004119"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.206164" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.202921" elapsed="0.003307"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.202579" elapsed="0.003698"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.202556" elapsed="0.003756"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.207099" 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-06-06T03:29:34.206550" elapsed="0.000587"/>
</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-06-06T03:29:34.207578" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.207237" elapsed="0.000442"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.208503" 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-06-06T03:29:34.207949" elapsed="0.000597"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.207714" elapsed="0.000884"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.207211" elapsed="0.001416"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.209396" 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-06-06T03:29:34.208887" elapsed="0.000547"/>
</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-06-06T03:29:34.209929" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.209531" elapsed="0.000480"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.210710" 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-06-06T03:29:34.210278" elapsed="0.000470"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.210044" elapsed="0.000753"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.209505" elapsed="0.001322"/>
</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-06-06T03:29:34.211024" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:34.211833" 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-06-06T03:29:34.211539" elapsed="0.000320"/>
</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-06-06T03:29:34.212056" elapsed="0.002315"/>
</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-06-06T03:29:34.197817" elapsed="0.016618"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.214617" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:34.214508" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.214487" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:34.217682" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:29:34.214850" elapsed="0.002862"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:34.217765" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:34.217955" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:34.185331" elapsed="0.032656"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:34.218050" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:34.218199" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:34.083220" elapsed="0.135005"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.247064" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:34.246607" elapsed="0.000485"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.247879" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.247598" elapsed="0.000397">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:34.248170" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:34.247261" elapsed="0.000934"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.248826" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:34.248365" elapsed="0.000489"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:34.249177" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:34.249306" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:34.249021" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.249779" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:34.249496" elapsed="0.000329"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:34.250325" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.249919" elapsed="0.000467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.251082" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:34.250560" elapsed="0.000549"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:34.250410" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:34.249874" elapsed="0.001293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.251849" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:34.251352" elapsed="0.000526"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:34.251928" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:34.245984" elapsed="0.006069"/>
</kw>
<msg time="2026-06-06T03:29:34.252106" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:34.232952" elapsed="0.019202"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.264710" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.277218" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.289856" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.290084" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.290268" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.290662" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.290499" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:34.290483" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.290889" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.291060" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.291229" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:34.290454" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.290347" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.291467" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.291543" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:34.291679" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:34.230283" elapsed="0.061424"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:34.291930" elapsed="0.002234"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:34.295211" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.294924" elapsed="0.000316"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:34.295986" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:34.295398" elapsed="0.000616"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:29:34.296504" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "inter-as-i-pmsi-a-d": {
       "route-distinguisher": "1.2.3.4:258",
       "source-as": 64496
      },
      "path-id": 0,
      "route-key": "AgwAAQECAwQBAgAA+/A="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:29:34.296719" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.296182" elapsed="0.000608">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.294489" elapsed="0.002448">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:34.294246" elapsed="0.002768">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:34.297211" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:34.297048" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:34.294227" elapsed="0.003062">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.219364" elapsed="0.078047">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.218548" elapsed="0.079041">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:34.218308" elapsed="0.079390">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:34.218290" elapsed="0.079445">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:34.297785" elapsed="0.000016"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:34.077369" elapsed="0.220537">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "inter-as-i-pmsi-a-d": {
+       "route-distinguisher": "1.2.3.4:258",
+       "source-as": 64496
+      },
+      "path-id": 0,
+      "route-key": "AgwAAQECAwQBAgAA+/A="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.356993" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.356550" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.357846" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.357570" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.358020" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.357215" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.358657" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.358217" elapsed="0.000470"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.359000" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.359167" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.358857" elapsed="0.000391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.359687" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.359415" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.360823" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.360495" elapsed="0.000374"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.361308" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.361036" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.362130" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.361727" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:36.363399" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.362850" elapsed="0.000652"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:36.363584" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:36.363903" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:36.362371" elapsed="0.001559"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.364091" elapsed="0.000382"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:36.361563" elapsed="0.002953"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.365190" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.364785" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:36.366459" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.365876" elapsed="0.000683"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:36.366637" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:29:36.366947" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:36.365407" elapsed="0.001567"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.367131" elapsed="0.000365"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:36.364630" elapsed="0.002908"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:36.361388" elapsed="0.006187"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:36.367618" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:29:36.367803" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:36.360157" elapsed="0.007670"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.359813" elapsed="0.008047"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.368039" elapsed="0.000194"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.367885" elapsed="0.000387"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.359789" elapsed="0.008503"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.369097" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:36.368445" elapsed="0.000681"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.369176" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:36.355879" elapsed="0.013422"/>
</kw>
<msg time="2026-06-06T03:29:36.369355" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.343015" elapsed="0.026389"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.381982" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.394631" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.406967" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.407176" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.407357" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.407745" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.407580" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:36.407565" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.407972" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.408144" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.408313" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:36.407536" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.407434" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.408540" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.408616" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:36.408759" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:36.338590" elapsed="0.070199"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.410096" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.409833" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.410258" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.409462" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.410616" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.410363" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.411188" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.410899" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.410716" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.410332" elapsed="0.000941"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.413607" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.411432" elapsed="0.002201"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:36.413696" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:36.413887" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:36.409121" elapsed="0.004792"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.415118" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.414930" elapsed="0.000243"/>
</kw>
<msg time="2026-06-06T03:29:36.415258" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.414570" elapsed="0.000712"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.415489" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:36.415353" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.415334" elapsed="0.000222"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.415892" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.416037" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.415724" elapsed="0.000338"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:36.416457" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.416222" elapsed="0.000260"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:36.416529" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:36.416699" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:36.414220" elapsed="0.002505"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.418293" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.417871" elapsed="0.000468"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.418793" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.418524" elapsed="0.000313"/>
</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-06-06T03:29:36.427964" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:36.428099" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:29:36.428195" 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-06-06T03:29:36.421178" elapsed="0.007044"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.418906" elapsed="0.009360"/>
</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-06-06T03:29:36.428451" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.428293" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.418888" elapsed="0.009648"/>
</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-06-06T03:29:36.431998" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.429565" elapsed="0.002480"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.429339" elapsed="0.002741"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.429320" elapsed="0.002785"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.434703" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.432388" elapsed="0.002361"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.432160" elapsed="0.002624"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.432143" elapsed="0.002666"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.435368" 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-06-06T03:29:36.434984" elapsed="0.000410"/>
</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-06-06T03:29:36.435769" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.435505" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.436322" 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-06-06T03:29:36.436020" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.435853" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.435485" elapsed="0.000919"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.436949" 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-06-06T03:29:36.436568" elapsed="0.000408"/>
</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-06-06T03:29:36.437286" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.437046" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.437842" 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-06-06T03:29:36.437531" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.437368" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.437028" elapsed="0.000897"/>
</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-06-06T03:29:36.438080" elapsed="0.000377"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:36.438933" 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-06-06T03:29:36.438628" elapsed="0.000331"/>
</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-06-06T03:29:36.439118" 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-06-06T03:29:36.428916" elapsed="0.012543"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.441636" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:36.441530" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.441511" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:36.444504" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:29:36.441876" elapsed="0.002657"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:36.444587" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:29:36.444790" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:36.417043" elapsed="0.027775"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.444886" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:36.445051" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:36.314146" elapsed="0.130936"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.473788" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.473286" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.474659" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.474334" elapsed="0.000455">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.475020" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.473988" elapsed="0.001058"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.475676" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.475217" elapsed="0.000488"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.476036" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.476185" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.475874" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.476657" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.476374" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:36.477184" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.476777" elapsed="0.000468"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.477943" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.477421" elapsed="0.000549"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.477270" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.476756" elapsed="0.001272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.478755" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:36.478180" elapsed="0.000604"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.478838" elapsed="0.000038"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:36.472663" elapsed="0.006315"/>
</kw>
<msg time="2026-06-06T03:29:36.479035" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.459979" elapsed="0.019109"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.491948" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.504409" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.517066" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.517344" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.517531" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.517957" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.517803" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:36.517786" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.518187" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.518357" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.518524" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:36.517748" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.517617" elapsed="0.001013"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.518798" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.518875" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:36.519005" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:36.457278" elapsed="0.061755"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.519214" elapsed="0.002240"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:36.522535" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.522231" elapsed="0.000333"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:36.523024" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.522749" elapsed="0.000303"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.523211" elapsed="0.000333"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.521798" elapsed="0.001806"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.521536" elapsed="0.002102"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.523834" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.523680" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.521516" elapsed="0.002393"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:36.446312" elapsed="0.077644"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:36.445442" elapsed="0.078589"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.445176" elapsed="0.078903"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.445156" elapsed="0.078948"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.524138" elapsed="0.000031"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:36.307703" elapsed="0.216567"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:34.071309" elapsed="2.453077"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:36.524616" elapsed="0.003012"/>
</kw>
<arg>inter_as_ipmsi_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:31.187754" elapsed="5.339957"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:31.103669" elapsed="5.424161"/>
</test>
<test id="s1-s16-t8" name="Odl_To_Play_spmsi_ad" line="86">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:36.532361" elapsed="0.000320"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:36.531974" elapsed="0.000786"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.534168" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:36.534010" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.533982" elapsed="0.000282"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.542176" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:36.542066" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.542048" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.543297" 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-06-06T03:29:36.542901" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.543818" 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-06-06T03:29:36.543490" elapsed="0.000355"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:36.543891" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:36.544048" 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-06-06T03:29:36.542476" elapsed="0.001597"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:36.549622" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:36.549513" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.549493" elapsed="0.000219"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:36.551015" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:36.550905" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.550885" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:36.551542" 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-06-06T03:29:36.551238" elapsed="0.000331"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:36.551985" level="INFO">${current_connection_index} = 7</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-06-06T03:29:36.551755" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:36.584817" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:36.552527" elapsed="0.032448"/>
</kw>
<msg time="2026-06-06T03:29:36.585178" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:36.585225" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:36.552179" elapsed="0.033081"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:36.611606" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:36.585932" elapsed="0.025795"/>
</kw>
<msg time="2026-06-06T03:29:36.611890" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:36.611936" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:29:36.585489" elapsed="0.026482"/>
</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-06-06T03:29:36.612305" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.612060" elapsed="0.000369"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.612035" elapsed="0.000421"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.612932" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:36.612605" elapsed="0.000394"/>
</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-06-06T03:29:36.613289" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.613067" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.613048" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:36.613404" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:36.616247" elapsed="0.000154"/>
</kw>
<msg time="2026-06-06T03:29:36.616465" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.615076" elapsed="0.001529"/>
</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="NOT RUN" start="2026-06-06T03:29:36.616915" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.617264" elapsed="0.000254"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:36.614342" elapsed="0.003319"/>
</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-06-06T03:29:36.613737" elapsed="0.003994"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:36.550541" elapsed="0.067292"/>
</kw>
<msg time="2026-06-06T03:29:36.617929" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:36.617973" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:36.549893" elapsed="0.068115"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:36.618198" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:36.618088" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.618069" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.618725" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.619120" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.619193" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:36.549174" elapsed="0.070127"/>
</kw>
<msg time="2026-06-06T03:29:36.619393" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:36.619437" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:36.544445" elapsed="0.075028"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.619834" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.619548" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.619530" elapsed="0.000383"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:36.544297" elapsed="0.075639"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:36.544127" elapsed="0.075841"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:36.541700" elapsed="0.078322"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:36.533584" elapsed="0.086494"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:36.532979" elapsed="0.087145"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:36.528905" elapsed="0.091272"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.621102" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/announce_spmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/announce_spmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.621292" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.620898" elapsed="0.000421"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:36.621709" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.621479" elapsed="0.000258"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.622088" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/withdraw_spmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/withdraw_spmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.622214" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.621898" elapsed="0.000342"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:36.622598" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.622397" elapsed="0.000228"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:36.622944" elapsed="0.002179"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.622712" elapsed="0.002446"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.622694" elapsed="0.002490"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.659597" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.659219" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.660403" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.660157" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.660579" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.659813" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.661179" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.660791" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.661507" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.661638" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.661373" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.662087" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.661843" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.663115" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.662842" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.663609" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.663325" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.664322" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.664024" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:36.665295" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.664884" elapsed="0.000439"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:36.665408" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:36.665564" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:36.664536" elapsed="0.001053"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.665771" elapsed="0.000250"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:36.663883" elapsed="0.002179"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.666611" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.666312" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:36.667601" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.667196" elapsed="0.000432"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:36.667695" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:36.667849" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:36.666846" elapsed="0.001028"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.668030" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:36.666174" elapsed="0.002121"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:36.663704" elapsed="0.004627"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:36.668374" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:36.668530" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:36.662498" elapsed="0.006057"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.662202" elapsed="0.006385"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.668782" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.668612" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.662182" elapsed="0.006677"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.669602" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:36.669008" elapsed="0.000623"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.669697" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:36.658560" elapsed="0.011262"/>
</kw>
<msg time="2026-06-06T03:29:36.669877" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.645624" elapsed="0.024301"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.682721" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.695511" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.708088" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.708391" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.708586" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.709021" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.708864" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:36.708845" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.709253" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.709426" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.709598" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:36.708805" elapsed="0.000861"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.708687" elapsed="0.001007"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.709850" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.709930" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:36.710080" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:36.641321" elapsed="0.068787"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.735236" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.734837" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.736161" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.735899" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.736331" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.735433" elapsed="0.000923"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.736942" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.736527" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.737280" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.737448" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.737136" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.737908" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;s-pmsi-a-d&gt;
      &lt;orig-route-ip&gt;1.0.0.1&lt;/orig-route-ip&gt;
      &lt;multicast-source&gt;10.0.0.10&lt;/multicast-source&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;c-g-address&gt;12.0.0.12&lt;/c-g-address&gt;
    &lt;/s-pmsi-a-d&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.737657" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:36.738379" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.738072" elapsed="0.000367"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.738932" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.738617" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.738465" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.738051" elapsed="0.000988"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.739673" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:36.739196" elapsed="0.000510"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.739758" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:36.734202" elapsed="0.005686"/>
</kw>
<msg time="2026-06-06T03:29:36.739947" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.721354" elapsed="0.018642"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.752733" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.765283" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.777827" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.778039" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.778224" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.778619" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.778468" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:36.778451" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.778867" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.779040" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.779247" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:36.778417" elapsed="0.000888"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.778307" elapsed="0.001027"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.779486" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.779618" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:36.779782" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:36.720444" elapsed="0.059369"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.781186" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.780906" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.781352" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.780511" elapsed="0.000866"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.781726" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.781449" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.782290" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.781995" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.781809" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.781430" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.784766" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.782530" elapsed="0.002263"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:36.784845" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:36.785001" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:36.780161" elapsed="0.004866"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.786571" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.786318" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.787038" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;s-pmsi-a-d&gt;
      &lt;orig-route-ip&gt;1.0.0.1&lt;/orig-route-ip&gt;
      &lt;multicast-source&gt;10.0.0.10&lt;/multicast-source&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;c-g-address&gt;12.0.0.12&lt;/c-g-address&gt;
    &lt;/s-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.786794" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.787522" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.787277" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.787977" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.787736" elapsed="0.000285"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:36.788845" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:36.788631" elapsed="0.000240"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:36.789215" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:36.789039" elapsed="0.000201"/>
</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-06-06T03:29:36.789392" elapsed="0.000210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.790024" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.789777" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:36.790147" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:36.790306" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:36.788224" elapsed="0.002108"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:36.802830" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '752', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;s-pmsi-a-d&gt;
      &lt;orig-route-ip&gt;1.0.0.1&lt;/orig-route-ip&gt;
      &lt;multicast-source&gt;10.0.0.10&lt;/multicast-source&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;c-g-address&gt;12.0.0.12&lt;/c-g-address&gt;
    &lt;/s-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:29:36.802893" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:36.803002" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:36.792697" elapsed="0.010331"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.790402" elapsed="0.012672"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.803301" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.803101" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.790384" elapsed="0.013009"/>
</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-06-06T03:29:36.810358" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.805026" elapsed="0.005430"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.804493" elapsed="0.006043"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.804312" elapsed="0.006281"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.814252" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.811304" elapsed="0.002998"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.810755" elapsed="0.003586"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.810715" elapsed="0.003655"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.815061" 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-06-06T03:29:36.814579" elapsed="0.000514"/>
</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-06-06T03:29:36.815665" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.815197" elapsed="0.000539"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.816319" 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-06-06T03:29:36.815966" elapsed="0.000382"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.815763" elapsed="0.000628"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.815154" elapsed="0.001261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.817045" 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-06-06T03:29:36.816615" elapsed="0.000460"/>
</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-06-06T03:29:36.817448" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.817165" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.818112" 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-06-06T03:29:36.817754" elapsed="0.000396"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.817539" elapsed="0.000650"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.817136" elapsed="0.001077"/>
</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-06-06T03:29:36.818394" elapsed="0.000401"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:36.819435" 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-06-06T03:29:36.819063" elapsed="0.000401"/>
</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-06-06T03:29:36.819678" elapsed="0.002453"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:29:36.803775" elapsed="0.018420"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:36.822377" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:29:36.822269" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.822250" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:36.822620" elapsed="0.000037"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.822706" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:36.825119" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:29:36.785363" elapsed="0.039783"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.825217" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:36.825373" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:36.630030" elapsed="0.195367"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.825766" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.825501" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.825484" elapsed="0.000375"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.825892" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:36.625454" elapsed="0.200562"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:36.829245" level="INFO">${update} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.826959" elapsed="0.002316"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.829455" elapsed="0.002295"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:36.831801" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:36.826681" elapsed="0.005246"/>
</kw>
<msg time="2026-06-06T03:29:36.832003" level="INFO">${update} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:36.826195" elapsed="0.005833"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.832896" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:29:36.832971" level="INFO">${len_1} = 160</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:36.832611" elapsed="0.000384"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.833409" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:29:36.833483" level="INFO">${len_2} = 160</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:36.833156" elapsed="0.000350"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.833680" elapsed="0.000311"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:36.834338" level="INFO">${sum_1} = 1045</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:36.834157" elapsed="0.000206"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:36.834719" level="INFO">${sum_2} = 1045</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:36.834520" elapsed="0.000262"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.834945" elapsed="0.000336"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:36.832245" elapsed="0.003097"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:36.835497" elapsed="0.001934"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.884781" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:36.884390" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.885540" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.885315" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:36.885725" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:36.884976" elapsed="0.000774"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.886303" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:36.885919" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:36.886632" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:36.886792" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:36.886495" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.887223" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.886978" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.888454" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.888145" elapsed="0.000355"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.888965" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.888692" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.889786" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.889357" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:36.890912" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.890425" elapsed="0.000567"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:36.891135" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:36.891380" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:36.890005" elapsed="0.001401"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.891564" elapsed="0.000414"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:36.889218" elapsed="0.002803"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.892701" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.892274" elapsed="0.000454"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:36.893828" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.893338" elapsed="0.000572"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:36.894046" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:36.894266" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:36.892919" elapsed="0.001372"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:36.894488" elapsed="0.000419"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:36.892136" elapsed="0.002814"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:36.889042" elapsed="0.005944"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:36.895030" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:36.895190" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:36.887663" elapsed="0.007552"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.887348" elapsed="0.007900"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.895442" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.895273" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.887328" elapsed="0.008193"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.896255" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:36.895684" elapsed="0.000600"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.896335" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:36.883773" elapsed="0.012687"/>
</kw>
<msg time="2026-06-06T03:29:36.896515" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:36.871119" elapsed="0.025444"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.909292" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.921737" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.934193" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.934403" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.934589" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.934994" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.934842" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:36.934826" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.935221" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.935390" elapsed="0.000033"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.935632" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:36.934793" elapsed="0.000910"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.934684" elapsed="0.001045"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.935883" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:36.935961" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:36.936097" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:36.866807" elapsed="0.069318"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.937287" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.937015" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:36.946306" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:36.946353" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:36.946444" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:36.939736" elapsed="0.006734"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.937403" elapsed="0.009107"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:36.946716" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.946537" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.937384" elapsed="0.009417"/>
</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-06-06T03:29:36.951036" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.947839" elapsed="0.003263"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.947597" elapsed="0.003554"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.947578" elapsed="0.003608"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.954829" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:36.951596" elapsed="0.003298"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.951264" elapsed="0.003679"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.951241" elapsed="0.003737"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.955824" 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-06-06T03:29:36.955229" elapsed="0.000632"/>
</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-06-06T03:29:36.956247" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.955961" elapsed="0.000343"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.956814" 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-06-06T03:29:36.956497" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.956328" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.955934" elapsed="0.000964"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.957429" 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-06-06T03:29:36.957067" elapsed="0.000389"/>
</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-06-06T03:29:36.957782" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:36.957526" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.958323" 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-06-06T03:29:36.958030" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.957865" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:36.957508" elapsed="0.000938"/>
</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-06-06T03:29:36.958603" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:36.959434" 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-06-06T03:29:36.959142" elapsed="0.000332"/>
</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-06-06T03:29:36.959637" elapsed="0.002309"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:36.947160" elapsed="0.014853"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:36.962063" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:36.964368" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:36.936396" elapsed="0.028000"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:36.964452" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:36.838882" elapsed="0.125697"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:36.838265" elapsed="0.126373"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:36.837741" elapsed="0.126977"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:36.968187" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:36.965711" elapsed="0.002506"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.968398" elapsed="0.002110"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:36.970558" elapsed="0.000028"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:36.965411" elapsed="0.005288"/>
</kw>
<msg time="2026-06-06T03:29:36.970777" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:36.964906" elapsed="0.005896"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.971706" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:29:36.971783" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:36.971387" elapsed="0.000420"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:36.972280" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:29:36.972383" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:36.971967" elapsed="0.000449"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.972657" elapsed="0.000432"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:36.973561" level="INFO">${sum_1} = 894</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:36.973313" elapsed="0.000283"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:36.974084" level="INFO">${sum_2} = 894</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:36.973839" elapsed="0.000280"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:36.974334" elapsed="0.000443"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:36.971020" elapsed="0.003840"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.020015" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:37.019626" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.020879" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.020602" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:37.021050" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:37.020209" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.021699" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:37.021252" elapsed="0.000476"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.022053" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:37.022202" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:37.021907" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.022639" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.022391" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.023765" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.023455" elapsed="0.000360"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.024249" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.023981" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.025189" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:37.024655" elapsed="0.000561"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:37.026354" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.025910" elapsed="0.000484"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:37.026511" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:37.026748" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:37.025407" elapsed="0.001368"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.026932" elapsed="0.000489"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:37.024503" elapsed="0.002960"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.028264" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:37.027758" elapsed="0.000532"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:37.029554" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.029118" elapsed="0.000477"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:37.029727" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:37.029947" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:37.028617" elapsed="0.001357"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.030135" elapsed="0.000494"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:37.027577" elapsed="0.003128"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:37.024328" elapsed="0.006414"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:37.030786" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:37.030942" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:37.023102" elapsed="0.007865"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:37.022801" elapsed="0.008198"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.031177" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.031024" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.022781" elapsed="0.008471"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.032004" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:37.031399" elapsed="0.000634"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:37.032126" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:37.018962" elapsed="0.013291"/>
</kw>
<msg time="2026-06-06T03:29:37.032308" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:37.006248" elapsed="0.026120"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.045175" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.057724" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.070164" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.070361" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.070540" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.070927" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.070778" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:37.070764" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.071150" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.071321" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.071490" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:37.070734" elapsed="0.000808"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.070615" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.071747" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.071823" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:37.071939" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:37.001897" elapsed="0.070069"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.073131" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.072880" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:37.079908" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:37.080051" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:37.080183" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:29:37.080225" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.075300" elapsed="0.005293">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:37.073243" elapsed="0.007450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.080887" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.080728" elapsed="0.000221"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:37.073225" elapsed="0.007747">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:37.084773" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.082019" elapsed="0.002802">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:37.081793" elapsed="0.003116">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:37.081774" elapsed="0.003179">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.088592" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.085367" elapsed="0.003271">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:37.085053" elapsed="0.003693">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:37.085028" elapsed="0.003762">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.089579" 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-06-06T03:29:37.089052" elapsed="0.000565"/>
</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-06-06T03:29:37.090082" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.089741" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.090870" 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-06-06T03:29:37.090430" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:37.090197" elapsed="0.000760"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.089714" elapsed="0.001273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.091777" 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-06-06T03:29:37.091215" elapsed="0.000602"/>
</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-06-06T03:29:37.092222" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.091916" elapsed="0.000400"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.092847" 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-06-06T03:29:37.092524" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:37.092348" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.091890" elapsed="0.001040"/>
</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-06-06T03:29:37.093087" elapsed="0.000355"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:37.093906" 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-06-06T03:29:37.093610" elapsed="0.000322"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:29:37.096352" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.094091" elapsed="0.002294">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:29:37.081344" elapsed="0.015175">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:37.096580" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:37.098947" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:29:37.098977" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:29:37.072263" elapsed="0.026744">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:37.099074" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:29:36.976625" elapsed="0.122617">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:36.975764" elapsed="0.123541"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:36.975176" elapsed="0.124188"/>
</kw>
<arg>spmsi_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:36.620470" elapsed="0.478946"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:36.528260" elapsed="0.571274"/>
</test>
<test id="s1-s16-t9" name="Play_To_Odl_spmsi_ad" line="90">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:37.104597" elapsed="0.000228"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:37.104326" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.105883" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:37.105771" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.105751" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.111052" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:37.110943" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.110925" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.112181" 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-06-06T03:29:37.111785" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.112691" 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-06-06T03:29:37.112375" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:37.112764" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:37.112925" 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-06-06T03:29:37.111355" elapsed="0.001595"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:37.118473" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:37.118364" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.118345" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:37.119732" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:37.119600" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.119581" elapsed="0.000232"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:37.120262" 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-06-06T03:29:37.119962" elapsed="0.000326"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:37.120689" level="INFO">${current_connection_index} = 7</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-06-06T03:29:37.120451" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:37.151436" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:37.121217" elapsed="0.030323"/>
</kw>
<msg time="2026-06-06T03:29:37.151742" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:37.151789" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:37.120879" elapsed="0.030944"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:37.175842" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:37.152357" elapsed="0.023617"/>
</kw>
<msg time="2026-06-06T03:29:37.176141" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:37.176188" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:29:37.152015" elapsed="0.024208"/>
</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-06-06T03:29:37.176560" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.176311" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.176286" elapsed="0.000352"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.177131" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "p "m "s "i "_ "a "d "[K"
[?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-06-06T03:29:37.176814" elapsed="0.000385"/>
</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-06-06T03:29:37.177487" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.177266" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.177248" elapsed="0.000316"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:37.177599" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:37.180271" elapsed="0.000144"/>
</kw>
<msg time="2026-06-06T03:29:37.180478" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:37.179113" elapsed="0.001499"/>
</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="NOT RUN" start="2026-06-06T03:29:37.180907" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.181240" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:37.178468" elapsed="0.002955"/>
</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-06-06T03:29:37.177918" elapsed="0.003571"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:37.119301" elapsed="0.062284"/>
</kw>
<msg time="2026-06-06T03:29:37.181698" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:37.181745" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:37.118713" elapsed="0.063067"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:37.182005" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:29:37.181857" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.181838" elapsed="0.000254"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.182492" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.182849" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.182921" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:37.117973" elapsed="0.065055"/>
</kw>
<msg time="2026-06-06T03:29:37.183128" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:37.183173" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:37.113327" elapsed="0.069881"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.183539" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.183284" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.183267" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:37.113178" elapsed="0.070477"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:37.113006" elapsed="0.070684"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:37.110411" elapsed="0.073334"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:37.105464" elapsed="0.078338"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:37.105037" elapsed="0.078814"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:37.100366" elapsed="0.083552"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.185041" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.184556" elapsed="0.000513"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.185716" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.185240" elapsed="0.000505"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.186295" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.185914" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.186703" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/announce_spmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/announce_spmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:37.186864" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:37.186485" elapsed="0.000406"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.187241" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/withdraw_spmsi_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/withdraw_spmsi_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:37.187361" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:37.187052" elapsed="0.000335"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:37.187541" elapsed="0.003070"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:37.190794" elapsed="0.001899"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.244932" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:37.244537" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.245775" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.245517" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:37.245949" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:37.245179" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.246526" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:37.246142" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.246877" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:37.247006" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:37.246740" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.247434" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.247192" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.248495" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.248206" elapsed="0.000334"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.248991" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.248726" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.249804" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:37.249383" elapsed="0.000448"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:37.251051" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.250479" elapsed="0.000679"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:37.251237" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:37.251530" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:37.250024" elapsed="0.001532"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.251733" elapsed="0.000422"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:37.249243" elapsed="0.003023"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.252945" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:37.252521" elapsed="0.000451"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:37.254327" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.253784" elapsed="0.000644"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:37.254514" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:37.254822" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:37.253304" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:37.255006" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:37.252382" elapsed="0.003033"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:37.249069" elapsed="0.006380"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:37.255491" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:37.255662" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:37.247866" elapsed="0.007823"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:37.247547" elapsed="0.008175"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.255901" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.255747" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.247528" elapsed="0.008483"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.256786" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:37.256176" elapsed="0.000639"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:37.256864" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:37.243887" elapsed="0.013099"/>
</kw>
<msg time="2026-06-06T03:29:37.257039" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:37.231155" elapsed="0.025931"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.269674" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.282128" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.294608" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.294823" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.295003" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.295371" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.295221" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:37.295206" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.295594" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.295782" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.295951" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:37.295179" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.295078" elapsed="0.000951"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.296193" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.296272" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:37.296392" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:37.226725" elapsed="0.069693"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.297748" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.297481" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:37.297908" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:37.297135" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.298255" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.298003" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.298826" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:37.298513" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:37.298337" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.297984" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.301445" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:37.299066" elapsed="0.002406"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:37.301524" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:37.301697" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:37.296799" elapsed="0.004924"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:37.302960" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.302716" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:37.303115" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:37.302361" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:37.303343" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:37.303209" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:37.303190" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.303576" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.303768" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.303835" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:37.305772" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:37.302030" elapsed="0.003768"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.307192" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.306944" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:37.307638" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:37.307398" elapsed="0.000301"/>
</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-06-06T03:29:37.314940" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:37.315078" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:37.315240" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:29:37.309888" elapsed="0.005747">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:37.307765" elapsed="0.007974">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:37.315931" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.315773" elapsed="0.000222"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:37.307746" elapsed="0.008272">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:29:37.316431" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.316563" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:37.316526" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:37.316509" elapsed="0.000118"/>
</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-06-06T03:29:37.316787" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.316856" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:29:37.306111" elapsed="0.010851">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.317037" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.203715" elapsed="0.113426">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:37.317525" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:37.317272" elapsed="0.000352"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:37.317249" elapsed="0.000430"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:37.317727" elapsed="0.000021"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:37.197582" elapsed="0.120280">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.374653" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.374237" elapsed="0.000451"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.375553" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.375295" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.375742" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.374947" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.376360" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.375939" elapsed="0.000448"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.376717" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:39.376877" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:39.376556" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.377316" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.377066" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.378406" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.378091" elapsed="0.000361"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.378913" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.378616" elapsed="0.000323"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.379737" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.379314" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:39.381013" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.380435" elapsed="0.000681"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:39.381198" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:39.381502" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:39.379956" elapsed="0.001572"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.381705" elapsed="0.000385"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:39.379171" elapsed="0.002962"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.382810" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.382386" elapsed="0.000451"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:39.384248" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.383659" elapsed="0.000693"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:39.384428" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:39.384749" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:39.383182" elapsed="0.001594"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.384934" elapsed="0.000374"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:39.382249" elapsed="0.003101"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:39.378994" elapsed="0.006392"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:39.385430" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:39.385588" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:39.377761" elapsed="0.007852"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.377439" elapsed="0.008222"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.385844" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.385688" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.377417" elapsed="0.008504"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.386721" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:39.386069" elapsed="0.000682"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.386800" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:39.373594" elapsed="0.013331"/>
</kw>
<msg time="2026-06-06T03:29:39.386979" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.360635" elapsed="0.026392"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.399862" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.412387" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.424826" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.425034" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.425218" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.425606" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.425454" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:39.425437" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.425853" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.426026" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.426202" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:39.425405" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.425299" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.426440" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.426518" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:39.426665" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:39.356285" elapsed="0.070410"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.428080" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.427811" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.428266" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.427424" elapsed="0.000867"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.428622" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.428363" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.429203" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.428906" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.428721" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.428343" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.431827" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.429441" elapsed="0.002413"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:39.431909" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:39.432064" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:39.427076" elapsed="0.005013"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.433357" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.433126" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.433513" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.432785" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:39.433761" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:39.433608" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.433589" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.433995" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.434171" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.434237" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:39.436160" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:39.432432" elapsed="0.003765"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.437600" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.437347" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.438067" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.437823" elapsed="0.000287"/>
</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-06-06T03:29:39.445868" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:39.446254" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '379'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:39.446394" 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-06-06T03:29:39.440299" elapsed="0.006122"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.438177" elapsed="0.008288"/>
</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-06-06T03:29:39.446668" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.446491" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.438158" elapsed="0.008599"/>
</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-06-06T03:29:39.450395" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.447785" elapsed="0.002660"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.447541" elapsed="0.002941"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.447522" elapsed="0.002985"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.453161" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.450813" elapsed="0.002395"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.450565" elapsed="0.002679"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.450547" elapsed="0.002723"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.453846" 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-06-06T03:29:39.453445" elapsed="0.000429"/>
</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-06-06T03:29:39.454192" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.453947" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.454762" 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-06-06T03:29:39.454443" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.454276" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.453928" elapsed="0.000920"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.455377" 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-06-06T03:29:39.455012" elapsed="0.000391"/>
</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-06-06T03:29:39.455729" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.455474" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.456304" 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-06-06T03:29:39.455978" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.455811" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.455455" elapsed="0.000937"/>
</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-06-06T03:29:39.456548" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:39.457374" 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-06-06T03:29:39.457085" elapsed="0.000316"/>
</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-06-06T03:29:39.457561" elapsed="0.002317"/>
</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-06-06T03:29:39.447121" elapsed="0.012822"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.460120" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:39.460014" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.459995" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.463147" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:39.460350" elapsed="0.002826"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:39.463228" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:39.463383" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:39.436509" elapsed="0.026900"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.463519" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:39.463692" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:39.333587" elapsed="0.130132"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.492363" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.491885" elapsed="0.000506"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.493198" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.492930" elapsed="0.000386">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.493494" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.492562" elapsed="0.000957"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.494151" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.493708" elapsed="0.000470"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.494503" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:39.494694" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:39.494345" elapsed="0.000377"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.495152" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "s-pmsi-a-d": {
          "orig-route-ip": "1.0.0.1",
          "multicast-source": "10.0.0.10",
          "route-distinguisher": "1.2.3.4:258",
          "c-g-address": "12.0.0.12"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.494883" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:39.495687" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.495269" elapsed="0.000480"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.496463" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.495924" elapsed="0.000566"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.495774" elapsed="0.000752"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.495249" elapsed="0.001298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.497201" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:39.496715" elapsed="0.000514"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.497279" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:39.491240" elapsed="0.006162"/>
</kw>
<msg time="2026-06-06T03:29:39.497459" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.478364" elapsed="0.019184"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.510272" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.522968" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.535454" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.535666" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.535851" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.536224" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.536075" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:39.536059" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.536477" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.536667" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.536841" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:39.536030" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.535928" elapsed="0.000993"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.537073" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.537148" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:39.537269" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:39.475705" elapsed="0.061591"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.537477" elapsed="0.002368"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.541028" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.540592" elapsed="0.000465"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.541678" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.541250" elapsed="0.000458"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:39.541868" elapsed="0.000328"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:39.540169" elapsed="0.002087"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.539925" elapsed="0.002366"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.542469" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.542316" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.539906" elapsed="0.002640"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:39.464898" elapsed="0.077695"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:39.464047" elapsed="0.078640"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.463804" elapsed="0.078930"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.463786" elapsed="0.078972"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.542791" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:39.328833" elapsed="0.214084"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:37.192867" elapsed="2.350111"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.592686" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.592259" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.593438" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.593227" elapsed="0.000275">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.593595" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.592886" elapsed="0.000733"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.594189" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.593805" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.594513" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:39.594639" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:39.594380" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.595086" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.594843" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.596286" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.595831" elapsed="0.000502"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.596823" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.596517" elapsed="0.000333"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.597673" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.597247" elapsed="0.000454"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:39.598912" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.598350" elapsed="0.000661"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:39.599089" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:39.599378" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:39.597895" elapsed="0.001510"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.599565" elapsed="0.000386"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:39.597108" elapsed="0.002886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.600698" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.600250" elapsed="0.000475"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:39.601938" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.601377" elapsed="0.000691"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:39.602148" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:39.602440" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:39.600921" elapsed="0.001545"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.602624" elapsed="0.000408"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:39.600108" elapsed="0.002965"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:39.596898" elapsed="0.006210"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:39.603151" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:39.603307" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:39.595491" elapsed="0.007842"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.595198" elapsed="0.008167"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.603544" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.603390" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.595179" elapsed="0.008440"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.604339" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:39.603784" elapsed="0.000584"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.604417" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:39.591630" elapsed="0.012926"/>
</kw>
<msg time="2026-06-06T03:29:39.604614" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.578906" elapsed="0.025771"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.617513" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.629883" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.642319" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.642528" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.642728" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.643114" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.642964" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:39.642948" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.643339" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.643509" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.643691" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:39.642915" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.642808" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.643922" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.643997" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:39.644133" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:39.574579" elapsed="0.069581"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.645492" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.645236" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.645671" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.644868" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.646028" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.645770" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.646580" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.646289" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.646110" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.645751" elapsed="0.000930"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.650454" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.646840" elapsed="0.003642"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:39.650536" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:39.650709" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:39.644486" elapsed="0.006249"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.651980" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.651744" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.652216" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.651380" elapsed="0.000861"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:39.652452" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:39.652315" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.652295" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.652718" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.652899" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.652967" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:39.654905" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:39.651046" elapsed="0.003886"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.656343" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.656087" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.656843" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.656554" elapsed="0.000335"/>
</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-06-06T03:29:39.663966" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:39.664103" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '379'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:39.664211" 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-06-06T03:29:39.659046" elapsed="0.005192"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.656963" elapsed="0.007319"/>
</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-06-06T03:29:39.664467" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.664308" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.656944" elapsed="0.007611"/>
</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-06-06T03:29:39.668066" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.665626" elapsed="0.002490"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.665400" elapsed="0.002751"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.665381" elapsed="0.002795"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.670939" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.668461" elapsed="0.002525"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.668233" elapsed="0.002788"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.668216" elapsed="0.002830"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.671602" 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-06-06T03:29:39.671219" elapsed="0.000410"/>
</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-06-06T03:29:39.671969" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.671725" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.672518" 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-06-06T03:29:39.672219" elapsed="0.000359"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.672051" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.671699" elapsed="0.000980"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.673219" 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-06-06T03:29:39.672850" elapsed="0.000396"/>
</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-06-06T03:29:39.673556" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.673317" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.674115" 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-06-06T03:29:39.673821" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.673651" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.673299" elapsed="0.000898"/>
</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-06-06T03:29:39.674352" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:39.675177" 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-06-06T03:29:39.674888" elapsed="0.000315"/>
</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-06-06T03:29:39.675364" elapsed="0.002323"/>
</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-06-06T03:29:39.664972" elapsed="0.012780"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.677931" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:39.677823" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.677804" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.681111" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:39.678149" elapsed="0.002991"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:39.681193" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:39.681351" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:39.655247" elapsed="0.026131"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.681442" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:39.681591" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:39.551838" elapsed="0.129779"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.710146" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.709672" elapsed="0.000503"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.711003" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.710710" elapsed="0.000419">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.711308" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.710344" elapsed="0.000990"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.711976" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.711507" elapsed="0.000547"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.712393" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:39.712564" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:39.712229" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.713070" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "s-pmsi-a-d": {
          "orig-route-ip": "1.0.0.1",
          "multicast-source": "10.0.0.10",
          "route-distinguisher": "1.2.3.4:258",
          "c-g-address": "12.0.0.12"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.712798" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:39.713596" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.713190" elapsed="0.000485"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.714374" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.713856" elapsed="0.000545"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.713701" elapsed="0.000737"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.713171" elapsed="0.001289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.715120" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:39.714612" elapsed="0.000538"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.715201" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:39.709039" elapsed="0.006288"/>
</kw>
<msg time="2026-06-06T03:29:39.715384" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.696054" elapsed="0.019379"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.728081" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.745969" elapsed="0.000110"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.760373" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.760616" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.760962" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.761417" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.761257" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:39.761236" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.761668" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.761846" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.762018" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:39.761190" elapsed="0.000882"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.761059" elapsed="0.001042"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.762255" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.762338" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:29:39.762513" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:39.693383" elapsed="0.069162"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.762757" elapsed="0.002663"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.766745" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.766235" elapsed="0.000539"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.767354" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.766934" elapsed="0.000448"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:39.767542" elapsed="0.000365"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:39.765777" elapsed="0.002190"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.765504" elapsed="0.002497"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.768186" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.768027" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.765484" elapsed="0.002776"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:39.682783" elapsed="0.085529"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:39.681965" elapsed="0.086431"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.681719" elapsed="0.086727"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.681701" elapsed="0.086770"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.768506" elapsed="0.000038"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:39.547464" elapsed="0.221197"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:39.543158" elapsed="0.225569"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.818476" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.818090" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.819301" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.819040" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.819475" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.818694" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.820075" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.819688" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.820406" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:39.820673" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:39.820268" elapsed="0.000433"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.821145" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.820864" elapsed="0.000329"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.822389" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.821900" elapsed="0.000536"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.822910" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.822605" elapsed="0.000332"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.823732" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.823306" elapsed="0.000453"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:39.824998" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.824410" elapsed="0.000690"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:39.825177" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:39.825473" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:39.823952" elapsed="0.001546"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.825672" elapsed="0.000386"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:39.823164" elapsed="0.002936"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.826767" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.826350" elapsed="0.000442"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:39.828001" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.827435" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:39.828184" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:39.828478" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:39.826980" elapsed="0.001524"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:39.828681" elapsed="0.000421"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:39.826213" elapsed="0.002931"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:39.822984" elapsed="0.006195"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:39.829222" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:39.829415" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:39.821556" elapsed="0.007884"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.821260" elapsed="0.008213"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.829669" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.829498" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.821240" elapsed="0.008507"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.830474" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:39.829892" elapsed="0.000611"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.830553" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:39.817447" elapsed="0.013246"/>
</kw>
<msg time="2026-06-06T03:29:39.830751" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.804559" elapsed="0.026240"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.843496" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.855934" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.868315" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.868512" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.868708" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.869097" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.868927" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:39.868912" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.869325" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.869498" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.869682" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:39.868884" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.868784" elapsed="0.000981"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.869915" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.870024" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:39.870147" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:39.800265" elapsed="0.069908"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.871435" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.871202" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.871592" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.870853" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.871958" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.871706" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.872515" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.872225" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.872040" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.871686" elapsed="0.000912"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.875186" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.872769" elapsed="0.002444"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:39.875266" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:39.875419" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:39.870503" elapsed="0.004940"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.876691" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.876444" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.876849" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.876102" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:39.877125" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:39.876945" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.876925" elapsed="0.000287"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.877365" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.877541" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.877607" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:39.879530" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:39.875768" elapsed="0.003788"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.880964" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.880714" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.881427" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.881184" elapsed="0.000287"/>
</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-06-06T03:29:39.889917" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:39.890096" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '379'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:39.890194" 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-06-06T03:29:39.883624" elapsed="0.006597"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.881538" elapsed="0.008891"/>
</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-06-06T03:29:39.890614" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.890455" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.881519" elapsed="0.009199"/>
</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-06-06T03:29:39.894495" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.891763" elapsed="0.002800"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.891519" elapsed="0.003094"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.891500" elapsed="0.003173"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.898300" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.895077" elapsed="0.003287"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.894758" elapsed="0.003654"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.894734" elapsed="0.003713"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.899228" 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-06-06T03:29:39.898702" elapsed="0.000564"/>
</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-06-06T03:29:39.899727" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.899365" elapsed="0.000445"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.900494" 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-06-06T03:29:39.900076" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.899844" elapsed="0.000737"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.899339" elapsed="0.001271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.901407" 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-06-06T03:29:39.900864" elapsed="0.000580"/>
</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-06-06T03:29:39.901901" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.901543" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.902549" 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-06-06T03:29:39.902223" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.902015" elapsed="0.000596"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.901517" elapsed="0.001115"/>
</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-06-06T03:29:39.902815" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:39.903612" 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-06-06T03:29:39.903335" elapsed="0.000303"/>
</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-06-06T03:29:39.903813" elapsed="0.002298"/>
</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-06-06T03:29:39.891091" elapsed="0.015082"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.906348" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:39.906242" elapsed="0.000149"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.906224" elapsed="0.000190"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.909367" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:39.906561" elapsed="0.002867"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:39.909483" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:39.909657" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:39.879883" elapsed="0.029802"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.909748" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:39.909898" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:39.777685" elapsed="0.132238"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.938349" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.937905" elapsed="0.000472"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.939162" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.938908" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:39.939448" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:39.938545" elapsed="0.000929"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.940101" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:39.939660" elapsed="0.000468"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:39.940448" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/spmsi_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:39.940579" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:39.940293" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.941049" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "s-pmsi-a-d": {
          "orig-route-ip": "1.0.0.1",
          "multicast-source": "10.0.0.10",
          "route-distinguisher": "1.2.3.4:258",
          "c-g-address": "12.0.0.12"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:39.940783" elapsed="0.000349"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:39.941613" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.941212" elapsed="0.000478"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.942360" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:39.941866" elapsed="0.000521"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.941716" elapsed="0.000707"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.941192" elapsed="0.001252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:39.943083" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:39.942592" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.943166" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:39.937272" elapsed="0.006017"/>
</kw>
<msg time="2026-06-06T03:29:39.943377" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.924361" elapsed="0.019066"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.955993" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.968442" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/spmsi_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.980895" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.981093" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.981296" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.981679" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.981518" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:39.981503" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.981905" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.982076" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.982244" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:39.981475" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.981374" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.982469" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:39.982544" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:39.982677" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:39.921712" elapsed="0.060994"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:39.982886" elapsed="0.002353"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.986453" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.986033" elapsed="0.000449"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:39.987062" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:39.986657" elapsed="0.000433"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:39.987248" elapsed="0.000319"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:39.985603" elapsed="0.002025"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.985361" elapsed="0.002317"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:39.987858" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:39.987705" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.985341" elapsed="0.002593"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:39.911066" elapsed="0.076916"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:39.910252" elapsed="0.077807"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:39.910006" elapsed="0.078099"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:39.909988" elapsed="0.078142"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:39.988163" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:39.773300" elapsed="0.214988"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:39.768967" elapsed="0.219379"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:39.988513" elapsed="0.002711"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.041098" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:40.040714" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.041893" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.041673" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:40.042061" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:40.041320" elapsed="0.000765"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.042636" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:40.042254" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.042988" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:40.043113" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:40.042852" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.043549" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.043306" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.044814" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.044511" elapsed="0.000349"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.045314" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:40.045028" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.046119" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:40.045718" elapsed="0.000427"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:40.047347" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:40.046808" elapsed="0.000639"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:40.047525" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:40.047832" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:40.046335" elapsed="0.001523"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:40.048017" elapsed="0.000370"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:40.045557" elapsed="0.002873"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.049096" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:40.048694" elapsed="0.000427"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:40.050365" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:40.049817" elapsed="0.000648"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:40.050543" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:40.050855" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:40.049345" elapsed="0.001536"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:40.051038" elapsed="0.000360"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:40.048542" elapsed="0.002899"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:40.045389" elapsed="0.006086"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:40.051518" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:40.051691" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:40.044019" elapsed="0.007699"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.043724" elapsed="0.008027"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.051928" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.051776" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.043704" elapsed="0.008301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.052753" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:40.052154" elapsed="0.000628"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:40.052832" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:40.040035" elapsed="0.012920"/>
</kw>
<msg time="2026-06-06T03:29:40.053009" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:40.026962" elapsed="0.026094"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.065984" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.078420" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.090775" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.090979" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.091159" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.091532" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.091383" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:40.091368" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.091775" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.091947" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.092115" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:40.091338" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.091237" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.092339" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.092414" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:40.092535" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:40.022598" elapsed="0.069963"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.093877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.093609" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:40.094036" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:40.093239" elapsed="0.000821"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.094381" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.094131" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.095160" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:40.094654" elapsed="0.000535"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.094464" elapsed="0.000762"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.094112" elapsed="0.001135"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.097615" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:40.095405" elapsed="0.002250"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:40.097710" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:40.097909" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:40.092901" elapsed="0.005033"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.099122" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:40.098930" elapsed="0.000251"/>
</kw>
<msg time="2026-06-06T03:29:40.099266" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:40.098569" elapsed="0.000722"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.099498" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:40.099361" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.099343" elapsed="0.000221"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.099895" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:40.100030" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:40.099729" elapsed="0.000326"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:40.100443" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:40.100214" elapsed="0.000255"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:40.100516" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:40.100684" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:40.098240" elapsed="0.002469"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.102119" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.101874" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.102558" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.102321" elapsed="0.000280"/>
</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-06-06T03:29:40.110419" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:40.110884" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '524'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:29:40.110985" 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-06-06T03:29:40.104782" elapsed="0.006228"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.102705" elapsed="0.008348"/>
</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-06-06T03:29:40.111242" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.111079" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.102683" elapsed="0.008643"/>
</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-06-06T03:29:40.115063" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"s-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"10.0.0.10","c-g-address":"12.0.0.12","orig-route-ip":"1.0.0.1"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.112345" elapsed="0.002789"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.112120" elapsed="0.003068"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.112102" elapsed="0.003163"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.119135" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.115693" elapsed="0.003507"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.115352" elapsed="0.003896"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.115327" elapsed="0.003956"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.120068" 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-06-06T03:29:40.119521" elapsed="0.000585"/>
</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-06-06T03:29:40.120546" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.120205" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.121334" 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-06-06T03:29:40.120919" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.120683" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.120179" elapsed="0.001269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.122257" 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-06-06T03:29:40.121786" elapsed="0.000497"/>
</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-06-06T03:29:40.122594" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.122353" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.123150" 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-06-06T03:29:40.122859" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.122691" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.122335" elapsed="0.000897"/>
</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-06-06T03:29:40.123384" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:40.124201" 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-06-06T03:29:40.123920" elapsed="0.000306"/>
</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-06-06T03:29:40.124383" elapsed="0.002323"/>
</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-06-06T03:29:40.111701" elapsed="0.015068"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.126945" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:40.126839" elapsed="0.000149"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.126820" elapsed="0.000190"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:40.130009" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:29:40.127163" elapsed="0.002874"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:40.130089" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:40.130243" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:40.101013" elapsed="0.029256"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:40.130331" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:40.130478" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:40.000042" elapsed="0.130462"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.160058" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:40.159592" elapsed="0.000528"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.160918" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.160633" elapsed="0.000401">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:40.161209" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:40.160292" elapsed="0.000942"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.161882" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:40.161404" elapsed="0.000505"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:40.162238" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:40.162366" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:40.162076" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.162839" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:40.162553" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:40.163351" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.162954" elapsed="0.000459"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.164110" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:40.163589" elapsed="0.000548"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:40.163437" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:40.162934" elapsed="0.001260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.164838" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:40.164344" elapsed="0.000523"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:40.164917" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:40.158971" elapsed="0.006071"/>
</kw>
<msg time="2026-06-06T03:29:40.165096" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:40.145056" elapsed="0.020088"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.177671" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.190186" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.202796" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.203002" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.203181" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.203549" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.203401" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:40.203386" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.203789" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.203961" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.204131" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:40.203357" elapsed="0.000827"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.203256" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.204359" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.204433" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:40.204550" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:40.142401" elapsed="0.062176"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:40.204772" elapsed="0.002376"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:40.208194" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:40.207907" elapsed="0.000315"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:40.208980" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:40.208379" elapsed="0.000631"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:29:40.209484" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "path-id": 0,
      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
      "s-pmsi-a-d": {
       "c-g-address": "12.0.0.12",
       "multicast-source": "10.0.0.10",
       "orig-route-ip": "1.0.0.1",
       "route-distinguisher": "1.2.3.4:258"
      }
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:29:40.209705" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.209170" elapsed="0.000647">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.207472" elapsed="0.002496">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:40.207228" elapsed="0.002820">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:40.210240" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:40.210084" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:40.207209" elapsed="0.003111">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.131635" elapsed="0.078810">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:29:40.130844" elapsed="0.079747">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:40.130586" elapsed="0.080113">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:40.130569" elapsed="0.080167">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:40.210818" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:39.995727" elapsed="0.215215">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,34 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "AxYAAQECAwQBAiAKAAAKIAwAAAwBAAAB",
+      "s-pmsi-a-d": {
+       "c-g-address": "12.0.0.12",
+       "multicast-source": "10.0.0.10",
+       "orig-route-ip": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.268006" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.267500" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.268866" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.268591" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.269046" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.268232" elapsed="0.000839"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.269681" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.269272" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.270025" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.270193" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.269879" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.270652" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.270390" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.271831" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.271497" elapsed="0.000381"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.272319" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.272046" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.273154" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.272744" elapsed="0.000477"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.274626" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.274074" elapsed="0.000678"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.274836" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:42.275140" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.273592" elapsed="0.001573"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.275329" elapsed="0.000399"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:42.272574" elapsed="0.003196"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.276433" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.276024" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.277702" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.277119" elapsed="0.000686"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.277950" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:42.278242" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.276664" elapsed="0.001604"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.278425" elapsed="0.000387"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:42.275886" elapsed="0.002969"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.272397" elapsed="0.006494"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.278935" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:42.279093" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:42.271155" elapsed="0.007963"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.270787" elapsed="0.008364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.279336" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.279178" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.270760" elapsed="0.008653"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.280401" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:42.279563" elapsed="0.000868"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.280483" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:42.266740" elapsed="0.013877"/>
</kw>
<msg time="2026-06-06T03:29:42.280691" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.253759" elapsed="0.026985"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.293468" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.306310" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.318949" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.319201" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.319394" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.319838" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.319680" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:42.319660" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.320069" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.320329" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.320504" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:42.319606" elapsed="0.000953"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.319481" elapsed="0.001105"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.320753" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.320834" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:42.320986" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:42.249196" elapsed="0.071818"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.322622" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.322228" elapsed="0.000494">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.322822" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.321810" elapsed="0.001038"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.323195" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.322920" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.323786" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.323470" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.323283" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.322900" elapsed="0.000970"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.326497" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.324026" elapsed="0.002512"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:42.326615" elapsed="0.000071"/>
</return>
<msg time="2026-06-06T03:29:42.326860" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:42.321422" elapsed="0.005472"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.328281" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.328071" elapsed="0.000266"/>
</kw>
<msg time="2026-06-06T03:29:42.328424" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.327713" elapsed="0.000735"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.328685" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:42.328523" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.328502" elapsed="0.000252"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.329072" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.329243" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.328904" elapsed="0.000413"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:42.329755" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.329494" elapsed="0.000288"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:42.329830" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:42.329987" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:42.327329" elapsed="0.002751"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.331525" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.331268" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.331990" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.331746" elapsed="0.000288"/>
</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-06-06T03:29:42.339726" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:42.339872" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:29:42.340000" 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-06-06T03:29:42.334531" elapsed="0.005497"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.332101" elapsed="0.007979"/>
</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-06-06T03:29:42.340336" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.340110" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.332082" elapsed="0.008383"/>
</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-06-06T03:29:42.345946" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.342176" elapsed="0.003847"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.341822" elapsed="0.004254"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.341792" elapsed="0.004323"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.350145" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.346549" elapsed="0.003662"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.346204" elapsed="0.004047"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.346179" elapsed="0.004098"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.350913" 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-06-06T03:29:42.350487" elapsed="0.000454"/>
</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-06-06T03:29:42.351262" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.351013" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.351840" 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-06-06T03:29:42.351518" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.351346" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.350994" elapsed="0.000933"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.352604" 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-06-06T03:29:42.352230" elapsed="0.000402"/>
</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-06-06T03:29:42.352974" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.352731" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.353550" 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-06-06T03:29:42.353223" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.353056" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.352710" elapsed="0.000927"/>
</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-06-06T03:29:42.353823" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:42.354664" 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-06-06T03:29:42.354346" elapsed="0.000346"/>
</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-06-06T03:29:42.354933" elapsed="0.002351"/>
</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-06-06T03:29:42.341076" elapsed="0.016314"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.357581" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:42.357466" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.357446" elapsed="0.000223"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:42.360543" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:29:42.357823" elapsed="0.002749"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:42.360626" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:29:42.360812" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:42.330412" elapsed="0.030427"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.360905" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:42.361058" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:42.226513" elapsed="0.134572"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.390268" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.389754" elapsed="0.000546"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.391163" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.390862" elapsed="0.000429">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.391468" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.390481" elapsed="0.001013"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.392130" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.391687" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.392497" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.392679" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.392332" elapsed="0.000375"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.393142" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.392872" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:42.393765" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.393272" elapsed="0.000560"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.394522" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.394010" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.393859" elapsed="0.000727"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.393246" elapsed="0.001361"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.395345" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:42.394842" elapsed="0.000532"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.395428" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:42.389054" elapsed="0.006509"/>
</kw>
<msg time="2026-06-06T03:29:42.395618" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.376186" elapsed="0.019506"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.408331" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.421065" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.434031" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.434263" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.434453" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.434890" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.434734" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:42.434716" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.435119" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.435292" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.435463" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:42.434675" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.434541" elapsed="0.001003"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.435711" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.435792" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:29:42.435937" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:42.373274" elapsed="0.062692"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.436218" elapsed="0.002328"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:42.439657" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.439328" elapsed="0.000359"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:42.440118" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.439846" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.440308" elapsed="0.000351"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.438890" elapsed="0.001832"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.438626" elapsed="0.002130"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.440935" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.440782" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.438607" elapsed="0.002405"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:42.362298" elapsed="0.078762"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:42.361454" elapsed="0.079684"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.361170" elapsed="0.080016"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.361153" elapsed="0.080058"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.441246" elapsed="0.000032"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:42.219766" elapsed="0.221613"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:39.991404" elapsed="2.450039"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:42.441708" elapsed="0.002496"/>
</kw>
<arg>spmsi_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:37.184175" elapsed="5.260093"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:37.099898" elapsed="5.344512"/>
</test>
<test id="s1-s16-t10" name="Odl_To_Play_leaf_ad" line="94">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:42.447745" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:42.447462" elapsed="0.000549"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.449017" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:42.448905" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.448886" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.454198" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:42.454090" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.454072" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.455270" 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-06-06T03:29:42.454888" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.455775" 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-06-06T03:29:42.455461" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:42.455848" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:42.456057" 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-06-06T03:29:42.454491" elapsed="0.001591"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:42.461761" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:42.461629" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.461609" elapsed="0.000222"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:42.463032" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:42.462924" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.462905" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:42.463558" 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-06-06T03:29:42.463255" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:42.463992" level="INFO">${current_connection_index} = 7</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-06-06T03:29:42.463770" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:42.493507" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:42.464525" elapsed="0.029156"/>
</kw>
<msg time="2026-06-06T03:29:42.493873" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:42.493920" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:42.464184" elapsed="0.029773"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:42.517888" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "e "a "f "_ "a "d "[K"
[?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-06-06T03:29:42.494557" elapsed="0.023477"/>
</kw>
<msg time="2026-06-06T03:29:42.518220" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:42.518265" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:29:42.494165" elapsed="0.024137"/>
</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-06-06T03:29:42.518716" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.518403" elapsed="0.000372"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.518372" elapsed="0.000430"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.519293" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "e "a "f "_ "a "d "[K"
[?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-06-06T03:29:42.518952" elapsed="0.000411"/>
</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-06-06T03:29:42.519677" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.519431" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.519412" elapsed="0.000345"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:42.519795" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:42.522537" elapsed="0.000394"/>
</kw>
<msg time="2026-06-06T03:29:42.522996" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.521377" elapsed="0.001755"/>
</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="NOT RUN" start="2026-06-06T03:29:42.523419" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.523783" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:42.520718" elapsed="0.003253"/>
</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-06-06T03:29:42.520127" elapsed="0.003909"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:42.462593" elapsed="0.061544"/>
</kw>
<msg time="2026-06-06T03:29:42.524288" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:42.524333" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:42.461988" elapsed="0.062383"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:42.524560" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:29:42.524450" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.524430" elapsed="0.000236"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.525089" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.525434" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.525505" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:42.461271" elapsed="0.064356"/>
</kw>
<msg time="2026-06-06T03:29:42.525739" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:42.525784" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:42.456460" elapsed="0.069362"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.526158" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.525899" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.525881" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:42.456313" elapsed="0.069953"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:42.456135" elapsed="0.070164"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:42.453727" elapsed="0.072628"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:42.448599" elapsed="0.077813"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:42.448166" elapsed="0.078293"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:42.445256" elapsed="0.081258"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.527417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/announce_leaf_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/announce_leaf_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.527592" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.527209" elapsed="0.000410"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:42.528021" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.527807" elapsed="0.000242"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.528404" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/withdraw_leaf_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/withdraw_leaf_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.528544" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.528213" elapsed="0.000358"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:42.528948" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.528746" elapsed="0.000228"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:42.529302" elapsed="0.001977"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.529044" elapsed="0.002272"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.529027" elapsed="0.002315"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.565993" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.565537" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.566845" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.566555" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.567018" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.566207" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.567607" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.567216" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.567964" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.568132" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.567820" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.568563" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.568320" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.569654" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.569382" elapsed="0.000346"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.570170" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.569896" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.570880" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.570561" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.571904" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.571414" elapsed="0.000517"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.571985" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:42.572145" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.571094" elapsed="0.001077"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.572330" elapsed="0.000241"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:42.570420" elapsed="0.002191"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.573181" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.572882" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.574153" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.573746" elapsed="0.000434"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.574232" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:42.574384" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.573396" elapsed="0.001013"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.574564" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:42.572745" elapsed="0.002100"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.570247" elapsed="0.004633"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.574922" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:42.575079" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:42.569047" elapsed="0.006057"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.568708" elapsed="0.006428"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.575315" elapsed="0.000065"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.575162" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.568681" elapsed="0.006757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.576373" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:42.575588" elapsed="0.000814"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.576452" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:42.564871" elapsed="0.011705"/>
</kw>
<msg time="2026-06-06T03:29:42.576631" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.551986" elapsed="0.024717"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.589219" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.601691" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.614148" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.614356" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.614537" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.614928" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.614778" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:42.614763" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.615153" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.615325" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.615495" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:42.614734" elapsed="0.000814"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.614613" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.615740" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.615817" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:42.615940" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:42.547279" elapsed="0.068724"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.640907" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.640514" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.641679" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.641438" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.641877" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.641103" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.642453" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.642071" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.642798" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.642951" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BBICDAABAQIDBAECAAAAAQEAAAE=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ip...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.642659" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.643391" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BBICDAABAQIDBAECAAAAAQEAAAE=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;leaf-a-d&gt;
      &lt;orig-route-ip&gt;1.0.0.1&lt;/orig-route-ip&gt;
      &lt;inter-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;1&lt;/source-as&gt;
      &lt;/inter-as-i-pmsi-a-d&gt;
    &lt;/leaf-a-d&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.643142" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:42.643829" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.643514" elapsed="0.000374"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.644362" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.644064" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.643914" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.643495" elapsed="0.000948"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.645051" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BBICDAABAQIDBAECAAAAAQEAAAE=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ip...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:42.644592" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.645132" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:42.639899" elapsed="0.005357"/>
</kw>
<msg time="2026-06-06T03:29:42.645313" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.627163" elapsed="0.018197"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.658078" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.670505" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.682960" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.683161" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.683343" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.683732" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.683567" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:42.683553" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.683957" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.684126" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.684291" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:42.683523" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.683419" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.684517" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.684591" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:42.684734" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BBICDAABAQIDBAECAAAAAQEAAAE=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ip...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:42.626286" elapsed="0.058478"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.686070" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.685799" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.686228" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.685434" elapsed="0.000819"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.686574" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.686322" elapsed="0.000366"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.687197" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.686903" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.686714" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.686303" elapsed="0.000977"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.689625" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.687436" elapsed="0.002231"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:42.689719" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:42.689872" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:42.685101" elapsed="0.004821"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.691446" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.691200" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.691901" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BBICDAABAQIDBAECAAAAAQEAAAE=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;leaf-a-d&gt;
      &lt;orig-route-ip&gt;1.0.0.1&lt;/orig-route-ip&gt;
      &lt;inter-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;1&lt;/source-as&gt;
      &lt;/inter-as-i-pmsi-a-d&gt;
    &lt;/leaf-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.691663" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.692350" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.692109" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.692802" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.692546" elapsed="0.000300"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:42.693670" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:42.693456" elapsed="0.000241"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:42.694047" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:42.693856" elapsed="0.000217"/>
</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-06-06T03:29:42.694225" elapsed="0.000204"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.694869" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.694607" elapsed="0.000306"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:42.694956" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:42.695110" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:42.693047" elapsed="0.002088"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:42.708969" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '740', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BBICDAABAQIDBAECAAAAAQEAAAE=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;leaf-a-d&gt;
      &lt;orig-route-ip&gt;1.0.0.1&lt;/orig-route-ip&gt;
      &lt;inter-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;1&lt;/source-as&gt;
      &lt;/inter-as-i-pmsi-a-d&gt;
    &lt;/leaf-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:29:42.709034" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=BBICDAABAQIDBAECAAAAAQEAAAE%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:42.709173" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:42.698626" elapsed="0.010574"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.695204" elapsed="0.014047"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.709479" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.709277" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.695186" elapsed="0.014384"/>
</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-06-06T03:29:42.713005" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.710627" elapsed="0.002422"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.710403" elapsed="0.002681"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.710384" elapsed="0.002726"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.715703" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.713390" elapsed="0.002359"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.713166" elapsed="0.002617"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.713149" elapsed="0.002659"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.716390" 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-06-06T03:29:42.715987" elapsed="0.000430"/>
</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-06-06T03:29:42.716748" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.716487" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.717299" 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-06-06T03:29:42.717000" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.716833" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.716469" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.717938" 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-06-06T03:29:42.717545" elapsed="0.000421"/>
</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-06-06T03:29:42.718281" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.718036" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.718853" 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-06-06T03:29:42.718525" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.718362" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.718017" elapsed="0.000917"/>
</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-06-06T03:29:42.719088" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:42.719909" 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-06-06T03:29:42.719601" 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-06-06T03:29:42.720096" elapsed="0.002343"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:29:42.709965" elapsed="0.012538"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:42.722706" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:29:42.722576" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.722556" elapsed="0.000242"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:42.722953" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.723020" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:42.725307" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:29:42.690251" elapsed="0.035083"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.725405" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:42.725558" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:42.536177" elapsed="0.189455"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.726018" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.725759" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.725740" elapsed="0.000371"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.726144" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:42.531618" elapsed="0.194653"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:42.729627" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.727206" elapsed="0.002482"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.729871" elapsed="0.002319"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:42.732248" elapsed="0.000030"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:42.726931" elapsed="0.005445"/>
</kw>
<msg time="2026-06-06T03:29:42.732453" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:42.726445" elapsed="0.006033"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.733365" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:29:42.733440" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:42.733088" elapsed="0.000377"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.733908" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:29:42.733998" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:42.733622" elapsed="0.000402"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.734185" elapsed="0.000316"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:42.734867" level="INFO">${sum_1} = 937</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:42.734681" elapsed="0.000213"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:42.735226" level="INFO">${sum_2} = 937</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:42.735048" elapsed="0.000203"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.735408" elapsed="0.000320"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:42.732715" elapsed="0.003074"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:42.735943" elapsed="0.002080"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.782274" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.781799" elapsed="0.000511"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.783156" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.782879" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.783335" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.782501" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.783944" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.783535" elapsed="0.000532"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.784388" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.784554" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.784241" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.785009" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.784759" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.786469" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.786139" elapsed="0.000375"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.787006" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.786725" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.787861" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.787420" elapsed="0.000467"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.789015" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.788504" elapsed="0.000591"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.789237" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:29:42.789478" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.788083" elapsed="0.001420"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.789681" elapsed="0.000431"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:42.787279" elapsed="0.002875"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.790852" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.790407" elapsed="0.000472"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.791988" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.791491" elapsed="0.000577"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.792206" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:42.792425" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.791069" elapsed="0.001382"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.792610" elapsed="0.000413"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:42.790269" elapsed="0.002796"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.787089" elapsed="0.006013"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.793146" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:42.793304" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:42.785522" elapsed="0.007807"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.785141" elapsed="0.008221"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.793548" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.793389" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.785113" elapsed="0.008510"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.794444" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:42.793791" elapsed="0.000682"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.794523" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:42.781021" elapsed="0.013658"/>
</kw>
<msg time="2026-06-06T03:29:42.794800" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.768053" elapsed="0.026804"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.807817" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.820499" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.833177" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.833419" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.833616" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.834084" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.833920" elapsed="0.000413"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:42.833901" elapsed="0.000475"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.834573" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.834768" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.834941" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:42.833857" elapsed="0.001137"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.833727" elapsed="0.001295"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.835176" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.835256" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:29:42.835438" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:42.763504" elapsed="0.071964"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.836773" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.836431" elapsed="0.000395"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:42.846336" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:42.846453" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:42.846549" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:42.839280" elapsed="0.007295"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.836893" elapsed="0.009723"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.846825" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.846664" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.836875" elapsed="0.010034"/>
</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-06-06T03:29:42.850349" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.847940" elapsed="0.002453"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.847711" elapsed="0.002717"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.847692" elapsed="0.002762"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.853795" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.850755" elapsed="0.003106"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.850511" elapsed="0.003398"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.850494" elapsed="0.003451"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.854791" 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-06-06T03:29:42.854214" elapsed="0.000616"/>
</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-06-06T03:29:42.855279" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.854931" elapsed="0.000430"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.856078" 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-06-06T03:29:42.855633" elapsed="0.000482"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.855395" elapsed="0.000771"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.854904" elapsed="0.001293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.856962" 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-06-06T03:29:42.856430" elapsed="0.000570"/>
</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-06-06T03:29:42.857442" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.857099" elapsed="0.000422"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.858271" 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-06-06T03:29:42.857809" elapsed="0.000501"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.857555" elapsed="0.000806"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.857072" elapsed="0.001318"/>
</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-06-06T03:29:42.858610" elapsed="0.000512"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:42.859677" 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-06-06T03:29:42.859330" elapsed="0.000375"/>
</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-06-06T03:29:42.859870" elapsed="0.002333"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:42.847278" elapsed="0.014992"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:42.862318" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:42.864589" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:42.835771" elapsed="0.028845"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.864686" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:42.739074" elapsed="0.125738"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:42.738607" elapsed="0.126260"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:42.738233" elapsed="0.126695"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:42.868246" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.865859" elapsed="0.002416"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.868455" elapsed="0.002153"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:42.870672" elapsed="0.000030"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:42.865568" elapsed="0.005230"/>
</kw>
<msg time="2026-06-06T03:29:42.870875" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:42.865100" elapsed="0.005799"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.871770" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:42.871846" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:42.871488" elapsed="0.000382"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.872287" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:42.872363" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:42.872029" elapsed="0.000358"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.872550" elapsed="0.000344"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:42.873239" level="INFO">${sum_1} = 786</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:42.873056" elapsed="0.000209"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:42.873608" level="INFO">${sum_2} = 786</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:42.873422" elapsed="0.000212"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:42.873810" elapsed="0.000312"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:42.871117" elapsed="0.003067"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.918448" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:42.918046" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.919261" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.919003" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:42.919581" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:42.918660" elapsed="0.000946"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.920187" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:42.919796" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:42.920517" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:42.920680" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:42.920380" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.921115" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.920869" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.922163" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.921903" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.922673" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.922386" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.923675" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.923107" elapsed="0.000596"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.924854" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.924386" elapsed="0.000510"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.925013" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:42.925235" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.923897" elapsed="0.001364"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.925419" elapsed="0.000509"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:42.922966" elapsed="0.003005"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.926775" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:42.926224" elapsed="0.000578"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:42.928106" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.927629" elapsed="0.000518"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:42.928266" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:42.928485" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:42.926994" elapsed="0.001517"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:42.928699" elapsed="0.000486"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:42.926086" elapsed="0.003141"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.922751" elapsed="0.006515"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:42.929312" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:42.929472" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:42.921529" elapsed="0.007969"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.921230" elapsed="0.008300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.929725" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.929555" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.921210" elapsed="0.008594"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.930534" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:42.929952" elapsed="0.000611"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.930612" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:42.917382" elapsed="0.013374"/>
</kw>
<msg time="2026-06-06T03:29:42.930811" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:42.904543" elapsed="0.026329"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.943666" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.956228" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.968803" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.969005" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.969184" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.969549" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.969402" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:42.969386" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.969788" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.969960" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.970128" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:42.969358" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.969259" elapsed="0.000946"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.970370" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:42.970445" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:42.970564" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:42.899987" elapsed="0.070603"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.971741" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:42.971477" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:42.978999" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:42.979137" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:42.979274" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:29:42.979317" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.973899" elapsed="0.005805">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:42.971852" elapsed="0.007934">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:42.979978" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.979819" elapsed="0.000254"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:42.971834" elapsed="0.008264">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:42.983959" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.981158" elapsed="0.002850">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:42.980930" elapsed="0.003166">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:42.980911" elapsed="0.003232">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.987823" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.984562" elapsed="0.003307">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:42.984245" elapsed="0.003710">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:42.984220" elapsed="0.003780">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.988822" 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-06-06T03:29:42.988263" elapsed="0.000598"/>
</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-06-06T03:29:42.989298" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.988960" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.990086" 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-06-06T03:29:42.989665" elapsed="0.000458"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.989412" elapsed="0.000759"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.988934" elapsed="0.001266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.990997" 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-06-06T03:29:42.990466" elapsed="0.000569"/>
</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-06-06T03:29:42.991403" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:42.991132" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:42.991958" 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-06-06T03:29:42.991662" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.991483" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:42.991107" elapsed="0.000932"/>
</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-06-06T03:29:42.992192" elapsed="0.000342"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:42.992995" 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-06-06T03:29:42.992717" elapsed="0.000304"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:29:42.995449" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.993178" elapsed="0.002304">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:29:42.980473" elapsed="0.015142">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:42.995693" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:42.998050" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:29:42.998080" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:29:42.970868" elapsed="0.027241">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:42.998209" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:29:42.875470" elapsed="0.122916">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:42.874846" elapsed="0.123635"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:42.874428" elapsed="0.124115"/>
</kw>
<arg>leaf_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:42.526825" elapsed="0.471770"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.444841" elapsed="0.553886"/>
</test>
<test id="s1-s16-t11" name="Play_To_Odl_leaf_ad" line="98">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:43.002036" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:43.001767" elapsed="0.000540"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.003332" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:43.003222" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.003203" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.008318" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:43.008206" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.008188" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.009394" 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-06-06T03:29:43.009012" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.009942" 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-06-06T03:29:43.009587" elapsed="0.000383"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:43.010015" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:43.010169" 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-06-06T03:29:43.008613" elapsed="0.001581"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:43.015673" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:43.015549" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.015530" elapsed="0.000214"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:43.016923" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:43.016815" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.016796" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:43.017440" 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-06-06T03:29:43.017143" elapsed="0.000324"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:43.017867" level="INFO">${current_connection_index} = 7</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-06-06T03:29:43.017630" elapsed="0.000263"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:43.049422" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:43.018396" elapsed="0.031130"/>
</kw>
<msg time="2026-06-06T03:29:43.049732" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:43.049780" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:43.018056" elapsed="0.031761"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:43.076120" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "l "e "a "f "_ "a "d "[K"
[?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-06-06T03:29:43.050476" elapsed="0.025752"/>
</kw>
<msg time="2026-06-06T03:29:43.076389" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:43.076434" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:29:43.049993" elapsed="0.026521"/>
</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-06-06T03:29:43.076859" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.076597" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.076576" elapsed="0.000364"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.077390" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "l "e "a "f "_ "a "d "[K"
[?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-06-06T03:29:43.077084" elapsed="0.000374"/>
</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-06-06T03:29:43.077764" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.077525" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.077507" elapsed="0.000337"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:43.077877" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:43.080427" elapsed="0.000143"/>
</kw>
<msg time="2026-06-06T03:29:43.080630" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:43.079355" elapsed="0.001426"/>
</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="NOT RUN" start="2026-06-06T03:29:43.081060" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.081396" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:43.078731" elapsed="0.002849"/>
</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-06-06T03:29:43.078150" elapsed="0.003513"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:43.016482" elapsed="0.065287"/>
</kw>
<msg time="2026-06-06T03:29:43.081861" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:43.081904" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:43.015900" elapsed="0.066042"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:43.082125" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:43.082018" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.081999" elapsed="0.000209"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.082625" elapsed="0.000041"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.082974" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.083046" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:43.015211" elapsed="0.067941"/>
</kw>
<msg time="2026-06-06T03:29:43.083244" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:43.083288" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:43.010578" elapsed="0.072748"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.083669" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.083401" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.083384" elapsed="0.000364"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:43.010428" elapsed="0.073343"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:43.010246" elapsed="0.073554"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:43.007845" elapsed="0.076007"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:43.002936" elapsed="0.080970"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:43.002481" elapsed="0.081505"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:42.999494" elapsed="0.084547"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.085155" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.084688" elapsed="0.000496"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.085821" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.085354" elapsed="0.000495"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.086399" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.086019" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:43.086836" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/announce_leaf_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/announce_leaf_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:43.086987" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:43.086614" elapsed="0.000399"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:43.087363" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/withdraw_leaf_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/withdraw_leaf_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:43.087483" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:43.087174" elapsed="0.000336"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:43.087682" elapsed="0.002374"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:43.090216" elapsed="0.002089"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.144525" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:43.144136" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:43.145332" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:43.145087" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:43.145502" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:43.144746" elapsed="0.000780"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.146097" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:43.145713" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:43.146425" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:43.146570" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:43.146289" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.147040" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:43.146795" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.148110" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:43.147816" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.148664" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.148373" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.149470" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:43.149060" elapsed="0.000437"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:43.150771" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.150172" elapsed="0.000703"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:43.150956" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:43.151254" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:43.149707" elapsed="0.001573"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.151441" elapsed="0.000408"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:43.148920" elapsed="0.002971"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.152714" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:43.152141" elapsed="0.000600"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:43.154291" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.153741" elapsed="0.000653"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:43.154472" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:43.154806" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:43.152943" elapsed="0.001889"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:43.154991" elapsed="0.000369"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:43.152004" elapsed="0.003399"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:43.148744" elapsed="0.006694"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:43.155481" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:43.155637" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:43.147467" elapsed="0.008257"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:43.147158" elapsed="0.008600"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.155938" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.155784" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.147136" elapsed="0.008877"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.156754" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:43.156159" elapsed="0.000624"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:43.156833" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:43.143491" elapsed="0.013464"/>
</kw>
<msg time="2026-06-06T03:29:43.157010" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:43.130805" elapsed="0.026254"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.169628" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.182077" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.194463" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.194677" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.194878" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.195252" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.195102" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:43.195087" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.195476" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.195662" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.195836" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:43.195058" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.194956" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.196066" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.196141" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:43.196266" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:43.126433" elapsed="0.069860"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:43.197618" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:43.197324" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:43.197804" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:43.196975" elapsed="0.000853"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.198151" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.197898" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.198755" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:43.198419" elapsed="0.000364"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:43.198232" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.197879" elapsed="0.000960"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.201357" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:43.198995" elapsed="0.002389"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:43.201436" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:43.201589" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:43.196624" elapsed="0.004989"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:43.202907" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:43.202656" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:43.203062" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:43.202301" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:43.203298" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:29:43.203158" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:43.203138" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.203531" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.203722" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.203790" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:43.205709" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:43.201974" elapsed="0.003761"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.207167" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:43.206913" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:43.207617" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:43.207376" elapsed="0.000310"/>
</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-06-06T03:29:43.214993" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:43.215134" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:43.215230" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:29:43.209879" elapsed="0.005875">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:43.207754" elapsed="0.008116">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:43.216139" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.215917" elapsed="0.000311"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:43.207735" elapsed="0.008531">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:29:43.216814" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.216998" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:43.216946" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:43.216921" elapsed="0.000167"/>
</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-06-06T03:29:43.217299" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.217456" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:29:43.206050" elapsed="0.011556">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.217734" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:29:43.103815" elapsed="0.114052">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:43.218260" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:43.217999" elapsed="0.000363"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:43.217975" elapsed="0.000421"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:43.218443" elapsed="0.000021"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:43.097883" elapsed="0.120696">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.275966" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.275554" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.276775" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.276516" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.276946" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.276176" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.277526" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.277139" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.277878" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.278034" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.277735" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.278484" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.278236" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.279572" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.279256" elapsed="0.000361"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.280077" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.279805" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.280902" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.280476" elapsed="0.000502"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.282240" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.281637" elapsed="0.000703"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.282423" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:45.282740" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.281173" elapsed="0.001594"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.282932" elapsed="0.000389"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:45.280335" elapsed="0.003027"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.284026" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.283612" elapsed="0.000440"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.285415" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.284871" elapsed="0.000645"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.285595" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:45.285910" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.284390" elapsed="0.001546"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.286108" elapsed="0.000383"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:45.283475" elapsed="0.003058"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.280156" elapsed="0.006413"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.286612" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:29:45.286790" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:45.278926" elapsed="0.007891"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.278606" elapsed="0.008244"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.287031" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.286876" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.278583" elapsed="0.008525"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.287850" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.287256" elapsed="0.000623"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.287928" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.274931" elapsed="0.013122"/>
</kw>
<msg time="2026-06-06T03:29:45.288109" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.262127" elapsed="0.026031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.301130" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.313739" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.326250" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.326474" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.326674" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.327083" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.326929" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.326910" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.327314" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.327488" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.327672" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.326873" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.326760" elapsed="0.000994"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.327907" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.327984" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:45.328137" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.257804" elapsed="0.070362"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.329549" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.329269" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.329735" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.328875" elapsed="0.000886"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.330104" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.329833" elapsed="0.000354"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.330717" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.330403" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.330213" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.329814" elapsed="0.000988"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.333360" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.330959" elapsed="0.002428"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:45.333441" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:45.333599" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:45.328499" elapsed="0.005125"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.334910" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.334675" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.335107" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.334310" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:45.335341" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:29:45.335204" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.335185" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.335574" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.335770" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.335838" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:45.337761" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:45.333952" elapsed="0.003836"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.339224" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.338967" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.339691" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.339431" elapsed="0.000304"/>
</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-06-06T03:29:45.347476" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:45.347860" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '354'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:45.347975" 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-06-06T03:29:45.341890" elapsed="0.006112"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.339802" elapsed="0.008244"/>
</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-06-06T03:29:45.348232" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.348072" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.339784" elapsed="0.008537"/>
</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-06-06T03:29:45.351813" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.349356" elapsed="0.002507"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.349128" elapsed="0.002771"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.349108" elapsed="0.002817"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.354702" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.352208" elapsed="0.002542"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.351982" elapsed="0.002804"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.351964" elapsed="0.002847"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.355374" 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-06-06T03:29:45.354984" elapsed="0.000417"/>
</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-06-06T03:29:45.355734" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.355473" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.356294" 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-06-06T03:29:45.355987" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.355819" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.355454" elapsed="0.000961"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.356971" 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-06-06T03:29:45.356585" elapsed="0.000413"/>
</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-06-06T03:29:45.357312" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.357070" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.357876" 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-06-06T03:29:45.357561" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.357395" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.357052" elapsed="0.000908"/>
</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-06-06T03:29:45.358116" elapsed="0.000379"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:45.358981" 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-06-06T03:29:45.358683" elapsed="0.000324"/>
</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-06-06T03:29:45.359170" elapsed="0.002299"/>
</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-06-06T03:29:45.348705" elapsed="0.012827"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.361724" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:45.361603" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.361584" elapsed="0.000207"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.364780" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:45.361941" elapsed="0.002868"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:45.364864" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:45.365023" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:45.338102" elapsed="0.026947"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.365111" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:45.365265" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:45.235283" elapsed="0.130008"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.393915" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.393422" elapsed="0.000522"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.394774" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.394483" elapsed="0.000414">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.395077" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.394113" elapsed="0.000990"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.395736" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.395275" elapsed="0.000529"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.396141" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.396308" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.395977" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.396782" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "leaf-a-d": {
          "orig-route-ip": "1.0.0.1",
          "inter-as-i-pmsi-a-d": {
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 1
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.396498" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:45.397313" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.396900" elapsed="0.000478"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.398089" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.397555" elapsed="0.000562"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.397403" elapsed="0.000752"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.396880" elapsed="0.001297"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.398896" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.398370" elapsed="0.000556"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.398979" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.392798" elapsed="0.006318"/>
</kw>
<msg time="2026-06-06T03:29:45.399177" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.379924" elapsed="0.019305"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.412017" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.424501" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.436991" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.437192" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.437432" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.437850" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.437697" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.437680" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.438074" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.438246" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.438445" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.437633" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.437519" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.438694" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.438772" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:45.438913" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.377238" elapsed="0.061703"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.439125" elapsed="0.002407"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.442837" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.442309" elapsed="0.000557"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.443495" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.443056" elapsed="0.000469"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:45.443704" elapsed="0.000330"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:45.441876" elapsed="0.002226"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.441613" elapsed="0.002528"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.444328" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.444168" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.441594" elapsed="0.002811"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:45.366467" elapsed="0.077989"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:45.365615" elapsed="0.078921"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.365374" elapsed="0.079210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.365357" elapsed="0.079252"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.444658" elapsed="0.000030"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:45.229412" elapsed="0.215378"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:43.092488" elapsed="2.352361"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.495100" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.494716" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.495897" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.495655" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.496072" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.495296" elapsed="0.000800"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.496667" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.496267" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.496998" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.497154" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.496862" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.497585" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.497339" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.498865" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.498340" elapsed="0.000575"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.499389" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.499095" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.500228" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.499823" elapsed="0.000434"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.501502" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.500948" elapsed="0.000655"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.501700" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:45.502001" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.500466" elapsed="0.001561"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.502189" elapsed="0.000435"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:45.499673" elapsed="0.003009"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.503345" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.502936" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.504880" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.504087" elapsed="0.000952"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.505165" elapsed="0.000056"/>
</return>
<msg time="2026-06-06T03:29:45.505628" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.503561" elapsed="0.002132"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.505958" elapsed="0.000571"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:45.502797" elapsed="0.003792"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.499470" elapsed="0.007171"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.506824" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:29:45.507053" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:45.498014" elapsed="0.009075"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.497715" elapsed="0.009422"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.507407" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.507178" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.497695" elapsed="0.009819"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.508600" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.507742" elapsed="0.001001"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.508819" elapsed="0.000040"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.493991" elapsed="0.015007"/>
</kw>
<msg time="2026-06-06T03:29:45.509079" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.481177" elapsed="0.027978"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.522432" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.534929" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.547335" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.547535" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.547734" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.548116" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.547967" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.547951" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.548344" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.548514" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.548698" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.547919" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.547814" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.548925" elapsed="0.000056"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.549041" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:45.549168" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.476845" elapsed="0.072350"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.550700" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.550232" elapsed="0.000546">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.550871" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.549878" elapsed="0.001018"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.551221" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.550967" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.551942" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.551490" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.551302" elapsed="0.000701"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.550948" elapsed="0.001076"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.554817" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.552178" elapsed="0.002666"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:45.554897" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:45.555051" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:45.549524" elapsed="0.005552"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.556312" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.556079" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.556468" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.555736" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:45.556714" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:45.556562" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.556543" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.556948" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.557122" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.557187" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:45.559123" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:45.555385" elapsed="0.003764"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.560553" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.560301" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.561019" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.560776" elapsed="0.000286"/>
</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-06-06T03:29:45.568496" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:45.568657" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '354'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:45.568758" 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-06-06T03:29:45.563229" elapsed="0.005556"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.561127" elapsed="0.007701"/>
</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-06-06T03:29:45.569014" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.568854" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.561109" elapsed="0.007990"/>
</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-06-06T03:29:45.573320" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.570143" elapsed="0.003247"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.569915" elapsed="0.003524"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.569895" elapsed="0.003580"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.577142" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.573900" elapsed="0.003307"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.573555" elapsed="0.003700"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.573531" elapsed="0.003758"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.578093" 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-06-06T03:29:45.577534" elapsed="0.000597"/>
</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-06-06T03:29:45.578617" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.578232" elapsed="0.000491"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.579405" 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-06-06T03:29:45.578999" elapsed="0.000432"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.578759" elapsed="0.000708"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.578206" elapsed="0.001283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.580051" 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-06-06T03:29:45.579675" elapsed="0.000404"/>
</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-06-06T03:29:45.580392" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.580151" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.581014" 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-06-06T03:29:45.580716" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.580474" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.580132" elapsed="0.000964"/>
</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-06-06T03:29:45.581260" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:45.582088" 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-06-06T03:29:45.581791" elapsed="0.000323"/>
</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-06-06T03:29:45.582275" elapsed="0.002378"/>
</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-06-06T03:29:45.569470" elapsed="0.015252"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.584963" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:45.584852" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.584832" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.588038" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:45.585183" elapsed="0.002884"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:45.588120" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:45.588281" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:45.559464" elapsed="0.028843"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.588373" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:45.588523" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:45.454032" elapsed="0.134518"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.617004" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.616490" elapsed="0.000546"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.617975" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.617669" elapsed="0.000436">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.618284" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.617294" elapsed="0.001016"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.618980" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.618488" elapsed="0.000520"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.619342" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.619506" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.619177" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.619986" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "leaf-a-d": {
          "orig-route-ip": "1.0.0.1",
          "inter-as-i-pmsi-a-d": {
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 1
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.619713" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:45.620544" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.620111" elapsed="0.000494"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.621311" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.620801" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.620632" elapsed="0.000745"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.620088" elapsed="0.001310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.622066" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.621552" elapsed="0.000593"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.622200" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.615815" elapsed="0.006521"/>
</kw>
<msg time="2026-06-06T03:29:45.622398" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.602899" elapsed="0.019549"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.635082" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.648606" elapsed="0.000071"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.661331" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.661721" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.661911" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.662312" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.662160" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.662144" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.662543" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.662740" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.662921" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.662109" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.661995" elapsed="0.001007"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.663152" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.663228" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:45.663375" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.600246" elapsed="0.063157"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.663679" elapsed="0.002445"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.667436" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.666939" elapsed="0.000526"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.668064" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.667623" elapsed="0.000469"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:45.668253" elapsed="0.000337"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:45.666465" elapsed="0.002201"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.666207" elapsed="0.002494"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.668880" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.668726" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.666187" elapsed="0.002769"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:45.589724" elapsed="0.079281"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:45.588900" elapsed="0.080183"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.588632" elapsed="0.080497"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.588615" elapsed="0.080539"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.669188" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:45.449621" elapsed="0.219697"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:45.445069" elapsed="0.224311"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.719292" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.718862" elapsed="0.000468"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.720235" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.719903" elapsed="0.000418">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.720420" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.719524" elapsed="0.000921"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.721023" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.720617" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.721358" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.721532" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.721216" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.721986" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.721736" elapsed="0.000371"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.723493" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.722947" elapsed="0.000593"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.724013" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.723735" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.724848" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.724411" elapsed="0.000464"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.726119" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.725542" elapsed="0.000686"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.726315" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:45.726618" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.725070" elapsed="0.001588"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.726836" elapsed="0.000393"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:45.724270" elapsed="0.003001"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.727942" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.727524" elapsed="0.000444"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.729190" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.728617" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.729371" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:45.729680" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.728157" elapsed="0.001550"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.729865" elapsed="0.000364"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:45.727386" elapsed="0.002885"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.724093" elapsed="0.006213"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.730349" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:45.730504" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:45.722555" elapsed="0.007974"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.722189" elapsed="0.008371"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.730754" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.730586" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.722165" elapsed="0.008702"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.731720" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.731028" elapsed="0.000723"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.731813" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.718128" elapsed="0.013816"/>
</kw>
<msg time="2026-06-06T03:29:45.732000" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.705284" elapsed="0.026764"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.744704" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.757246" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.769856" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.770059" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.770239" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.770616" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.770466" elapsed="0.000226"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.770450" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.770903" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.771082" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.771253" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.770420" elapsed="0.000885"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.770316" elapsed="0.001015"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.771479" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.771579" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:29:45.771730" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.700915" elapsed="0.070842"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.773197" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.772940" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.773362" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.772574" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.773724" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.773456" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.774283" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.773992" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.773808" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.773437" elapsed="0.000929"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.778126" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.774520" elapsed="0.003633"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:45.778206" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:45.778403" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:45.772095" elapsed="0.006334"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.779712" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.779461" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.779872" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.779116" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:45.780106" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:45.779969" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.779950" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.780341" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.780518" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.780583" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:45.782509" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:45.778756" elapsed="0.003780"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.784028" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.783758" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.784481" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.784237" elapsed="0.000288"/>
</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-06-06T03:29:45.792460" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:45.792604" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '354'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:45.792736" 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-06-06T03:29:45.786726" elapsed="0.006037"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.784595" elapsed="0.008212"/>
</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-06-06T03:29:45.792995" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.792836" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.784575" elapsed="0.008508"/>
</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-06-06T03:29:45.797085" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.794117" elapsed="0.003036"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.793890" elapsed="0.003313"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.793871" elapsed="0.003368"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.801116" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.797636" elapsed="0.003544"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.797318" elapsed="0.003910"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.797294" elapsed="0.003970"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.802084" 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-06-06T03:29:45.801516" elapsed="0.000607"/>
</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-06-06T03:29:45.802659" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.802289" elapsed="0.000454"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.803430" 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-06-06T03:29:45.803046" elapsed="0.000410"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.802777" elapsed="0.000714"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.802261" elapsed="0.001252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.804065" 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-06-06T03:29:45.803699" elapsed="0.000393"/>
</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-06-06T03:29:45.804404" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.804163" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.804963" 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-06-06T03:29:45.804668" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.804485" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.804144" elapsed="0.000900"/>
</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-06-06T03:29:45.805201" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:45.806030" 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-06-06T03:29:45.805734" elapsed="0.000323"/>
</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-06-06T03:29:45.806217" elapsed="0.002334"/>
</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-06-06T03:29:45.793452" elapsed="0.015163"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.808811" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:45.808702" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.808682" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.811878" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:45.809029" elapsed="0.002878"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:45.811960" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:45.812121" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:45.782898" elapsed="0.029249"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.812210" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:29:45.812358" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:45.678235" elapsed="0.134150"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.841491" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.840994" elapsed="0.000531"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.842369" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.842066" elapsed="0.000431">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.842757" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.841722" elapsed="0.001062"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.843435" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.842986" elapsed="0.000477"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.843814" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/leaf_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.843975" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.843631" elapsed="0.000391"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.844485" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "leaf-a-d": {
          "orig-route-ip": "1.0.0.1",
          "inter-as-i-pmsi-a-d": {
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 1
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.844205" elapsed="0.000331"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:45.845039" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.844610" elapsed="0.000491"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.845810" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.845279" elapsed="0.000558"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.845128" elapsed="0.000746"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.844588" elapsed="0.001307"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.846540" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.846048" elapsed="0.000521"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.846620" elapsed="0.000064"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.840356" elapsed="0.006448"/>
</kw>
<msg time="2026-06-06T03:29:45.846864" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.827240" elapsed="0.019675"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.859760" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.872314" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/leaf_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.885089" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.885374" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.885566" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.885983" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.885831" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.885816" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.886208" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.886380" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.886549" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.885783" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.885667" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.886798" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.886874" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:45.887027" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.824379" elapsed="0.062676"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.887235" elapsed="0.002389"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.890880" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.890391" elapsed="0.000518"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:45.891523" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.891096" elapsed="0.000456"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:45.891729" elapsed="0.000335"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:45.889967" elapsed="0.002158"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.889723" elapsed="0.002437"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.892345" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.892186" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.889703" elapsed="0.002717"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:45.813532" elapsed="0.078937"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:45.812726" elapsed="0.079822"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.812467" elapsed="0.080129"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.812449" elapsed="0.080171"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.892669" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:45.673876" elapsed="0.218924"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:45.669560" elapsed="0.223352"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:45.893086" elapsed="0.002534"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.948143" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:45.947741" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.949011" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.948717" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:45.949184" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:45.948359" elapsed="0.000850"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.949791" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:45.949386" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:45.950131" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:45.950296" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:45.949987" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.950754" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.950491" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.952109" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:45.951786" elapsed="0.000370"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.952603" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.952325" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.953451" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.953031" elapsed="0.000447"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.954735" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.954155" elapsed="0.000683"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.954920" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:45.955257" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.953689" elapsed="0.001595"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.955452" elapsed="0.000405"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:45.952886" elapsed="0.003014"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.956560" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:45.956153" elapsed="0.000434"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:45.957819" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.957253" elapsed="0.000667"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:45.957998" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:45.958289" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:45.956796" elapsed="0.001519"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:45.958478" elapsed="0.000387"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:45.956015" elapsed="0.002948"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.952706" elapsed="0.006295"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:45.959046" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:45.959223" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:45.951198" elapsed="0.008050"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:45.950879" elapsed="0.008402"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.959461" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.959306" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:45.950855" elapsed="0.008684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:45.960287" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:45.959703" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:45.960367" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:45.947077" elapsed="0.013414"/>
</kw>
<msg time="2026-06-06T03:29:45.960546" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:45.934222" elapsed="0.026371"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.973203" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.985623" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.998100" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.998339" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.998524" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.999005" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:45.998852" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:45.998835" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.999246" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.999426" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.999599" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:45.998796" elapsed="0.000877"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:45.998607" elapsed="0.001155"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:45.999923" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:46.000004" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:46.000144" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:45.929669" elapsed="0.070502"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:46.001540" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:46.001268" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:46.001726" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:46.000888" elapsed="0.000864"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.002087" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.001825" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.002924" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:46.002359" elapsed="0.000593"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.002171" elapsed="0.000819"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.001806" elapsed="0.001205"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.005402" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:46.003173" elapsed="0.002256"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:46.005483" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:46.005653" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:46.000522" elapsed="0.005159"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:46.006876" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:46.006683" elapsed="0.000246"/>
</kw>
<msg time="2026-06-06T03:29:46.007015" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:46.006325" elapsed="0.000715"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:46.007266" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:46.007112" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.007093" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:46.007666" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:46.007818" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:46.007483" elapsed="0.000360"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:46.008241" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:46.008005" elapsed="0.000262"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:46.008315" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:46.008467" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:46.005993" elapsed="0.002499"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.009895" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:46.009629" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.010386" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:46.010140" elapsed="0.000290"/>
</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-06-06T03:29:46.017798" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:46.018244" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '499'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:29:46.018350" 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-06-06T03:29:46.012627" elapsed="0.005749"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.010498" elapsed="0.007923"/>
</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-06-06T03:29:46.018609" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.018448" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.010479" elapsed="0.008235"/>
</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-06-06T03:29:46.023006" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BBICDAABAQIDBAECAAAAAQEAAAE=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"leaf-a-d":{"inter-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","source-as":1},"orig-route-ip":"1.0.0.1"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:46.019791" elapsed="0.003290"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.019543" elapsed="0.003590"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.019524" elapsed="0.003645"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.027087" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:46.023605" elapsed="0.003547"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.023274" elapsed="0.003927"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.023248" elapsed="0.004027"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.028116" 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-06-06T03:29:46.027538" elapsed="0.000616"/>
</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-06-06T03:29:46.028531" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.028255" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.029099" 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-06-06T03:29:46.028799" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.028613" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.028228" elapsed="0.000954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.029725" 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-06-06T03:29:46.029347" elapsed="0.000405"/>
</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-06-06T03:29:46.030063" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.029822" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.030604" 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-06-06T03:29:46.030310" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.030143" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.029804" elapsed="0.000899"/>
</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-06-06T03:29:46.030861" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:46.031711" 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-06-06T03:29:46.031401" elapsed="0.000336"/>
</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-06-06T03:29:46.032012" elapsed="0.002299"/>
</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-06-06T03:29:46.019079" elapsed="0.015299"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:46.034558" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:46.034449" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.034430" elapsed="0.000197"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:46.037758" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:29:46.034794" elapsed="0.002993"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:46.037841" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:46.038002" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:46.008817" elapsed="0.029211"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:46.038093" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:29:46.038242" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:45.906950" elapsed="0.131318"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.066777" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:46.066277" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:46.067661" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:46.067351" elapsed="0.000435">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:46.067979" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:46.066979" elapsed="0.001027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.068629" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:46.068178" elapsed="0.000496"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:46.069004" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:46.069158" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:46.068843" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.069625" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:46.069355" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:46.070170" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.069761" elapsed="0.000469"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.070931" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:46.070406" elapsed="0.000552"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:46.070255" elapsed="0.000739"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:46.069741" elapsed="0.001343"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.071767" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:46.071243" elapsed="0.000553"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:46.071847" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:46.065641" elapsed="0.006331"/>
</kw>
<msg time="2026-06-06T03:29:46.072027" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:46.052798" elapsed="0.019277"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.084588" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.097015" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.109504" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.109717" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.109900" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.110281" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.110132" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:46.110117" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.110510" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.110697" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.110869" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:46.110087" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:46.109980" elapsed="0.000971"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.111103" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:46.111181" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:46.111315" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:46.050101" elapsed="0.061256"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:46.111599" elapsed="0.002474"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:46.115182" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:46.114875" elapsed="0.000335"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:46.116017" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:46.115395" elapsed="0.000651"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:29:46.116535" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "leaf-a-d": {
       "inter-as-i-pmsi-a-d": {
        "route-distinguisher": "1.2.3.4:258",
        "source-as": 1
       },
       "orig-route-ip": "1.0.0.1"
      },
      "path-id": 0,
      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:29:46.116761" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:29:46.116208" elapsed="0.000634">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:29:46.114422" elapsed="0.002566">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:46.114156" elapsed="0.002911">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:46.117257" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:46.117103" elapsed="0.000210"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:46.114136" elapsed="0.003200">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:29:46.039446" elapsed="0.078042">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:29:46.038602" elapsed="0.079051">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:46.038352" elapsed="0.079396">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:46.038335" elapsed="0.079449">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:46.117834" elapsed="0.000016"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:45.900692" elapsed="0.217265">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,35 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "leaf-a-d": {
+       "inter-as-i-pmsi-a-d": {
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 1
+       },
+       "orig-route-ip": "1.0.0.1"
+      },
+      "path-id": 0,
+      "route-key": "BBICDAABAQIDBAECAAAAAQEAAAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.174555" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.174124" elapsed="0.000466"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.175418" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.175162" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.175589" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.174795" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.176221" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.175820" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.176633" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.176809" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.176485" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.177249" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.177001" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.178346" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.178029" elapsed="0.000391"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.178894" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.178591" elapsed="0.000330"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.179719" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.179291" elapsed="0.000455"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.180991" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.180401" elapsed="0.000692"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.181173" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:48.181477" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.179940" elapsed="0.001563"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.181685" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:48.179149" elapsed="0.002965"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.182812" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.182366" elapsed="0.000472"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.184054" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.183492" elapsed="0.000662"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.184230" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:48.184526" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.183031" elapsed="0.001521"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.184728" elapsed="0.000381"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:48.182228" elapsed="0.002925"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.178974" elapsed="0.006214"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.185231" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:48.185394" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:48.177698" elapsed="0.007723"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.177372" elapsed="0.008082"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.185635" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.185480" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.177349" elapsed="0.008383"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.186758" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:48.185906" elapsed="0.000882"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.186839" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:48.173457" elapsed="0.013509"/>
</kw>
<msg time="2026-06-06T03:29:48.187021" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.160441" elapsed="0.026628"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.199604" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.211970" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.224359" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.224558" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.224751" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.225123" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.224972" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:48.224957" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.225346" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.225517" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.225702" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:48.224928" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.224827" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.225997" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.226073" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:48.226191" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:48.155917" elapsed="0.070299"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.227630" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.227388" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.227807" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.227038" elapsed="0.000793"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.228151" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.227901" elapsed="0.000341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.228765" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.228454" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.228268" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.227882" elapsed="0.000966"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.231198" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.229003" elapsed="0.002222"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:48.231276" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:48.231434" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:48.226566" elapsed="0.004893"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.232799" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.232598" elapsed="0.000255"/>
</kw>
<msg time="2026-06-06T03:29:48.232937" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.232257" elapsed="0.000704"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.233166" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.233031" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.233012" elapsed="0.000220"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.233545" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.233694" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.233380" elapsed="0.000340"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:48.234114" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.233882" elapsed="0.000258"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:48.234186" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:48.234338" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:48.231928" elapsed="0.002434"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.235794" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.235526" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.236238" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.235997" elapsed="0.000284"/>
</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-06-06T03:29:48.246001" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:48.246135" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:29:48.246231" 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-06-06T03:29:48.238628" elapsed="0.007629"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.236346" elapsed="0.009955"/>
</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-06-06T03:29:48.246511" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.246327" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.236328" elapsed="0.010270"/>
</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-06-06T03:29:48.250055" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.247629" elapsed="0.002507"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.247404" elapsed="0.002768"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.247385" elapsed="0.002813"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.252815" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.250490" elapsed="0.002371"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.250254" elapsed="0.002642"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.250237" elapsed="0.002684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.253482" 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-06-06T03:29:48.253096" elapsed="0.000413"/>
</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-06-06T03:29:48.253845" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.253579" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.254390" 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-06-06T03:29:48.254093" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.253926" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.253561" elapsed="0.000910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.255044" 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-06-06T03:29:48.254666" elapsed="0.000404"/>
</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-06-06T03:29:48.255378" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.255140" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.255934" 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-06-06T03:29:48.255623" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.255460" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.255121" elapsed="0.000894"/>
</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-06-06T03:29:48.256169" elapsed="0.000343"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:48.256980" 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-06-06T03:29:48.256699" elapsed="0.000306"/>
</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-06-06T03:29:48.257163" elapsed="0.002311"/>
</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-06-06T03:29:48.246982" elapsed="0.012556"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.259730" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.259607" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.259588" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:48.262582" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:29:48.259947" elapsed="0.002664"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:48.262677" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:48.262836" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:48.234717" elapsed="0.028145"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.262925" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:48.263074" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:48.132961" elapsed="0.130139"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.292835" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.292305" elapsed="0.000563"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.293724" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.293400" elapsed="0.000452">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.294030" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.293050" elapsed="0.001006"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.294709" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.294230" elapsed="0.000508"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.295071" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.295231" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.294907" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.295713" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.295421" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:48.296294" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.295841" elapsed="0.000515"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.297063" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.296537" elapsed="0.000553"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.296385" elapsed="0.000740"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.295816" elapsed="0.001331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.297821" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:48.297300" elapsed="0.000551"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.297902" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:48.291631" elapsed="0.006407"/>
</kw>
<msg time="2026-06-06T03:29:48.298092" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.278833" elapsed="0.019310"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.310853" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.323532" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.336393" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.336629" elapsed="0.000039"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.336836" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.337258" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.337102" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:48.337083" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.337487" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.337676" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.337849" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:48.337045" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.336924" elapsed="0.001005"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.338078" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.338155" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:48.338300" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:48.276090" elapsed="0.062239"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.338509" elapsed="0.002485"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:48.342113" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.341792" elapsed="0.000350"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:48.342573" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.342300" elapsed="0.000301"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.342794" elapsed="0.000339"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.341335" elapsed="0.001859"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.341076" elapsed="0.002151"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.343406" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.343252" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.341055" elapsed="0.002428"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:48.264238" elapsed="0.079293"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:48.263425" elapsed="0.080185"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.263184" elapsed="0.080556"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.263167" elapsed="0.080600"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.343804" elapsed="0.000035"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:48.126748" elapsed="0.217195"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:45.895828" elapsed="2.448177"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:48.344240" elapsed="0.002794"/>
</kw>
<arg>leaf_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:43.084295" elapsed="5.262808"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:42.999040" elapsed="5.348187"/>
</test>
<test id="s1-s16-t12" name="Odl_To_Play_source_active_ad" line="102">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:48.350686" elapsed="0.000221"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:48.350381" elapsed="0.000582"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.352016" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.351893" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.351871" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.357266" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.357157" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.357138" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.358358" 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-06-06T03:29:48.357968" elapsed="0.000418"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.358883" 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-06-06T03:29:48.358552" elapsed="0.000357"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:48.358955" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:48.359113" 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-06-06T03:29:48.357567" elapsed="0.001570"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:48.364665" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.364541" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.364521" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:48.365936" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.365827" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.365808" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:48.366463" 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-06-06T03:29:48.366155" elapsed="0.000334"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:48.366917" level="INFO">${current_connection_index} = 7</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-06-06T03:29:48.366682" elapsed="0.000261"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:48.397474" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:48.367451" elapsed="0.030209"/>
</kw>
<msg time="2026-06-06T03:29:48.397869" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:48.397918" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:48.367109" elapsed="0.030846"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:48.425572" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "o "u "r "c "e "_ "a "c "t "i "v "e "_ "a "d "[K"
[?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-06-06T03:29:48.398589" elapsed="0.027139"/>
</kw>
<msg time="2026-06-06T03:29:48.425997" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:48.426045" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:29:48.398181" elapsed="0.027902"/>
</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-06-06T03:29:48.426461" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.426181" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.426153" elapsed="0.000390"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.427070" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "o "u "r "c "e "_ "a "c "t "i "v "e "_ "a "d "[K"
[?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-06-06T03:29:48.426718" elapsed="0.000425"/>
</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-06-06T03:29:48.427434" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.427212" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.427193" elapsed="0.000320"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:48.427551" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:48.430251" elapsed="0.000346"/>
</kw>
<msg time="2026-06-06T03:29:48.430678" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.429129" elapsed="0.001717"/>
</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="NOT RUN" start="2026-06-06T03:29:48.431135" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.431474" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:48.428465" elapsed="0.003222"/>
</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-06-06T03:29:48.427893" elapsed="0.003861"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:48.365497" elapsed="0.066354"/>
</kw>
<msg time="2026-06-06T03:29:48.431945" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:48.431989" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:48.364893" elapsed="0.067133"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:48.432216" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:48.432105" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.432085" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.432743" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.433091" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.433162" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:48.364204" elapsed="0.069067"/>
</kw>
<msg time="2026-06-06T03:29:48.433363" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:48.433408" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:48.359521" elapsed="0.073928"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.433796" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.433523" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.433505" elapsed="0.000370"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:48.359368" elapsed="0.074532"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:48.359194" elapsed="0.074737"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:48.356794" elapsed="0.077191"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:48.351576" elapsed="0.082514"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:48.351122" elapsed="0.083016"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:48.348208" elapsed="0.085985"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.435107" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/announce_source_active_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/announce_source_active_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.435314" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.434901" elapsed="0.000440"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:48.435751" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.435506" elapsed="0.000272"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.436133" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/withdraw_source_active_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/withdraw_source_active_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.436263" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.435943" elapsed="0.000346"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:48.436665" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.436447" elapsed="0.000247"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:48.436993" elapsed="0.002958"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.436766" elapsed="0.003222"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.436747" elapsed="0.003267"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.475354" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.474939" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.476223" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.475944" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.476397" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.475572" elapsed="0.000850"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.477027" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.476612" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.477392" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.477566" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.477226" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.478023" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.477774" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.479146" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.478881" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.479713" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.479359" elapsed="0.000381"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.480411" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.480111" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.481414" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.480971" elapsed="0.000474"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.481501" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:48.481694" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.480629" elapsed="0.001092"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.481883" elapsed="0.000252"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:48.479970" elapsed="0.002206"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.482746" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.482427" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.483725" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.483300" elapsed="0.000452"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.483802" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:48.483954" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.482975" elapsed="0.001003"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.484134" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:48.482290" elapsed="0.002107"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.479794" elapsed="0.004639"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.484476" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:48.484632" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:48.478498" elapsed="0.006175"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.478150" elapsed="0.006557"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.484888" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.484733" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.478125" elapsed="0.006840"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.485711" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:48.485115" elapsed="0.000625"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.485790" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:48.474231" elapsed="0.011683"/>
</kw>
<msg time="2026-06-06T03:29:48.485970" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.461343" elapsed="0.024677"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.498936" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.511564" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.524209" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.524430" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.524621" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.525191" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.525034" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:48.525015" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.525425" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.525599" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.525795" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:48.524975" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.524722" elapsed="0.001156"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.526032" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.526110" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:48.526255" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:48.456675" elapsed="0.069608"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.552402" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.551956" elapsed="0.000483"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.553269" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.553011" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.553439" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.552629" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.554050" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.553636" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.554392" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.554572" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BRIAAQECAwQBAiABAAABIAIAAAI=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ip...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.554247" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.555060" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BRIAAQECAwQBAiABAAABIAIAAAI=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;source-active-a-d&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
      &lt;multicast-group&gt;2.0.0.2&lt;/multicast-group&gt;
    &lt;/source-active-a-d&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.554784" elapsed="0.000409"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:48.555669" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.555278" elapsed="0.000455"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.556221" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.555916" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.555760" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.555252" elapsed="0.001054"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.556950" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BRIAAQECAwQBAiABAAABIAIAAAI=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ip...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:48.556465" elapsed="0.000516"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.557035" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:48.551126" elapsed="0.006051"/>
</kw>
<msg time="2026-06-06T03:29:48.557238" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.537617" elapsed="0.019673"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.570471" elapsed="0.000070"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.583450" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.596071" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.596311" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.596508" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.596962" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.596800" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:48.596780" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.597200" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.597373" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.597542" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:48.596735" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.596595" elapsed="0.001027"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.597882" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.597964" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:29:48.598135" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BRIAAQECAwQBAiABAAABIAIAAAI=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ip...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:48.536582" elapsed="0.061586"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.599745" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.599407" elapsed="0.000421">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.599924" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.598896" elapsed="0.001053"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.600295" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.600019" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.600886" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.600570" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.600376" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.600000" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.603379" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.601123" elapsed="0.002283"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:48.603462" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:48.603620" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:48.598512" elapsed="0.005148"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.605216" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.604960" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.605681" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BRIAAQECAwQBAiABAAABIAIAAAI=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;source-active-a-d&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
      &lt;multicast-group&gt;2.0.0.2&lt;/multicast-group&gt;
    &lt;/source-active-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.605424" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.606135" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.605893" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.606570" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.606330" elapsed="0.000284"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:48.607468" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:48.607260" elapsed="0.000234"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:48.607843" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:48.607665" elapsed="0.000204"/>
</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-06-06T03:29:48.608021" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.608709" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.608441" elapsed="0.000314"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:48.608797" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:48.608954" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:48.606835" elapsed="0.002143"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:48.621980" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '721', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BRIAAQECAwQBAiABAAABIAIAAAI=&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;source-active-a-d&gt;
      &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
      &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
      &lt;multicast-group&gt;2.0.0.2&lt;/multicast-group&gt;
    &lt;/source-active-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:29:48.622045" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=BRIAAQECAwQBAiABAAABIAIAAAI%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:48.622160" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:48.611381" elapsed="0.010805"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.609049" elapsed="0.013185"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.622428" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.622262" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.609030" elapsed="0.013487"/>
</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-06-06T03:29:48.626008" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.623608" elapsed="0.002444"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.623382" elapsed="0.002706"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.623362" elapsed="0.002751"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.628736" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.626394" elapsed="0.002389"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.626169" elapsed="0.002650"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.626152" elapsed="0.002692"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.629420" 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-06-06T03:29:48.629023" elapsed="0.000424"/>
</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-06-06T03:29:48.629779" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.629518" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.630414" 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-06-06T03:29:48.630029" elapsed="0.000411"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.629862" elapsed="0.000614"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.629499" elapsed="0.000998"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.631072" 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-06-06T03:29:48.630685" elapsed="0.000414"/>
</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-06-06T03:29:48.631410" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.631170" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.631967" 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-06-06T03:29:48.631670" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.631490" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.631151" elapsed="0.000899"/>
</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-06-06T03:29:48.632206" elapsed="0.000406"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:48.633091" 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-06-06T03:29:48.632802" elapsed="0.000315"/>
</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-06-06T03:29:48.633278" elapsed="0.002351"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:29:48.622922" elapsed="0.012786"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:48.635894" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:29:48.635783" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.635764" elapsed="0.000216"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:48.636133" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.636202" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:29:48.638556" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:29:48.603998" elapsed="0.034585"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.638670" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:48.638828" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:48.445077" elapsed="0.193776"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.639216" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.638959" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.638941" elapsed="0.000368"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.639342" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:48.440294" elapsed="0.199172"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:48.643116" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.640413" elapsed="0.002733"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.643328" elapsed="0.002344"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:48.645725" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:48.640135" elapsed="0.005718"/>
</kw>
<msg time="2026-06-06T03:29:48.645930" level="INFO">${update} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:48.639660" elapsed="0.006295"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.646823" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:29:48.646899" level="INFO">${len_1} = 152</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:48.646536" elapsed="0.000387"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.647352" level="INFO">Length is 152.</msg>
<msg time="2026-06-06T03:29:48.647431" level="INFO">${len_2} = 152</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:48.647099" elapsed="0.000355"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.647613" elapsed="0.000322"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:48.648276" level="INFO">${sum_1} = 991</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:48.648096" elapsed="0.000206"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:48.648700" level="INFO">${sum_2} = 991</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:48.648496" elapsed="0.000230"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.648885" elapsed="0.000309"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:48.646169" elapsed="0.003085"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:48.649408" elapsed="0.002160"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.695109" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.694712" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.695947" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.695696" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.696117" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.695330" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.696720" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.696315" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.697057" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.697212" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.696915" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.697663" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.697398" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.698967" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.698631" elapsed="0.000383"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.699494" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.699214" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.700338" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.699924" elapsed="0.000440"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.701487" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.701004" elapsed="0.000565"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.701729" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:48.701959" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.700562" elapsed="0.001422"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.702146" elapsed="0.000407"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:48.699782" elapsed="0.002813"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.703288" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.702864" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.704411" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.703939" elapsed="0.000551"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.704623" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:29:48.704866" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.703506" elapsed="0.001438"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.705104" elapsed="0.000397"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:48.702726" elapsed="0.002817"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.699575" elapsed="0.006004"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.705622" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:29:48.705800" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:48.698115" elapsed="0.007710"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.697786" elapsed="0.008072"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.706037" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.705884" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.697764" elapsed="0.008350"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.706872" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:48.706263" elapsed="0.000638"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.706949" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:48.694054" elapsed="0.013019"/>
</kw>
<msg time="2026-06-06T03:29:48.707129" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.681335" elapsed="0.025871"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.719937" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.732382" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.745329" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.745569" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.745773" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.746193" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.746038" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:48.746019" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.746421" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.746592" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.746847" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:48.745980" elapsed="0.000920"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.745861" elapsed="0.001067"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.747082" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.747160" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:48.747342" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:48.677018" elapsed="0.070353"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.748593" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.748292" elapsed="0.000366"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:48.759165" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:48.759294" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:48.759442" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:48.750801" elapsed="0.008668"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.748727" elapsed="0.010784"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.759729" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.759538" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.748708" elapsed="0.011105"/>
</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-06-06T03:29:48.763275" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.760878" elapsed="0.002441"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.760627" elapsed="0.002729"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.760607" elapsed="0.002775"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.766080" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.763808" elapsed="0.002317"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.763442" elapsed="0.002716"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.763422" elapsed="0.002761"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.766792" 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-06-06T03:29:48.766368" elapsed="0.000452"/>
</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-06-06T03:29:48.767138" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.766891" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.767741" 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-06-06T03:29:48.767422" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.767220" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.766872" elapsed="0.000951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.768349" 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-06-06T03:29:48.767987" elapsed="0.000388"/>
</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-06-06T03:29:48.768699" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.768444" elapsed="0.000366"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.769306" 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-06-06T03:29:48.769008" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.768837" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.768425" elapsed="0.000963"/>
</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-06-06T03:29:48.769547" elapsed="0.000375"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:48.770394" 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-06-06T03:29:48.770095" elapsed="0.000325"/>
</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-06-06T03:29:48.770582" elapsed="0.002457"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:48.760198" elapsed="0.012906"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:48.773154" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:48.775437" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:48.747671" elapsed="0.027794"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.775520" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:48.652598" elapsed="0.123068"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:48.652176" elapsed="0.123551"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:48.651784" elapsed="0.124006"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:48.779025" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.776743" elapsed="0.002311"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.779238" elapsed="0.002160"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:48.781449" elapsed="0.000030"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:48.776450" elapsed="0.005126"/>
</kw>
<msg time="2026-06-06T03:29:48.781670" level="INFO">${update} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:48.775968" elapsed="0.005728"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.782578" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:48.782670" level="INFO">${len_1} = 140</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:48.782302" elapsed="0.000394"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.783108" level="INFO">Length is 140.</msg>
<msg time="2026-06-06T03:29:48.783181" level="INFO">${len_2} = 140</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:48.782855" elapsed="0.000349"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.783395" elapsed="0.000324"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:48.784060" level="INFO">${sum_1} = 840</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:48.783880" elapsed="0.000206"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:48.784415" level="INFO">${sum_2} = 840</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:48.784239" elapsed="0.000201"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:48.784594" elapsed="0.000327"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:48.781929" elapsed="0.003051"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.830533" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:48.830135" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.831483" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.831183" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:48.831669" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:48.830834" elapsed="0.000861"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.832253" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:48.831865" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:48.832599" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:48.832771" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:48.832451" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.833205" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.832959" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.834291" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.834031" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.834796" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.834503" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.835780" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.835196" elapsed="0.000610"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.836962" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.836482" elapsed="0.000521"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.837126" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:48.837357" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.835999" elapsed="0.001383"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.837541" elapsed="0.000522"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:48.835055" elapsed="0.003051"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.838888" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:48.838359" elapsed="0.000555"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:48.840088" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.839625" elapsed="0.000504"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:48.840246" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:48.840462" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:48.839107" elapsed="0.001381"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.840676" elapsed="0.000599"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:48.838222" elapsed="0.003097"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.834876" elapsed="0.006479"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:48.841398" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:48.841561" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:48.833674" elapsed="0.007912"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.833327" elapsed="0.008292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.841826" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.841667" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.833304" elapsed="0.008599"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.842708" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:48.842100" elapsed="0.000643"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.842793" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:48.829452" elapsed="0.013465"/>
</kw>
<msg time="2026-06-06T03:29:48.842972" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.816508" elapsed="0.026527"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.856114" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.868681" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.881254" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.881480" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.881688" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.882114" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.881956" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:48.881937" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.882345" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.882517" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.882701" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:48.881897" elapsed="0.000860"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.881776" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.882938" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.883016" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:29:48.883168" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:48.810400" elapsed="0.072796"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.884503" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:48.884210" elapsed="0.000344"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:48.892012" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:48.892159" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:48.892323" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:29:48.892367" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.886726" elapsed="0.006284">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:48.884622" elapsed="0.008472">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.893299" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.893129" elapsed="0.000233"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:48.884603" elapsed="0.008783">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:48.897036" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.894500" elapsed="0.002570">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:48.894265" elapsed="0.002869">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:48.894245" elapsed="0.002922">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.899978" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.897471" elapsed="0.002541">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:48.897240" elapsed="0.002835">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:48.897222" elapsed="0.002886">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.900853" 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-06-06T03:29:48.900311" elapsed="0.000581"/>
</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-06-06T03:29:48.901335" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.900993" elapsed="0.000423"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.902135" 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-06-06T03:29:48.901709" elapsed="0.000463"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.901451" elapsed="0.000771"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.900966" elapsed="0.001286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.903019" 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-06-06T03:29:48.902485" elapsed="0.000572"/>
</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-06-06T03:29:48.903557" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.903157" elapsed="0.000570"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.904431" 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-06-06T03:29:48.904006" elapsed="0.000492"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.903767" elapsed="0.000819"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.903131" elapsed="0.001536"/>
</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-06-06T03:29:48.905050" elapsed="0.000886"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:48.907060" 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-06-06T03:29:48.906346" elapsed="0.000777"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:29:48.910341" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.907561" elapsed="0.002813">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:29:48.893805" elapsed="0.016708">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:48.910579" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:48.912993" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:29:48.913024" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:29:48.883548" elapsed="0.029505">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:48.913121" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:29:48.786063" elapsed="0.127229">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:48.785617" elapsed="0.127739"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:48.785212" elapsed="0.128205"/>
</kw>
<arg>source_active_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:48.434487" elapsed="0.478983"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.347726" elapsed="0.565863"/>
</test>
<test id="s1-s16-t13" name="Play_To_Odl_source_active_ad" line="106">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:48.916863" elapsed="0.000215"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:48.916574" elapsed="0.000560"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.918159" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.918046" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.918026" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.923351" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.923244" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.923226" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.924476" 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-06-06T03:29:48.924089" elapsed="0.000414"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.924998" 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-06-06T03:29:48.924684" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:48.925069" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:48.925226" 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-06-06T03:29:48.923702" elapsed="0.001549"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:48.930892" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.930770" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.930745" elapsed="0.000230"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:48.932261" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:48.932151" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.932132" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:48.932821" 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-06-06T03:29:48.932482" elapsed="0.000367"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:48.933240" level="INFO">${current_connection_index} = 7</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-06-06T03:29:48.933016" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:48.963493" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:48.933808" elapsed="0.029920"/>
</kw>
<msg time="2026-06-06T03:29:48.963946" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:48.963995" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:48.933432" elapsed="0.030607"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:48.990235" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "o "u "r "c "e "_ "a "c "t "i "v "e "_ "a "d "[K"
[?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-06-06T03:29:48.964756" elapsed="0.025625"/>
</kw>
<msg time="2026-06-06T03:29:48.990566" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:48.990612" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:29:48.964299" elapsed="0.026391"/>
</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-06-06T03:29:48.991091" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.990800" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.990767" elapsed="0.000408"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:48.991699" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "o "u "r "c "e "_ "a "c "t "i "v "e "_ "a "d "[K"
[?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-06-06T03:29:48.991324" elapsed="0.000452"/>
</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-06-06T03:29:48.992070" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.991846" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.991826" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:48.992185" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:48.995028" elapsed="0.000379"/>
</kw>
<msg time="2026-06-06T03:29:48.995479" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:48.993948" elapsed="0.001746"/>
</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="NOT RUN" start="2026-06-06T03:29:48.995984" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.996324" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:48.993274" elapsed="0.003236"/>
</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-06-06T03:29:48.992515" elapsed="0.004060"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:48.931840" elapsed="0.064984"/>
</kw>
<msg time="2026-06-06T03:29:48.996922" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:48.996968" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:48.931147" elapsed="0.065858"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:48.997252" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:48.997141" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.997120" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.997797" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.998144" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:48.998216" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:48.930329" elapsed="0.067995"/>
</kw>
<msg time="2026-06-06T03:29:48.998418" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:48.998463" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:48.925634" elapsed="0.072867"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:48.998852" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:48.998577" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:48.998559" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:48.925486" elapsed="0.073468"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:48.925310" elapsed="0.073676"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:48.922882" elapsed="0.076159"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:48.917753" elapsed="0.081345"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:48.917292" elapsed="0.081852"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:48.914373" elapsed="0.084827"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.000359" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:48.999880" elapsed="0.000507"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.001027" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.000563" elapsed="0.000492"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.001599" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.001224" elapsed="0.000402"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:49.002115" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/announce_source_active_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/announce_source_active_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:49.002282" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:49.001907" elapsed="0.000403"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:49.002674" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/withdraw_source_active_ad.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/withdraw_source_active_ad.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:49.002805" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:49.002468" elapsed="0.000366"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:49.002992" elapsed="0.002607"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:49.005795" elapsed="0.002079"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.061551" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:49.061132" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:49.062510" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:49.062238" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:49.062701" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:49.061881" elapsed="0.000846"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.063294" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:49.062901" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:49.063669" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:49.063837" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:49.063496" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.064274" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:49.064027" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.065428" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:49.065117" elapsed="0.000357"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.065937" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.065663" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.066763" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:49.066340" elapsed="0.000449"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:49.068075" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.067446" elapsed="0.000731"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:49.068260" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:29:49.068565" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:49.066984" elapsed="0.001607"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.068771" elapsed="0.000391"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:49.066199" elapsed="0.003005"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.069878" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:49.069457" elapsed="0.000447"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:49.071185" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.070597" elapsed="0.000689"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:49.071364" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:49.071686" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:49.070122" elapsed="0.001592"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:49.071874" elapsed="0.000374"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:49.069319" elapsed="0.002973"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:49.066019" elapsed="0.006309"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:49.072372" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:49.072529" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:49.064763" elapsed="0.007791"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:49.064400" elapsed="0.008188"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.072838" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:49.072616" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:49.064376" elapsed="0.008542"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.073888" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:49.073068" elapsed="0.000850"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:49.073969" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:49.060438" elapsed="0.013656"/>
</kw>
<msg time="2026-06-06T03:29:49.074150" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:49.047303" elapsed="0.026897"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.086830" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.099231" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.111620" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.111869" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.112055" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.112435" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:49.112285" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:49.112269" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.112674" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.112847" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.113016" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:49.112239" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.112134" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.113242" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.113315" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:49.113439" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:49.042881" elapsed="0.070621"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:49.114831" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:49.114546" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:49.114997" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:49.114187" elapsed="0.000834"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.115344" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:49.115092" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.115938" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:49.115609" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:49.115426" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:49.115073" elapsed="0.000949"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.118349" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:49.116176" elapsed="0.002200"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:49.118427" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:49.118581" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:49.113854" elapsed="0.004752"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:49.119917" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:49.119597" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:49.120076" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:49.119258" elapsed="0.000843"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:49.120308" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:29:49.120172" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:49.120153" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.120547" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.120738" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.120805" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:49.122902" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:49.118931" elapsed="0.003998"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.124349" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:49.124099" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:49.124810" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:49.124550" elapsed="0.000304"/>
</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-06-06T03:29:49.133520" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:49.133719" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:49.133818" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:29:49.126989" elapsed="0.007199">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:49.124918" elapsed="0.009353">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:49.134471" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:49.134305" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:49.124900" elapsed="0.009660">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:29:49.134956" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.135089" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:49.135052" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:49.135034" elapsed="0.000118"/>
</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-06-06T03:29:49.135300" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.135370" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:29:49.123245" elapsed="0.012229">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.135550" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:29:49.019341" elapsed="0.116320">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:49.135978" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:49.135787" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:49.135740" elapsed="0.000334"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:49.136107" elapsed="0.000014"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:49.012676" elapsed="0.123527">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.194921" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.194440" elapsed="0.000516"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.195833" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.195559" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.196008" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.195209" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.196599" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.196204" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.196955" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.197111" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.196812" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.197547" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.197300" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.198699" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.198327" elapsed="0.000419"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.199204" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.198910" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.200040" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.199602" elapsed="0.000464"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.201284" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.200731" elapsed="0.000654"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.201464" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:51.201782" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.200256" elapsed="0.001553"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.201973" elapsed="0.000381"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:51.199461" elapsed="0.002934"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.203114" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.202709" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.204345" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.203803" elapsed="0.000641"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.204523" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:51.204885" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.203330" elapsed="0.001582"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.205069" elapsed="0.000365"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:51.202508" elapsed="0.002967"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.199284" elapsed="0.006227"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.205554" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:51.205728" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:51.197999" elapsed="0.007755"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.197692" elapsed="0.008094"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.205965" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.205813" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.197668" elapsed="0.008375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.207026" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.206226" elapsed="0.000830"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.207107" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.193806" elapsed="0.013425"/>
</kw>
<msg time="2026-06-06T03:29:51.207286" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.181101" elapsed="0.026233"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.220139" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.233007" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.245390" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.245597" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.245794" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.246180" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.246028" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.246012" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.246403" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.246572" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.246782" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.245980" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.245874" elapsed="0.000988"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.247015" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.247090" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:51.247226" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.176624" elapsed="0.070629"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.248624" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.248362" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.248808" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.247993" elapsed="0.000840"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.249160" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.248904" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.249737" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.249429" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.249241" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.248885" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.252243" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.249974" elapsed="0.002295"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:51.252321" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:51.252473" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.247630" elapsed="0.004868"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.253743" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.253496" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.253908" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.253155" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:51.254141" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:51.254004" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.253985" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.254375" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.254550" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.254653" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:51.256740" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.252826" elapsed="0.003940"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.258167" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.257914" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.258613" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.258370" elapsed="0.000341"/>
</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-06-06T03:29:51.266559" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:51.266988" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:51.267125" 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-06-06T03:29:51.260852" elapsed="0.006300"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.258784" elapsed="0.008412"/>
</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-06-06T03:29:51.267382" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.267222" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.258765" elapsed="0.008703"/>
</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-06-06T03:29:51.272298" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.268918" elapsed="0.003449"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.268582" elapsed="0.003835"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.268555" elapsed="0.003897"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.275950" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.272871" elapsed="0.003125"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.272531" elapsed="0.003500"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.272507" elapsed="0.003549"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.276609" 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-06-06T03:29:51.276229" elapsed="0.000407"/>
</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-06-06T03:29:51.276973" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.276725" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.277524" 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-06-06T03:29:51.277224" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.277057" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.276706" elapsed="0.000903"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.278152" 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-06-06T03:29:51.277789" elapsed="0.000390"/>
</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-06-06T03:29:51.278488" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.278250" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.279201" 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-06-06T03:29:51.278876" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.278581" elapsed="0.000692"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.278231" elapsed="0.001063"/>
</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-06-06T03:29:51.279448" elapsed="0.000362"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:51.280266" 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-06-06T03:29:51.279981" elapsed="0.000311"/>
</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-06-06T03:29:51.280453" elapsed="0.002449"/>
</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-06-06T03:29:51.267993" elapsed="0.014975"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.283151" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:51.283039" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.283020" elapsed="0.000197"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.286142" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:51.283367" elapsed="0.002804"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:51.286225" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:51.286380" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:51.257081" elapsed="0.029327"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.286505" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:51.286692" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:51.151373" elapsed="0.135347"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.315099" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.314430" elapsed="0.000698"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.316097" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.315637" elapsed="0.000581">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.316394" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.315296" elapsed="0.001123"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.317063" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.316593" elapsed="0.000498"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.317417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.317575" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.317259" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.318048" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "source-active-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "multicast-source": "1.0.0.1",
          "multicast-group": "2.0.0.2"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.317780" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:51.318566" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.318164" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.319345" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.318842" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.318667" elapsed="0.000741"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.318144" elapsed="0.001284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.320095" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.319578" elapsed="0.000546"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.320176" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.313781" elapsed="0.006520"/>
</kw>
<msg time="2026-06-06T03:29:51.320357" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.301096" elapsed="0.019341"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.334536" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.347235" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.359814" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.360017" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.360201" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.360591" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.360434" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.360418" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.360837" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.361014" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.361189" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.360388" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.360281" elapsed="0.000989"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.361422" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.361499" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:51.361652" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.298418" elapsed="0.063264"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.361865" elapsed="0.002292"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.365361" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.364929" elapsed="0.000461"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.366033" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.365607" elapsed="0.000455"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:51.366225" elapsed="0.000331"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:51.364479" elapsed="0.002138"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.364237" elapsed="0.002431"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.366881" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.366694" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.364218" elapsed="0.002743"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:51.287879" elapsed="0.079129"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:51.287051" elapsed="0.080032"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.286808" elapsed="0.080320"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.286791" elapsed="0.080361"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.367185" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:51.145893" elapsed="0.221418"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:49.008057" elapsed="2.359312"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.466236" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.465842" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.467073" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.466802" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.467243" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.466446" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.467840" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.467436" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.468175" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.468337" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.468033" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.468790" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.468523" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.469879" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.469547" elapsed="0.000378"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.470358" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.470089" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.471280" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.470843" elapsed="0.000464"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.472548" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.471987" elapsed="0.000684"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.472755" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:51.473056" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.471502" elapsed="0.001582"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.473246" elapsed="0.000383"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:51.470700" elapsed="0.002988"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.474346" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.473941" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.475764" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.475193" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.476085" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:51.476384" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.474563" elapsed="0.001848"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.476570" elapsed="0.000392"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:51.473802" elapsed="0.003203"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.470495" elapsed="0.006546"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.477084" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:51.477244" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:51.469219" elapsed="0.008051"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.468913" elapsed="0.008390"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.477482" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.477328" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.468889" elapsed="0.008672"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.478302" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.477723" elapsed="0.000609"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.478381" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.465200" elapsed="0.013306"/>
</kw>
<msg time="2026-06-06T03:29:51.478561" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.452462" elapsed="0.026147"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.491196" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.503633" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.516213" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.516426" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.516609" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.517003" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.516852" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.516835" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.517227" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.517417" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.517793" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.516805" elapsed="0.001055"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.516702" elapsed="0.001185"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.518056" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.518134" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:51.518264" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.448055" elapsed="0.070236"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.519727" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.519429" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.519894" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.519027" elapsed="0.000891"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.520244" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.519990" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.520905" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.520509" elapsed="0.000423"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.520325" elapsed="0.000644"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.519971" elapsed="0.001019"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.523593" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.521147" elapsed="0.002474"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:51.523690" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:51.523846" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.518628" elapsed="0.005243"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.525238" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.524958" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.525441" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.524546" elapsed="0.000920"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:51.525692" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:29:51.525537" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.525518" elapsed="0.000268"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.525945" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.526153" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.526227" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:51.528236" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.524183" elapsed="0.004080"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.529700" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.529418" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.530193" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.529909" elapsed="0.000338"/>
</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-06-06T03:29:51.538709" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:51.539071" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:51.539368" 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-06-06T03:29:51.532523" elapsed="0.006910"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.530329" elapsed="0.009212"/>
</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-06-06T03:29:51.540040" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.539606" elapsed="0.000592"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.530309" elapsed="0.009941"/>
</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-06-06T03:29:51.546984" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.542802" elapsed="0.004280"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.542212" elapsed="0.004923"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.542165" elapsed="0.005007"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.550823" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.547586" elapsed="0.003303"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.547255" elapsed="0.003683"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.547230" elapsed="0.003743"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.551850" 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-06-06T03:29:51.551274" elapsed="0.000616"/>
</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-06-06T03:29:51.552339" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.551992" elapsed="0.000430"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.553146" 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-06-06T03:29:51.552721" elapsed="0.000535"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.552457" elapsed="0.000852"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.551965" elapsed="0.001374"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.554103" 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-06-06T03:29:51.553569" elapsed="0.000573"/>
</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-06-06T03:29:51.554577" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.554240" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.555379" 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-06-06T03:29:51.554950" elapsed="0.000466"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.554715" elapsed="0.000751"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.554214" elapsed="0.001282"/>
</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-06-06T03:29:51.555946" elapsed="0.000544"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:51.557168" 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-06-06T03:29:51.556761" elapsed="0.000443"/>
</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-06-06T03:29:51.557429" elapsed="0.002935"/>
</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-06-06T03:29:51.541143" elapsed="0.019289"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.560613" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:51.560503" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.560484" elapsed="0.000216"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.563664" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:51.560852" elapsed="0.002843"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:51.563748" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:51.563911" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:51.528579" elapsed="0.035359"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.564003" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:51.564156" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:51.376375" elapsed="0.187807"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.593037" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.592545" elapsed="0.000521"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.593897" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.593580" elapsed="0.000441">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.594198" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.593236" elapsed="0.000988"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.594857" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.594395" elapsed="0.000531"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.595279" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.595437" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.595114" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.595918" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "source-active-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "multicast-source": "1.0.0.1",
          "multicast-group": "2.0.0.2"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.595631" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:51.596439" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.596037" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.597198" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.596692" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.596524" elapsed="0.000737"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.596017" elapsed="0.001265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.597950" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.597433" elapsed="0.000546"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.598029" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.591926" elapsed="0.006228"/>
</kw>
<msg time="2026-06-06T03:29:51.598213" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.578997" elapsed="0.019264"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.610784" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.623691" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.636193" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.636405" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.636636" elapsed="0.000041"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.637054" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.636902" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.636886" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.637280" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.637452" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.637623" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.636855" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.636743" elapsed="0.000977"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.637873" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.637950" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:51.638096" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.576291" elapsed="0.061833"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.638304" elapsed="0.002438"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.641958" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.641500" elapsed="0.000487"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.642544" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.642145" elapsed="0.000427"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:51.642747" elapsed="0.000333"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:51.641073" elapsed="0.002097"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.640825" elapsed="0.002385"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.643393" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.643238" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.640805" elapsed="0.002663"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:51.565342" elapsed="0.078176"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:51.564517" elapsed="0.079078"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.564266" elapsed="0.079390"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.564249" elapsed="0.079433"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.643716" elapsed="0.000031"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:51.371991" elapsed="0.271856"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:51.367546" elapsed="0.276361"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.693420" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.693042" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.694205" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.693974" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.694375" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.693615" elapsed="0.000785"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.694970" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.694567" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.695331" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.695484" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.695162" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.695938" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.695691" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.697142" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.696684" elapsed="0.000505"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.697633" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.697356" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.698451" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.698047" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.699734" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.699142" elapsed="0.000693"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.699913" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:51.700209" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.698688" elapsed="0.001546"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.700394" elapsed="0.000402"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:51.697908" elapsed="0.002929"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.701482" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.701085" elapsed="0.000423"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.702732" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.702167" elapsed="0.000670"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.702915" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:51.703245" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.701711" elapsed="0.001561"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.703429" elapsed="0.000391"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:51.700950" elapsed="0.002911"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.697733" elapsed="0.006163"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.703970" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:51.704133" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:51.696345" elapsed="0.007813"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.696050" elapsed="0.008141"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.704369" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.704216" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.696031" elapsed="0.008415"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.705180" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.704593" elapsed="0.000616"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.705258" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.692406" elapsed="0.012976"/>
</kw>
<msg time="2026-06-06T03:29:51.705437" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.679563" elapsed="0.025922"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.718094" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.730907" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.743488" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.743727" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.743915" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.744332" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.744174" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.744156" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.744562" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.744750" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.744921" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.744116" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.744000" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.745153" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.745297" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:29:51.745448" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.675307" elapsed="0.070169"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.746885" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.746587" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.747053" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.746192" elapsed="0.000886"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.747460" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.747152" elapsed="0.000368"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.748280" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.747750" elapsed="0.000557"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.747546" elapsed="0.000799"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.747131" elapsed="0.001235"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.750740" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.748528" elapsed="0.002239"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:51.750821" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:51.750982" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.745833" elapsed="0.005175"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.752354" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.752095" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.752520" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.751739" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:51.752775" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:51.752616" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.752597" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.753011" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.753188" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.753256" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:51.755187" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.751368" elapsed="0.003845"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.756633" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.756378" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.757099" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.756856" elapsed="0.000286"/>
</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-06-06T03:29:51.765183" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:51.765386" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '356'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:29:51.765483" 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-06-06T03:29:51.759313" elapsed="0.006197"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.757208" elapsed="0.008346"/>
</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-06-06T03:29:51.765766" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.765580" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.757190" elapsed="0.008664"/>
</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-06-06T03:29:51.770360" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.766901" elapsed="0.003528"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.766669" elapsed="0.003816"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.766630" elapsed="0.003902"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.774276" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.770998" elapsed="0.003341"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.770627" elapsed="0.003762"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.770597" elapsed="0.003826"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.775247" 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-06-06T03:29:51.774696" elapsed="0.000589"/>
</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-06-06T03:29:51.775759" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.775431" elapsed="0.000387"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.776348" 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-06-06T03:29:51.776020" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.775843" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.775404" elapsed="0.001029"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.776996" 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-06-06T03:29:51.776602" elapsed="0.000422"/>
</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-06-06T03:29:51.777337" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.777095" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.777938" 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-06-06T03:29:51.777609" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.777420" elapsed="0.000583"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.777076" elapsed="0.000949"/>
</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-06-06T03:29:51.778192" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:51.779057" 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-06-06T03:29:51.778758" elapsed="0.000327"/>
</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-06-06T03:29:51.779251" elapsed="0.002468"/>
</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-06-06T03:29:51.766222" elapsed="0.015566"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.781970" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:51.781859" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.781839" elapsed="0.000243"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.785184" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:51.782239" elapsed="0.002976"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:51.785269" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:51.785431" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:51.755546" elapsed="0.029911"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.785520" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:51.785689" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:51.652774" elapsed="0.132942"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.814620" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.814138" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.815534" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.815202" elapsed="0.000476">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.815859" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.814854" elapsed="0.001031"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.816503" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.816059" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.816948" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_active_ad/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.817134" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.816758" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.817636" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "source-active-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "multicast-source": "1.0.0.1",
          "multicast-group": "2.0.0.2"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.817360" elapsed="0.000344"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:51.818216" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.817779" elapsed="0.000497"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.818978" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.818452" elapsed="0.000563"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.818302" elapsed="0.000757"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.817757" elapsed="0.001326"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.820018" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.819256" elapsed="0.000838"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.820150" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.813492" elapsed="0.006814"/>
</kw>
<msg time="2026-06-06T03:29:51.820381" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.800364" elapsed="0.020077"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.834491" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.847046" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_active_ad/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.859510" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.859734" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.859921" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.860319" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.860166" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.860151" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.860553" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.860742" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.860914" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.860117" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.860007" elapsed="0.000988"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.861146" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.861223" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:51.861369" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
        "attributes": {
          "ipv4-next-hop": {
    ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.797718" elapsed="0.063679"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.861632" elapsed="0.002449"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.865300" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.864861" elapsed="0.000468"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:51.865916" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.865490" elapsed="0.000455"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:51.866106" elapsed="0.000333"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:51.864414" elapsed="0.002087"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.864164" elapsed="0.002372"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.866734" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.866561" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.864144" elapsed="0.002670"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:51.786875" elapsed="0.079989"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:51.786050" elapsed="0.080892"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.785802" elapsed="0.081188"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.785784" elapsed="0.081231"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.867049" elapsed="0.000030"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:51.648410" elapsed="0.218771"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:51.644123" elapsed="0.223120"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:51.867435" elapsed="0.002707"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.922782" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.922357" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.923713" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.923396" elapsed="0.000399">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.923891" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.923002" elapsed="0.000914"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.924504" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.924091" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.924869" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.925028" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.924724" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.925537" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.925282" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.926972" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.926633" elapsed="0.000387"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.927553" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.927192" elapsed="0.000394"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.928423" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.928002" elapsed="0.000449"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.930235" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.929420" elapsed="0.000960"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.930496" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:29:51.930944" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.928762" elapsed="0.002219"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.931209" elapsed="0.000614"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:51.927857" elapsed="0.004029"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.932848" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.932245" elapsed="0.000640"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:51.934609" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.933830" elapsed="0.000946"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:51.934888" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:29:51.935304" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:51.933154" elapsed="0.002187"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:51.935625" elapsed="0.000545"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:51.932050" elapsed="0.004180"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.927669" elapsed="0.008608"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:51.936338" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:29:51.936549" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:51.926062" elapsed="0.010512"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.925695" elapsed="0.010912"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.936827" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.936633" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.925670" elapsed="0.011234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.937669" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:51.937052" elapsed="0.000647"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:51.937749" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:51.921671" elapsed="0.016202"/>
</kw>
<msg time="2026-06-06T03:29:51.937928" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:51.908373" elapsed="0.029605"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.950566" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.963181" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.975786" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.976011" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.976203" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.976630" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.976467" elapsed="0.000236"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:51.976448" elapsed="0.000282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.976881" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.977057" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.977227" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:51.976408" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.976291" elapsed="0.001017"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.977459" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.977544" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:29:51.977705" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:51.904094" elapsed="0.073794"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.979272" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.978986" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:51.979443" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.978576" elapsed="0.000893"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:51.979856" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.979540" elapsed="0.000377"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.981678" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:51.980128" elapsed="0.001579"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.979942" elapsed="0.001803"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.979521" elapsed="0.002246"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.984135" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:51.981927" elapsed="0.002235"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:51.984214" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:51.984427" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.978222" elapsed="0.006231"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.985664" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.985459" elapsed="0.000260"/>
</kw>
<msg time="2026-06-06T03:29:51.985805" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:51.985113" elapsed="0.000716"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:51.986036" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:51.985900" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.985881" elapsed="0.000221"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:51.986414" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:51.986566" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:51.986249" elapsed="0.000342"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:51.987008" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:51.986768" elapsed="0.000266"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:51.987082" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:51.987234" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:51.984779" elapsed="0.002480"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.988701" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.988430" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:51.989154" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:51.988908" elapsed="0.000290"/>
</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-06-06T03:29:51.997351" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:51.998026" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '501'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:29:51.998180" 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-06-06T03:29:51.991350" elapsed="0.006866"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.989265" elapsed="0.009013"/>
</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-06-06T03:29:51.998541" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:51.998315" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.989246" elapsed="0.009468"/>
</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-06-06T03:29:52.003753" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BRIAAQECAwQBAiABAAABIAIAAAI=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-active-a-d":{"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","multicast-group":"2.0.0.2"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:52.000159" elapsed="0.003668"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:51.999843" elapsed="0.004034"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:51.999815" elapsed="0.004098"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.007574" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:52.004368" elapsed="0.003307"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:52.004041" elapsed="0.003685"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:52.004015" elapsed="0.003746"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.008538" 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-06-06T03:29:52.008002" elapsed="0.000574"/>
</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-06-06T03:29:52.009043" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:52.008700" elapsed="0.000424"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.009837" 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-06-06T03:29:52.009392" elapsed="0.000483"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:52.009158" elapsed="0.000767"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:52.008672" elapsed="0.001284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.010716" 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-06-06T03:29:52.010187" elapsed="0.000567"/>
</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-06-06T03:29:52.011192" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:52.010854" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.011988" 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-06-06T03:29:52.011536" elapsed="0.000488"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:52.011305" elapsed="0.000770"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:52.010828" elapsed="0.001277"/>
</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-06-06T03:29:52.012324" elapsed="0.000509"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:52.013617" 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-06-06T03:29:52.013134" elapsed="0.000552"/>
</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-06-06T03:29:52.013968" elapsed="0.003780"/>
</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-06-06T03:29:51.999212" elapsed="0.018618"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:52.018045" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:52.017922" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:52.017896" elapsed="0.000244"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:52.021580" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:29:52.018325" elapsed="0.003284"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:52.021680" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:52.021845" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:51.987568" elapsed="0.034304"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:52.021936" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:52.022084" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:51.881416" elapsed="0.140695"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.050874" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:52.050371" elapsed="0.000618"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:52.051832" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:52.051508" elapsed="0.000453">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:52.052136" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:52.051165" elapsed="0.000996"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.052796" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:52.052330" elapsed="0.000494"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:52.053153" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:52.053304" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:52.052991" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.053784" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:52.053494" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:52.054299" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:52.053899" elapsed="0.000461"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.055060" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:52.054537" elapsed="0.000550"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:52.054385" elapsed="0.000739"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:52.053880" elapsed="0.001265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.055830" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:52.055297" elapsed="0.000563"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:52.055910" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:52.049751" elapsed="0.006286"/>
</kw>
<msg time="2026-06-06T03:29:52.056091" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:52.036995" elapsed="0.019144"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.068995" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.082153" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.094708" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.094914" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.095095" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.095490" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:52.095339" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:52.095323" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.095765" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.095944" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.096113" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:52.095291" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:52.095180" elapsed="0.001014"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.096344" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:52.096420" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:52.096544" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:52.034312" elapsed="0.062260"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:52.096770" elapsed="0.002224"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:52.100164" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:52.099850" elapsed="0.000342"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:52.100984" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:52.100351" elapsed="0.000661"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:29:52.101491" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "path-id": 0,
      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
      "source-active-a-d": {
       "multicast-group": "2.0.0.2",
       "multicast-source": "1.0.0.1",
       "route-distinguisher": "1.2.3.4:258"
      }
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:29:52.101700" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:29:52.101174" elapsed="0.000636">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:29:52.099317" elapsed="0.002642">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:52.099073" elapsed="0.002965">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:52.102227" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:52.102073" elapsed="0.000210"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:52.099054" elapsed="0.003252">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:29:52.023311" elapsed="0.079119">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:29:52.022455" elapsed="0.080125">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:52.022194" elapsed="0.080493">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:52.022176" elapsed="0.080548">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:52.102801" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:51.875602" elapsed="0.227323">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,33 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BRIAAQECAwQBAiABAAABIAIAAAI=",
+      "source-active-a-d": {
+       "multicast-group": "2.0.0.2",
+       "multicast-source": "1.0.0.1",
+       "route-distinguisher": "1.2.3.4:258"
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.160300" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.159896" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.161235" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.160963" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.161413" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.160518" elapsed="0.000919"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.162043" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.161610" elapsed="0.000462"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.162417" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.162587" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.162244" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.163047" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.162797" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.164142" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.163825" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.164630" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.164356" elapsed="0.000325"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.165465" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.165056" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.166801" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.166169" elapsed="0.000736"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.166990" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:54.167341" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.165707" elapsed="0.001661"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.167538" elapsed="0.000422"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:54.164915" elapsed="0.003087"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.168844" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.168255" elapsed="0.000616"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.170083" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.169517" elapsed="0.000670"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.170265" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:54.170658" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.169062" elapsed="0.001624"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.170847" elapsed="0.000373"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:54.168117" elapsed="0.003146"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.164737" elapsed="0.006561"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.171342" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:54.171500" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:54.163480" elapsed="0.008045"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.163171" elapsed="0.008387"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.171793" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.171584" elapsed="0.000268"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.163146" elapsed="0.008728"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.172605" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:54.172021" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.172702" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:54.159250" elapsed="0.013580"/>
</kw>
<msg time="2026-06-06T03:29:54.172885" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.146411" elapsed="0.026524"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.185624" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.198122" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.210472" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.210690" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.210874" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.211247" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.211099" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:54.211084" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.211468" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.211699" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.211875" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:54.211053" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.210952" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.212103" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.212180" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:54.212303" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:54.142024" elapsed="0.070306"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.213634" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.213371" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.213818" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.213013" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.214168" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.213913" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.214796" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.214447" elapsed="0.000376"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.214250" elapsed="0.000610"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.213894" elapsed="0.000987"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.217381" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.215037" elapsed="0.002372"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:54.217462" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:54.217616" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:54.212674" elapsed="0.004980"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.218984" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.218790" elapsed="0.000247"/>
</kw>
<msg time="2026-06-06T03:29:54.219123" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.218300" elapsed="0.000847"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.219354" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.219218" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.219199" elapsed="0.000221"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.219765" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.219911" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.219567" elapsed="0.000369"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:54.220332" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.220097" elapsed="0.000261"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:54.220404" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:54.220556" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:54.217965" elapsed="0.002649"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.222022" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.221773" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.222484" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.222227" elapsed="0.000300"/>
</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-06-06T03:29:54.230307" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:54.230480" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:29:54.230600" 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-06-06T03:29:54.224694" elapsed="0.005934"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.222593" elapsed="0.008112"/>
</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-06-06T03:29:54.231110" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.230738" elapsed="0.000441"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.222574" elapsed="0.008627"/>
</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-06-06T03:29:54.235062" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.232511" elapsed="0.002599"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.232265" elapsed="0.002879"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.232243" elapsed="0.002927"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.237913" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.235455" elapsed="0.002504"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.235228" elapsed="0.002767"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.235210" elapsed="0.002811"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.238618" 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-06-06T03:29:54.238208" elapsed="0.000453"/>
</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-06-06T03:29:54.238984" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.238735" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.239541" 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-06-06T03:29:54.239239" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.239068" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.238716" elapsed="0.000909"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.240171" 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-06-06T03:29:54.239807" 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-06-06T03:29:54.240513" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.240269" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.241075" 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-06-06T03:29:54.240778" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.240594" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.240250" 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-06-06T03:29:54.241315" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:54.242136" 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-06-06T03:29:54.241850" elapsed="0.000313"/>
</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-06-06T03:29:54.242385" elapsed="0.002357"/>
</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-06-06T03:29:54.231608" elapsed="0.013201"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.244989" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.244880" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.244860" elapsed="0.000199"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:54.247884" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:29:54.245211" elapsed="0.002703"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:54.247967" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:54.248130" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:54.220944" elapsed="0.027211"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.248220" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:54.248371" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:54.118701" elapsed="0.129696"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.277050" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.276556" elapsed="0.000523"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.277909" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.277589" elapsed="0.000450">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.278215" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.277250" elapsed="0.000991"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.278950" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.278411" elapsed="0.000568"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.279309" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.279462" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.279147" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.279946" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.279672" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:54.280471" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.280062" elapsed="0.000470"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.281238" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.280726" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.280557" elapsed="0.000745"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.280042" elapsed="0.001282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.282158" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:54.281562" elapsed="0.000626"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.282239" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:54.275931" elapsed="0.006436"/>
</kw>
<msg time="2026-06-06T03:29:54.282422" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.262969" elapsed="0.019536"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.295477" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.308358" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.321196" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.321405" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.321591" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.322001" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.321846" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:54.321831" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.322228" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.322403" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.322991" elapsed="0.000112"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:54.321800" elapsed="0.001429"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.321690" elapsed="0.001612"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.323751" elapsed="0.000051"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.323939" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:29:54.324466" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:54.260263" elapsed="0.064274"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.325185" elapsed="0.005966"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:54.332625" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.332291" elapsed="0.000378"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:54.333105" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.332832" elapsed="0.000300"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.333295" elapsed="0.000362"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.331828" elapsed="0.001893"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.331359" elapsed="0.002397"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.333940" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.333784" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.331309" elapsed="0.002708"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:54.249573" elapsed="0.084497"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:54.248768" elapsed="0.085385"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.248504" elapsed="0.085699"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.248465" elapsed="0.085765"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.334266" elapsed="0.000036"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:54.112185" elapsed="0.222223"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:51.870339" elapsed="2.464133"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:54.334732" elapsed="0.003298"/>
</kw>
<arg>source_active_ad</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:48.999458" elapsed="5.338632"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:48.913929" elapsed="5.424287"/>
</test>
<test id="s1-s16-t14" name="Odl_To_Play_shared_tree_join" line="110">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:54.342862" elapsed="0.000369"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:54.342410" elapsed="0.000908"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.344851" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.344670" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.344619" elapsed="0.000332"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.355472" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.355228" elapsed="0.000346"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.355187" elapsed="0.000438"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.357928" 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-06-06T03:29:54.357042" elapsed="0.000947"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.359102" 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-06-06T03:29:54.358356" elapsed="0.000803"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:54.359259" elapsed="0.000176"/>
</return>
<msg time="2026-06-06T03:29:54.359665" 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-06-06T03:29:54.356167" elapsed="0.003524"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:54.365373" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.365261" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.365241" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:54.366678" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.366522" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.366503" elapsed="0.000246"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:54.367206" 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-06-06T03:29:54.366901" elapsed="0.000332"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:54.367619" level="INFO">${current_connection_index} = 7</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-06-06T03:29:54.367399" elapsed="0.000260"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:54.398232" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:54.368168" elapsed="0.030328"/>
</kw>
<msg time="2026-06-06T03:29:54.398992" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:54.399098" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:54.367828" elapsed="0.031350"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:54.426238" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "h "a "r "e "d "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:29:54.400228" elapsed="0.026117"/>
</kw>
<msg time="2026-06-06T03:29:54.426508" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:54.426554" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:29:54.399617" elapsed="0.026972"/>
</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-06-06T03:29:54.426986" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.426727" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.426699" elapsed="0.000369"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.427521" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "h "a "r "e "d "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:29:54.427217" elapsed="0.000375"/>
</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-06-06T03:29:54.427901" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.427676" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.427655" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:54.428014" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:54.430726" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:29:54.430939" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.429571" elapsed="0.001502"/>
</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="NOT RUN" start="2026-06-06T03:29:54.431354" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.431714" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:54.428922" elapsed="0.002976"/>
</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-06-06T03:29:54.428339" elapsed="0.003623"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:54.366220" elapsed="0.065895"/>
</kw>
<msg time="2026-06-06T03:29:54.432211" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:54.432257" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:54.365599" elapsed="0.066694"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:54.432481" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:29:54.432371" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.432351" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.432996" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.433338" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.433410" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:54.364915" elapsed="0.068605"/>
</kw>
<msg time="2026-06-06T03:29:54.433616" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:54.433675" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:54.360085" elapsed="0.073627"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.434044" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.433789" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.433771" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:54.359936" elapsed="0.074209"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:54.359755" elapsed="0.074424"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:54.354358" elapsed="0.079878"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:54.344229" elapsed="0.090064"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:54.343549" elapsed="0.090790"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:54.339212" elapsed="0.095181"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.435495" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/announce_shared_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/announce_shared_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.435685" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.435290" elapsed="0.000423"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:54.436086" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.435874" elapsed="0.000239"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.436460" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/withdraw_shared_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/withdraw_shared_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.436586" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.436272" elapsed="0.000340"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:29:54.437209" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.436786" elapsed="0.000451"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:54.437528" elapsed="0.017629"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.437309" elapsed="0.017885"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.437290" elapsed="0.017930"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.493964" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.493566" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.494803" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.494502" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.494982" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.494163" elapsed="0.000843"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.495566" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.495180" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.495914" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.496045" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.495777" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.496477" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.496233" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.497493" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.497237" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.497998" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.497720" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.498747" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.498397" elapsed="0.000377"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.499869" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.499292" elapsed="0.000604"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.499948" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:54.500101" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.498967" elapsed="0.001160"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.500287" elapsed="0.000252"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:54.498255" elapsed="0.002325"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.501150" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.500851" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.502109" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.501703" elapsed="0.000433"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.502186" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:54.502335" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.501364" elapsed="0.000995"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.502517" elapsed="0.000266"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:54.500712" elapsed="0.002113"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.498077" elapsed="0.004782"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.502901" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:54.503059" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:54.496908" elapsed="0.006176"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.496590" elapsed="0.006561"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.503332" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.503177" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.496570" elapsed="0.006837"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.504168" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:54.503555" elapsed="0.000642"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.504246" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:54.492946" elapsed="0.011424"/>
</kw>
<msg time="2026-06-06T03:29:54.504425" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.480057" elapsed="0.024414"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.517288" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.530031" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.542433" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.542636" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.542850" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.543221" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.543072" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:54.543056" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.543446" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.543618" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.543806" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:54.543028" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.542928" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.544034" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.544143" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:54.544265" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:54.475741" elapsed="0.068551"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.573812" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.573275" elapsed="0.000578"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.574937" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.574545" elapsed="0.000497">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.575165" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.574089" elapsed="0.001109"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.575942" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.575423" elapsed="0.000556"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.576384" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.576598" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BhYAAQECAwQBAgAAABAgAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.576200" elapsed="0.000438"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.577206" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BhYAAQECAwQBAgAAABAgAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;shared-tree-join&gt;
      &lt;c-multicast&gt;
        &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;16&lt;/source-as&gt;
        &lt;c-g-address&gt;2.0.0.2&lt;/c-g-address&gt;
      &lt;/c-multicast&gt;
    &lt;/shared-tree-join&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.576877" elapsed="0.000409"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:54.577777" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.577385" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.578438" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.578097" elapsed="0.000371"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.577882" elapsed="0.000627"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.577354" elapsed="0.001181"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.579258" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BhYAAQECAwQBAgAAABAgAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:54.578727" elapsed="0.000567"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.579350" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:54.572453" elapsed="0.007038"/>
</kw>
<msg time="2026-06-06T03:29:54.579598" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.555784" elapsed="0.023880"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.592184" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.604797" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.619593" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.619808" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.619989" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.620374" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.620226" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:54.620210" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.620595" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.620784" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.620953" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:54.620180" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.620070" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.621181" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.621255" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:54.621382" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BhYAAQECAwQBAgAAABAgAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:54.554839" elapsed="0.066571"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.622716" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.622438" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.622952" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.622093" elapsed="0.000885"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.623301" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.623050" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.623881" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.623566" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.623382" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.623031" elapsed="0.000933"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.626475" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.624121" elapsed="0.002381"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:54.626553" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:54.626722" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:54.621764" elapsed="0.004983"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.628305" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.628056" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.628771" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BhYAAQECAwQBAgAAABAgAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;shared-tree-join&gt;
      &lt;c-multicast&gt;
        &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;16&lt;/source-as&gt;
        &lt;c-g-address&gt;2.0.0.2&lt;/c-g-address&gt;
      &lt;/c-multicast&gt;
    &lt;/shared-tree-join&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.628509" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.629230" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.628984" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.629684" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.629428" elapsed="0.000300"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:54.630540" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:29:54.630341" elapsed="0.000225"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:29:54.630965" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:29:54.630740" elapsed="0.000251"/>
</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-06-06T03:29:54.631143" elapsed="0.000210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.631781" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.631512" elapsed="0.000313"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:29:54.631866" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:54.632020" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:29:54.629933" elapsed="0.002112"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:54.646070" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '796', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BhYAAQECAwQBAgAAABAgAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;shared-tree-join&gt;
      &lt;c-multicast&gt;
        &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;16&lt;/source-as&gt;
        &lt;c-g-address&gt;2.0.0.2&lt;/c-g-address&gt;
      &lt;/c-multicast&gt;
    &lt;/shared-tree-join&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:29:54.646204" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=BhYAAQECAwQBAgAAABAgAQAAASACAAAC,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:54.646350" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:54.634213" elapsed="0.012174"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.632114" elapsed="0.014337"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.646736" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.646487" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.632097" elapsed="0.014764"/>
</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-06-06T03:29:54.654126" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.648817" elapsed="0.005407"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.648283" elapsed="0.006018"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.648240" elapsed="0.006120"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.660874" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.655134" elapsed="0.005846"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.654485" elapsed="0.006574"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.654447" elapsed="0.006668"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.662381" 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-06-06T03:29:54.661496" elapsed="0.000946"/>
</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-06-06T03:29:54.663232" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.662599" elapsed="0.000764"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.664630" 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-06-06T03:29:54.663968" elapsed="0.000749"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.663419" elapsed="0.001376"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.662558" elapsed="0.002284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.666038" 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-06-06T03:29:54.665207" elapsed="0.000890"/>
</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-06-06T03:29:54.666816" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.666252" elapsed="0.000735"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.667829" 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-06-06T03:29:54.667412" elapsed="0.000443"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.667043" elapsed="0.000847"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.666212" elapsed="0.001699"/>
</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-06-06T03:29:54.668065" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:54.668884" 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-06-06T03:29:54.668578" elapsed="0.000331"/>
</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-06-06T03:29:54.669069" elapsed="0.002316"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:29:54.647400" elapsed="0.024047"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:54.671626" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:29:54.671520" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.671501" elapsed="0.000228"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:29:54.671883" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.671950" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:54.674225" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:29:54.627106" elapsed="0.047146"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.674359" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:54.674515" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:54.460786" elapsed="0.213753"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.674905" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.674659" elapsed="0.000344"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.674627" elapsed="0.000401"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.675061" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:29:54.455534" elapsed="0.219653"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:54.678996" level="INFO">${update} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.676134" elapsed="0.002891"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.679203" elapsed="0.002124"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:54.681378" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:54.675860" elapsed="0.005642"/>
</kw>
<msg time="2026-06-06T03:29:54.681578" level="INFO">${update} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:54.675364" elapsed="0.006241"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.682474" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:29:54.682549" level="INFO">${len_1} = 160</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:54.682210" elapsed="0.000363"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.683031" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:29:54.683106" level="INFO">${len_2} = 160</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:54.682747" elapsed="0.000382"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.683292" elapsed="0.000308"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:54.684096" level="INFO">${sum_1} = 1024</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:54.683839" elapsed="0.000293"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:54.684598" level="INFO">${sum_2} = 1024</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:54.684350" elapsed="0.000282"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.684878" elapsed="0.000425"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:54.681840" elapsed="0.003546"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:54.685601" elapsed="0.002326"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.735022" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.734617" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.735812" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.735562" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.736025" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.735221" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.736611" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.736220" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.736962" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.737207" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.736824" elapsed="0.000411"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.737673" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.737398" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.738760" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.738420" elapsed="0.000385"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.739282" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.738972" elapsed="0.000336"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.740126" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.739708" elapsed="0.000444"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.741271" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.740791" elapsed="0.000562"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.741492" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:29:54.741738" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.740344" elapsed="0.001420"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.741921" elapsed="0.000526"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:54.739542" elapsed="0.002949"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.743196" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.742762" elapsed="0.000461"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.744469" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.743847" elapsed="0.000702"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.744712" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:54.744932" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.743411" elapsed="0.001547"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.745115" elapsed="0.000395"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:54.742606" elapsed="0.002946"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.739362" elapsed="0.006224"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.745630" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:29:54.745807" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:54.738091" elapsed="0.007742"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.737791" elapsed="0.008074"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.746046" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.745890" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.737770" elapsed="0.008352"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.746852" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:54.746271" elapsed="0.000611"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.746931" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:54.733996" elapsed="0.013091"/>
</kw>
<msg time="2026-06-06T03:29:54.747188" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.721215" elapsed="0.026024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.760065" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.772682" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.785226" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.785442" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.785630" elapsed="0.000037"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.786067" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.785909" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:54.785891" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.786296" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.786469" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.786652" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:54.785853" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.785736" elapsed="0.000999"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.786889" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.786968" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:54.787143" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:54.716893" elapsed="0.070279"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.788365" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.788081" elapsed="0.000385"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:54.799343" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:54.799421" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:54.799572" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:29:54.790619" elapsed="0.008991"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.788536" elapsed="0.011164"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.799985" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.799740" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.788517" elapsed="0.011587"/>
</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-06-06T03:29:54.805180" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.801569" elapsed="0.003673"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.801245" elapsed="0.004047"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.801218" elapsed="0.004111"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.808981" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.805750" elapsed="0.003295"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.805410" elapsed="0.003683"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.805385" elapsed="0.003742"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.809955" 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-06-06T03:29:54.809378" elapsed="0.000616"/>
</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-06-06T03:29:54.810442" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.810096" elapsed="0.000427"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.811284" 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-06-06T03:29:54.810816" elapsed="0.000505"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.810557" elapsed="0.000814"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.810070" elapsed="0.001330"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.812062" 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-06-06T03:29:54.811673" elapsed="0.000415"/>
</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-06-06T03:29:54.812399" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.812159" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.812957" 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-06-06T03:29:54.812660" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.812480" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.812140" elapsed="0.000899"/>
</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-06-06T03:29:54.813205" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:54.814048" 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-06-06T03:29:54.813744" elapsed="0.000330"/>
</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-06-06T03:29:54.814237" elapsed="0.002338"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:29:54.800658" elapsed="0.015981"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:54.816700" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:54.818961" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:29:54.787447" elapsed="0.031541"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.819133" elapsed="0.000032"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:29:54.689348" elapsed="0.129924"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:54.688757" elapsed="0.130574"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:54.688185" elapsed="0.131209"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:54.823244" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.820346" elapsed="0.002928"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.823433" elapsed="0.002187"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:29:54.825688" elapsed="0.000031"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:29:54.820068" elapsed="0.005747"/>
</kw>
<msg time="2026-06-06T03:29:54.825893" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:54.819570" elapsed="0.006348"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.826789" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:29:54.826865" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:54.826500" elapsed="0.000389"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.827378" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:29:54.827453" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:29:54.827048" elapsed="0.000428"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.827663" elapsed="0.000454"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:54.828597" level="INFO">${sum_1} = 873</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:54.828343" elapsed="0.000290"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:29:54.829126" level="INFO">${sum_2} = 873</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:29:54.828880" elapsed="0.000281"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:54.829380" elapsed="0.000452"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:29:54.826134" elapsed="0.003781"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.876330" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:54.875914" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.877175" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.876889" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:54.877344" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:54.876528" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.877945" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:54.877540" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:54.878276" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:54.878429" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:54.878139" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.878879" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.878614" elapsed="0.000352"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.880001" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.879737" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.880485" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.880213" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.881457" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.880896" elapsed="0.000588"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.882619" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.882178" elapsed="0.000501"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.882800" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:54.883019" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.881697" elapsed="0.001348"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.883232" elapsed="0.000511"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:29:54.880757" elapsed="0.003029"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.884710" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:54.884179" elapsed="0.000557"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:54.886004" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.885397" elapsed="0.000648"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:54.886162" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:54.886378" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:54.884923" elapsed="0.001481"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:54.886560" elapsed="0.000534"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:54.884042" elapsed="0.003105"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.880563" elapsed="0.006652"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:54.887271" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:54.887437" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:54.879362" elapsed="0.008100"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.879039" elapsed="0.008456"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.887694" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.887521" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.879017" elapsed="0.008769"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.888607" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:54.887975" elapsed="0.000661"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.888705" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:54.875249" elapsed="0.013587"/>
</kw>
<msg time="2026-06-06T03:29:54.888892" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:54.862441" elapsed="0.026512"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.901711" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.914304" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.926913" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.927112" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.927409" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.927825" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.927667" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:54.927625" elapsed="0.000288"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.928060" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.928232" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.928399" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:54.927597" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.927497" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.928624" elapsed="0.000034"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.928715" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:54.928834" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:54.858029" elapsed="0.070831"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.929998" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:54.929737" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:29:54.938186" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:54.938331" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:54.938465" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:29:54.938506" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.932211" elapsed="0.006768">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:54.930110" elapsed="0.008952">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:54.939306" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.939095" elapsed="0.000282"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:54.930092" elapsed="0.009311">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:54.944479" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.940871" elapsed="0.003657">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:54.940519" elapsed="0.004098">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:54.940492" elapsed="0.004192">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.948202" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.945107" elapsed="0.003128">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:54.944788" elapsed="0.003510">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:54.944763" elapsed="0.003567">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.948918" 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-06-06T03:29:54.948518" elapsed="0.000428"/>
</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-06-06T03:29:54.949264" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.949019" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.949830" 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-06-06T03:29:54.949512" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.949346" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.949000" elapsed="0.000913"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.950438" 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-06-06T03:29:54.950078" elapsed="0.000387"/>
</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-06-06T03:29:54.950792" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:54.950535" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.951352" 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-06-06T03:29:54.951040" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.950875" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.950516" elapsed="0.000918"/>
</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-06-06T03:29:54.951587" elapsed="0.000364"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:54.952395" 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-06-06T03:29:54.952120" elapsed="0.000300"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:29:54.954987" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.952578" elapsed="0.002442">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:29:54.939898" elapsed="0.015257">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:29:54.955281" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:54.957670" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:29:54.957702" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:29:54.929124" elapsed="0.028607">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:54.957798" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:29:54.831462" elapsed="0.126504">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:54.830813" elapsed="0.127215"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:29:54.830239" elapsed="0.127849"/>
</kw>
<arg>shared_tree_join</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:54.434716" elapsed="0.523424"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.338685" elapsed="0.619578"/>
</test>
<test id="s1-s16-t15" name="Play_To_Odl_shared_tree_join" line="114">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:29:54.961748" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:29:54.961453" elapsed="0.000565"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.963037" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.962926" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.962907" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:29:54.968177" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.968059" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.968038" elapsed="0.000214"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.969317" 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-06-06T03:29:54.968911" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:29:54.969830" 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-06-06T03:29:54.969512" elapsed="0.000344"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:29:54.969901" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:54.970060" 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-06-06T03:29:54.968505" elapsed="0.001580"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:29:54.975615" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.975499" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.975479" elapsed="0.000221"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:29:54.976953" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:54.976845" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:54.976826" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:29:54.977474" 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-06-06T03:29:54.977173" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:29:54.977909" level="INFO">${current_connection_index} = 7</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-06-06T03:29:54.977684" elapsed="0.000252"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:29:55.007514" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:29:54.978446" elapsed="0.029169"/>
</kw>
<msg time="2026-06-06T03:29:55.007835" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:29:55.007903" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:29:54.978102" elapsed="0.029837"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:29:55.034451" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "h "a "r "e "d "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:29:55.008615" elapsed="0.026006"/>
</kw>
<msg time="2026-06-06T03:29:55.034809" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:29:55.034856" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:29:55.008118" elapsed="0.026775"/>
</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-06-06T03:29:55.035207" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.034973" elapsed="0.000289"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.034951" elapsed="0.000335"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.035805" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "h "a "r "e "d "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:29:55.035470" elapsed="0.000406"/>
</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-06-06T03:29:55.036172" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.035945" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.035926" elapsed="0.000326"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:29:55.036286" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:29:55.038979" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:29:55.039189" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:55.037837" elapsed="0.001490"/>
</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="NOT RUN" start="2026-06-06T03:29:55.039715" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.040064" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:29:55.037190" elapsed="0.003061"/>
</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-06-06T03:29:55.036579" elapsed="0.003739"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:29:54.976510" elapsed="0.063906"/>
</kw>
<msg time="2026-06-06T03:29:55.040509" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:55.040553" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:54.975856" elapsed="0.064733"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:29:55.040797" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:29:55.040686" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.040666" elapsed="0.000241"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.041325" elapsed="0.000034"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.041685" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.041758" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:29:54.975150" elapsed="0.066715"/>
</kw>
<msg time="2026-06-06T03:29:55.041959" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:29:55.042002" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:29:54.970472" elapsed="0.071565"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.042368" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.042112" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.042094" elapsed="0.000350"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:29:54.970323" elapsed="0.072145"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:29:54.970144" elapsed="0.072388"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:29:54.967650" elapsed="0.074942"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:29:54.962605" elapsed="0.080059"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:29:54.962174" elapsed="0.080539"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:29:54.959165" elapsed="0.083601"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.043929" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.043423" elapsed="0.000534"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.044577" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.044129" elapsed="0.000477"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.045173" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.044795" elapsed="0.000405"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:55.045565" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/announce_shared_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/announce_shared_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:55.045744" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:55.045363" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:55.046117" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/withdraw_shared_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/withdraw_shared_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:55.046238" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:55.045930" elapsed="0.000334"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:29:55.046425" elapsed="0.003007"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:55.049594" elapsed="0.001991"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.105859" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:55.105451" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:55.106668" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:55.106402" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:55.106842" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:55.106063" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.107422" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:55.107037" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:55.107833" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:55.107981" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:55.107691" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.108463" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:55.108212" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.109527" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:55.109233" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.110031" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.109764" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.110853" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:55.110430" elapsed="0.000449"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:55.112115" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.111548" elapsed="0.000667"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:55.112296" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:55.112594" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:55.111071" elapsed="0.001549"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.112798" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:55.110290" elapsed="0.002938"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.115493" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:55.113477" elapsed="0.002043"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:55.116754" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.116196" elapsed="0.000661"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:55.116935" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:55.117226" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:55.115737" elapsed="0.001515"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:55.117420" elapsed="0.000383"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:55.113341" elapsed="0.004505"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:55.110112" elapsed="0.007770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:55.117927" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:55.118084" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:55.108905" elapsed="0.009204"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:55.108585" elapsed="0.009557"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.118322" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.118167" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.108562" elapsed="0.009837"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.119171" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:55.118545" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:55.119251" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:55.104828" elapsed="0.014547"/>
</kw>
<msg time="2026-06-06T03:29:55.119431" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:55.092092" elapsed="0.027415"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.132196" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.144871" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.157355" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.157556" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.157751" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.158123" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.157973" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:55.157958" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.158349" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.158521" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.158712" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:55.157930" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.157829" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.158943" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.159017" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:55.159136" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:55.087498" elapsed="0.071665"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:55.160495" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:55.160217" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:55.160674" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:55.159870" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.161022" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.160772" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.161576" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:55.161285" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:55.161104" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.160753" elapsed="0.000923"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.164211" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:55.161835" elapsed="0.002403"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:55.164332" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:55.164492" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:55.159513" elapsed="0.005004"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:55.165787" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:55.165524" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:55.165946" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:55.165183" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:55.166177" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:55.166041" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:55.166023" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.166410" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.166587" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.166669" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:55.168619" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:55.164850" elapsed="0.003810"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.170063" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:55.169814" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:55.170507" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:55.170265" elapsed="0.000285"/>
</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-06-06T03:29:55.179162" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:55.179318" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:29:55.179449" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:29:55.172764" elapsed="0.007115">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:55.170616" elapsed="0.009356">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:29:55.180201" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.180010" elapsed="0.000258"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:55.170597" elapsed="0.009695">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:29:55.180733" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.180925" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:55.180884" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:55.180864" elapsed="0.000125"/>
</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-06-06T03:29:55.181139" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.181208" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:29:55.168979" elapsed="0.012338">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.181394" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:29:55.064634" elapsed="0.116857">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:55.181788" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:55.181586" elapsed="0.000276"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:55.181569" elapsed="0.000317"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:55.181918" elapsed="0.000015"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:55.057989" elapsed="0.124027">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.238209" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.237786" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.239058" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.238793" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.239232" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.238427" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.239839" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.239432" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.240180" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.240354" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.240033" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.240812" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.240542" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.241954" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.241579" elapsed="0.000492"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.242522" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.242243" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.243469" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.242957" elapsed="0.000541"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.244784" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.244194" elapsed="0.000695"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.244971" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:29:57.245275" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.243723" elapsed="0.001579"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.245464" elapsed="0.000437"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:57.242812" elapsed="0.003132"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.246805" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.246199" elapsed="0.000632"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.248075" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.247489" elapsed="0.000690"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.248259" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:57.248554" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.247025" elapsed="0.001556"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.248758" elapsed="0.000476"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:57.246061" elapsed="0.003216"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.242605" elapsed="0.006709"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.249358" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:57.249517" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:57.241249" elapsed="0.008294"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.240938" elapsed="0.008638"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.249817" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.249603" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.240913" elapsed="0.009022"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.250689" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.250089" elapsed="0.000632"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.250771" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.237142" elapsed="0.013755"/>
</kw>
<msg time="2026-06-06T03:29:57.250952" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.224039" elapsed="0.026963"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.263854" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.276684" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.289358" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.289570" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.289772" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.290204" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.290043" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.290026" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.290458" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.290635" elapsed="0.000033"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.290823" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.289987" elapsed="0.000889"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.289853" elapsed="0.001050"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.291056" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.291133" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:29:57.291266" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.219700" elapsed="0.071593"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.292628" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.292363" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.292815" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.291995" elapsed="0.000845"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.293171" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.292910" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.293751" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.293437" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.293254" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.292891" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.296416" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.294012" elapsed="0.002431"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:57.296497" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:57.296711" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.291628" elapsed="0.005109"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.298024" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.297755" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.298186" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.297384" elapsed="0.000828"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:57.298424" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:57.298285" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.298265" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.298677" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.298860" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.298928" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:57.300866" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.297049" elapsed="0.003844"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.302559" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.302277" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.303041" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.302790" elapsed="0.000296"/>
</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-06-06T03:29:57.312939" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:57.313345" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}} 
 </msg>
<msg time="2026-06-06T03:29:57.313446" 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-06-06T03:29:57.305283" elapsed="0.008190"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.303155" elapsed="0.010362"/>
</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-06-06T03:29:57.313726" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.313544" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.303136" elapsed="0.010685"/>
</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-06-06T03:29:57.318850" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.315073" elapsed="0.003850"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.314750" elapsed="0.004225"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.314718" elapsed="0.004294"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.322699" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.319417" elapsed="0.003347"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.319092" elapsed="0.003708"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.319068" elapsed="0.003757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.323435" 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-06-06T03:29:57.323039" elapsed="0.000424"/>
</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-06-06T03:29:57.323801" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.323537" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.324354" 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-06-06T03:29:57.324053" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.323886" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.323517" elapsed="0.000920"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.324979" 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-06-06T03:29:57.324602" elapsed="0.000404"/>
</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-06-06T03:29:57.325316" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.325076" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.325879" 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-06-06T03:29:57.325562" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.325397" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.325058" elapsed="0.000904"/>
</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-06-06T03:29:57.326135" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:57.326958" 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-06-06T03:29:57.326665" elapsed="0.000319"/>
</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-06-06T03:29:57.327144" elapsed="0.002298"/>
</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-06-06T03:29:57.314268" elapsed="0.015239"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.329700" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:57.329578" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.329559" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.332757" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:57.329923" elapsed="0.002864"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:57.332840" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:57.333000" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:57.301270" elapsed="0.031757"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.333091" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:29:57.333244" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:57.196150" elapsed="0.137121"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.362333" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.361767" elapsed="0.000597"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.363263" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.362944" elapsed="0.000520">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.363665" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.362546" elapsed="0.001150"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.364320" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.363872" elapsed="0.000476"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.364697" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.364867" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.364515" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.365363" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "shared-tree-join": {
          "c-multicast": {
            "multicast-source": "1.0.0.1",
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 16,
            "c-g-address": "2.0.0.2"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.365059" elapsed="0.000357"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:57.365990" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.365498" elapsed="0.000581"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.366836" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.366261" elapsed="0.000603"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.366106" elapsed="0.000797"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.365473" elapsed="0.001451"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.367587" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.367080" elapsed="0.000537"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.367704" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.361114" elapsed="0.006746"/>
</kw>
<msg time="2026-06-06T03:29:57.367922" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.347754" elapsed="0.020221"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.383207" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.395882" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.408715" elapsed="0.000059"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.409029" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.409223" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.409698" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.409522" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.409502" elapsed="0.000281"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.409934" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.410138" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.410312" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.409460" elapsed="0.000906"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.409317" elapsed="0.001077"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.410545" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.410625" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:29:57.410806" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.345058" elapsed="0.065777"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.411021" elapsed="0.002769"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.415136" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.414626" elapsed="0.000539"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.415772" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.415326" elapsed="0.000474"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:57.415966" elapsed="0.000352"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:57.414180" elapsed="0.002199"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.413875" elapsed="0.002538"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.416595" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.416440" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.413854" elapsed="0.002836"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:57.334446" elapsed="0.082296"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:57.333599" elapsed="0.083223"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.333356" elapsed="0.083589"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.333338" elapsed="0.083633"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.417010" elapsed="0.000038"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:57.191412" elapsed="0.225743"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:55.051782" elapsed="2.365436"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.468812" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.468356" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.469661" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.469387" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.469832" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.469029" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.470452" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.470028" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.470811" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.470984" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.470663" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.471422" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.471173" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.472851" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.472272" elapsed="0.000626"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.473344" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.473068" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.474212" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.473776" elapsed="0.000463"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.475467" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.474919" elapsed="0.000651"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.475664" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:29:57.475968" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.474436" elapsed="0.001560"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.476160" elapsed="0.000383"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:29:57.473607" elapsed="0.002977"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.477259" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.476857" elapsed="0.000429"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.478538" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.477975" elapsed="0.000739"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.478795" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:57.479089" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.477474" elapsed="0.001641"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.479274" elapsed="0.000381"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:57.476718" elapsed="0.002981"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.473429" elapsed="0.006306"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.479778" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:57.479938" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:57.471945" elapsed="0.008019"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.471553" elapsed="0.008444"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.480179" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.480024" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.471527" elapsed="0.008729"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.481007" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.480402" elapsed="0.000635"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.481087" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.467555" elapsed="0.013657"/>
</kw>
<msg time="2026-06-06T03:29:57.481268" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.454097" elapsed="0.027221"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.494119" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.506769" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.519307" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.519509" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.519707" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.520087" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.519937" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.519922" elapsed="0.000289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.520359" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.520532" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.520717" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.519891" elapsed="0.000881"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.519787" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.520948" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.521023" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:57.521147" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.449143" elapsed="0.072031"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.522499" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.522239" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.522680" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.521857" elapsed="0.000850"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.523037" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.522779" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.523596" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.523304" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.523120" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.522759" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.526287" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.523852" elapsed="0.002462"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:57.526367" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:57.526522" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.521504" elapsed="0.005044"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.527812" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.527556" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.527969" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.527212" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:57.528198" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:57.528063" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.528044" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.528431" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.528605" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.528686" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:57.530631" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.526877" elapsed="0.003829"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.532143" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.531874" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.532596" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.532350" elapsed="0.000305"/>
</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-06-06T03:29:57.541978" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:57.542169" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}} 
 </msg>
<msg time="2026-06-06T03:29:57.542331" 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-06-06T03:29:57.534849" elapsed="0.007519"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.532725" elapsed="0.009702"/>
</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-06-06T03:29:57.542707" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.542464" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.532706" elapsed="0.010122"/>
</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-06-06T03:29:57.547880" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.544253" elapsed="0.003698"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.543935" elapsed="0.004065"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.543909" elapsed="0.004127"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.551740" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.548442" elapsed="0.003368"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.548118" elapsed="0.003741"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.548093" elapsed="0.003803"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.552743" 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-06-06T03:29:57.552138" elapsed="0.000645"/>
</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-06-06T03:29:57.553233" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.552885" elapsed="0.000431"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.554032" 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-06-06T03:29:57.553585" elapsed="0.000486"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.553350" elapsed="0.000772"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.552858" elapsed="0.001294"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.554942" 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-06-06T03:29:57.554402" elapsed="0.000578"/>
</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-06-06T03:29:57.555417" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.555079" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.556380" 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-06-06T03:29:57.555787" elapsed="0.000630"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.555532" elapsed="0.000936"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.555052" elapsed="0.001446"/>
</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-06-06T03:29:57.556786" elapsed="0.000498"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:57.557951" 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-06-06T03:29:57.557527" elapsed="0.000462"/>
</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-06-06T03:29:57.558217" elapsed="0.002545"/>
</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-06-06T03:29:57.543324" elapsed="0.017525"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.561091" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:57.560949" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.560921" elapsed="0.000259"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.564235" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:57.561370" elapsed="0.002894"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:57.564318" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:57.564476" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:57.531028" elapsed="0.033474"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.564566" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:57.564733" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:57.426331" elapsed="0.138428"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.594379" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.593885" elapsed="0.000523"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.595225" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.594949" elapsed="0.000397">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.595523" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.594579" elapsed="0.000970"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.596207" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.595757" elapsed="0.000477"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.596563" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.596742" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.596402" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.597199" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "shared-tree-join": {
          "c-multicast": {
            "multicast-source": "1.0.0.1",
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 16,
            "c-g-address": "2.0.0.2"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.596931" elapsed="0.000362"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:57.597803" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.597364" elapsed="0.000501"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.598573" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.598042" elapsed="0.000559"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.597890" elapsed="0.000747"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.597344" elapsed="0.001331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.599320" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.598833" elapsed="0.000516"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.599399" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.593248" elapsed="0.006277"/>
</kw>
<msg time="2026-06-06T03:29:57.599581" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.580631" elapsed="0.019000"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.612352" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.624900" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.638521" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.638740" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.638925" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.639307" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.639157" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.639142" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.639533" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.639723" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.639898" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.639113" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.639007" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.640168" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.640246" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:57.640368" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.577470" elapsed="0.062926"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.640577" elapsed="0.002262"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.644037" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.643580" elapsed="0.000486"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.644667" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.644229" elapsed="0.000470"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:57.644861" elapsed="0.000328"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:57.643165" elapsed="0.002084"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.642921" elapsed="0.002362"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.645459" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.645308" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.642901" elapsed="0.002635"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:57.566067" elapsed="0.079515"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:57.565244" elapsed="0.080428"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.564845" elapsed="0.080875"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.564827" elapsed="0.080917"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.645778" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:57.421815" elapsed="0.224088"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:57.417401" elapsed="0.228560"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.696127" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.695746" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.696894" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.696677" elapsed="0.000284">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.697094" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.696325" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.697692" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.697291" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.698021" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.698154" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.697885" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.698613" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.698339" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.699678" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.699370" elapsed="0.000355"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.700157" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.699890" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.700960" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.700539" elapsed="0.000447"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.702200" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.701631" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.702420" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:29:57.702755" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.701176" elapsed="0.001605"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.702941" elapsed="0.000376"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:57.700403" elapsed="0.002955"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.704031" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.703607" elapsed="0.000449"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.705270" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.704723" elapsed="0.000648"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.705449" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:57.705761" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.704246" elapsed="0.001541"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.705944" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:57.703471" elapsed="0.002882"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.700232" elapsed="0.006182"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.706460" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:57.706619" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:57.699042" elapsed="0.007617"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.698744" elapsed="0.007949"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.706871" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.706718" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.698724" elapsed="0.008225"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.707697" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.707097" elapsed="0.000748"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.707898" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.695104" elapsed="0.012922"/>
</kw>
<msg time="2026-06-06T03:29:57.708117" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.682194" elapsed="0.025973"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.720993" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.733367" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.745959" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.746156" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.746336" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.746743" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.746580" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.746565" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.746970" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.747140" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.747309" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.746536" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.746410" elapsed="0.000977"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.747535" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.747611" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:57.747746" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.677943" elapsed="0.069829"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.749026" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.748791" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.749222" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.748428" elapsed="0.000819"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.749568" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.749318" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.750134" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.749842" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.749665" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.749299" elapsed="0.000918"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.752633" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.750372" elapsed="0.002301"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:57.752727" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:57.752881" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.748100" elapsed="0.004806"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.754138" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.753903" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.754294" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.753542" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:29:57.754560" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:29:57.754390" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.754371" elapsed="0.000291"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.754836" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.755014" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.755080" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:57.757168" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.753212" elapsed="0.003983"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.758606" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.758340" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.759077" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.758834" elapsed="0.000286"/>
</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-06-06T03:29:57.768243" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:57.768395" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}} 
 </msg>
<msg time="2026-06-06T03:29:57.768514" 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-06-06T03:29:57.761268" elapsed="0.007274"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.759186" elapsed="0.009438"/>
</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-06-06T03:29:57.768859" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.768680" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.759168" elapsed="0.009779"/>
</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-06-06T03:29:57.773436" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.770083" elapsed="0.003424"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.769851" elapsed="0.003705"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.769830" elapsed="0.003762"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.777474" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.774022" elapsed="0.003516"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.773699" elapsed="0.003888"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.773672" elapsed="0.003949"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.778416" 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-06-06T03:29:57.777883" elapsed="0.000570"/>
</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-06-06T03:29:57.778905" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.778591" elapsed="0.000373"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.779459" 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-06-06T03:29:57.779157" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.778989" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.778563" elapsed="0.000980"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.780090" 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-06-06T03:29:57.779725" 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-06-06T03:29:57.780427" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.780187" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.780988" 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-06-06T03:29:57.780689" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.780508" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.780169" elapsed="0.000901"/>
</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-06-06T03:29:57.781225" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:57.782037" 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-06-06T03:29:57.781754" elapsed="0.000309"/>
</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-06-06T03:29:57.782223" elapsed="0.002495"/>
</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-06-06T03:29:57.769355" elapsed="0.015427"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.784963" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:57.784854" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.784834" elapsed="0.000196"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.788031" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:29:57.785183" elapsed="0.002878"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:57.788113" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:57.788273" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:57.757505" elapsed="0.030794"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.788404" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:57.788560" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:57.654910" elapsed="0.133677"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.817310" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.816859" elapsed="0.000481"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.818144" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.817875" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.818434" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.817510" elapsed="0.000950"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.819128" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.818677" elapsed="0.000478"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.819478" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/shared_tree_join/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.819619" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.819321" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.820092" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "shared-tree-join": {
          "c-multicast": {
            "multicast-source": "1.0.0.1",
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 16,
            "c-g-address": "2.0.0.2"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.819824" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:57.820608" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.820211" elapsed="0.000473"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.821370" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.820868" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.820710" elapsed="0.000724"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.820191" elapsed="0.001264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.822110" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.821607" elapsed="0.000533"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.822190" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.816220" elapsed="0.006094"/>
</kw>
<msg time="2026-06-06T03:29:57.822370" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.803303" elapsed="0.019115"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.835131" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.847903" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/shared_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.860499" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.860716" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.860900" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.861280" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.861129" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.861114" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.861507" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.861696" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.861871" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.861084" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.860979" elapsed="0.000972"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.862101" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.862178" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:29:57.862299" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.800572" elapsed="0.061755"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.862509" elapsed="0.002347"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.866114" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.865609" elapsed="0.000536"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:57.866835" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.866341" elapsed="0.000557"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:29:57.867065" elapsed="0.000339"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:29:57.865188" elapsed="0.002278"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.864944" elapsed="0.002556"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.867721" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.867526" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.864920" elapsed="0.002893"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:29:57.789753" elapsed="0.078121"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:29:57.788932" elapsed="0.079031"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.788688" elapsed="0.079338"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.788669" elapsed="0.079386"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.868097" elapsed="0.000040"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:29:57.650465" elapsed="0.217789"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:57.646137" elapsed="0.222184"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:29:57.868491" elapsed="0.003019"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.923910" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.923518" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.924684" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.924439" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.924848" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.924104" elapsed="0.000769"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.925423" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.925041" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.925768" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.925901" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.925614" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.926328" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.926086" elapsed="0.000288"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.927398" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.927110" elapsed="0.000334"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.927902" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.927609" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.928703" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.928286" elapsed="0.000443"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.929984" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.929416" elapsed="0.000670"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.930166" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:57.930462" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.928959" elapsed="0.001529"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.930694" elapsed="0.000393"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:29:57.928148" elapsed="0.002982"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.931808" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.931381" elapsed="0.000453"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:29:57.933053" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.932479" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:29:57.933233" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:29:57.933529" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:29:57.932023" elapsed="0.001532"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:29:57.933730" elapsed="0.000369"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:29:57.931243" elapsed="0.002899"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.927977" elapsed="0.006200"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:29:57.934221" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:29:57.934379" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:29:57.926779" elapsed="0.007626"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.926441" elapsed="0.007997"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.934618" elapsed="0.000226"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.934464" elapsed="0.000419"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.926421" elapsed="0.008484"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.935627" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:57.935058" elapsed="0.000614"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:57.935725" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:57.922900" elapsed="0.012956"/>
</kw>
<msg time="2026-06-06T03:29:57.935911" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:57.910068" elapsed="0.025891"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.948525" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.960977" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.973921" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.974127" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.974311" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.974728" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.974537" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:57.974521" elapsed="0.000291"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.974960" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.975133" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.975307" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:57.974491" elapsed="0.000871"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.974388" elapsed="0.000999"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.975536" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.975612" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:29:57.975756" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:57.905789" elapsed="0.069995"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.977086" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.976841" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:57.977248" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.976464" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:57.977607" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.977353" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.978187" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:57.977891" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.977713" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.977328" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.980678" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:57.978427" elapsed="0.002278"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:29:57.980757" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:57.980910" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.976126" elapsed="0.004809"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.982133" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.981938" elapsed="0.000289"/>
</kw>
<msg time="2026-06-06T03:29:57.982316" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:57.981579" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:29:57.982547" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:57.982412" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.982392" elapsed="0.000222"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:57.982964" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:57.983195" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:57.982791" elapsed="0.000430"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:29:57.983616" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:29:57.983383" elapsed="0.000279"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:29:57.983712" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:29:57.983867" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:29:57.981245" elapsed="0.002647"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.985275" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.985029" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:57.985929" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.985478" elapsed="0.000496"/>
</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-06-06T03:29:57.994509" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:29:57.995052" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '531'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}]} 
 </msg>
<msg time="2026-06-06T03:29:57.995174" 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-06-06T03:29:57.988155" elapsed="0.007046"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.986043" elapsed="0.009202"/>
</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-06-06T03:29:57.995432" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:57.995271" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.986024" elapsed="0.009494"/>
</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-06-06T03:29:58.000312" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BhYAAQECAwQBAgAAABAgAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"shared-tree-join":{"c-multicast":{"source-as":16,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:57.996915" elapsed="0.003467"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:57.996576" elapsed="0.003854"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:57.996549" elapsed="0.003916"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.004145" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:58.000892" elapsed="0.003316"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:58.000543" elapsed="0.003715"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:58.000519" elapsed="0.003772"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.005085" 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-06-06T03:29:58.004530" elapsed="0.000593"/>
</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-06-06T03:29:58.005565" elapsed="0.000094"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:58.005222" elapsed="0.000495"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.006414" 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-06-06T03:29:58.005994" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:58.005753" elapsed="0.000747"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:58.005195" elapsed="0.001335"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.007336" 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-06-06T03:29:58.006820" elapsed="0.000555"/>
</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-06-06T03:29:58.007835" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:58.007478" elapsed="0.000417"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.008378" 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-06-06T03:29:58.008086" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:58.007919" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:58.007451" elapsed="0.001010"/>
</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-06-06T03:29:58.008615" elapsed="0.000367"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:29:58.009432" 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-06-06T03:29:58.009153" elapsed="0.000305"/>
</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-06-06T03:29:58.009618" elapsed="0.002342"/>
</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-06-06T03:29:57.995986" elapsed="0.016038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:58.012201" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:29:58.012094" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:58.012075" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:58.015358" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:29:58.012421" elapsed="0.002966"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:29:58.015441" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:29:58.015597" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:29:57.984202" elapsed="0.031422"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:29:58.015706" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:29:58.015857" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:29:57.882729" elapsed="0.133154"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.044608" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:58.044139" elapsed="0.000521"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:29:58.045456" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:29:58.045181" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:29:58.045771" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:29:58.044835" elapsed="0.000999"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.046461" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:29:58.046011" elapsed="0.000478"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:29:58.046882" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:29:58.047025" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:29:58.046675" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.047491" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:29:58.047219" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:29:58.048033" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:58.047610" elapsed="0.000484"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.048802" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:29:58.048271" elapsed="0.000559"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:58.048119" elapsed="0.000747"/>
</branch>
<status status="PASS" start="2026-06-06T03:29:58.047590" elapsed="0.001298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.049524" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:29:58.049041" elapsed="0.000512"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:29:58.049605" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:29:58.043489" elapsed="0.006268"/>
</kw>
<msg time="2026-06-06T03:29:58.049811" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:58.030681" elapsed="0.019179"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.062705" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.075703" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.088824" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.089041" elapsed="0.000068"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.089279" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.089700" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:58.089530" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:29:58.089514" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.089931" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.090134" elapsed="0.000025"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.090315" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:29:58.089481" elapsed="0.000888"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:29:58.089366" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.090550" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:58.090628" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:29:58.090778" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:29:58.028007" elapsed="0.062800"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:29:58.091023" elapsed="0.002334"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:58.094508" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:58.094200" elapsed="0.000336"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:29:58.095352" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:29:58.094710" elapsed="0.000671"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:29:58.095908" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "path-id": 0,
      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
      "shared-tree-join": {
       "c-multicast": {
        "c-g-address": "2.0.0.2",
        "multicast-source": "1.0.0.1",
        "route-distinguisher": "1.2.3.4:258",
        "source-as": 16
       }
      }
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:29:58.096106" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:29:58.095553" elapsed="0.000627">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:29:58.093726" elapsed="0.002635">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:58.093444" elapsed="0.003000">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:29:58.096635" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:29:58.096480" elapsed="0.000233"/>
</branch>
<status status="FAIL" start="2026-06-06T03:29:58.093424" elapsed="0.003315">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:29:58.017025" elapsed="0.079842">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:29:58.016206" elapsed="0.080828">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:29:58.015965" elapsed="0.081161">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:29:58.015948" elapsed="0.081217">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:29:58.097224" elapsed="0.000019"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:29:57.876410" elapsed="0.220946">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BhYAAQECAwQBAgAAABAgAQAAASACAAAC",
+      "shared-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 16
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.153735" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.153294" elapsed="0.000475"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.154581" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.154318" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.154773" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.153962" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.155364" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.154974" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.155719" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.155887" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.155559" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.156331" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.156078" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.157489" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.157168" elapsed="0.000368"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.158023" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.157749" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.158847" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.158422" elapsed="0.000451"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:00.160104" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.159526" elapsed="0.000679"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:00.160287" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:00.160592" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:00.159067" elapsed="0.001551"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.160797" elapsed="0.000415"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:00.158281" elapsed="0.002974"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.161937" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.161509" elapsed="0.000454"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:00.163176" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.162612" elapsed="0.000665"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:00.163353" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:00.163666" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:00.162154" elapsed="0.001539"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.163854" elapsed="0.000433"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:00.161370" elapsed="0.002959"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:00.158104" elapsed="0.006261"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:00.164408" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:00.166220" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:00.156819" elapsed="0.009436"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.156458" elapsed="0.009843"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.166561" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.166339" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.156434" elapsed="0.010289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.167608" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:00.166922" elapsed="0.000733"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.167723" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:00.152577" elapsed="0.015290"/>
</kw>
<msg time="2026-06-06T03:30:00.167927" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.139777" elapsed="0.028204"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.184932" elapsed="0.000070"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.202778" elapsed="0.000074"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.218417" elapsed="0.000051"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.218778" elapsed="0.000034"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.219041" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.219566" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.219394" elapsed="0.000259"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:00.219370" elapsed="0.000324"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.219884" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.220072" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.220248" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:00.219320" elapsed="0.001069"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.219153" elapsed="0.001265"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.220576" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.220679" elapsed="0.000024"/>
</return>
<msg time="2026-06-06T03:30:00.220852" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:00.135385" elapsed="0.085497"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.222420" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.222116" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.222597" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.221675" elapsed="0.000949"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.223018" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.222727" elapsed="0.000355"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.223666" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.223319" elapsed="0.000381"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.223108" elapsed="0.000632"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.222704" elapsed="0.001059"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.226283" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.223927" elapsed="0.002384"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:00.226368" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:00.226533" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:00.221275" elapsed="0.005284"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.228180" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.227977" elapsed="0.000259"/>
</kw>
<msg time="2026-06-06T03:30:00.228324" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.227595" elapsed="0.000753"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.228563" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:00.228421" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.228401" elapsed="0.000231"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.228990" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.229175" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.228811" elapsed="0.000391"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:00.229626" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.229366" elapsed="0.000314"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:00.229735" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:00.229935" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:00.227207" elapsed="0.002762"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.231628" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.231365" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.232120" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.231868" elapsed="0.000298"/>
</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-06-06T03:30:00.240555" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:00.240730" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:00.240862" 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-06-06T03:30:00.234739" elapsed="0.006153"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.232236" elapsed="0.008706"/>
</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-06-06T03:30:00.241199" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.240973" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.232216" elapsed="0.009079"/>
</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-06-06T03:30:00.246743" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.242798" elapsed="0.004024"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.242390" elapsed="0.004486"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.242361" elapsed="0.004554"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.250519" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.247352" elapsed="0.003216"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.247001" elapsed="0.003604"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.246975" elapsed="0.003656"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.251277" 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-06-06T03:30:00.250859" elapsed="0.000447"/>
</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-06-06T03:30:00.251633" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.251380" elapsed="0.000340"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.252235" 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-06-06T03:30:00.251927" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.251746" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.251360" elapsed="0.000962"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.252903" 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-06-06T03:30:00.252491" elapsed="0.000441"/>
</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-06-06T03:30:00.253300" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.253004" elapsed="0.000388"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.253998" 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-06-06T03:30:00.253623" elapsed="0.000406"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.253439" elapsed="0.000628"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.252986" elapsed="0.001103"/>
</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-06-06T03:30:00.254254" elapsed="0.000378"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:00.255152" 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-06-06T03:30:00.254846" elapsed="0.000333"/>
</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-06-06T03:30:00.255345" elapsed="0.002494"/>
</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-06-06T03:30:00.241728" elapsed="0.016246"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.258161" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:00.258049" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.258029" elapsed="0.000203"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:00.261172" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:00.258384" elapsed="0.002819"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:00.261258" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:00.261430" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:00.230426" elapsed="0.031031"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.261522" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:00.261695" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:00.111509" elapsed="0.150215"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.293102" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.292404" elapsed="0.000768"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.294315" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.293926" elapsed="0.000549">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.294722" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.293416" elapsed="0.001344"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.295574" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.294996" elapsed="0.000613"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.296083" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.296293" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.295865" elapsed="0.000463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.296944" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.296552" elapsed="0.000461"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:00.297826" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.297122" elapsed="0.000784"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.298832" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.298140" elapsed="0.000731"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.297938" elapsed="0.000978"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.297088" elapsed="0.001857"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.299795" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:00.299147" elapsed="0.000862"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.300083" elapsed="0.000047"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:00.291456" elapsed="0.008808"/>
</kw>
<msg time="2026-06-06T03:30:00.300338" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.277220" elapsed="0.023185"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.313713" elapsed="0.000063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.329235" elapsed="0.000066"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.344558" elapsed="0.000070"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.344922" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.345128" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.345773" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.345548" elapsed="0.000304"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:00.345524" elapsed="0.000363"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.346092" elapsed="0.000030"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.346335" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.346569" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:00.345473" elapsed="0.001192"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.345294" elapsed="0.001415"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.346921" elapsed="0.000027"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.347023" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:30:00.347227" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:00.274441" elapsed="0.072828"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.347616" elapsed="0.003363"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:00.352632" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.352170" elapsed="0.000526"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:00.353363" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.352926" elapsed="0.000478"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:00.353658" elapsed="0.000496"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:00.351518" elapsed="0.002732"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.351104" elapsed="0.003198"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.354575" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.354345" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.351071" elapsed="0.003645"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:00.263014" elapsed="0.091780"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:00.262107" elapsed="0.092808"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.261828" elapsed="0.093157"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.261803" elapsed="0.093224"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.355087" elapsed="0.000052"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:00.105193" elapsed="0.250099"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:29:57.871720" elapsed="2.483666"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:00.355739" elapsed="0.003161"/>
</kw>
<arg>shared_tree_join</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:29:55.043027" elapsed="5.315974"/>
</kw>
<status status="PASS" start="2026-06-06T03:29:54.958677" elapsed="5.400524"/>
</test>
<test id="s1-s16-t16" name="Odl_To_Play_source_tree_join" line="118">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:00.364330" elapsed="0.000397"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:00.363908" elapsed="0.000909"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.366405" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:00.366227" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.366195" elapsed="0.000313"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.374101" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:00.373945" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.373918" elapsed="0.000303"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.375836" 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-06-06T03:30:00.375194" elapsed="0.000685"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.376566" 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-06-06T03:30:00.376133" elapsed="0.000472"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:00.376689" elapsed="0.000053"/>
</return>
<msg time="2026-06-06T03:30:00.376939" 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-06-06T03:30:00.374599" elapsed="0.002379"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:00.385292" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:00.385072" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.385039" elapsed="0.000369"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:00.387220" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:00.387072" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.387045" elapsed="0.000274"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:00.388006" 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-06-06T03:30:00.387553" elapsed="0.000494"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:00.388630" level="INFO">${current_connection_index} = 7</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-06-06T03:30:00.388303" elapsed="0.000387"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:00.431880" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:00.389479" elapsed="0.042633"/>
</kw>
<msg time="2026-06-06T03:30:00.432349" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:00.432398" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:00.388930" elapsed="0.043507"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:00.460765" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "o "u "r "c "e "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:30:00.433176" elapsed="0.027704"/>
</kw>
<msg time="2026-06-06T03:30:00.461045" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:00.461090" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:30:00.432727" elapsed="0.028400"/>
</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-06-06T03:30:00.461528" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.461228" elapsed="0.000356"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.461197" elapsed="0.000415"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.462106" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "s "o "u "r "c "e "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:30:00.461789" elapsed="0.000391"/>
</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-06-06T03:30:00.462473" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.462249" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.462229" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:00.462590" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:00.465354" elapsed="0.000376"/>
</kw>
<msg time="2026-06-06T03:30:00.465798" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.464200" elapsed="0.001736"/>
</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="NOT RUN" start="2026-06-06T03:30:00.466224" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.466566" elapsed="0.000094"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:00.463512" elapsed="0.003265"/>
</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-06-06T03:30:00.462940" elapsed="0.003906"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:00.386617" elapsed="0.080329"/>
</kw>
<msg time="2026-06-06T03:30:00.467041" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:00.467087" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:00.385673" elapsed="0.081452"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:00.467367" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:00.467255" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.467235" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.467888" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.468234" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.468307" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:00.384514" elapsed="0.083901"/>
</kw>
<msg time="2026-06-06T03:30:00.468510" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:00.468554" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:00.377720" elapsed="0.090871"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.468940" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.468682" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.468663" elapsed="0.000355"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:00.377378" elapsed="0.091664"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:00.377066" elapsed="0.092008"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:00.373407" elapsed="0.095723"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:00.365797" elapsed="0.103389"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:00.365058" elapsed="0.104175"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:00.360437" elapsed="0.108850"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.470210" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/announce_source_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/announce_source_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.470384" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.470003" elapsed="0.000409"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:00.470816" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.470574" elapsed="0.000270"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.471201" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/withdraw_source_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/withdraw_source_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.471328" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.471009" elapsed="0.000346"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:00.471734" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.471513" elapsed="0.000248"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:00.472052" elapsed="0.002410"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.471833" elapsed="0.002665"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.471814" elapsed="0.002709"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.508861" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.508448" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.509805" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.509522" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.509981" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.509140" elapsed="0.000866"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.510567" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.510178" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.510949" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.511102" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.510805" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.511545" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.511294" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.512601" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.512340" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.513105" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.512835" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.513840" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.513516" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:00.514846" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.514378" elapsed="0.000495"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:00.514925" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:00.515084" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:00.514056" elapsed="0.001053"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.515269" elapsed="0.000239"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:00.513359" elapsed="0.002191"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.516119" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.515817" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:00.517085" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.516675" elapsed="0.000438"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:00.517165" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:00.517317" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:00.516335" elapsed="0.001007"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.517532" elapsed="0.000244"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:00.515679" elapsed="0.002140"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:00.513184" elapsed="0.004670"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:00.517897" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:00.518052" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:00.512008" elapsed="0.006069"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.511691" elapsed="0.006419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.518291" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.518136" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.511667" elapsed="0.006700"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.519349" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:00.518517" elapsed="0.000862"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.519430" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:00.507818" elapsed="0.011739"/>
</kw>
<msg time="2026-06-06T03:30:00.519614" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.495083" elapsed="0.024611"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.532235" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.544702" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.557220" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.557457" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.557659" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.558051" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.557899" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:00.557883" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.558278" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.558451" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.558620" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:00.557849" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.557742" elapsed="0.000976"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.558870" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.558946" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:00.559073" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:00.490556" elapsed="0.068544"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.584101" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.583712" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.584901" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.584653" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.585072" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.584299" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.585678" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.585265" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.586017" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.586183" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BxYAAQECAwQBAgAAAAogAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.585877" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.586618" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BxYAAQECAwQBAgAAAAogAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;source-tree-join&gt;
      &lt;c-multicast&gt;
        &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;10&lt;/source-as&gt;
        &lt;c-g-address&gt;2.0.0.2&lt;/c-g-address&gt;
      &lt;/c-multicast&gt;
    &lt;/source-tree-join&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.586373" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:00.587065" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.586762" elapsed="0.000362"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.587597" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.587301" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.587150" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.586741" elapsed="0.000957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.588439" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BxYAAQECAwQBAgAAAAogAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:00.587850" elapsed="0.000620"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.588519" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:00.583073" elapsed="0.005588"/>
</kw>
<msg time="2026-06-06T03:30:00.588721" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.570281" elapsed="0.018489"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.601491" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.614025" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.626441" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.626664" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.626857" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.627254" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.627101" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:00.627084" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.627477" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.627662" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.627835" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:00.627051" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.626937" elapsed="0.000976"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.628064" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.628139" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:00.628282" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BxYAAQECAwQBAgAAAAogAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
     ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:00.569371" elapsed="0.058941"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.629708" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.629385" elapsed="0.000402">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.629884" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.629015" elapsed="0.000893"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.630238" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.629979" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.630814" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.630504" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.630317" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.629959" elapsed="0.000938"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.633253" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.631052" elapsed="0.002228"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:00.633365" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:00.633533" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:00.628667" elapsed="0.004891"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.635106" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.634855" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.635550" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BxYAAQECAwQBAgAAAAogAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;source-tree-join&gt;
      &lt;c-multicast&gt;
        &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;10&lt;/source-as&gt;
        &lt;c-g-address&gt;2.0.0.2&lt;/c-g-address&gt;
      &lt;/c-multicast&gt;
    &lt;/source-tree-join&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.635310" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.636023" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.635777" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.636464" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.636221" elapsed="0.000286"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:00.637339" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:00.637141" elapsed="0.000224"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:00.637741" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:00.637546" elapsed="0.000221"/>
</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-06-06T03:30:00.637920" elapsed="0.000207"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.638531" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.638285" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:00.638617" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:30:00.638789" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:00.636727" elapsed="0.002087"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:00.654318" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '796', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;BxYAAQECAwQBAgAAAAogAQAAASACAAAC&lt;/route-key&gt;
    &lt;attributes&gt;
      &lt;ipv4-next-hop&gt;
        &lt;global&gt;127.1.1.1&lt;/global&gt;
      &lt;/ipv4-next-hop&gt;
      &lt;multi-exit-disc&gt;
        &lt;med&gt;0&lt;/med&gt;
      &lt;/multi-exit-disc&gt;
      &lt;as-path/&gt;
      &lt;origin&gt;
        &lt;value&gt;egp&lt;/value&gt;
      &lt;/origin&gt;
      &lt;local-pref&gt;
        &lt;pref&gt;100&lt;/pref&gt;
      &lt;/local-pref&gt;
    &lt;/attributes&gt;
    &lt;source-tree-join&gt;
      &lt;c-multicast&gt;
        &lt;multicast-source&gt;1.0.0.1&lt;/multicast-source&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;source-as&gt;10&lt;/source-as&gt;
        &lt;c-g-address&gt;2.0.0.2&lt;/c-g-address&gt;
      &lt;/c-multicast&gt;
    &lt;/source-tree-join&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:00.654383" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=BxYAAQECAwQBAgAAAAogAQAAASACAAAC,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:00.654475" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:00.641156" elapsed="0.013346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.638884" elapsed="0.015664"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.654755" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.654574" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.638866" elapsed="0.016013"/>
</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-06-06T03:30:00.658303" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.655935" elapsed="0.002410"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.655702" elapsed="0.002678"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.655683" elapsed="0.002722"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.660994" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.658699" elapsed="0.002341"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.658461" elapsed="0.002613"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.658444" elapsed="0.002655"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.661709" 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-06-06T03:30:00.661269" elapsed="0.000469"/>
</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-06-06T03:30:00.662060" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.661814" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.662613" 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-06-06T03:30:00.662311" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.662144" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.661793" elapsed="0.000920"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.663242" 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-06-06T03:30:00.662879" elapsed="0.000390"/>
</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-06-06T03:30:00.663579" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.663338" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.664140" 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-06-06T03:30:00.663843" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.663677" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.663320" elapsed="0.000903"/>
</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-06-06T03:30:00.664377" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:00.665190" 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-06-06T03:30:00.664909" elapsed="0.000308"/>
</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-06-06T03:30:00.665375" elapsed="0.002324"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:00.655247" elapsed="0.012516"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:00.667950" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:00.667842" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.667822" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:00.668190" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.668259" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:00.670690" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:00.633906" elapsed="0.036812"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.670793" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:00.670950" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:00.479411" elapsed="0.191564"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.671357" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.671116" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.671098" elapsed="0.000351"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.671483" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:00.474905" elapsed="0.196701"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:00.674557" level="INFO">${update} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.672539" elapsed="0.002048"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:00.674792" elapsed="0.002269"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:00.677114" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:00.672266" elapsed="0.004972"/>
</kw>
<msg time="2026-06-06T03:30:00.677313" level="INFO">${update} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:00.671800" elapsed="0.005538"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.678251" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:30:00.678327" level="INFO">${len_1} = 160</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:00.677985" elapsed="0.000366"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.678779" level="INFO">Length is 160.</msg>
<msg time="2026-06-06T03:30:00.678854" level="INFO">${len_2} = 160</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:00.678510" elapsed="0.000367"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:00.679036" elapsed="0.000306"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:00.679710" level="INFO">${sum_1} = 1019</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:00.679504" elapsed="0.000232"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:00.680079" level="INFO">${sum_2} = 1019</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:00.679898" elapsed="0.000207"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:00.680262" elapsed="0.000309"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:00.677590" elapsed="0.003042"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:00.680805" elapsed="0.001907"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.725975" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:00.725554" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.726764" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.726513" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:00.726931" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:00.726173" elapsed="0.000782"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.727513" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:00.727125" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:00.727861" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:00.728056" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:00.727721" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.728492" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.728246" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.729768" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.729416" elapsed="0.000399"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.730262" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.729983" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.731102" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.730684" elapsed="0.000444"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:00.732246" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.731767" elapsed="0.000562"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:00.732467" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:00.732708" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:00.731322" elapsed="0.001412"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.732894" elapsed="0.000403"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:00.730521" elapsed="0.002818"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.734056" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.733620" elapsed="0.000462"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:00.735182" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.734705" elapsed="0.000557"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:00.735396" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:00.735615" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:00.734272" elapsed="0.001386"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:00.735817" elapsed="0.000393"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:00.733455" elapsed="0.002797"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:00.730342" elapsed="0.005944"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:00.736327" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:00.736485" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:00.728933" elapsed="0.007578"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.728611" elapsed="0.007931"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.736737" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.736568" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.728589" elapsed="0.008226"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.737534" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:00.736964" elapsed="0.000599"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.737625" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:00.724934" elapsed="0.012833"/>
</kw>
<msg time="2026-06-06T03:30:00.737827" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:00.712222" elapsed="0.025653"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.750560" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.763159" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.777231" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.777437" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.777622" elapsed="0.000046"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.778038" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.777885" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:00.777869" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.778265" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.778440" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.778612" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:00.777839" elapsed="0.000843"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.777732" elapsed="0.000976"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.778860" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.778935" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:00.779058" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:00.707920" elapsed="0.071165"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.780221" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.779955" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:00.789571" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:00.789618" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:00.789810" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:00.782439" elapsed="0.007399"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.780336" elapsed="0.009542"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:00.790061" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.789904" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.780317" elapsed="0.009833"/>
</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-06-06T03:30:00.793519" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.791162" elapsed="0.002402"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.790935" elapsed="0.002664"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.790917" elapsed="0.002708"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.796247" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:00.793947" elapsed="0.002346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.793711" elapsed="0.002617"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.793693" elapsed="0.002660"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.796995" 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-06-06T03:30:00.796551" elapsed="0.000472"/>
</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-06-06T03:30:00.797355" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.797097" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.797979" 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-06-06T03:30:00.797612" elapsed="0.000395"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.797440" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.797077" elapsed="0.000990"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.798658" 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-06-06T03:30:00.798243" elapsed="0.000446"/>
</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-06-06T03:30:00.799010" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:00.798763" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.799563" 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-06-06T03:30:00.799262" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.799094" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:00.798743" elapsed="0.000920"/>
</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-06-06T03:30:00.799825" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:00.800654" 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-06-06T03:30:00.800347" elapsed="0.000335"/>
</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-06-06T03:30:00.800844" elapsed="0.002479"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:00.790504" elapsed="0.012888"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:00.803440" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:00.805731" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:00.779351" elapsed="0.026408"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:00.805814" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:00.683740" elapsed="0.122198"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:00.683289" elapsed="0.122703"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:00.682917" elapsed="0.123134"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:00.829261" level="INFO">${update} = </msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:00.807003" elapsed="0.022287"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:00.831682" level="FAIL"> == </msg>
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.829470" elapsed="0.002334"> == </status>
</kw>
<return>
<value>${update}</value>
<status status="NOT RUN" start="2026-06-06T03:30:00.831864" elapsed="0.000018"/>
</return>
<doc>Returns hex update message.</doc>
<status status="FAIL" start="2026-06-06T03:30:00.806720" elapsed="0.025254"> == </status>
</kw>
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:02.837243" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:02.833579" elapsed="0.003735"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:02.837774" elapsed="0.005096"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:02.842992" elapsed="0.000080"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:02.832825" elapsed="0.010472"/>
</kw>
<msg time="2026-06-06T03:30:02.843467" level="INFO">${update} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:00.806224" elapsed="2.037299"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.845619" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:30:02.845834" level="INFO">${len_1} = 148</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:02.844953" elapsed="0.000939"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.846913" level="INFO">Length is 148.</msg>
<msg time="2026-06-06T03:30:02.847092" level="INFO">${len_2} = 148</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:02.846272" elapsed="0.000877"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:02.847528" elapsed="0.000860"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:02.849032" level="INFO">${sum_1} = 868</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:02.848812" elapsed="0.000246"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:02.849392" level="INFO">${sum_2} = 868</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:02.849213" elapsed="0.000204"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:02.849574" elapsed="0.000330"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:02.844075" elapsed="0.005888"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.894441" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:02.894044" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:02.895299" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:02.895018" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:02.895473" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:02.894666" elapsed="0.000831"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.896108" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:02.895690" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:02.896446" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:02.896612" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:02.896303" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.897074" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:02.896821" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.898219" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:02.897888" elapsed="0.000378"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.898724" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:02.898434" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.899714" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:02.899130" elapsed="0.000643"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:02.900947" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:02.900469" elapsed="0.000520"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:02.901113" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:02.901344" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:02.899978" elapsed="0.001393"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:02.901534" elapsed="0.000518"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:02.898989" elapsed="0.003106"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.902881" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:02.902350" elapsed="0.000557"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:02.904241" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:02.903577" elapsed="0.000706"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:02.904403" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:02.904628" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:02.903098" elapsed="0.001586"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:02.904846" elapsed="0.000487"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:02.902211" elapsed="0.003164"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:02.898807" elapsed="0.006604"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:02.905455" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:02.905614" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:02.897512" elapsed="0.008142"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:02.897197" elapsed="0.008492"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.905871" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:02.905715" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.897173" elapsed="0.008775"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.906696" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:02.906097" elapsed="0.000629"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:02.906776" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:02.893339" elapsed="0.013562"/>
</kw>
<msg time="2026-06-06T03:30:02.906956" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:02.880322" elapsed="0.026695"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.919991" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.932626" elapsed="0.000078"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.945219" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.945421" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.945603" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.945992" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:02.945841" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:02.945826" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.946218" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.946391" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.946562" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:02.945797" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:02.945694" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.946811" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:02.946887" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:02.947008" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:02.875882" elapsed="0.071152"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.948207" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:02.947954" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:02.956013" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:02.956153" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:02.956288" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:02.956331" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:02.950404" elapsed="0.006316">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:02.948322" elapsed="0.008512">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:02.957036" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:02.956874" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:02.948303" elapsed="0.008820">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:02.960787" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:02.958192" elapsed="0.002629">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:02.957964" elapsed="0.002921">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:02.957944" elapsed="0.002973">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.963528" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:02.961218" elapsed="0.002344">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:02.960989" elapsed="0.002636">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:02.960971" elapsed="0.002703">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.964301" 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-06-06T03:30:02.963910" elapsed="0.000419"/>
</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-06-06T03:30:02.964666" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:02.964402" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.965227" 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-06-06T03:30:02.964922" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:02.964751" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.964383" elapsed="0.000929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.965936" 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-06-06T03:30:02.965477" elapsed="0.000487"/>
</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-06-06T03:30:02.966278" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:02.966036" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.966854" 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-06-06T03:30:02.966529" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:02.966360" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.966017" elapsed="0.000921"/>
</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-06-06T03:30:02.967092" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:02.967941" 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-06-06T03:30:02.967612" elapsed="0.000356"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:02.970397" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:02.968132" elapsed="0.002298">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:02.957504" elapsed="0.013061">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:02.970681" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:02.973167" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:02.973199" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:02.947301" elapsed="0.025927">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:02.973296" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:02.851051" elapsed="0.122418">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:02.850598" elapsed="0.122935"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:02.850196" elapsed="0.123398"/>
</kw>
<arg>source_tree_join</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:00.469604" elapsed="2.504056"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:00.359679" elapsed="2.614099"/>
</test>
<test id="s1-s16-t17" name="Play_To_Odl_source_tree_join" line="122">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:02.977143" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:02.976870" elapsed="0.000542"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:02.978431" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:02.978319" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.978300" elapsed="0.000201"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:02.983440" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:02.983331" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.983312" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.984551" 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-06-06T03:30:02.984167" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:02.985058" 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-06-06T03:30:02.984760" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:02.985128" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:02.985282" 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-06-06T03:30:02.983756" elapsed="0.001550"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:02.990836" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:02.990726" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.990706" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:02.992097" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:02.991990" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:02.991971" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:02.992610" 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-06-06T03:30:02.992314" elapsed="0.000323"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:02.993037" level="INFO">${current_connection_index} = 7</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-06-06T03:30:02.992818" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:03.021210" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:02.993572" elapsed="0.027743"/>
</kw>
<msg time="2026-06-06T03:30:03.021480" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:03.021527" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:02.993227" elapsed="0.028338"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:03.048542" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "o "u "r "c "e "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:30:03.022243" elapsed="0.026488"/>
</kw>
<msg time="2026-06-06T03:30:03.048901" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:03.048948" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:30:03.021760" elapsed="0.027226"/>
</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-06-06T03:30:03.049318" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.049069" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.049047" elapsed="0.000354"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.049897" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "s "o "u "r "c "e "_ "t "r "e "e "_ "j "o "i "n "[K"
[?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-06-06T03:30:03.049549" elapsed="0.000422"/>
</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-06-06T03:30:03.050265" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.050039" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.050020" elapsed="0.000324"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:03.050380" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:03.053064" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:30:03.053279" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:03.051942" elapsed="0.001473"/>
</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="NOT RUN" start="2026-06-06T03:30:03.053711" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.054052" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:03.051247" elapsed="0.002990"/>
</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-06-06T03:30:03.050697" elapsed="0.003606"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:02.991669" elapsed="0.062737"/>
</kw>
<msg time="2026-06-06T03:30:03.054504" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:03.054549" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:02.991058" elapsed="0.063530"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:03.054802" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:03.054691" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.054669" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.055294" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.055656" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.055730" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:02.990301" elapsed="0.065536"/>
</kw>
<msg time="2026-06-06T03:30:03.055951" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:03.055995" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:02.985692" elapsed="0.070342"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.056368" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.056111" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.056092" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:02.985529" elapsed="0.070941"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:02.985359" elapsed="0.071188"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:02.982967" elapsed="0.073642"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:02.978029" elapsed="0.078656"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:02.977569" elapsed="0.079164"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:02.974570" elapsed="0.082219"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.057935" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.057436" elapsed="0.000527"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.058579" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.058135" elapsed="0.000471"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.059185" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.058808" elapsed="0.000403"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:03.059581" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/announce_source_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/announce_source_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:03.059763" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:03.059376" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:03.060175" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/withdraw_source_tree_join.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/withdraw_source_tree_join.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:03.060297" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:03.059984" elapsed="0.000339"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:03.060477" elapsed="0.002762"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:03.063407" elapsed="0.001937"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.117668" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:03.117266" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:03.118468" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:03.118215" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:03.118653" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:03.117874" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.119249" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:03.118856" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:03.119584" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:03.119755" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:03.119444" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.120264" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:03.120010" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.121357" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:03.121046" elapsed="0.000358"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.121866" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.121570" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.122688" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:03.122264" elapsed="0.000451"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:03.123936" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.123365" elapsed="0.000711"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:03.124158" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:03.124459" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:03.122909" elapsed="0.001577"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.124669" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:03.122123" elapsed="0.002976"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.125933" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:03.125350" elapsed="0.000609"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:03.127165" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.126607" elapsed="0.000658"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:03.127342" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:03.127629" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:03.126152" elapsed="0.001518"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:03.127832" elapsed="0.000394"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:03.125213" elapsed="0.003055"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:03.121947" elapsed="0.006356"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:03.128346" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:03.128503" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:03.120715" elapsed="0.007813"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:03.120387" elapsed="0.008174"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.128757" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.128585" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.120364" elapsed="0.008471"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.129567" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:03.128985" elapsed="0.000611"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:03.129661" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:03.116629" elapsed="0.013160"/>
</kw>
<msg time="2026-06-06T03:30:03.129844" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:03.103879" elapsed="0.026014"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.142571" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.155538" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.167965" elapsed="0.000042"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.168214" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.168405" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.168849" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.168690" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:03.168669" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.169089" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.169263" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.169434" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:03.168613" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.168492" elapsed="0.001023"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.169684" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.169765" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:03.169916" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:03.099569" elapsed="0.070375"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:03.171406" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:03.171059" elapsed="0.000423">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:03.171577" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:03.170659" elapsed="0.000943"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.171967" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.171695" elapsed="0.000360"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.172571" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:03.172272" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:03.172080" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.171675" elapsed="0.000998"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.175230" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:03.172831" elapsed="0.002425"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:03.175367" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:03.175528" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:03.170286" elapsed="0.005267"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:03.176872" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:03.176602" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:03.177033" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:03.176254" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:03.177265" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:03.177128" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:03.177109" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.177499" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.177688" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.177755" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:30:03.179685" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:03.175887" elapsed="0.003824"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.181159" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:03.180901" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:03.181606" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:03.181363" elapsed="0.000302"/>
</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-06-06T03:30:03.190744" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:03.190944" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:03.191096" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:30:03.183817" elapsed="0.007813">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:03.181733" elapsed="0.010046">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:03.192124" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.191832" elapsed="0.000391"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:03.181714" elapsed="0.010543">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:03.192864" elapsed="0.000041"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.193137" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:03.193078" elapsed="0.000123"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:03.193049" elapsed="0.000186"/>
</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-06-06T03:30:03.193455" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.193558" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:03.180059" elapsed="0.013679">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.193854" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:03.077015" elapsed="0.116980">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:03.194422" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:03.194148" elapsed="0.000380"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:03.194123" elapsed="0.000440"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:03.194611" elapsed="0.000020"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:03.070791" elapsed="0.123984">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.252700" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.252272" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.253528" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.253264" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.253720" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.252916" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.254398" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.253919" elapsed="0.000507"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.254764" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.254935" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.254597" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.255375" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.255125" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.256473" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.256162" elapsed="0.000413"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.257054" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.256776" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.257914" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.257455" elapsed="0.000550"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.259240" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.258687" elapsed="0.000655"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.259423" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:05.259745" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.258201" elapsed="0.001571"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.259934" elapsed="0.000386"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:05.257314" elapsed="0.003048"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.261247" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.260612" elapsed="0.000662"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.262571" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.262009" elapsed="0.000708"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.262798" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:05.263332" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.261474" elapsed="0.001895"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.263590" elapsed="0.000536"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:05.260475" elapsed="0.003710"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.257137" elapsed="0.007098"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.264294" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:05.264512" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:05.255827" elapsed="0.008720"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.255500" elapsed="0.009092"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.264882" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.264627" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.255475" elapsed="0.009514"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.266187" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.265194" elapsed="0.001037"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.266300" elapsed="0.000041"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.251568" elapsed="0.014908"/>
</kw>
<msg time="2026-06-06T03:30:05.266553" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.238448" elapsed="0.028172"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.279364" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.292713" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.305279" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.305482" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.305677" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.306110" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.305913" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:05.305898" elapsed="0.000295"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.306340" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.306510" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.306699" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:05.305868" elapsed="0.000890"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.305764" elapsed="0.001019"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.306937" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.307012" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:05.307135" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.233894" elapsed="0.073268"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.308435" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.308191" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.308598" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.307841" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.308964" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.308712" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.309530" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.309234" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.309048" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.308692" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.313735" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.309785" elapsed="0.003978"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:05.313817" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:05.314063" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:05.307491" elapsed="0.006602"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.315486" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.315229" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.315663" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.314792" elapsed="0.000898"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:05.315905" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:05.315764" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.315744" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.316144" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.316321" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.316388" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:05.318358" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:05.314425" elapsed="0.003961"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.319842" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.319553" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.320310" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.320062" elapsed="0.000293"/>
</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-06-06T03:30:05.329882" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:05.330350" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}} 
 </msg>
<msg time="2026-06-06T03:30:05.330464" 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-06-06T03:30:05.322541" elapsed="0.007949"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.320422" elapsed="0.010113"/>
</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-06-06T03:30:05.330740" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.330562" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.320403" elapsed="0.010425"/>
</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-06-06T03:30:05.335798" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.332246" elapsed="0.003624"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.331906" elapsed="0.004014"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.331880" elapsed="0.004076"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.339616" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.336362" elapsed="0.003317"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.336038" elapsed="0.003677"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.336012" elapsed="0.003728"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.340347" 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-06-06T03:30:05.339951" elapsed="0.000425"/>
</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-06-06T03:30:05.340715" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.340450" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.341278" 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-06-06T03:30:05.340974" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.340799" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.340430" elapsed="0.000932"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.341930" 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-06-06T03:30:05.341528" elapsed="0.000430"/>
</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-06-06T03:30:05.342347" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.342085" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.342912" 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-06-06T03:30:05.342595" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.342429" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.342063" elapsed="0.000932"/>
</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-06-06T03:30:05.343150" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:05.343992" 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-06-06T03:30:05.343704" elapsed="0.000313"/>
</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-06-06T03:30:05.344178" elapsed="0.002349"/>
</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-06-06T03:30:05.331293" elapsed="0.015298"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.346816" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:05.346679" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.346657" elapsed="0.000230"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.349968" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:30:05.347086" elapsed="0.002918"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:05.351028" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:05.351194" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:05.318731" elapsed="0.032490"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.351284" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:05.351434" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:05.208408" elapsed="0.143052"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.382860" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.382338" elapsed="0.000552"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.383724" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.383410" elapsed="0.000499">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.384088" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.383064" elapsed="0.001051"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.384758" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.384286" elapsed="0.000500"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.385122" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.385391" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.384955" elapsed="0.000465"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.385884" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "source-tree-join": {
          "c-multicast": {
            "multicast-source": "1.0.0.1",
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 10,
            "c-g-address": "2.0.0.2"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.385589" elapsed="0.000349"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:05.386473" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.386014" elapsed="0.000521"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.387254" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.386743" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.386561" elapsed="0.000758"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.385992" elapsed="0.001348"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.388007" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.387493" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.388086" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.381650" elapsed="0.006566"/>
</kw>
<msg time="2026-06-06T03:30:05.388273" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.367399" elapsed="0.020922"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.401028" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.415073" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.428993" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.429206" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.429393" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.429813" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.429656" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:05.429627" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.430041" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.430244" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.430420" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:05.429592" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.429478" elapsed="0.001025"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.430670" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.430752" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:05.430892" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.363618" elapsed="0.067303"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.431106" elapsed="0.002453"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.434896" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.434403" elapsed="0.000524"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.435529" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.435094" elapsed="0.000464"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:05.435738" elapsed="0.000337"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:05.433916" elapsed="0.002222"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.433659" elapsed="0.002513"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.436351" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.436197" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.433623" elapsed="0.002806"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:05.352629" elapsed="0.083850"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:05.351805" elapsed="0.084754"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.351542" elapsed="0.085114"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.351525" elapsed="0.085159"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.436720" elapsed="0.000031"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:05.203869" elapsed="0.232985"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:03.065531" elapsed="2.371384"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.487389" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.487009" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.488199" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.487946" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.488369" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.487588" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.488967" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.488563" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.489295" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.489463" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.489159" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.489934" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.489665" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.491266" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.490780" elapsed="0.000533"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.491802" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.491483" elapsed="0.000346"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.492764" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.492339" elapsed="0.000453"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.494024" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.493449" elapsed="0.000677"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.494253" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:05.494651" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.492985" elapsed="0.001696"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.494844" elapsed="0.000385"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:05.492054" elapsed="0.003217"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.495966" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.495522" elapsed="0.000471"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.497213" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.496661" elapsed="0.000690"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.497433" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:05.497746" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.496183" elapsed="0.001590"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.497932" elapsed="0.000421"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:05.495385" elapsed="0.003015"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.491880" elapsed="0.006555"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.498478" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:05.498637" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:05.490433" elapsed="0.008246"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.490055" elapsed="0.008656"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.498891" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.498736" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.490035" elapsed="0.008933"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.499719" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.499115" elapsed="0.000633"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.499799" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.486364" elapsed="0.013559"/>
</kw>
<msg time="2026-06-06T03:30:05.499979" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.473203" elapsed="0.026824"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.512756" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.527545" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.539988" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.540186" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.540367" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.540748" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.540586" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:05.540571" elapsed="0.000298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.541018" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.541191" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.541360" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:05.540542" elapsed="0.000871"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.540442" elapsed="0.000996"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.541586" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.541681" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:05.541804" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.468700" elapsed="0.073131"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.543137" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.542892" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.543300" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.542522" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.543665" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.543397" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.544227" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.543931" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.543749" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.543378" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.546944" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.544465" elapsed="0.002506"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:05.547024" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:05.547180" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:05.542159" elapsed="0.005046"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.548440" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.548208" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.548598" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.547863" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:05.548847" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:05.548710" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.548691" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.549087" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.549263" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.549328" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:05.551281" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:05.547514" elapsed="0.003832"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.552769" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.552501" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.553219" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.552975" elapsed="0.000288"/>
</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-06-06T03:30:05.562357" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:05.562499" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}} 
 </msg>
<msg time="2026-06-06T03:30:05.562598" 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-06-06T03:30:05.555478" elapsed="0.007146"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.553330" elapsed="0.009362"/>
</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-06-06T03:30:05.562880" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.562720" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.553311" elapsed="0.009679"/>
</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-06-06T03:30:05.568124" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.564435" elapsed="0.003758"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.564115" elapsed="0.004128"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.564088" elapsed="0.004191"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.571942" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.568701" elapsed="0.003306"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.568359" elapsed="0.003698"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.568335" elapsed="0.003758"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.572905" 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-06-06T03:30:05.572340" elapsed="0.000608"/>
</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-06-06T03:30:05.573418" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.573056" elapsed="0.000443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.574295" 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-06-06T03:30:05.573800" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.573533" elapsed="0.000859"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.573028" elapsed="0.001394"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.575139" 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-06-06T03:30:05.574683" elapsed="0.000483"/>
</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-06-06T03:30:05.575479" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.575238" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.576042" 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-06-06T03:30:05.575744" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.575561" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.575218" elapsed="0.000908"/>
</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-06-06T03:30:05.576474" elapsed="0.000385"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:05.577335" 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-06-06T03:30:05.577039" elapsed="0.000322"/>
</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-06-06T03:30:05.577526" elapsed="0.002386"/>
</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-06-06T03:30:05.563493" elapsed="0.016494"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.580173" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:05.580060" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.580041" elapsed="0.000202"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.583283" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:30:05.580395" elapsed="0.002917"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:05.583367" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:05.583536" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:05.551676" elapsed="0.031887"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.583629" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:05.583803" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:05.445933" elapsed="0.137897"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.612867" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.612335" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.613745" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.613429" elapsed="0.000447">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.614055" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.613078" elapsed="0.001003"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.614743" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.614278" elapsed="0.000492"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.615111" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.615277" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.614939" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.615748" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "source-tree-join": {
          "c-multicast": {
            "multicast-source": "1.0.0.1",
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 10,
            "c-g-address": "2.0.0.2"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.615463" elapsed="0.000392"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:05.616357" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.615931" elapsed="0.000488"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.617142" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.616598" elapsed="0.000572"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.616445" elapsed="0.000761"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.615908" elapsed="0.001320"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.617903" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.617381" elapsed="0.000552"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.617986" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.611693" elapsed="0.006425"/>
</kw>
<msg time="2026-06-06T03:30:05.618178" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.598513" elapsed="0.019714"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.630851" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.643302" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.655745" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.655944" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.656123" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.656510" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.656360" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:05.656345" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.656749" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.656922" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.657092" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:05.656314" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.656204" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.657371" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.657449" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:05.657572" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.595781" elapsed="0.061818"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.657798" elapsed="0.002398"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.661421" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.660963" elapsed="0.000486"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.662046" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.661608" elapsed="0.000466"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:05.662231" elapsed="0.000353"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:05.660523" elapsed="0.002135"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.660278" elapsed="0.002416"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.662870" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.662719" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.660259" elapsed="0.002687"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:05.585019" elapsed="0.077976"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:05.584179" elapsed="0.078892"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.583915" elapsed="0.079202"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.583897" elapsed="0.079244"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.663175" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:05.441430" elapsed="0.221873"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:05.437098" elapsed="0.226266"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.713256" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.712870" elapsed="0.000414"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.714030" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.713805" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.714238" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.713451" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.714863" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.714454" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.715193" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.715338" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.715056" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.715793" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.715526" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.717013" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.716534" elapsed="0.000526"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.717510" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.717232" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.718327" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.717925" elapsed="0.000465"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.719656" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.719103" elapsed="0.000658"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.719840" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:05.720128" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.718620" elapsed="0.001534"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.720312" elapsed="0.000399"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:05.717785" elapsed="0.002968"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.721402" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.721002" elapsed="0.000426"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.722691" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.722096" elapsed="0.000698"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.722871" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:05.723181" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.721615" elapsed="0.001593"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.723365" elapsed="0.000386"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:05.720865" elapsed="0.002928"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.717585" elapsed="0.006242"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.723870" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:05.724026" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:05.716207" elapsed="0.007844"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.715907" elapsed="0.008175"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.724259" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.724107" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.715888" elapsed="0.008446"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.725063" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.724481" elapsed="0.000610"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.725140" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.712233" elapsed="0.013030"/>
</kw>
<msg time="2026-06-06T03:30:05.725354" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.699281" elapsed="0.026122"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.747550" elapsed="0.000081"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.760208" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.772561" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.772827" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.773031" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.773496" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.773329" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:05.773308" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.773753" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.773930" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.774104" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:05.773260" elapsed="0.000896"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.773122" elapsed="0.001064"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.774342" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.774448" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:30:05.774635" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.695007" elapsed="0.079675"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.776244" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.775910" elapsed="0.000494">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.776505" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.775425" elapsed="0.001106"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.776901" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.776603" elapsed="0.000361"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.777488" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.777185" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.776989" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.776584" elapsed="0.000987"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.780284" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.777745" elapsed="0.002566"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:05.780364" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:05.780523" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:05.775030" elapsed="0.005518"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.781814" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.781562" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.781971" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.781218" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:05.782204" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:05.782067" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.782047" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.782467" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.782661" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.782729" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:05.784661" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:05.780877" elapsed="0.003811"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.786117" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.785855" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.786583" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.786322" elapsed="0.000305"/>
</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-06-06T03:30:05.795541" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:05.795711" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '386'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}} 
 </msg>
<msg time="2026-06-06T03:30:05.795812" 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-06-06T03:30:05.788925" elapsed="0.006914"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.786708" elapsed="0.009213"/>
</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-06-06T03:30:05.796111" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.795950" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.786689" elapsed="0.009510"/>
</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-06-06T03:30:05.800244" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.797242" elapsed="0.003072"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.797015" elapsed="0.003349"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.796995" elapsed="0.003405"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.804067" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.800821" elapsed="0.003312"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.800480" elapsed="0.003701"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.800456" elapsed="0.003760"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.805039" 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-06-06T03:30:05.804461" elapsed="0.000616"/>
</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-06-06T03:30:05.805521" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.805178" elapsed="0.000424"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.806322" 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-06-06T03:30:05.805899" elapsed="0.000460"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.805637" elapsed="0.000773"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.805151" elapsed="0.001389"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.807229" 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-06-06T03:30:05.806817" elapsed="0.000440"/>
</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-06-06T03:30:05.807567" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.807327" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.808128" 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-06-06T03:30:05.807834" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.807665" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.807309" elapsed="0.000900"/>
</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-06-06T03:30:05.808364" elapsed="0.000356"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:05.809198" 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-06-06T03:30:05.808891" elapsed="0.000333"/>
</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-06-06T03:30:05.809385" elapsed="0.002450"/>
</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-06-06T03:30:05.796569" elapsed="0.015328"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.812080" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:05.811974" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.811953" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.815149" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:30:05.812299" elapsed="0.002878"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:05.815231" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:05.815388" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:05.785008" elapsed="0.030406"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.815516" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:05.815692" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:05.672279" elapsed="0.143441"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.845343" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.844868" elapsed="0.000505"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.846194" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.845919" elapsed="0.000398">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.846511" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.845543" elapsed="0.000994"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.847174" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.846725" elapsed="0.000476"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.847526" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/source_tree_join/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.847699" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.847365" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.848161" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "source-tree-join": {
          "c-multicast": {
            "multicast-source": "1.0.0.1",
            "route-distinguisher": "1.2.3.4:258",
            "source-as": 10,
            "c-g-address": "2.0.0.2"
          }
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.847890" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:05.848700" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.848279" elapsed="0.000484"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.849446" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.848940" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.848788" elapsed="0.000721"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.848259" elapsed="0.001272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.850207" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.849712" elapsed="0.000524"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.850286" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.844229" elapsed="0.006183"/>
</kw>
<msg time="2026-06-06T03:30:05.850497" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.830122" elapsed="0.020426"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.863178" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.875809" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/source_tree_join/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.888342" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.888552" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.888762" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.889183" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.889026" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:05.889008" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.889418" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.889594" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.889786" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:05.888970" elapsed="0.000872"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.888851" elapsed="0.001018"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.890022" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:05.890103" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:05.890265" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "path-id": 0,
        "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
        "attributes": {
          "ipv4-next-hop": {
...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.827479" elapsed="0.062815"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.890481" elapsed="0.002820"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.894675" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.894137" elapsed="0.000569"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:05.895306" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.894870" elapsed="0.000525"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:05.895562" elapsed="0.000367"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:05.893679" elapsed="0.002311"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.893385" elapsed="0.002639"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.896204" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.896049" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.893365" elapsed="0.002915"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:05.816880" elapsed="0.079452"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:05.816055" elapsed="0.080358"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.815807" elapsed="0.080656"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.815789" elapsed="0.080699"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.896523" elapsed="0.000036"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:05.667868" elapsed="0.228807"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:05.663545" elapsed="0.233196"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:05.896912" elapsed="0.002538"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.950189" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:05.949725" elapsed="0.000506"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.951188" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.950911" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:05.951407" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:05.950429" elapsed="0.001011"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.952113" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:05.951700" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:05.952460" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:05.952683" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:05.952314" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.953160" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.952882" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.954824" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:05.954376" elapsed="0.000497"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.955353" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.955056" elapsed="0.000323"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.956284" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.955858" elapsed="0.000452"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.957769" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.957126" elapsed="0.000750"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.957965" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:30:05.958299" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.956621" elapsed="0.001706"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.958501" elapsed="0.000482"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:05.955707" elapsed="0.003321"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.959855" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:05.959306" elapsed="0.000577"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:05.961171" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.960580" elapsed="0.000695"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:05.961355" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:05.961715" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:05.960079" elapsed="0.001665"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:05.961905" elapsed="0.000374"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:05.959146" elapsed="0.003175"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.955437" elapsed="0.006919"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:05.962400" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:05.962633" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:05.953722" elapsed="0.008964"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:05.953293" elapsed="0.009432"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.962932" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:05.962752" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:05.953268" elapsed="0.009747"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:05.963846" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:05.963169" elapsed="0.000706"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:05.963927" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:05.948893" elapsed="0.015161"/>
</kw>
<msg time="2026-06-06T03:30:05.964111" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:05.935592" elapsed="0.028571"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.977582" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:05.990885" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.004632" elapsed="0.000046"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.004878" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.005077" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.005551" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.005364" elapsed="0.000268"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:06.005346" elapsed="0.000333"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.005860" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.006042" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.006216" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:06.005299" elapsed="0.000970"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.005163" elapsed="0.001134"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.006449" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.006552" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:06.006765" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:05.931274" elapsed="0.075522"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:06.008319" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:06.008025" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:06.008502" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:06.007567" elapsed="0.000971"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.008931" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.008654" elapsed="0.000343"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.009856" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:06.009215" elapsed="0.000668"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.009022" elapsed="0.000900"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.008614" elapsed="0.001331"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.012467" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:06.010112" elapsed="0.002389"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:06.012576" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:30:06.012772" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:06.007160" elapsed="0.005638"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:06.014059" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:06.013864" elapsed="0.000289"/>
</kw>
<msg time="2026-06-06T03:30:06.014241" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:06.013445" elapsed="0.000821"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.014481" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:06.014340" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.014320" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:06.014994" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:06.015153" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:06.014818" elapsed="0.000361"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:06.015630" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:06.015345" elapsed="0.000335"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:06.015733" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:06.015894" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:06.013112" elapsed="0.002808"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.017404" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:06.017149" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.017936" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:06.017678" elapsed="0.000303"/>
</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-06-06T03:30:06.028126" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:06.028893" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '531'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:06.029079" 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-06-06T03:30:06.020286" elapsed="0.008833"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.018050" elapsed="0.011137"/>
</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-06-06T03:30:06.029486" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.029228" elapsed="0.000393"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.018031" elapsed="0.011666"/>
</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-06-06T03:30:06.035504" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"BxYAAQECAwQBAgAAAAogAQAAASACAAAC","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"source-tree-join":{"c-multicast":{"source-as":10,"route-distinguisher":"1.2.3.4:258","multicast-source":"1.0.0.1","c-g-address":"2.0.0.2"}}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:06.031440" elapsed="0.004165"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.031090" elapsed="0.004620"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.031057" elapsed="0.004712"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.039688" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:06.036222" elapsed="0.003515"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.035864" elapsed="0.003910"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.035836" elapsed="0.003963"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.040445" 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-06-06T03:30:06.040010" elapsed="0.000464"/>
</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-06-06T03:30:06.040866" elapsed="0.000101"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.040574" elapsed="0.000434"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.041545" 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-06-06T03:30:06.041213" elapsed="0.000372"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.041034" elapsed="0.000602"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.040546" elapsed="0.001133"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.042231" 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-06-06T03:30:06.041853" elapsed="0.000405"/>
</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-06-06T03:30:06.042623" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.042332" elapsed="0.000385"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.043223" 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-06-06T03:30:06.042912" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.042742" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.042312" elapsed="0.000996"/>
</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-06-06T03:30:06.043473" elapsed="0.000427"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:06.044380" 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-06-06T03:30:06.044076" elapsed="0.000331"/>
</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-06-06T03:30:06.044615" elapsed="0.002722"/>
</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-06-06T03:30:06.030279" elapsed="0.017130"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.047658" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:06.047487" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.047462" elapsed="0.000279"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:06.051203" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:30:06.047898" elapsed="0.003336"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:06.051290" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:30:06.051492" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:06.016240" elapsed="0.035291"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:06.051623" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:30:06.051808" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:05.908616" elapsed="0.143219"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.082260" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:06.081742" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:06.083277" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:06.082971" elapsed="0.000434">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:06.083628" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:06.082503" elapsed="0.001221"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.084379" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:06.083908" elapsed="0.000501"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:06.084823" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:06.084988" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:06.084629" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.085455" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:06.085182" elapsed="0.000331"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:06.086061" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.085612" elapsed="0.000511"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.086931" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:06.086302" elapsed="0.000661"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:06.086148" elapsed="0.000853"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:06.085583" elapsed="0.001439"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.087749" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:06.087178" elapsed="0.000607"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:06.087843" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:06.081014" elapsed="0.006967"/>
</kw>
<msg time="2026-06-06T03:30:06.088036" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:06.067544" elapsed="0.020541"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.101975" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.115854" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.130301" elapsed="0.000049"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.130668" elapsed="0.000145"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.131070" elapsed="0.000032"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.131705" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.131456" elapsed="0.000335"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:06.131429" elapsed="0.000402"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.132054" elapsed="0.000031"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.132312" elapsed="0.000031"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.132568" elapsed="0.000031"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:06.131374" elapsed="0.001293"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.131199" elapsed="0.001511"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.132936" elapsed="0.000031"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.133053" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:06.133262" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:06.064745" elapsed="0.068559"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:06.133578" elapsed="0.003467"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:06.138678" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:06.138211" elapsed="0.000548"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:06.139615" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:06.138983" elapsed="0.000691"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:06.140177" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "path-id": 0,
      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
      "source-tree-join": {
       "c-multicast": {
        "c-g-address": "2.0.0.2",
        "multicast-source": "1.0.0.1",
        "route-distinguisher": "1.2.3.4:258",
        "source-as": 10
       }
      }
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:06.140386" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:06.139840" elapsed="0.000627">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:06.137542" elapsed="0.003125">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:06.137167" elapsed="0.003587">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:06.140950" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:06.140790" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:06.137138" elapsed="0.003892">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:06.053165" elapsed="0.087994">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:06.052243" elapsed="0.089070">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:06.051924" elapsed="0.089482">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:06.051905" elapsed="0.089538">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:06.141495" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:05.904207" elapsed="0.237413">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,36 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "BxYAAQECAwQBAgAAAAogAQAAASACAAAC",
+      "source-tree-join": {
+       "c-multicast": {
+        "c-g-address": "2.0.0.2",
+        "multicast-source": "1.0.0.1",
+        "route-distinguisher": "1.2.3.4:258",
+        "source-as": 10
+       }
+      }
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.198143" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.197735" elapsed="0.000441"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.198982" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.198722" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.199160" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.198358" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.199764" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.199356" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.200108" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.200277" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.199959" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.200752" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.200463" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.201859" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.201519" elapsed="0.000387"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.202357" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.202080" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.203193" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.202780" elapsed="0.000439"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.204463" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.203907" elapsed="0.000690"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.204696" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:08.204997" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.203410" elapsed="0.001614"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.205186" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:08.202613" elapsed="0.003003"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.206300" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.205891" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.207728" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.207152" elapsed="0.000678"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.207908" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:08.208218" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.206684" elapsed="0.001561"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.208405" elapsed="0.000576"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:08.205752" elapsed="0.003273"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.202436" elapsed="0.006624"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.209104" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:08.209262" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:08.201189" elapsed="0.008098"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.200878" elapsed="0.008441"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.209499" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.209344" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.200853" elapsed="0.008722"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.210328" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:08.209739" elapsed="0.000618"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.210407" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:08.197082" elapsed="0.013449"/>
</kw>
<msg time="2026-06-06T03:30:08.210586" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.184293" elapsed="0.026343"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.223339" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.235883" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.248265" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.248468" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.248680" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.249063" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.248907" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:08.248891" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.249290" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.249463" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.249631" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:08.248862" elapsed="0.000879"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.248759" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.249919" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.249995" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:08.250118" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:08.179983" elapsed="0.070163"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.251568" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.251308" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.251752" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.250915" elapsed="0.000862"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.252104" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.251848" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.252713" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.252368" elapsed="0.000372"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.252186" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.251829" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.255589" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.252988" elapsed="0.002633"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:08.255694" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:08.255874" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:08.250518" elapsed="0.005384"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.257330" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.257105" elapsed="0.000285"/>
</kw>
<msg time="2026-06-06T03:30:08.257479" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.256636" elapsed="0.000868"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.257771" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:08.257592" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.257567" elapsed="0.000277"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.258208" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.258397" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.258012" elapsed="0.000421"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:08.258865" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.258601" elapsed="0.000291"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:08.258940" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:08.259098" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:08.256254" elapsed="0.002869"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.260692" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.260365" elapsed="0.000381"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.261166" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.260912" elapsed="0.000299"/>
</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-06-06T03:30:08.269856" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:08.269997" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:08.270095" 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-06-06T03:30:08.263381" elapsed="0.006740"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.261280" elapsed="0.008885"/>
</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-06-06T03:30:08.270351" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.270192" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.261261" elapsed="0.009195"/>
</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-06-06T03:30:08.274570" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.271528" elapsed="0.003109"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.271298" elapsed="0.003410"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.271279" elapsed="0.003464"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.278618" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.275143" elapsed="0.003562"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.274822" elapsed="0.003934"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.274799" elapsed="0.003991"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.279574" 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-06-06T03:30:08.279037" elapsed="0.000574"/>
</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-06-06T03:30:08.280082" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.279733" elapsed="0.000431"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.280929" 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-06-06T03:30:08.280433" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.280198" elapsed="0.000821"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.279706" elapsed="0.001346"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.281819" 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-06-06T03:30:08.281283" elapsed="0.000574"/>
</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-06-06T03:30:08.282296" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.281955" elapsed="0.000422"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.283075" 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-06-06T03:30:08.282659" elapsed="0.000453"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.282410" elapsed="0.000751"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.281929" elapsed="0.001261"/>
</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-06-06T03:30:08.283408" elapsed="0.000507"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:08.284577" 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-06-06T03:30:08.284158" elapsed="0.000456"/>
</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-06-06T03:30:08.284859" elapsed="0.003212"/>
</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-06-06T03:30:08.270857" elapsed="0.017373"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.288485" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:08.288331" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.288304" elapsed="0.000308"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:08.291591" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:08.288849" elapsed="0.002773"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:08.291698" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:30:08.291875" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:08.259496" elapsed="0.032406"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.291967" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:08.292125" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:08.157461" elapsed="0.134691"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.321055" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.320513" elapsed="0.000573"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.321972" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.321629" elapsed="0.000472">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.322279" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.321264" elapsed="0.001041"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.323020" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.322505" elapsed="0.000543"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.323385" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.323553" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.323218" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.324033" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.323759" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:08.324611" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.324154" elapsed="0.000535"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.325385" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.324870" elapsed="0.000542"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.324717" elapsed="0.000731"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.324130" elapsed="0.001339"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.326152" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:08.325621" elapsed="0.000616"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.326291" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:08.319870" elapsed="0.006587"/>
</kw>
<msg time="2026-06-06T03:30:08.326519" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.306708" elapsed="0.019864"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.339274" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.352111" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.366049" elapsed="0.000051"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.366385" elapsed="0.000033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.366654" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.367224" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.367016" elapsed="0.000286"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:08.366989" elapsed="0.000351"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.367498" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.367721" elapsed="0.000031"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.367947" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:08.366934" elapsed="0.001086"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.366756" elapsed="0.001303"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.368242" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.368342" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:08.368545" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:08.304006" elapsed="0.064580"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.368969" elapsed="0.002653"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:08.372862" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.372459" elapsed="0.000435"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:08.373328" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.373054" elapsed="0.000302"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.373514" elapsed="0.000362"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.372009" elapsed="0.001927"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.371725" elapsed="0.002244"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.374152" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.373995" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.371704" elapsed="0.002523"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:08.293394" elapsed="0.080883"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:08.292528" elapsed="0.081827"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.292241" elapsed="0.082161"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.292222" elapsed="0.082205"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.374463" elapsed="0.000035"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:08.150621" elapsed="0.223980"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:05.899631" elapsed="2.475048"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:08.374906" elapsed="0.002584"/>
</kw>
<arg>source_tree_join</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:03.057046" elapsed="5.320505"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:02.974097" elapsed="5.403636"/>
</test>
<test id="s1-s16-t18" name="Odl_To_Play_intra_pe_distinguisher" line="126">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:08.382592" elapsed="0.000357"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:08.382168" elapsed="0.000868"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.384580" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:08.384401" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.384370" elapsed="0.000363"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.391249" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:08.391137" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.391118" elapsed="0.000203"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.392366" 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-06-06T03:30:08.391967" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.392898" 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-06-06T03:30:08.392560" elapsed="0.000364"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:08.392971" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:08.393130" 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-06-06T03:30:08.391559" elapsed="0.001596"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:08.400406" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:08.400289" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.400268" elapsed="0.000210"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:08.401766" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:08.401613" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.401594" elapsed="0.000241"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:08.402296" 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-06-06T03:30:08.401988" elapsed="0.000336"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:08.402730" level="INFO">${current_connection_index} = 7</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-06-06T03:30:08.402492" elapsed="0.000265"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:08.435473" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:08.403266" elapsed="0.032370"/>
</kw>
<msg time="2026-06-06T03:30:08.435863" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:08.435911" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:08.402922" elapsed="0.033029"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:08.466026" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "p "e "_ "d "i "s "t "i "n "g "u "i "s "h "e "r "[K"
[?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-06-06T03:30:08.436588" elapsed="0.029670"/>
</kw>
<msg time="2026-06-06T03:30:08.466488" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:08.466536" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:30:08.436173" elapsed="0.030402"/>
</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-06-06T03:30:08.467056" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.466716" elapsed="0.000399"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.466679" elapsed="0.000462"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.467694" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "p "e "_ "d "i "s "t "i "n "g "u "i "s "h "e "r "[K"
[?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-06-06T03:30:08.467292" elapsed="0.000481"/>
</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-06-06T03:30:08.468068" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.467841" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.467822" elapsed="0.000325"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:08.468185" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:08.470978" elapsed="0.000162"/>
</kw>
<msg time="2026-06-06T03:30:08.471212" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.469826" elapsed="0.001531"/>
</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="NOT RUN" start="2026-06-06T03:30:08.471670" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.472013" elapsed="0.000072"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:08.469148" elapsed="0.003052"/>
</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-06-06T03:30:08.468514" elapsed="0.003753"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:08.401305" elapsed="0.071065"/>
</kw>
<msg time="2026-06-06T03:30:08.472470" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:08.472517" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:08.400669" elapsed="0.071888"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:08.472910" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:30:08.472785" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.472758" elapsed="0.000243"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.473465" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.473839" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.473912" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:08.399927" elapsed="0.074102"/>
</kw>
<msg time="2026-06-06T03:30:08.474128" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:08.474174" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:08.393616" elapsed="0.080597"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.474565" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.474292" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.474274" elapsed="0.000386"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:08.393465" elapsed="0.081221"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:08.393212" elapsed="0.081508"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:08.390767" elapsed="0.084012"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:08.383955" elapsed="0.090881"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:08.383272" elapsed="0.091612"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:08.378813" elapsed="0.096125"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.475919" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/announce_intra_pe_distinguisher.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/announce_intra_pe_distinguisher.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.476114" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00570200000040c01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.475695" elapsed="0.000447"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:08.476526" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00570200000040c01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.476308" elapsed="0.000246"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.476956" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/withdraw_intra_pe_distinguisher.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/withdraw_intra_pe_distinguisher.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.477089" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.476760" elapsed="0.000356"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:08.477481" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.477275" elapsed="0.000233"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:08.477844" elapsed="0.003853"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.477588" elapsed="0.004159"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.477565" elapsed="0.004214"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.521502" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.521067" elapsed="0.000611"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.522539" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.522229" elapsed="0.000393">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.522736" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.521870" elapsed="0.000891"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.523335" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.522936" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.523698" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.523869" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.523537" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.524311" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.524063" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.525419" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.525156" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.525917" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.525632" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.526611" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.526311" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.527627" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.527176" elapsed="0.000503"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.527735" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:08.527895" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.526845" elapsed="0.001075"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.528080" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:08.526171" elapsed="0.002197"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.529176" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.528866" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.530149" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.529736" elapsed="0.000440"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.530227" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:08.530378" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.529395" elapsed="0.001008"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.530557" elapsed="0.000239"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:08.528489" elapsed="0.002349"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.525997" elapsed="0.004876"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.530916" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:08.531071" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:08.524814" elapsed="0.006282"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.524434" elapsed="0.006695"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.531309" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.531155" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.524410" elapsed="0.007012"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.532192" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:08.531579" elapsed="0.000642"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.532271" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:08.520102" elapsed="0.012293"/>
</kw>
<msg time="2026-06-06T03:30:08.532451" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.506068" elapsed="0.026432"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.545135" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.558545" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.571636" elapsed="0.000045"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.571893" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.572087" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.572519" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.572356" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:08.572337" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.572772" elapsed="0.000045"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.572997" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.573179" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:08.572296" elapsed="0.000936"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.572172" elapsed="0.001088"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.573414" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.573496" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:08.573671" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:08.501485" elapsed="0.072217"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.599605" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.599172" elapsed="0.000479"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.600452" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.600194" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.600623" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.599837" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.601275" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.600877" elapsed="0.000426"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.601619" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.601819" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.601472" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.602277" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pe-distinguisher-labels-attribute&gt;
            &lt;pe-distinguisher-label-attribute&gt;
                &lt;pe-address&gt;10.10.10.1&lt;/pe-address&gt;
                &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;/pe-distinguisher-label-attribute&gt;
            &lt;pe-distinguisher-label-attribute&gt;
                &lt;pe-address&gt;10.10.20.2&lt;/pe-address&gt;
                &lt;mpls-label&gt;20028&lt;/mpls-label&gt;
            &lt;/pe-distinguisher-label-attribute&gt;
        &lt;/pe-distinguisher-labels-attribute&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.602018" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:08.602815" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.602437" elapsed="0.000440"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.603364" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.603060" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.602905" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.602408" elapsed="0.001040"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.604096" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:08.603602" elapsed="0.000525"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.604181" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:08.598447" elapsed="0.005872"/>
</kw>
<msg time="2026-06-06T03:30:08.604434" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.585080" elapsed="0.019406"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.617328" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.629999" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.642635" elapsed="0.000057"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.642925" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.643119" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.643562" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.643405" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:08.643386" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.643817" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.643989" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.644159" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:08.643344" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.643207" elapsed="0.001033"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.644392" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.644471" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:08.644670" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:08.584110" elapsed="0.060593"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.646398" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.646006" elapsed="0.000493">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.646697" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.645510" elapsed="0.001215"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.647083" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.646800" elapsed="0.000341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.647689" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.647367" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.647166" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.646780" elapsed="0.000997"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.650501" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.647937" elapsed="0.002593"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:08.650584" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:08.650769" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:08.645136" elapsed="0.005659"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.652559" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.652275" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.653096" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pe-distinguisher-labels-attribute&gt;
            &lt;pe-distinguisher-label-attribute&gt;
                &lt;pe-address&gt;10.10.10.1&lt;/pe-address&gt;
                &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;/pe-distinguisher-label-attribute&gt;
            &lt;pe-distinguisher-label-attribute&gt;
                &lt;pe-address&gt;10.10.20.2&lt;/pe-address&gt;
                &lt;mpls-label&gt;20028&lt;/mpls-label&gt;
            &lt;/pe-distinguisher-label-attribute&gt;
        &lt;/pe-distinguisher-labels-attribute&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.652800" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.653569" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.653319" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.654041" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.653793" elapsed="0.000298"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:08.655058" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:08.654843" elapsed="0.000242"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:08.655426" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:08.655247" elapsed="0.000206"/>
</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-06-06T03:30:08.655610" elapsed="0.000256"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.656343" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.656032" elapsed="0.000372"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:08.656452" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:08.656630" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:08.654348" elapsed="0.002326"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:08.679132" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '1181', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;pe-distinguisher-labels-attribute&gt;
            &lt;pe-distinguisher-label-attribute&gt;
                &lt;pe-address&gt;10.10.10.1&lt;/pe-address&gt;
                &lt;mpls-label&gt;20024&lt;/mpls-label&gt;
            &lt;/pe-distinguisher-label-attribute&gt;
            &lt;pe-distinguisher-label-attribute&gt;
                &lt;pe-address&gt;10.10.20.2&lt;/pe-address&gt;
                &lt;mpls-label&gt;20028&lt;/mpls-label&gt;
            &lt;/pe-distinguisher-label-attribute&gt;
        &lt;/pe-distinguisher-labels-attribute&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:08.679442" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AQwAAQECAwQBAgoKCgo%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:08.679760" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:08.659188" elapsed="0.020634"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.656758" elapsed="0.023183"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.680431" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.680010" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.656736" elapsed="0.023895"/>
</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-06-06T03:30:08.687902" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.683276" elapsed="0.004694"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.682744" elapsed="0.005278"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.682697" elapsed="0.005363"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.692284" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.688480" elapsed="0.003873"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.688144" elapsed="0.004262"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.688118" elapsed="0.004325"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.693420" 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-06-06T03:30:08.692750" elapsed="0.000712"/>
</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-06-06T03:30:08.693957" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.693567" elapsed="0.000471"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.694550" 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-06-06T03:30:08.694233" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.694063" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.693540" elapsed="0.001096"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.695190" 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-06-06T03:30:08.694821" elapsed="0.000396"/>
</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-06-06T03:30:08.695526" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.695287" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.696083" 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-06-06T03:30:08.695788" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.695607" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.695269" elapsed="0.000895"/>
</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-06-06T03:30:08.696325" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:08.697222" 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-06-06T03:30:08.696866" elapsed="0.000383"/>
</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-06-06T03:30:08.697414" elapsed="0.002360"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:08.681581" elapsed="0.018263"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:08.700034" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:30:08.699920" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.699900" elapsed="0.000233"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:08.700289" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.700356" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:08.702729" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:08.651142" elapsed="0.051615"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.702903" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:08.703069" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:08.487854" elapsed="0.215240"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.703469" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.703204" elapsed="0.000336"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.703185" elapsed="0.000379"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.703598" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:08.482129" elapsed="0.221615"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:08.708018" level="INFO">${update} = ffffffffffffffffffffffffffffffff00570200000040400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.704716" elapsed="0.003339"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.708294" elapsed="0.002630"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:08.711007" elapsed="0.000051"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:08.704414" elapsed="0.006797"/>
</kw>
<msg time="2026-06-06T03:30:08.711329" level="INFO">${update} = ffffffffffffffffffffffffffffffff00570200000040400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:08.703931" elapsed="0.007437"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.712748" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:30:08.712867" level="INFO">${len_1} = 174</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:08.712315" elapsed="0.000590"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.713569" level="INFO">Length is 174.</msg>
<msg time="2026-06-06T03:30:08.713708" level="INFO">${len_2} = 174</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:08.713185" elapsed="0.000563"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.713993" elapsed="0.000471"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:08.714994" level="INFO">${sum_1} = 2055</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:08.714724" elapsed="0.000309"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:08.715516" level="INFO">${sum_2} = 2055</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:08.715256" elapsed="0.000297"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.715795" elapsed="0.000445"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:08.711743" elapsed="0.004585"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:08.716549" elapsed="0.002120"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.765069" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.764560" elapsed="0.000545"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.765932" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.765663" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.766195" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.765289" elapsed="0.000933"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.766808" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.766394" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.767153" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.767460" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.767006" elapsed="0.000483"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.767931" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.767670" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.769216" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.768766" elapsed="0.000521"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.770000" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.769546" elapsed="0.000501"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.771139" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.770588" elapsed="0.000584"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.772677" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.772029" elapsed="0.000773"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.773066" elapsed="0.000058"/>
</return>
<msg time="2026-06-06T03:30:08.773420" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.771416" elapsed="0.002044"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.773723" elapsed="0.000640"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:08.770386" elapsed="0.004033"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.775269" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.774763" elapsed="0.000539"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.777502" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.776496" elapsed="0.001129"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.777832" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:30:08.778161" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.775563" elapsed="0.002635"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.778405" elapsed="0.000581"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:08.774566" elapsed="0.004478"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.770131" elapsed="0.008959"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.779150" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:30:08.779386" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:08.768396" elapsed="0.011028"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.768062" elapsed="0.011409"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.779780" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.779515" elapsed="0.000354"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.768036" elapsed="0.011868"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.781174" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:08.780147" elapsed="0.001070"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.781292" elapsed="0.000042"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:08.763893" elapsed="0.017581"/>
</kw>
<msg time="2026-06-06T03:30:08.781666" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.749005" elapsed="0.032748"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.800688" elapsed="0.000051"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.822037" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.834496" elapsed="0.000041"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.834772" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.834973" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.835410" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.835249" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:08.835230" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.835660" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.835841" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.836015" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:08.835190" elapsed="0.000879"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.835063" elapsed="0.001033"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.836248" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.836328" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:08.836485" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:08.744653" elapsed="0.091861"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.837784" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.837463" elapsed="0.000468"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:08.848665" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:08.848723" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:08.848833" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:08.840095" elapsed="0.008766"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.838003" elapsed="0.010905"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.849187" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.848938" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.837983" elapsed="0.011294"/>
</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-06-06T03:30:08.856940" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.850873" elapsed="0.006259"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.850328" elapsed="0.006897"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.850287" elapsed="0.006997"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.860491" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.858058" elapsed="0.002484"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.857418" elapsed="0.003161"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.857378" elapsed="0.003227"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.861307" 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-06-06T03:30:08.860837" elapsed="0.000499"/>
</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-06-06T03:30:08.861723" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.861414" elapsed="0.000373"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.862307" 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-06-06T03:30:08.861989" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.861812" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.861393" elapsed="0.001001"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.863163" 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-06-06T03:30:08.862726" elapsed="0.000465"/>
</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-06-06T03:30:08.863515" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.863266" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.864165" 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-06-06T03:30:08.863799" elapsed="0.000394"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.863599" elapsed="0.000631"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.863246" elapsed="0.001006"/>
</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-06-06T03:30:08.864423" elapsed="0.000383"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:08.865395" 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-06-06T03:30:08.864981" elapsed="0.000444"/>
</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-06-06T03:30:08.865611" elapsed="0.002423"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:08.849702" elapsed="0.018405"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:08.868164" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:30:08.870471" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:08.836822" elapsed="0.033676"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.870627" elapsed="0.000045"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:08.719744" elapsed="0.151032"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:08.719273" elapsed="0.151563"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:08.718862" elapsed="0.152038"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:08.874266" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.871911" elapsed="0.002385"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.874478" elapsed="0.003140"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:08.877715" elapsed="0.000045"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:08.871598" elapsed="0.006306"/>
</kw>
<msg time="2026-06-06T03:30:08.878017" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:08.871082" elapsed="0.006973"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.879361" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:08.879473" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:08.878960" elapsed="0.000548"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.880145" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:08.880254" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:08.879769" elapsed="0.000520"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.880526" elapsed="0.000480"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:08.881708" level="INFO">${sum_1} = 1904</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:08.881396" elapsed="0.000353"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:08.882254" level="INFO">${sum_2} = 1904</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:08.881982" elapsed="0.000308"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:08.882521" elapsed="0.000483"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:08.878385" elapsed="0.004707"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.928742" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:08.928323" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.929593" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.929319" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:08.929779" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:08.928956" elapsed="0.000848"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.930368" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:08.929974" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:08.930720" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:08.930884" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:08.930562" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.931321" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.931073" elapsed="0.000364"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.932488" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.932226" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.932991" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.932717" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.934044" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.933470" elapsed="0.000601"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.935221" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.934760" elapsed="0.000504"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.935385" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:08.935611" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.934264" elapsed="0.001373"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.935823" elapsed="0.000502"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:08.933328" elapsed="0.003039"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.937166" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:08.936618" elapsed="0.000574"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:08.938478" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.937875" elapsed="0.000644"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:08.938636" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:30:08.938875" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:08.937381" elapsed="0.001519"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:08.939062" elapsed="0.000486"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:08.936482" elapsed="0.003108"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.933078" elapsed="0.006547"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:08.939684" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:08.939844" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:08.931864" elapsed="0.008004"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.931516" elapsed="0.008384"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.940077" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.939925" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:08.931492" elapsed="0.008661"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.940959" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:08.940298" elapsed="0.000690"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:08.941038" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:08.927628" elapsed="0.013564"/>
</kw>
<msg time="2026-06-06T03:30:08.941246" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:08.914702" elapsed="0.026607"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.953986" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.967257" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.980123" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.980353" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.980543" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.980975" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.980820" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:08.980801" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.981238" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.981415" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.981587" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:08.980761" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.980628" elapsed="0.001056"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.981838" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:08.981917" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:08.982065" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:08.910148" elapsed="0.071946"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:08.983326" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:08.983027" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:08.991854" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:08.991996" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:08.992143" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:08.992186" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.985546" elapsed="0.007127">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:08.983444" elapsed="0.009312">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:08.992950" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:08.992790" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:08.983426" elapsed="0.009615">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:08.998208" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.994198" elapsed="0.004060">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:08.993922" elapsed="0.004426">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:08.993903" elapsed="0.004491">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.002106" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.998856" elapsed="0.003284">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:08.998493" elapsed="0.003710">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:08.998468" elapsed="0.003769">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.002886" 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-06-06T03:30:09.002455" elapsed="0.000459"/>
</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-06-06T03:30:09.003235" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.002987" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.003813" 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-06-06T03:30:09.003488" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:09.003317" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.002967" elapsed="0.000930"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.004433" 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-06-06T03:30:09.004062" elapsed="0.000398"/>
</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-06-06T03:30:09.004793" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.004531" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.005388" 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-06-06T03:30:09.005045" elapsed="0.000370"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:09.004876" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.004512" elapsed="0.000959"/>
</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-06-06T03:30:09.005632" elapsed="0.000370"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:09.006471" 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-06-06T03:30:09.006175" elapsed="0.000323"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:09.008942" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:09.006674" elapsed="0.002301">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:08.993461" elapsed="0.015653">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:09.009290" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:09.011674" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:09.011705" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:08.982371" elapsed="0.029363">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:09.011801" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:08.884730" elapsed="0.127242">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:08.884074" elapsed="0.127968"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:08.883458" elapsed="0.128647"/>
</kw>
<arg>intra_pe_distinguisher</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:08.475251" elapsed="0.536907"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:08.378091" elapsed="0.634187"/>
</test>
<test id="s1-s16-t19" name="Play_To_Odl_intra_pe_distinguisher" line="130">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:09.017469" elapsed="0.000237"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:09.017191" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.018795" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:09.018681" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.018660" elapsed="0.000205"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.023818" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:09.023711" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.023692" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.024901" 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-06-06T03:30:09.024499" elapsed="0.000429"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.025422" 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-06-06T03:30:09.025092" elapsed="0.000356"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:09.025492" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:09.025661" 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-06-06T03:30:09.024120" elapsed="0.001567"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:09.031180" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:09.031071" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.031052" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:09.032445" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:09.032339" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.032320" elapsed="0.000193"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:09.032991" 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-06-06T03:30:09.032689" elapsed="0.000328"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:09.033429" level="INFO">${current_connection_index} = 7</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-06-06T03:30:09.033206" elapsed="0.000249"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:09.065778" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:09.033980" elapsed="0.031926"/>
</kw>
<msg time="2026-06-06T03:30:09.066087" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:09.066134" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:09.033619" elapsed="0.032552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:09.100917" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "p "e "_ "d "i "s "t "i "n "g "u "i "s "h "e "r "[K"
[?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-06-06T03:30:09.066770" elapsed="0.034522"/>
</kw>
<msg time="2026-06-06T03:30:09.101587" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:09.101695" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:30:09.066369" elapsed="0.035397"/>
</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-06-06T03:30:09.102417" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.101946" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.101895" elapsed="0.000660"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.103343" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "p "e "_ "d "i "s "t "i "n "g "u "i "s "h "e "r "[K"
[?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-06-06T03:30:09.102807" elapsed="0.000655"/>
</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-06-06T03:30:09.103962" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.103569" elapsed="0.000483"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.103539" elapsed="0.000550"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:09.104154" elapsed="0.000068"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:09.109673" elapsed="0.000352"/>
</kw>
<msg time="2026-06-06T03:30:09.110097" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:09.106980" elapsed="0.003259"/>
</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="NOT RUN" start="2026-06-06T03:30:09.110548" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.110927" elapsed="0.000079"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:09.105581" elapsed="0.005547"/>
</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-06-06T03:30:09.104669" elapsed="0.006544"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:09.032035" elapsed="0.079284"/>
</kw>
<msg time="2026-06-06T03:30:09.111418" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:09.111468" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:09.031404" elapsed="0.080116"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:09.111761" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:09.111618" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.111592" elapsed="0.000258"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.112305" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.112776" elapsed="0.000031"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.112857" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:09.030734" elapsed="0.082237"/>
</kw>
<msg time="2026-06-06T03:30:09.113089" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:09.113144" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:09.026072" elapsed="0.087114"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.113634" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.113306" elapsed="0.000418"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.113280" elapsed="0.000475"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:09.025919" elapsed="0.087868"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:09.025746" elapsed="0.088123"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:09.023336" elapsed="0.090609"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:09.018368" elapsed="0.095651"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:09.017922" elapsed="0.096161"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:09.013236" elapsed="0.100919"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.115718" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.115094" elapsed="0.000661"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.116545" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.115978" elapsed="0.000602"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.117348" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.116818" elapsed="0.000565"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:09.117862" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/announce_intra_pe_distinguisher.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/announce_intra_pe_distinguisher.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:09.118057" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff00570200000040c01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:09.117598" elapsed="0.000487"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:09.118447" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/withdraw_intra_pe_distinguisher.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/withdraw_intra_pe_distinguisher.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:09.118574" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:09.118252" elapsed="0.000349"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:09.118827" elapsed="0.002678"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:09.121712" elapsed="0.002179"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.179817" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:09.179379" elapsed="0.000475"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:09.180711" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:09.180401" elapsed="0.000404">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:09.180907" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:09.180043" elapsed="0.000890"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.181523" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:09.181107" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:09.181929" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:09.182127" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:09.181753" elapsed="0.000464"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.182736" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:09.182408" elapsed="0.000381"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.183985" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:09.183606" elapsed="0.000427"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.184515" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.184212" elapsed="0.000338"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.185452" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:09.184990" elapsed="0.000490"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:09.186950" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.186332" elapsed="0.000724"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:09.187142" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:09.187458" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:09.185700" elapsed="0.001786"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.187691" elapsed="0.000420"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:09.184843" elapsed="0.003312"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.188858" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:09.188416" elapsed="0.000469"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:09.190362" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.189804" elapsed="0.000663"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:09.190548" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:09.190866" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:09.189275" elapsed="0.001620"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:09.191055" elapsed="0.000378"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:09.188273" elapsed="0.003203"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:09.184610" elapsed="0.006902"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:09.191557" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:09.191741" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:09.183233" elapsed="0.008535"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:09.182875" elapsed="0.008928"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.191988" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.191830" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.182847" elapsed="0.009226"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.192856" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:09.192224" elapsed="0.000661"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:09.192935" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:09.178496" elapsed="0.014563"/>
</kw>
<msg time="2026-06-06T03:30:09.193115" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:09.165187" elapsed="0.027978"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.206062" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.218720" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.231398" elapsed="0.000051"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.231704" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.231906" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.232368" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.232206" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:09.232186" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.232605" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.232799" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.232969" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:09.232141" elapsed="0.000881"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.231997" elapsed="0.001053"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.233203" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.233283" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:30:09.233492" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:09.160704" elapsed="0.072818"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:09.235132" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:09.234793" elapsed="0.000420">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:09.235310" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:09.234362" elapsed="0.000973"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.235704" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.235409" elapsed="0.000355"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.236369" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:09.236058" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:09.235853" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.235389" elapsed="0.001063"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.239147" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:09.236611" elapsed="0.002564"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:09.239230" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:09.239400" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:09.233977" elapsed="0.005448"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:09.240787" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:09.240494" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:09.240958" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:09.240134" elapsed="0.000849"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:09.241209" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:30:09.241060" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:09.241040" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.241506" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.241706" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.241773" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:09.243782" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:09.239777" elapsed="0.004031"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.245318" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:09.245038" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:09.245805" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:09.245542" elapsed="0.000308"/>
</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-06-06T03:30:09.253917" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:09.254073" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:09.254217" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:30:09.248141" elapsed="0.006476">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:09.245919" elapsed="0.008815">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:09.254971" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.254775" elapsed="0.000342"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:09.245899" elapsed="0.009246">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:09.255586" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.255749" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:09.255708" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:09.255687" elapsed="0.000130"/>
</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-06-06T03:30:09.255970" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.256041" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:09.244160" elapsed="0.011996">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.256233" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:09.136628" elapsed="0.119703">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:09.256616" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:09.256426" elapsed="0.000280"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:09.256409" elapsed="0.000321"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:09.256763" elapsed="0.000015"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:09.130332" elapsed="0.126532">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.315454" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.315039" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.316307" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.316040" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.316489" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.315689" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.317097" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.316703" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.317437" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:11.317603" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:11.317293" elapsed="0.000417"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.318133" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.317879" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.319277" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.318933" elapsed="0.000392"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.319810" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.319495" elapsed="0.000342"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.320654" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.320222" elapsed="0.000461"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:11.321936" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.321353" elapsed="0.000688"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:11.322124" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:11.322427" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:11.320878" elapsed="0.001576"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.322616" elapsed="0.000422"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:11.320074" elapsed="0.003008"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.323795" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.323340" elapsed="0.000484"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:11.325314" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.324704" elapsed="0.000714"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:11.325499" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:11.325814" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:11.324214" elapsed="0.001627"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.326002" elapsed="0.000374"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:11.323200" elapsed="0.003218"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:11.319896" elapsed="0.006557"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:11.326497" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:11.326674" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:11.318579" elapsed="0.008121"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.318262" elapsed="0.008472"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.326919" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.326760" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.318236" elapsed="0.008791"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.327850" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:11.327205" elapsed="0.000675"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.327930" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:11.314346" elapsed="0.013711"/>
</kw>
<msg time="2026-06-06T03:30:11.328112" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.301293" elapsed="0.026871"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.341023" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.353884" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.366449" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.366727" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.366925" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.367387" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.367228" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:11.367208" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.367621" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.367815" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.367986" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:11.367167" elapsed="0.000872"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.367014" elapsed="0.001052"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.368234" elapsed="0.000025"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.368318" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:11.368480" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:11.296925" elapsed="0.071583"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.369989" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.369683" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.370163" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.369247" elapsed="0.000940"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.370534" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.370259" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.371209" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.370894" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.370698" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.370240" elapsed="0.001053"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.373894" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.371451" elapsed="0.002471"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:11.373975" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:11.374136" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:11.368878" elapsed="0.005284"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.375480" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.375229" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.375657" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.374837" elapsed="0.000847"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:11.375895" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:11.375757" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.375737" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.376130" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.376308" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.376373" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:11.378310" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:11.374482" elapsed="0.003854"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.379871" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.379575" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.380326" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.380081" elapsed="0.000289"/>
</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-06-06T03:30:11.390848" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:11.391403" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '492'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:11.391535" 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-06-06T03:30:11.382616" elapsed="0.008961"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.380439" elapsed="0.011198"/>
</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-06-06T03:30:11.391921" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.391714" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.380420" elapsed="0.011593"/>
</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-06-06T03:30:11.397872" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.393703" elapsed="0.004341"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.393341" elapsed="0.004763"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.393311" elapsed="0.004834"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.401456" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.398602" elapsed="0.002901"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.398236" elapsed="0.003303"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.398208" elapsed="0.003356"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.402205" 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-06-06T03:30:11.401790" elapsed="0.000442"/>
</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-06-06T03:30:11.402555" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.402304" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.403152" 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-06-06T03:30:11.402828" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.402638" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.402285" elapsed="0.000951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.403787" 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-06-06T03:30:11.403405" elapsed="0.000409"/>
</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-06-06T03:30:11.404127" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.403885" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.404687" 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-06-06T03:30:11.404375" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.404209" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.403866" elapsed="0.000905"/>
</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-06-06T03:30:11.404935" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:11.405784" 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-06-06T03:30:11.405463" elapsed="0.000347"/>
</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-06-06T03:30:11.405973" elapsed="0.002389"/>
</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-06-06T03:30:11.392614" elapsed="0.015821"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.408622" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:11.408509" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.408489" elapsed="0.000221"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.411813" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:30:11.408863" elapsed="0.002980"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:11.411897" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:11.412068" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:11.378669" elapsed="0.033426"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.412159" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:11.412334" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:11.272876" elapsed="0.139486"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.442103" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.441529" elapsed="0.000608"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.443063" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.442741" elapsed="0.000498">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.443417" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.442329" elapsed="0.001114"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.444080" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.443618" elapsed="0.000490"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.444449" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:11.444629" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:11.444282" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.445118" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "pe-distinguisher-labels-attribute": {
            "pe-distinguisher-label-attribute": [
              {
                "pe-address": "10.10.10.1",
                "mpls-label": 20024
              },
              {
                "pe-address": "10.10.20.2",
                "mpls-label": 20028
              }
            ]
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.444844" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:11.445924" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.445400" elapsed="0.000589"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.446898" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.446174" elapsed="0.000751"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.446017" elapsed="0.000944"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.445228" elapsed="0.001756"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.447708" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:11.447170" elapsed="0.000567"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.447790" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:11.440707" elapsed="0.007226"/>
</kw>
<msg time="2026-06-06T03:30:11.447994" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.427396" elapsed="0.020653"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.460799" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.473459" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.486142" elapsed="0.000047"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.486424" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.486621" elapsed="0.000037"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.487081" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.486922" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:11.486904" elapsed="0.000281"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.487336" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.487512" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.487700" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:11.486865" elapsed="0.000891"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.486730" elapsed="0.001053"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.487936" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.488015" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:11.488197" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:11.424479" elapsed="0.063754"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.488443" elapsed="0.002625"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.492540" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.491939" elapsed="0.000631"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.493289" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.492769" elapsed="0.000549"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:11.493481" elapsed="0.000366"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:11.491475" elapsed="0.002435"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.491193" elapsed="0.002751"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.494129" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.493972" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.491172" elapsed="0.003097"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:11.413616" elapsed="0.080706"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:11.412761" elapsed="0.081643"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.412449" elapsed="0.082004"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.412431" elapsed="0.082047"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.494515" elapsed="0.000035"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:11.266130" elapsed="0.228543"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:09.124111" elapsed="2.370627"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.548005" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.547548" elapsed="0.000491"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.548857" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.548576" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.549030" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.548221" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.549617" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.549226" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.549976" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:11.550145" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:11.549831" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.550582" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.550334" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.552076" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.551476" elapsed="0.000649"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.552573" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.552297" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.553447" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.553037" elapsed="0.000437"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:11.554767" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.554180" elapsed="0.000690"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:11.554949" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:11.555299" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:11.553694" elapsed="0.001632"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.555566" elapsed="0.000411"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:11.552890" elapsed="0.003131"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.556735" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.556280" elapsed="0.000483"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:11.558014" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.557437" elapsed="0.000681"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:11.558202" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:11.558504" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:11.556964" elapsed="0.001567"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.558709" elapsed="0.000372"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:11.556139" elapsed="0.002986"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:11.552687" elapsed="0.006473"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:11.559229" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:11.559402" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:11.551105" elapsed="0.008325"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.550730" elapsed="0.008734"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.559672" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.559493" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.550704" elapsed="0.009047"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.560535" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:11.559904" elapsed="0.000661"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.560616" elapsed="0.000050"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:11.546749" elapsed="0.014041"/>
</kw>
<msg time="2026-06-06T03:30:11.560850" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.533842" elapsed="0.027065"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.573761" elapsed="0.000052"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.586851" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.599670" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.599977" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.600169" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.600598" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.600441" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:11.600422" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.600849" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.601022" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.601194" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:11.600381" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.600261" elapsed="0.001015"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.601427" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.601505" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:11.601670" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:11.528037" elapsed="0.073662"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.603091" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.602808" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.603287" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.602391" elapsed="0.000922"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.603670" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.603384" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.604239" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.603943" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.603756" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.603365" elapsed="0.000955"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.608141" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.604476" elapsed="0.003693"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:11.608221" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:11.608377" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:11.602035" elapsed="0.006368"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.609663" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.609411" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.609825" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.609063" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:11.610060" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:11.609923" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.609904" elapsed="0.000280"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.610337" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.610513" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.610580" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:11.612575" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:11.608726" elapsed="0.003876"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.614210" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.613946" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.614680" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.614419" elapsed="0.000307"/>
</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-06-06T03:30:11.623692" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:11.623850" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '492'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:11.623967" 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-06-06T03:30:11.616904" elapsed="0.007091"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.614794" elapsed="0.009245"/>
</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-06-06T03:30:11.624287" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.624068" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.614775" elapsed="0.009635"/>
</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-06-06T03:30:11.629475" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.625960" elapsed="0.003591"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.625609" elapsed="0.003991"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.625581" elapsed="0.004056"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.681542" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.630132" elapsed="0.051477"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.629745" elapsed="0.051929"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.629719" elapsed="0.051988"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.682383" 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-06-06T03:30:11.681923" elapsed="0.000488"/>
</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-06-06T03:30:11.682760" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.682490" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.683354" 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-06-06T03:30:11.683016" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.682845" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.682469" elapsed="0.000970"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.683993" 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-06-06T03:30:11.683607" elapsed="0.000413"/>
</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-06-06T03:30:11.684407" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.684162" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.684976" 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-06-06T03:30:11.684674" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.684490" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.684142" elapsed="0.000918"/>
</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-06-06T03:30:11.685225" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:11.686055" 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-06-06T03:30:11.685761" elapsed="0.000321"/>
</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-06-06T03:30:11.686243" elapsed="0.002327"/>
</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-06-06T03:30:11.624988" elapsed="0.063664"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.688861" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:11.688744" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.688719" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.692043" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:30:11.689080" elapsed="0.002993"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:11.692127" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:11.692293" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:11.612933" elapsed="0.079386"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.692383" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:11.692533" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:11.503877" elapsed="0.188683"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.721107" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.720616" elapsed="0.000520"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.721980" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.721674" elapsed="0.000433">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.722431" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.721307" elapsed="0.001150"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.723094" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.722629" elapsed="0.000496"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.723496" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:11.723711" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:11.723295" elapsed="0.000444"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.724174" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "pe-distinguisher-labels-attribute": {
            "pe-distinguisher-label-attribute": [
              {
                "pe-address": "10.10.10.1",
                "mpls-label": 20024
              },
              {
                "pe-address": "10.10.20.2",
                "mpls-label": 20028
              }
            ]
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.723902" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:11.724713" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.724294" elapsed="0.000481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.725462" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.724950" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.724800" elapsed="0.000726"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.724275" elapsed="0.001272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.726229" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:11.725730" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.726310" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:11.719992" elapsed="0.006443"/>
</kw>
<msg time="2026-06-06T03:30:11.726495" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.707284" elapsed="0.019260"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.739362" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.751896" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.764522" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.764735" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.764916" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.765330" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.765183" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:11.765168" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.765553" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.765740" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.765913" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:11.765138" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.765028" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.766143" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.766219" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:11.766357" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:11.704498" elapsed="0.061886"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.766564" elapsed="0.002237"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.770084" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.769544" elapsed="0.000569"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.770819" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.770272" elapsed="0.000577"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:11.771012" elapsed="0.000363"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:11.769124" elapsed="0.002315"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.768881" elapsed="0.002592"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.771670" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.771498" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.768863" elapsed="0.002887"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:11.693748" elapsed="0.078049"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:11.692915" elapsed="0.078960"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.692658" elapsed="0.079262"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.692626" elapsed="0.079318"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.771978" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:11.499375" elapsed="0.272732"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:11.494924" elapsed="0.277242"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.821656" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.821264" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.822417" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.822193" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.822578" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.821854" elapsed="0.000748"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.823171" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.822787" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.823530" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:11.823688" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:11.823362" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.824121" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.823877" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.825160" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.824873" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.825658" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.825371" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.826450" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.826049" elapsed="0.000427"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:11.827891" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.827142" elapsed="0.000853"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:11.828073" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:11.828365" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:11.826684" elapsed="0.001707"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.828550" elapsed="0.000394"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:11.825910" elapsed="0.003076"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.829636" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.829234" elapsed="0.000444"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:11.830894" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.830321" elapsed="0.000675"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:11.831074" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:11.831366" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:11.829866" elapsed="0.001540"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:11.831564" elapsed="0.000390"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:11.829098" elapsed="0.002898"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:11.825737" elapsed="0.006294"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:11.832075" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:11.832237" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:11.824531" elapsed="0.007770"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.824237" elapsed="0.008099"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.832516" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.832362" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.824218" elapsed="0.008376"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.833492" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:11.832756" elapsed="0.000766"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.833572" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:11.820631" elapsed="0.013081"/>
</kw>
<msg time="2026-06-06T03:30:11.833768" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.807940" elapsed="0.025876"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.846542" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.859007" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.871481" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.871701" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.871888" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.872271" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.872121" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:11.872104" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.872496" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.872688" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.872861" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:11.872071" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.871967" elapsed="0.000974"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.873090" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.873218" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:11.873352" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:11.803482" elapsed="0.069897"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.874715" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.874434" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.874882" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.874067" elapsed="0.000840"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.875236" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.874978" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.875848" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.875531" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.875320" elapsed="0.000591"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.874959" elapsed="0.000974"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.878302" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.876089" elapsed="0.002240"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:11.878382" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:11.878538" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:11.873722" elapsed="0.004842"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.879834" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.879580" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.879996" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.879222" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:11.880230" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:11.880093" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.880074" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.880467" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.880660" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.880729" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:11.882844" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:11.878889" elapsed="0.003983"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.884312" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.884057" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.884780" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.884518" elapsed="0.000307"/>
</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-06-06T03:30:11.893694" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:11.893875" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '492'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:11.893975" 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-06-06T03:30:11.886987" elapsed="0.007014"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.884892" elapsed="0.009153"/>
</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-06-06T03:30:11.894262" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.894072" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.884874" elapsed="0.009511"/>
</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-06-06T03:30:11.899281" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.895880" elapsed="0.003472"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.895540" elapsed="0.003861"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.895513" elapsed="0.003944"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.903102" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.899883" elapsed="0.003284"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.899540" elapsed="0.003676"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.899515" elapsed="0.003736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.904089" 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-06-06T03:30:11.903527" elapsed="0.000600"/>
</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-06-06T03:30:11.904450" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.904203" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.905023" 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-06-06T03:30:11.904718" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.904533" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.904184" elapsed="0.000926"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.905665" 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-06-06T03:30:11.905281" elapsed="0.000413"/>
</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-06-06T03:30:11.906011" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.905767" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.906556" 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-06-06T03:30:11.906259" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.906093" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.905748" elapsed="0.000907"/>
</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-06-06T03:30:11.906813" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:11.907633" 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-06-06T03:30:11.907333" elapsed="0.000342"/>
</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-06-06T03:30:11.907837" elapsed="0.002420"/>
</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-06-06T03:30:11.894917" elapsed="0.015405"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.910500" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:11.910393" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.910374" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.913664" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<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="PASS" start="2026-06-06T03:30:11.910734" elapsed="0.002994"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:11.913784" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:11.913947" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:11.883195" elapsed="0.030780"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.914039" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:11.914197" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:11.781113" elapsed="0.133111"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.942552" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.942080" elapsed="0.000501"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.943454" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:11.943118" elapsed="0.000491">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:11.943809" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:11.942773" elapsed="0.001063"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.944451" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:11.944009" elapsed="0.000469"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:11.944825" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:11.944976" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:11.944662" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.945433" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "multi-exit-disc": {
            "med": 0
          },
          "pe-distinguisher-labels-attribute": {
            "pe-distinguisher-label-attribute": [
              {
                "pe-address": "10.10.10.1",
                "mpls-label": 20024
              },
              {
                "pe-address": "10.10.20.2",
                "mpls-label": 20028
              }
            ]
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:11.945165" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:11.945969" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.945551" elapsed="0.000480"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.946731" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:11.946206" elapsed="0.000552"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.946056" elapsed="0.000737"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.945532" elapsed="0.001282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:11.947458" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:11.946964" elapsed="0.000571"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.947589" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:11.941441" elapsed="0.006301"/>
</kw>
<msg time="2026-06-06T03:30:11.947803" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.928775" elapsed="0.019078"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.960615" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.973243" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_pe_distinguisher/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.985784" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.985985" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.986167" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.986550" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.986400" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:11.986384" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.986794" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.986968" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.987144" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:11.986354" elapsed="0.000846"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.986247" elapsed="0.000980"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.987377" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:11.987453" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:11.987608" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "ipv4-next-hop": {
            ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:11.926082" elapsed="0.061553"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:11.987876" elapsed="0.002214"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.991387" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.990861" elapsed="0.000556"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:11.992134" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "127.1.1.1"
     },
     "local-pref": {
      "pref": 100
     },
     "multi...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:11.991605" elapsed="0.000559"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:11.992326" elapsed="0.000346"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:11.990421" elapsed="0.002314"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.990177" elapsed="0.002594"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:11.992952" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:11.992797" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.990158" elapsed="0.002873"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:11.915378" elapsed="0.077700"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:11.914554" elapsed="0.078601"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:11.914307" elapsed="0.078895"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:11.914290" elapsed="0.078937"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:11.993261" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:11.776775" elapsed="0.216614"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:11.772380" elapsed="0.221070"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:11.993618" elapsed="0.003295"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.049692" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:12.049220" elapsed="0.000507"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.050619" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.050334" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:12.050830" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:12.049935" elapsed="0.000931"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.051543" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:12.051076" elapsed="0.000522"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.052012" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:12.052215" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:12.051844" elapsed="0.000401"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.052789" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.052508" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.053978" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.053663" elapsed="0.000363"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.054470" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:12.054196" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.055312" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:12.054899" elapsed="0.000440"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:12.056675" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:12.056090" elapsed="0.000688"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:12.056861" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:30:12.057177" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:12.055546" elapsed="0.001657"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:12.057367" elapsed="0.000407"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:12.054757" elapsed="0.003061"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.058477" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:12.058075" elapsed="0.000428"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:12.059757" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:12.059170" elapsed="0.000691"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:12.059938" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:12.060282" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:12.058709" elapsed="0.001601"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:12.060496" elapsed="0.000420"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:12.057934" elapsed="0.003026"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:12.054553" elapsed="0.006442"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:12.061042" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:12.061206" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:12.053297" elapsed="0.007938"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.052924" elapsed="0.008357"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.061528" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.061324" elapsed="0.000281"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.052897" elapsed="0.008738"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.062929" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:12.061866" elapsed="0.001093"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:12.063011" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:12.048432" elapsed="0.014735"/>
</kw>
<msg time="2026-06-06T03:30:12.063238" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:12.035333" elapsed="0.027975"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.076989" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.090059" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.102702" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.102960" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.103156" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.103624" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.103433" elapsed="0.000270"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:12.103414" elapsed="0.000318"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.103885" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.104057" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.104233" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:12.103373" elapsed="0.000912"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.103245" elapsed="0.001068"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.104463" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.104542" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:12.104713" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:12.031033" elapsed="0.073709"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.106212" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.105915" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:12.106387" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:12.105488" elapsed="0.000924"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.106770" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.106483" elapsed="0.000346"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.107400" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:12.107043" elapsed="0.000384"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.106854" elapsed="0.000610"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.106464" elapsed="0.001022"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.109938" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:12.107686" elapsed="0.002280"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:12.110020" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:12.110281" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:12.105125" elapsed="0.005194"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.111546" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:12.111349" elapsed="0.000304"/>
</kw>
<msg time="2026-06-06T03:30:12.111751" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:12.111003" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.111987" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:12.111848" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.111829" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.112378" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:12.112537" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:12.112208" elapsed="0.000354"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:12.112984" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:12.112740" elapsed="0.000269"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:12.113057" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:12.113211" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:12.110662" elapsed="0.002573"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.114636" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.114387" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.115102" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.114858" elapsed="0.000290"/>
</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-06-06T03:30:12.123958" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:12.124495" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '637'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:12.124614" 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-06-06T03:30:12.117704" elapsed="0.006954"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.115214" elapsed="0.009502"/>
</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-06-06T03:30:12.124935" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.124749" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.115196" elapsed="0.009829"/>
</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-06-06T03:30:12.129259" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"pe-distinguisher-labels-attribute":{"pe-distinguisher-label-attribute":[{"mpls-label":20024,"pe-address":"10.10.10.1"},{"mpls-label":20028,"pe-address":"10.10.20.2"}]},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"}},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.126201" elapsed="0.003152"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.125954" elapsed="0.003552"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.125934" elapsed="0.003618"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.133768" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.130071" elapsed="0.003780"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.129676" elapsed="0.004237"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.129622" elapsed="0.004333"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.134945" 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-06-06T03:30:12.134279" elapsed="0.000718"/>
</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-06-06T03:30:12.135548" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.135125" elapsed="0.000650"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.136444" 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-06-06T03:30:12.136124" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.135839" elapsed="0.000669"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.135093" elapsed="0.001437"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.137126" 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-06-06T03:30:12.136718" elapsed="0.000435"/>
</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-06-06T03:30:12.137473" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.137227" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.138123" 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-06-06T03:30:12.137794" elapsed="0.000374"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.137557" elapsed="0.000661"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.137207" elapsed="0.001035"/>
</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-06-06T03:30:12.138425" elapsed="0.000384"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:12.139285" 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-06-06T03:30:12.138984" elapsed="0.000328"/>
</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-06-06T03:30:12.139476" elapsed="0.002537"/>
</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-06-06T03:30:12.125468" elapsed="0.016629"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.142313" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:12.142190" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.142163" elapsed="0.000224"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:12.148335" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:30:12.142566" elapsed="0.005824"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:12.148511" elapsed="0.000068"/>
</return>
<msg time="2026-06-06T03:30:12.148817" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:12.113551" elapsed="0.035312"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:12.148978" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:30:12.149223" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:12.008103" elapsed="0.141168"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.190098" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:12.189415" elapsed="0.000729"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.191276" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.190882" elapsed="0.000553">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:12.191710" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:12.190389" elapsed="0.001356"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.192537" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:12.191975" elapsed="0.000598"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:12.193015" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:12.193223" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:12.192806" elapsed="0.000455"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.193837" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:12.193475" elapsed="0.000418"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:12.194614" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.193996" elapsed="0.000718"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.195589" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:12.194951" elapsed="0.000674"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:12.194749" elapsed="0.001002"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:12.193962" elapsed="0.001819"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.196673" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:12.195985" elapsed="0.000726"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:12.196776" elapsed="0.000051"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:12.188362" elapsed="0.008605"/>
</kw>
<msg time="2026-06-06T03:30:12.197045" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:12.170971" elapsed="0.026149"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.211839" elapsed="0.000069"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.225348" elapsed="0.000068"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.239901" elapsed="0.000067"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.240231" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.240429" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.240913" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.240753" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:12.240733" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.241147" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.241322" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.241495" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:12.240690" elapsed="0.000861"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.240519" elapsed="0.001059"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.241751" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.241835" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:12.242007" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:12.167071" elapsed="0.074965"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:12.242225" elapsed="0.002472"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:12.245896" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:12.245547" elapsed="0.000379"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:12.246834" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:12.246089" elapsed="0.000774"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:12.247397" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       },
       "pe-distinguisher-labels-attribute": {
        "pe-distinguisher-label-attribute": [
         {
          "mpls-label": 20024,
          "pe-address": "10.10.10.1"
         },
         {
          "mpls-label": 20028,
          "pe-address": "10.10.20.2"
         }
        ]
       }
      },
      "intra-as-i-pmsi-a-d": {
       "orig-route-ip": "10.10.10.10",
       "route-distinguisher": "1.2.3.4:258"
      },
      "path-id": 0,
      "route-key": "AQwAAQECAwQBAgoKCgo="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:12.247673" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       },
+       "pe-distinguisher-labels-attribute": {
+        "pe-distinguisher-label-attribute": [
+         {
+          "mpls-label": 20024,
+          "pe-address": "10.10.10.1"
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.247033" elapsed="0.000834">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.245088" elapsed="0.002968">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:12.244791" elapsed="0.003362">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:12.248363" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:12.248196" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:12.244769" elapsed="0.003676">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.151222" elapsed="0.097376">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.149981" elapsed="0.098810">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:12.149434" elapsed="0.099461">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:12.149400" elapsed="0.099557">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:12.249016" elapsed="0.000020"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:12.001979" elapsed="0.247189">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,44 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
    [ Message content over the limit has been removed. ]
+         },
+         {
+          "mpls-label": 20028,
+          "pe-address": "10.10.20.2"
+         }
+        ]
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.304652" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.304241" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.305483" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.305229" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.305668" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.304872" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.306273" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.305868" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.306616" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.306800" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.306470" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.307242" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.306992" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.308347" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.308032" elapsed="0.000361"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.308859" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.308561" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.309709" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.309280" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.310973" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.310402" elapsed="0.000681"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.311163" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:14.311462" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.309930" elapsed="0.001559"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.311684" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:14.309115" elapsed="0.003056"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.312870" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.312427" elapsed="0.000470"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.314155" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.313568" elapsed="0.000688"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.314343" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:14.314654" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.313087" elapsed="0.001595"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.314844" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:14.312286" elapsed="0.002969"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.308939" elapsed="0.006352"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.315335" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:14.315503" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:14.307696" elapsed="0.007833"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.307373" elapsed="0.008190"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.315766" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.315589" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.307349" elapsed="0.008497"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.316814" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:14.315996" elapsed="0.000848"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.316895" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:14.303595" elapsed="0.013426"/>
</kw>
<msg time="2026-06-06T03:30:14.317076" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.290570" elapsed="0.026555"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.330132" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.343172" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.356003" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.356234" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.356504" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.356951" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.356795" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:14.356777" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.357194" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.357409" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.357584" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:14.356738" elapsed="0.000900"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.356601" elapsed="0.001079"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.357835" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.357914" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:14.358060" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:14.286248" elapsed="0.071839"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.359470" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.359190" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.359638" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.358794" elapsed="0.000886"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.360025" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.359753" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.360595" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.360299" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.360108" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.359734" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.363083" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.360861" elapsed="0.002249"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:14.363164" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:14.363325" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:14.358419" elapsed="0.004932"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.364557" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.364356" elapsed="0.000256"/>
</kw>
<msg time="2026-06-06T03:30:14.364715" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.364013" elapsed="0.000727"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.364947" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:14.364811" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.364792" elapsed="0.000224"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.365353" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.365594" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.365164" elapsed="0.000456"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:14.366042" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.365802" elapsed="0.000266"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:14.366117" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:14.366276" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:14.363678" elapsed="0.002623"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.367721" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.367451" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.368174" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.367928" elapsed="0.000291"/>
</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-06-06T03:30:14.375560" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:14.375716" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:14.375831" 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-06-06T03:30:14.370594" elapsed="0.005264"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.368286" elapsed="0.007616"/>
</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-06-06T03:30:14.376088" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.375929" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.368267" elapsed="0.007908"/>
</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-06-06T03:30:14.379666" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.377216" elapsed="0.002500"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.376984" elapsed="0.002767"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.376965" elapsed="0.002812"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.382394" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.380065" elapsed="0.002375"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.379835" elapsed="0.002640"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.379818" elapsed="0.002682"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.383072" 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-06-06T03:30:14.382688" elapsed="0.000412"/>
</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-06-06T03:30:14.383419" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.383173" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.383992" 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-06-06T03:30:14.383687" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.383502" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.383154" elapsed="0.000923"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.384609" 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-06-06T03:30:14.384246" elapsed="0.000390"/>
</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-06-06T03:30:14.384969" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.384725" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.385536" 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-06-06T03:30:14.385220" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.385051" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.384706" elapsed="0.000963"/>
</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-06-06T03:30:14.385835" elapsed="0.000353"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:14.386662" 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-06-06T03:30:14.386361" elapsed="0.000329"/>
</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-06-06T03:30:14.386853" elapsed="0.002306"/>
</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-06-06T03:30:14.376541" elapsed="0.012683"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.389433" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:14.389324" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.389302" elapsed="0.000200"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:14.392299" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:14.389669" elapsed="0.002659"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:14.392383" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:14.392542" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:14.366612" elapsed="0.025958"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.392635" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:14.392805" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:14.263173" elapsed="0.129659"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.421924" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.421444" elapsed="0.000509"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.422764" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.422461" elapsed="0.000431">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.423075" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.422122" elapsed="0.000978"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.423776" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.423284" elapsed="0.000520"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.424143" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.424304" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.423978" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.424781" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.424495" elapsed="0.000333"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:14.425428" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.424905" elapsed="0.000586"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.426201" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.425688" elapsed="0.000544"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.425518" elapsed="0.000750"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.424881" elapsed="0.001409"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.426968" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:14.426444" elapsed="0.000554"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.427051" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:14.420789" elapsed="0.006396"/>
</kw>
<msg time="2026-06-06T03:30:14.427263" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.407833" elapsed="0.019481"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.440065" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.452728" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.465467" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.465682" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.465867" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.466259" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.466108" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:14.466092" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.466487" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.466677" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.466855" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:14.466062" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.465950" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.467088" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.467200" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:30:14.467325" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:14.405118" elapsed="0.062234"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.467536" elapsed="0.002249"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:14.470857" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.470536" elapsed="0.000349"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:14.471314" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.471044" elapsed="0.000297"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.471500" elapsed="0.000344"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.470108" elapsed="0.001795"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.469866" elapsed="0.002071"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.472115" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.471963" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.469846" elapsed="0.002345"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:14.393992" elapsed="0.078247"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:14.393159" elapsed="0.079157"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.392917" elapsed="0.079444"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.392900" elapsed="0.079485"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.472419" elapsed="0.000027"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:14.257123" elapsed="0.215423"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:11.997092" elapsed="2.475515"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:14.472843" elapsed="0.003404"/>
</kw>
<arg>intra_pe_distinguisher</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:09.114501" elapsed="5.361807"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:09.012711" elapsed="5.463726"/>
</test>
<test id="s1-s16-t20" name="Odl_To_Play_intra_vrf" line="134">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:14.479750" elapsed="0.000212"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:14.479466" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.481023" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:14.480911" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.480891" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.486213" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:14.486103" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.486085" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.487336" 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-06-06T03:30:14.486950" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.487845" 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-06-06T03:30:14.487529" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:14.487918" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:14.488071" 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-06-06T03:30:14.486552" elapsed="0.001543"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:14.493615" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:14.493505" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.493485" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:14.494866" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:14.494758" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.494739" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:14.495381" 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-06-06T03:30:14.495086" elapsed="0.000322"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:14.495809" level="INFO">${current_connection_index} = 7</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-06-06T03:30:14.495572" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:14.530592" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:14.496341" elapsed="0.034402"/>
</kw>
<msg time="2026-06-06T03:30:14.530919" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:14.530966" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:14.496000" elapsed="0.035002"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:14.558338" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "v "r "f "[K"
[?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-06-06T03:30:14.531567" elapsed="0.026875"/>
</kw>
<msg time="2026-06-06T03:30:14.558602" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:14.558670" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:30:14.531196" elapsed="0.027512"/>
</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-06-06T03:30:14.559037" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.558792" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.558768" elapsed="0.000349"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.559563" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "v "r "f "[K"
[?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-06-06T03:30:14.559264" elapsed="0.000366"/>
</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-06-06T03:30:14.559938" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.559716" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.559697" elapsed="0.000319"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:14.560050" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:14.562871" elapsed="0.000323"/>
</kw>
<msg time="2026-06-06T03:30:14.563258" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.561751" elapsed="0.001639"/>
</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="NOT RUN" start="2026-06-06T03:30:14.563698" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.564086" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:14.561074" elapsed="0.003197"/>
</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-06-06T03:30:14.560504" elapsed="0.003831"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:14.494430" elapsed="0.070003"/>
</kw>
<msg time="2026-06-06T03:30:14.564525" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:14.564569" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:14.493857" elapsed="0.070748"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:14.564812" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:14.564702" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.564682" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.565298" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.565687" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.565762" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:14.493145" elapsed="0.072725"/>
</kw>
<msg time="2026-06-06T03:30:14.565963" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:14.566009" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:14.488462" elapsed="0.077584"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.566386" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.566122" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.566104" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:14.488317" elapsed="0.078171"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:14.488148" elapsed="0.078371"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:14.485743" elapsed="0.080830"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:14.480606" elapsed="0.086024"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:14.480172" elapsed="0.086521"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:14.477268" elapsed="0.089479"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.567612" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/announce_intra_vrf.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/announce_intra_vrf.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.567798" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.567409" elapsed="0.000416"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:14.568198" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.567987" elapsed="0.000238"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.568576" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/withdraw_intra_vrf.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/withdraw_intra_vrf.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.568721" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.568386" elapsed="0.000361"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:14.569111" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.568906" elapsed="0.000264"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:14.569482" elapsed="0.002297"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.569245" elapsed="0.002570"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.569226" elapsed="0.002615"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.606264" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.605883" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.607059" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.606815" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.607227" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.606460" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.607827" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.607421" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.608158" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.608287" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.608023" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.608734" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.608474" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.609781" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.609505" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.610262" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.609994" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.610974" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.610670" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.611952" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.611516" elapsed="0.000464"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.612031" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:14.612184" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.611191" elapsed="0.001019"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.612369" elapsed="0.000239"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:14.610509" elapsed="0.002157"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.613218" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.612918" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.614209" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.613805" elapsed="0.000432"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.614290" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:14.614442" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.613457" elapsed="0.001011"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.614624" elapsed="0.000240"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:14.612781" elapsed="0.002159"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.610339" elapsed="0.004650"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.615033" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:14.615194" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:14.609149" elapsed="0.006073"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.608846" elapsed="0.006411"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.615437" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.615282" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.608827" elapsed="0.006688"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.616433" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:14.615690" elapsed="0.000773"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.616514" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:14.605213" elapsed="0.011445"/>
</kw>
<msg time="2026-06-06T03:30:14.616717" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.592299" elapsed="0.024468"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.629304" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.641834" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.654377" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.654576" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.654772" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.655139" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.654990" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:14.654975" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.655367" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.655542" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.655729" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:14.654948" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.654848" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.656000" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.656077" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:14.656196" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:14.587783" elapsed="0.068440"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.681038" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.680662" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.681831" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.681603" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.681988" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.681239" elapsed="0.000774"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.682565" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.682181" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.682911" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.683044" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.682775" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.683476" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.683234" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:14.683913" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.683604" elapsed="0.000367"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.684439" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.684147" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.683996" elapsed="0.000504"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.683585" elapsed="0.000936"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.685129" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:14.684687" elapsed="0.000472"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.685244" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:14.680034" elapsed="0.005339"/>
</kw>
<msg time="2026-06-06T03:30:14.685433" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.667356" elapsed="0.018124"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.698232" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.710744" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.723251" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.723448" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.723628" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.724012" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.723864" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:14.723848" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.724241" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.724413" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.724583" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:14.723820" elapsed="0.000815"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.723718" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.724829" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.724904" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:14.725038" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:14.666491" elapsed="0.058577"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.726413" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.726170" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.726569" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.725822" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.726941" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.726691" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.727488" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.727198" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.727023" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.726671" elapsed="0.000899"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.729959" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.727743" elapsed="0.002242"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:14.730037" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:14.730190" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:14.725441" elapsed="0.004774"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.731753" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.731489" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.732195" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.731958" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.732673" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.732416" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.733112" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.732874" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:14.733996" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:14.733803" elapsed="0.000219"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:14.734350" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:14.734179" elapsed="0.000196"/>
</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-06-06T03:30:14.734526" elapsed="0.000211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.735143" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.734899" elapsed="0.000287"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:14.735230" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:14.735383" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:14.733355" elapsed="0.002053"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:14.756057" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '1171', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:14.756320" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AQwAAQECAwQBAgoKCgo%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:14.756534" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:14.737794" elapsed="0.018799"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.735477" elapsed="0.021261"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.757172" elapsed="0.000076"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.756800" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.735459" elapsed="0.021943"/>
</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-06-06T03:30:14.764128" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.759917" elapsed="0.004270"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.759380" elapsed="0.004855"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.759337" elapsed="0.004939"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.768001" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.764688" elapsed="0.003377"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.764354" elapsed="0.003760"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.764331" elapsed="0.003818"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.768953" 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-06-06T03:30:14.768391" elapsed="0.000601"/>
</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-06-06T03:30:14.769438" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.769091" elapsed="0.000428"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.770281" 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-06-06T03:30:14.769858" elapsed="0.000461"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.769592" elapsed="0.000777"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.769064" elapsed="0.001335"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.771107" 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-06-06T03:30:14.770589" elapsed="0.000545"/>
</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-06-06T03:30:14.771444" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.771204" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.772004" 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-06-06T03:30:14.771707" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.771526" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.771186" elapsed="0.000901"/>
</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-06-06T03:30:14.772240" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:14.773078" 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-06-06T03:30:14.772791" elapsed="0.000313"/>
</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-06-06T03:30:14.773269" elapsed="0.002364"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:14.758329" elapsed="0.017383"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:14.775896" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:30:14.775787" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.775767" elapsed="0.000219"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:14.776140" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.776208" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:14.778547" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:14.730540" elapsed="0.048034"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.778695" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:14.778853" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:14.576625" elapsed="0.202253"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.779227" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.778982" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.778965" elapsed="0.000357"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.779355" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:14.572117" elapsed="0.207362"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:14.782829" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.780421" elapsed="0.002438"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.783016" elapsed="0.003684"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:14.786776" elapsed="0.000042"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:14.780147" elapsed="0.006809"/>
</kw>
<msg time="2026-06-06T03:30:14.787062" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:14.779678" elapsed="0.007420"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.788333" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:14.788440" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:14.787949" elapsed="0.000525"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.789129" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:14.789234" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:14.788746" elapsed="0.000522"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.789502" elapsed="0.000509"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:14.790507" level="INFO">${sum_1} = 1291</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:14.790244" elapsed="0.000299"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:14.791039" level="INFO">${sum_2} = 1291</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:14.790784" elapsed="0.000291"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.791300" elapsed="0.000456"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:14.787396" elapsed="0.004444"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:14.792057" elapsed="0.002266"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.838083" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.837691" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.838904" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.838631" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.839152" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.838289" elapsed="0.000889"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.839755" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.839348" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.840092" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.840245" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.839951" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.840696" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.840434" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.842001" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.841453" elapsed="0.000594"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.842726" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.842327" elapsed="0.000426"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.843594" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.843142" elapsed="0.000479"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.844940" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.844427" elapsed="0.000596"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.845257" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:30:14.845511" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.843929" elapsed="0.001608"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.845750" elapsed="0.000421"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:14.842985" elapsed="0.003229"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.847082" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.846662" elapsed="0.000446"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.848436" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.847940" elapsed="0.000586"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.848694" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:14.848948" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.847339" elapsed="0.001645"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.849155" elapsed="0.000429"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:14.846387" elapsed="0.003303"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.842808" elapsed="0.006919"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.849778" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:14.849966" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:14.841124" elapsed="0.008869"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.840818" elapsed="0.009207"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.850211" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.850050" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.840795" elapsed="0.009492"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.851023" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:14.850434" elapsed="0.000618"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.851101" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:14.837026" elapsed="0.014198"/>
</kw>
<msg time="2026-06-06T03:30:14.851391" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.824226" elapsed="0.027218"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.867205" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.881279" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.896924" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.897151" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.897350" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.897848" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.897610" elapsed="0.000300"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:14.897592" elapsed="0.000345"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.898087" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.898260" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.898428" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:14.897554" elapsed="0.000926"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.897435" elapsed="0.001072"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.898674" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:14.898754" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:14.898894" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:14.819845" elapsed="0.079077"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.900098" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.899816" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:14.909636" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:14.909886" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:14.910062" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:14.902592" elapsed="0.007511"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.900214" elapsed="0.009956"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:14.910595" elapsed="0.000077"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.910223" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.900195" elapsed="0.010622"/>
</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-06-06T03:30:14.918518" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.913127" elapsed="0.005456"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.912590" elapsed="0.006045"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.912549" elapsed="0.006152"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.922534" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.919126" elapsed="0.003478"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.918786" elapsed="0.003889"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.918761" elapsed="0.003954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.923557" 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-06-06T03:30:14.922984" elapsed="0.000613"/>
</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-06-06T03:30:14.924094" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.923727" elapsed="0.000453"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.924943" 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-06-06T03:30:14.924471" elapsed="0.000511"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.924218" elapsed="0.000818"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.923698" elapsed="0.001370"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.925925" 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-06-06T03:30:14.925317" elapsed="0.000648"/>
</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-06-06T03:30:14.926369" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:14.926072" elapsed="0.000355"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.926934" 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-06-06T03:30:14.926618" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.926452" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.926044" elapsed="0.000975"/>
</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-06-06T03:30:14.927177" elapsed="0.000355"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:14.928014" 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-06-06T03:30:14.927720" elapsed="0.000320"/>
</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-06-06T03:30:14.928203" elapsed="0.002341"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:14.911636" elapsed="0.018973"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:14.930674" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:14.932942" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:14.899190" elapsed="0.033779"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:14.933025" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:14.795368" elapsed="0.137783"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:14.794935" elapsed="0.138272"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:14.794515" elapsed="0.138753"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:14.936572" level="INFO">${update} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.934245" elapsed="0.002357"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.936809" elapsed="0.002152"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:14.939011" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:14.933965" elapsed="0.005172"/>
</kw>
<msg time="2026-06-06T03:30:14.939213" level="INFO">${update} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:14.933439" elapsed="0.005799"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.940111" level="INFO">Length is 150.</msg>
<msg time="2026-06-06T03:30:14.940189" level="INFO">${len_1} = 150</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:14.939843" elapsed="0.000372"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.940635" level="INFO">Length is 150.</msg>
<msg time="2026-06-06T03:30:14.940733" level="INFO">${len_2} = 150</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:14.940377" elapsed="0.000380"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.940920" elapsed="0.000314"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:14.941581" level="INFO">${sum_1} = 1140</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:14.941396" elapsed="0.000210"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:14.941993" level="INFO">${sum_2} = 1140</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:14.941810" elapsed="0.000208"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:14.942177" elapsed="0.000424"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:14.939455" elapsed="0.003254"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.989527" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:14.989133" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.990405" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.990124" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:14.990579" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:14.989774" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.991179" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:14.990792" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:14.991514" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:14.991691" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:14.991375" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.992121" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.991879" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.993173" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:14.992918" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.993667" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.993383" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.994723" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.994156" elapsed="0.000595"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.995907" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.995437" elapsed="0.000513"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.996071" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:14.996301" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.994945" elapsed="0.001383"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.996489" elapsed="0.000511"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:14.994012" elapsed="0.003031"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:14.997864" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:14.997294" elapsed="0.000597"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:14.999188" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.998564" elapsed="0.000665"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:14.999351" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:14.999573" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:14.998083" elapsed="0.001516"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:14.999773" elapsed="0.000484"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:14.997157" elapsed="0.003142"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:14.993829" elapsed="0.006505"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:15.000377" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:15.000536" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:14.992547" elapsed="0.008015"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.992241" elapsed="0.008353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.000790" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.000620" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:14.992218" elapsed="0.008651"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.001597" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:15.001018" elapsed="0.000608"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:15.001757" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:14.988467" elapsed="0.013419"/>
</kw>
<msg time="2026-06-06T03:30:15.001942" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:14.975379" elapsed="0.026625"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.014690" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.027233" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.039823" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.040026" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.040211" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.040590" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.040441" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:15.040424" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.040833" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.041006" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.041177" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:15.040394" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.040293" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.041412" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.041487" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:15.041608" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:14.970870" elapsed="0.070764"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.042850" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:15.042577" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:15.052014" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:15.052197" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:15.052390" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:15.052449" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.045035" elapsed="0.007936">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:15.042963" elapsed="0.010119">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.053349" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.053128" elapsed="0.000360"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:15.042945" elapsed="0.010577">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:15.058698" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.055040" elapsed="0.003708">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:15.054720" elapsed="0.004116">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:15.054693" elapsed="0.004188">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.062628" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.059301" elapsed="0.003402">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:15.058982" elapsed="0.003809">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:15.058957" elapsed="0.003878">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.063665" 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-06-06T03:30:15.063104" elapsed="0.000603"/>
</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-06-06T03:30:15.064149" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.063809" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.064939" 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-06-06T03:30:15.064497" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:15.064264" elapsed="0.000762"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.063782" elapsed="0.001273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.065852" 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-06-06T03:30:15.065288" elapsed="0.000603"/>
</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-06-06T03:30:15.066304" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.065990" elapsed="0.000370"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.066863" 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-06-06T03:30:15.066550" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:15.066384" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.065964" elapsed="0.000980"/>
</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-06-06T03:30:15.067098" elapsed="0.000340"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:15.067907" 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-06-06T03:30:15.067607" elapsed="0.000326"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:15.070338" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.068092" elapsed="0.002279">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:15.054087" elapsed="0.016417">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:15.070565" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:15.072916" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:15.072945" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:15.041967" elapsed="0.031008">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:15.073076" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:14.944200" elapsed="0.129050">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:14.943589" elapsed="0.129723"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:14.943030" elapsed="0.130342"/>
</kw>
<arg>intra_vrf</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:14.567035" elapsed="0.506390"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:14.476797" elapsed="0.596745"/>
</test>
<test id="s1-s16-t21" name="Play_To_Odl_intra_vrf" line="138">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:15.076947" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:15.076677" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.078226" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:15.078117" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.078098" elapsed="0.000197"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.083380" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:15.083274" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.083256" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.084456" 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-06-06T03:30:15.084074" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.085016" 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-06-06T03:30:15.084716" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:15.085088" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:15.085242" 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-06-06T03:30:15.083692" elapsed="0.001575"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:15.090773" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:15.090662" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.090627" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:15.092030" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:15.091923" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.091904" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:15.092548" 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-06-06T03:30:15.092247" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:15.092975" level="INFO">${current_connection_index} = 7</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-06-06T03:30:15.092755" elapsed="0.000246"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:15.126026" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:15.093508" elapsed="0.032686"/>
</kw>
<msg time="2026-06-06T03:30:15.126393" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:15.126441" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:15.093167" elapsed="0.033309"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:15.154146" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "v "r "f "[K"
[?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-06-06T03:30:15.127352" elapsed="0.026936"/>
</kw>
<msg time="2026-06-06T03:30:15.154469" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:15.154593" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:30:15.126730" elapsed="0.027902"/>
</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-06-06T03:30:15.155043" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.154757" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.154728" elapsed="0.000399"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.155616" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "v "r "f "[K"
[?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-06-06T03:30:15.155281" elapsed="0.000424"/>
</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-06-06T03:30:15.156001" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.155775" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.155757" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:15.156116" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:15.158765" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:30:15.158978" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:15.157691" elapsed="0.001421"/>
</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="NOT RUN" start="2026-06-06T03:30:15.159392" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.159755" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:15.157030" elapsed="0.002912"/>
</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-06-06T03:30:15.156440" elapsed="0.003567"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:15.091596" elapsed="0.068510"/>
</kw>
<msg time="2026-06-06T03:30:15.160200" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:15.160245" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:15.090998" elapsed="0.069284"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:15.160466" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:30:15.160359" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.160340" elapsed="0.000210"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.160975" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.161320" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.161392" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:15.090308" elapsed="0.071192"/>
</kw>
<msg time="2026-06-06T03:30:15.161593" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:15.161637" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:15.085636" elapsed="0.076066"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.162049" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.161778" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.161761" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:15.085489" elapsed="0.076661"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:15.085321" elapsed="0.076861"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:15.082914" elapsed="0.079323"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:15.077830" elapsed="0.084462"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:15.077368" elapsed="0.085018"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:15.074414" elapsed="0.088029"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.163570" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.163101" elapsed="0.000498"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.164233" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.163786" elapsed="0.000477"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.164826" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.164432" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:15.165223" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/announce_intra_vrf.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/announce_intra_vrf.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:15.165447" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:15.165019" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:15.165968" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/withdraw_intra_vrf.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/withdraw_intra_vrf.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:15.166094" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:15.165735" elapsed="0.000386"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:15.166280" elapsed="0.002259"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:15.168740" elapsed="0.001800"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.223426" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:15.223001" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:15.224296" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.224013" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:15.224471" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:15.223658" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.225077" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:15.224689" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:15.225416" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:15.225587" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:15.225275" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.226061" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:15.225796" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.227181" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:15.226869" elapsed="0.000412"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.227750" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.227452" elapsed="0.000325"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.228635" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:15.228229" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:15.229937" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.229332" elapsed="0.000707"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:15.230120" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:15.230423" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:15.228873" elapsed="0.001577"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.230612" elapsed="0.000400"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:15.228085" elapsed="0.002971"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.231911" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:15.231308" elapsed="0.000630"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:15.233146" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.232585" elapsed="0.000666"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:15.233329" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:15.233618" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:15.232132" elapsed="0.001526"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:15.233819" elapsed="0.000389"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:15.231170" elapsed="0.003087"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:15.227835" elapsed="0.006458"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:15.234336" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:15.234493" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:15.226524" elapsed="0.007994"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:15.226188" elapsed="0.008364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.234749" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.234578" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.226164" elapsed="0.008663"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.235557" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:15.234974" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:15.235636" elapsed="0.000083"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:15.222280" elapsed="0.013537"/>
</kw>
<msg time="2026-06-06T03:30:15.235874" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:15.209237" elapsed="0.026686"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.248522" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.261037" elapsed="0.000090"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.273600" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.273838" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.274052" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.274466" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.274309" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:15.274290" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.274712" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.274886" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.275057" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:15.274251" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.274138" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.275287" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.275363" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:15.275513" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:15.204792" elapsed="0.070749"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:15.276981" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.276673" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:15.277155" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:15.276256" elapsed="0.000924"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.277514" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.277250" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.278119" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:15.277803" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:15.277596" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.277231" elapsed="0.000970"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.280771" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:15.278365" elapsed="0.002433"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:15.280850" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:15.281006" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:15.275894" elapsed="0.005182"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:15.282377" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.282122" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:15.282535" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:15.281738" elapsed="0.000821"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:15.282782" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:15.282629" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:15.282610" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.283016" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.283191" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.283257" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:15.285180" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:15.281394" elapsed="0.003812"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.286630" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:15.286375" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:15.287095" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:15.286853" elapsed="0.000285"/>
</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-06-06T03:30:15.295292" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:15.295434" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:15.295539" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:30:15.289283" elapsed="0.006661">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:15.287203" elapsed="0.008828">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:15.296231" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.296065" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:15.287184" elapsed="0.009136">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:15.296736" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.296874" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:15.296835" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:15.296816" elapsed="0.000167"/>
</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-06-06T03:30:15.297138" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.297208" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:15.285519" elapsed="0.011800">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.297394" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.182059" elapsed="0.115432">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:15.297788" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:15.297586" elapsed="0.000276"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:15.297569" elapsed="0.000316"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:15.297966" elapsed="0.000021"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:15.175837" elapsed="0.122241">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.360665" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.360027" elapsed="0.000695"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.362288" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.361509" elapsed="0.000980">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.362792" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.360997" elapsed="0.001827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.364020" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.363233" elapsed="0.000818"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.364435" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:17.364746" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:17.364241" elapsed="0.000535"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.365221" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.364955" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.366722" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.366360" elapsed="0.000411"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.367236" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.366946" elapsed="0.000435"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.368266" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.367838" elapsed="0.000457"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:17.369577" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.368997" elapsed="0.000700"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:17.369784" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:30:17.370112" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:17.368504" elapsed="0.001636"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.370308" elapsed="0.000416"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:17.367684" elapsed="0.003085"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.374088" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.371032" elapsed="0.003084"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:17.375392" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.374802" elapsed="0.000694"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:17.375577" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:17.375944" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:17.374318" elapsed="0.001652"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.376132" elapsed="0.000372"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:17.370891" elapsed="0.005657"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:17.367457" elapsed="0.009128"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:17.376631" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:30:17.376816" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:17.365923" elapsed="0.010920"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.365386" elapsed="0.011489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.377064" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.376904" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.365347" elapsed="0.011795"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.377932" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:17.377294" elapsed="0.000668"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.378012" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:17.359044" elapsed="0.019097"/>
</kw>
<msg time="2026-06-06T03:30:17.378202" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.342329" elapsed="0.035930"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.391155" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.403638" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.416140" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.416351" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.416537" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.416950" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.416796" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:17.416778" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.417178" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.417351" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.417522" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:17.416744" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.416619" elapsed="0.000983"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.417770" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.417849" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:17.417983" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:17.337987" elapsed="0.080023"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.419396" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.419085" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.419575" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.418705" elapsed="0.000894"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.419952" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.419689" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.420527" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.420228" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.420036" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.419668" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.423175" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.420786" elapsed="0.002416"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:17.423255" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:17.423425" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:17.418346" elapsed="0.005105"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.424727" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.424468" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.424927" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.424121" elapsed="0.000831"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:17.425166" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:17.425025" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.425005" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.425407" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.425586" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.425671" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:17.427633" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:17.423785" elapsed="0.003891"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.429280" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.429025" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.429748" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.429485" elapsed="0.000307"/>
</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-06-06T03:30:17.439022" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:17.439694" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '516'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:17.439894" 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-06-06T03:30:17.431959" elapsed="0.007971"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.429859" elapsed="0.010134"/>
</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-06-06T03:30:17.440258" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.440030" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.429841" elapsed="0.010543"/>
</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-06-06T03:30:17.445336" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.441872" elapsed="0.003534"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.441530" elapsed="0.003926"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.441503" elapsed="0.003988"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.449180" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.446041" elapsed="0.003185"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.445718" elapsed="0.003545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.445693" elapsed="0.003595"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.449885" 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-06-06T03:30:17.449466" elapsed="0.000446"/>
</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-06-06T03:30:17.450234" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.449985" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.450881" 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-06-06T03:30:17.450552" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.450378" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.449966" elapsed="0.001000"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.451514" 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-06-06T03:30:17.451134" elapsed="0.000407"/>
</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-06-06T03:30:17.451872" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.451612" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.452418" 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-06-06T03:30:17.452120" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.451954" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.451594" elapsed="0.000907"/>
</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-06-06T03:30:17.452678" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:17.453512" 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-06-06T03:30:17.453205" 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-06-06T03:30:17.453716" elapsed="0.002352"/>
</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-06-06T03:30:17.440929" elapsed="0.015206"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.456315" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:17.456207" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.456188" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.459484" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<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="PASS" start="2026-06-06T03:30:17.456532" elapsed="0.002982"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:17.459568" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:17.459752" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:17.428005" elapsed="0.031774"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.459845" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:17.459999" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:17.315450" elapsed="0.144575"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.489637" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.489085" elapsed="0.000614"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.490627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.490262" elapsed="0.000523">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.490968" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.489896" elapsed="0.001098"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.491752" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.491252" elapsed="0.000529"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.492129" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:17.492312" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:17.491956" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.492804" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "vrf-route-import-extended-community": {
                "inet4-specific-extended-community-common": {
                  "global-administrator": "10.0.0.1",
                  "local-administrator": "MTA="
                }
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.492508" elapsed="0.000351"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:17.493439" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.492951" elapsed="0.000554"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.494219" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.493702" elapsed="0.000546"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.493534" elapsed="0.000750"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.492920" elapsed="0.001387"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.495006" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:17.494463" elapsed="0.000573"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.495092" elapsed="0.000039"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:17.488337" elapsed="0.006901"/>
</kw>
<msg time="2026-06-06T03:30:17.495301" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.475000" elapsed="0.020354"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.508115" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.520695" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.533204" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.533504" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.533716" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.534183" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.534025" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:17.534006" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.534424" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.534599" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.534789" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:17.533960" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.533820" elapsed="0.001055"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.535031" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.535112" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:17.535297" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:17.472238" elapsed="0.063089"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.535537" elapsed="0.002573"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.539567" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.538940" elapsed="0.000657"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.540288" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.539786" elapsed="0.000531"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:17.540480" elapsed="0.000378"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:17.538460" elapsed="0.002461"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.538194" elapsed="0.002763"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.541144" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.540985" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.538174" elapsed="0.003047"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:17.461218" elapsed="0.080060"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:17.460377" elapsed="0.080985"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.460113" elapsed="0.081300"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.460095" elapsed="0.081344"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.541479" elapsed="0.000040"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:17.309116" elapsed="0.232513"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:15.170752" elapsed="2.371024"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.592769" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.592318" elapsed="0.000492"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.593671" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.593359" elapsed="0.000402">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.593860" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.593003" elapsed="0.000882"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.594452" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.594060" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.594811" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:17.594988" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:17.594664" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.595431" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.595179" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.596939" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.596311" elapsed="0.000676"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.597455" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.597162" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.598336" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.597927" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:17.599667" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.599070" elapsed="0.000703"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:17.599856" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:30:17.600177" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:17.598559" elapsed="0.001645"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.600371" elapsed="0.000414"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:17.597779" elapsed="0.003048"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.601483" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.601083" elapsed="0.000426"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:17.602740" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.602173" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:17.602918" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:17.603208" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:17.601716" elapsed="0.001518"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.603396" elapsed="0.000420"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:17.600945" elapsed="0.002971"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:17.597549" elapsed="0.006404"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:17.604001" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:17.604163" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:17.595979" elapsed="0.008209"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.595604" elapsed="0.008617"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.604406" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.604250" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.595569" elapsed="0.008914"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.605491" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:17.604633" elapsed="0.000887"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.605569" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:17.591626" elapsed="0.014086"/>
</kw>
<msg time="2026-06-06T03:30:17.605771" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.578496" elapsed="0.027326"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.618502" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.630874" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.643219" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.643461" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.643700" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.644153" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.643992" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:17.643972" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.644386" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.644559" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.644745" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:17.643928" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.643797" elapsed="0.001096"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.645057" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.645138" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:17.645301" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:17.573826" elapsed="0.071504"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.646815" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.646498" elapsed="0.000399">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.646991" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.646070" elapsed="0.000947"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.647357" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.647089" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.647969" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.647669" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.647439" elapsed="0.000591"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.647069" elapsed="0.000982"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.650726" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.648209" elapsed="0.002544"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:17.650805" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:17.650961" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:17.645687" elapsed="0.005299"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.652259" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.652025" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.652420" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.651679" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:17.652668" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:17.652516" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.652497" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.652907" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.653083" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.653148" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:30:17.655064" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:17.651298" elapsed="0.003793"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.656535" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.656279" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.657000" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.656755" elapsed="0.000288"/>
</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-06-06T03:30:17.667233" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:17.667421" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '516'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:17.667563" 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-06-06T03:30:17.659243" elapsed="0.008349"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.657153" elapsed="0.010513"/>
</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-06-06T03:30:17.667888" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.667702" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.657133" elapsed="0.010843"/>
</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-06-06T03:30:17.671922" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.669140" elapsed="0.002835"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.668894" elapsed="0.003117"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.668872" elapsed="0.003165"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.674624" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.672327" elapsed="0.002359"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.672094" elapsed="0.002627"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.672077" elapsed="0.002669"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.675359" 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-06-06T03:30:17.674937" elapsed="0.000450"/>
</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-06-06T03:30:17.675739" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.675458" elapsed="0.000340"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.676298" 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-06-06T03:30:17.675997" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.675823" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.675439" elapsed="0.000942"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.676938" 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-06-06T03:30:17.676548" elapsed="0.000417"/>
</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-06-06T03:30:17.677279" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.677036" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.677842" 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-06-06T03:30:17.677528" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.677362" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.677018" elapsed="0.000906"/>
</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-06-06T03:30:17.678088" elapsed="0.000356"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:17.678945" 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-06-06T03:30:17.678617" elapsed="0.000354"/>
</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-06-06T03:30:17.679135" elapsed="0.002485"/>
</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-06-06T03:30:17.668402" elapsed="0.013367"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.681960" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:17.681843" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.681823" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.685148" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<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="PASS" start="2026-06-06T03:30:17.682184" elapsed="0.002994"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:17.685233" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:17.685404" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:17.655418" elapsed="0.030013"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.685497" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:30:17.685665" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:17.550809" elapsed="0.134884"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.715060" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.714498" elapsed="0.000602"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.716092" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.715721" elapsed="0.000512">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.716412" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.715294" elapsed="0.001144"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.717082" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.716615" elapsed="0.000495"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.717443" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:17.717626" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:17.717278" elapsed="0.000392"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.718109" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "vrf-route-import-extended-community": {
                "inet4-specific-extended-community-common": {
                  "global-administrator": "10.0.0.1",
                  "local-administrator": "MTA="
                }
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.717837" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:17.718744" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.718256" elapsed="0.000619"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.719594" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.719068" elapsed="0.000554"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.718910" elapsed="0.000765"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.718223" elapsed="0.001475"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.720378" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:17.719856" elapsed="0.000559"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.720472" elapsed="0.000041"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:17.713800" elapsed="0.006819"/>
</kw>
<msg time="2026-06-06T03:30:17.720706" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.700630" elapsed="0.020129"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.733351" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.745834" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.758278" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.758494" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.758693" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.759133" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.758977" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:17.758959" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.759362" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.759535" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.759733" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:17.758921" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.758789" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.759973" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.760105" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:30:17.760276" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:17.697794" elapsed="0.062510"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.760489" elapsed="0.002495"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.764425" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.763825" elapsed="0.000629"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.765139" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.764611" elapsed="0.000557"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:17.765331" elapsed="0.000364"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:17.763325" elapsed="0.002432"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.763069" elapsed="0.002721"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.765969" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.765817" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.763048" elapsed="0.002995"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:17.686873" elapsed="0.079222"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:17.686037" elapsed="0.080137"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.685781" elapsed="0.080439"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.685762" elapsed="0.080483"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.766280" elapsed="0.000035"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:17.546374" elapsed="0.220046"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:17.541967" elapsed="0.224516"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.816863" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.816401" elapsed="0.000500"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.817748" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.817451" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.817931" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.817089" elapsed="0.000866"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.818512" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.818126" elapsed="0.000510"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.818971" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:17.819147" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:17.818823" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.819587" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.819338" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.821043" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.820467" elapsed="0.000623"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.821547" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.821262" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.822414" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.822010" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:17.823726" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.823114" elapsed="0.000724"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:17.823920" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:30:17.824233" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:17.822635" elapsed="0.001624"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.824423" elapsed="0.000412"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:17.821865" elapsed="0.003011"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.825528" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.825129" elapsed="0.000425"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:17.826785" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.826216" elapsed="0.000669"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:17.826962" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:17.827255" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:17.825760" elapsed="0.001521"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:17.827442" elapsed="0.000397"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:17.824994" elapsed="0.002888"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:17.821638" elapsed="0.006281"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:17.827964" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:17.828122" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:17.820134" elapsed="0.008013"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.819763" elapsed="0.008416"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.828365" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.828207" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.819732" elapsed="0.008709"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.829228" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:17.828590" elapsed="0.000666"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.829309" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:17.815665" elapsed="0.013773"/>
</kw>
<msg time="2026-06-06T03:30:17.829537" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.802793" elapsed="0.026798"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.842252" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.855818" elapsed="0.000053"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.868328" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.868591" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.868804" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.869273" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.869109" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:17.869090" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.869509" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.869694" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.869864" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:17.869042" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.868898" elapsed="0.001048"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.870096" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.870178" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:30:17.870364" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:17.798314" elapsed="0.072080"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.871994" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.871629" elapsed="0.000451">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.872184" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.871166" elapsed="0.001043"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.872633" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.872353" elapsed="0.000355"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.873234" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.872934" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.872733" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.872332" elapsed="0.000986"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.876003" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.873478" elapsed="0.002553"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:17.876085" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:17.876245" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:17.870770" elapsed="0.005499"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.877515" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.877279" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.877688" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.876937" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:17.877924" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:17.877787" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.877768" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.878156" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.878331" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.878394" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:17.880544" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:17.876584" elapsed="0.003991"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.882059" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.881797" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.882505" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.882263" elapsed="0.000285"/>
</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-06-06T03:30:17.892024" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:17.892193" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '516'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:17.892301" 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-06-06T03:30:17.884736" elapsed="0.007590"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.882614" elapsed="0.009757"/>
</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-06-06T03:30:17.892579" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.892401" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.882595" elapsed="0.010088"/>
</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-06-06T03:30:17.897894" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.893866" elapsed="0.004080"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.893550" elapsed="0.004430"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.893530" elapsed="0.004476"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.900638" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.898296" elapsed="0.002404"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.898063" elapsed="0.002671"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.898046" elapsed="0.002713"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.901366" 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-06-06T03:30:17.900948" elapsed="0.000445"/>
</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-06-06T03:30:17.901730" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.901464" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.902282" 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-06-06T03:30:17.901983" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.901813" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.901445" elapsed="0.000925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.902916" 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-06-06T03:30:17.902535" elapsed="0.000407"/>
</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-06-06T03:30:17.903252" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.903011" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.903824" 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-06-06T03:30:17.903499" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.903333" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.902993" elapsed="0.000915"/>
</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-06-06T03:30:17.904070" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:17.904921" 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-06-06T03:30:17.904591" elapsed="0.000356"/>
</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-06-06T03:30:17.905110" elapsed="0.002427"/>
</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-06-06T03:30:17.893093" elapsed="0.014513"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.907842" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:17.907726" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.907682" elapsed="0.000233"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.910973" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<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="PASS" start="2026-06-06T03:30:17.908068" elapsed="0.002935"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:17.911056" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:17.911224" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:17.880932" elapsed="0.030318"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.911314" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:17.911466" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:17.775701" elapsed="0.135791"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.940173" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.939659" elapsed="0.000545"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.941097" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:17.940754" elapsed="0.000478">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:17.941410" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:17.940379" elapsed="0.001057"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.942072" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:17.941609" elapsed="0.000491"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:17.942430" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_vrf/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:17.942595" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:17.942267" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.943073" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "vrf-route-import-extended-community": {
                "inet4-specific-extended-community-common": {
                  "global-administrator": "10.0.0.1",
                  "local-administrator": "MTA="
                }
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:17.942804" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:17.943607" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.943196" elapsed="0.000489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.944389" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:17.943875" elapsed="0.000540"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.943722" elapsed="0.000729"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.943174" elapsed="0.001299"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:17.945133" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:17.944623" elapsed="0.000539"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.945213" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:17.939017" elapsed="0.006326"/>
</kw>
<msg time="2026-06-06T03:30:17.945405" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.926112" elapsed="0.019342"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.958089" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.970692" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_vrf/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.983320" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.983580" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.983805" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.984274" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.984114" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:17.984094" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.984511" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.984700" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.984875" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:17.984048" elapsed="0.000881"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.983907" elapsed="0.001051"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.985111" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:17.985192" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:17.985399" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:17.923391" elapsed="0.062039"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:17.985617" elapsed="0.002656"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.989769" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.989128" elapsed="0.000671"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:17.990467" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-community": {
    ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:17.989960" elapsed="0.000536"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:17.990677" elapsed="0.000355"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:17.988665" elapsed="0.002503"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.988360" elapsed="0.002843"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:17.991384" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:17.991229" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.988340" elapsed="0.003246"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:17.912755" elapsed="0.078905"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:17.911913" elapsed="0.080070"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:17.911619" elapsed="0.080510"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:17.911601" elapsed="0.080561"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:17.992212" elapsed="0.000050"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:17.771022" elapsed="0.221350"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:17.766682" elapsed="0.225754"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:17.992622" elapsed="0.003483"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.045994" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:18.045587" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.046875" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.046547" elapsed="0.000414">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:18.047057" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:18.046201" elapsed="0.000881"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.047664" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:18.047253" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.048020" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:18.048181" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:18.047875" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.048621" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.048375" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.049932" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.049610" elapsed="0.000368"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.050432" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:18.050149" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.051289" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:18.050880" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:18.052571" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:18.052018" elapsed="0.000753"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:18.052861" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:18.053168" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:18.051511" elapsed="0.001683"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:18.053363" elapsed="0.000408"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:18.050735" elapsed="0.003081"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.054477" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:18.054072" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:18.055728" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:18.055167" elapsed="0.000673"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:18.055919" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:18.056211" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:18.054711" elapsed="0.001526"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:18.056395" elapsed="0.000381"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:18.053933" elapsed="0.002885"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:18.050519" elapsed="0.006335"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:18.056899" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:18.057057" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:18.049071" elapsed="0.008012"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.048762" elapsed="0.008354"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.057298" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.057143" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.048738" elapsed="0.008637"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.058149" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:18.057523" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:18.058228" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:18.044946" elapsed="0.013411"/>
</kw>
<msg time="2026-06-06T03:30:18.058414" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:18.032252" elapsed="0.026213"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.071184" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.083610" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.096245" elapsed="0.000056"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.096758" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.096963" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.097451" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.097285" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:18.097264" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.097713" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.097889" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.098060" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:18.097213" elapsed="0.000900"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.097059" elapsed="0.001083"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.098295" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.098378" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:30:18.098579" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:18.027947" elapsed="0.070664"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.100243" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.099917" elapsed="0.000411">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:18.100426" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:18.099428" elapsed="0.001023"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.100819" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.100522" elapsed="0.000356"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.101724" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:18.101097" elapsed="0.000653"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.100903" elapsed="0.000884"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.100503" elapsed="0.001305"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.104354" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:18.101967" elapsed="0.002420"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:18.104442" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:18.104604" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:18.099020" elapsed="0.005608"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.105902" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:18.105690" elapsed="0.000267"/>
</kw>
<msg time="2026-06-06T03:30:18.106042" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:18.105323" elapsed="0.000743"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.106276" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:18.106137" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.106117" elapsed="0.000286"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.106746" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:18.106912" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:18.106557" elapsed="0.000381"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:18.107366" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:18.107110" elapsed="0.000283"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:18.107442" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:18.107597" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:18.104974" elapsed="0.002648"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.109091" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.108835" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.109541" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.109295" elapsed="0.000290"/>
</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-06-06T03:30:18.118118" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:18.118765" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '661'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:18.118938" 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-06-06T03:30:18.111928" elapsed="0.007041"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.109671" elapsed="0.009369"/>
</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-06-06T03:30:18.119357" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.119087" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.109633" elapsed="0.009819"/>
</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-06-06T03:30:18.123601" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.120935" elapsed="0.002736"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.120665" elapsed="0.003043"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.120620" elapsed="0.003113"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.126586" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.124069" elapsed="0.002563"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.123791" elapsed="0.002903"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.123773" elapsed="0.002947"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.127347" 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-06-06T03:30:18.126918" elapsed="0.000456"/>
</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-06-06T03:30:18.127713" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.127445" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.128296" 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-06-06T03:30:18.127991" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.127798" elapsed="0.000632"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.127427" elapsed="0.001026"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.129005" 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-06-06T03:30:18.128620" elapsed="0.000413"/>
</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-06-06T03:30:18.129350" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.129104" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.129912" 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-06-06T03:30:18.129598" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.129431" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.129085" elapsed="0.000910"/>
</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-06-06T03:30:18.130160" elapsed="0.000353"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:18.131032" 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-06-06T03:30:18.130707" elapsed="0.000351"/>
</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-06-06T03:30:18.131223" elapsed="0.002341"/>
</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-06-06T03:30:18.120073" elapsed="0.013559"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.133834" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:18.133720" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.133700" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:18.137090" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:30:18.134060" elapsed="0.003059"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:18.137173" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:18.137344" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:18.107976" elapsed="0.029395"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:18.137436" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:18.137591" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:18.005242" elapsed="0.132375"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.166256" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:18.165812" elapsed="0.000472"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.167140" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.166828" elapsed="0.000445">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:18.167450" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:18.166459" elapsed="0.001017"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.168124" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:18.167665" elapsed="0.000487"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:18.168527" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:18.168706" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:18.168363" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.169168" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:18.168896" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:18.169711" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.169284" elapsed="0.000489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.170462" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:18.169950" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:18.169799" elapsed="0.000727"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:18.169264" elapsed="0.001283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.171201" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:18.170715" elapsed="0.000515"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:18.171281" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:18.165172" elapsed="0.006235"/>
</kw>
<msg time="2026-06-06T03:30:18.171462" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:18.152235" elapsed="0.019277"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.184116" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.196686" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.209464" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.209725" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.209922" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.210369" elapsed="0.000101"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.210207" elapsed="0.000303"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:18.210189" elapsed="0.000350"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.210708" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.210887" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.211061" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:18.210148" elapsed="0.000967"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.210015" elapsed="0.001129"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.211300" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.211387" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:18.211539" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:18.149558" elapsed="0.062010"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:18.211769" elapsed="0.002649"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:18.215788" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:18.215430" elapsed="0.000386"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:18.216698" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:18.215989" elapsed="0.000738"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:18.217225" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "transitive": true,
         "vrf-route-import-extended-community": {
          "inet4-specific-extended-community-common": {
           "global-administrator": "10.0.0.1",
           "local-administrator": "MTA="
          }
         }
        }
       ],
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "intra-as-i-pmsi-a-d": {
       "orig-route-ip": "10.10.10.10",
       "route-distinguisher": "1.2.3.4:258"
      },
      "path-id": 0,
      "route-key": "AQwAAQECAwQBAgoKCgo="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:18.217482" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.216891" elapsed="0.000679">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.214972" elapsed="0.004534">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:18.214501" elapsed="0.005119">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:18.219867" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:18.219689" elapsed="0.000253"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:18.214482" elapsed="0.005484">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.138818" elapsed="0.081307">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.137985" elapsed="0.082317">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:18.137730" elapsed="0.082682">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:18.137712" elapsed="0.082739">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:18.220546" elapsed="0.000021"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:18.000812" elapsed="0.219917">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,43 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.277025" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.276604" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.277923" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.277655" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.278101" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.277286" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.278724" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.278305" elapsed="0.000448"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.279096" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.279274" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.278924" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.279741" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.279470" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.280896" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.280545" elapsed="0.000399"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.281436" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.281112" elapsed="0.000351"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.282299" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.281881" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.283626" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.283064" elapsed="0.000682"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.283829" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:20.284140" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.282565" elapsed="0.001601"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.284333" elapsed="0.000414"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:20.281734" elapsed="0.003056"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.285530" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.285046" elapsed="0.000510"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.286785" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.286222" elapsed="0.000664"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.287019" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:20.287310" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.285765" elapsed="0.001570"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.287492" elapsed="0.000382"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:20.284907" elapsed="0.003009"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.281522" elapsed="0.006429"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.287994" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:20.288150" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:20.280208" elapsed="0.007968"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.279867" elapsed="0.008340"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.288388" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.288233" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.279841" elapsed="0.008627"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.289450" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:20.288616" elapsed="0.000863"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.289531" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:20.275968" elapsed="0.013707"/>
</kw>
<msg time="2026-06-06T03:30:20.289732" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.263102" elapsed="0.026680"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.306278" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.322466" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.334950" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.335178" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.335369" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.335802" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.335630" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:20.335612" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.336166" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.336345" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.336519" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:20.335574" elapsed="0.000999"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.335457" elapsed="0.001143"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.336768" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.336847" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:20.336990" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:20.258495" elapsed="0.078523"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.338493" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.338194" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.338681" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.337793" elapsed="0.000914"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.339049" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.338780" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.339623" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.339320" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.339133" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.338760" elapsed="0.000964"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.342090" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.339882" elapsed="0.002235"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:20.342169" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:20.342326" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:20.337412" elapsed="0.004940"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.343539" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.343348" elapsed="0.000245"/>
</kw>
<msg time="2026-06-06T03:30:20.343694" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.343006" elapsed="0.000713"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.343926" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:20.343789" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.343770" elapsed="0.000223"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.344310" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.344465" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.344142" elapsed="0.000348"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:20.344906" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.344666" elapsed="0.000266"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:20.345016" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:20.345171" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:20.342676" elapsed="0.002520"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.346795" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.346395" elapsed="0.000447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.347242" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.346999" elapsed="0.000287"/>
</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-06-06T03:30:20.356164" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:20.356340" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:20.356479" 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-06-06T03:30:20.349664" elapsed="0.006852"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.347351" elapsed="0.009226"/>
</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-06-06T03:30:20.356870" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.356614" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.347333" elapsed="0.009658"/>
</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-06-06T03:30:20.361897" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.358462" elapsed="0.003502"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.358142" elapsed="0.003872"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.358116" elapsed="0.003934"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.365819" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.362457" elapsed="0.003427"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.362131" elapsed="0.003801"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.362106" elapsed="0.003860"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.366765" 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-06-06T03:30:20.366206" elapsed="0.000597"/>
</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-06-06T03:30:20.367244" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.366903" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.368031" 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-06-06T03:30:20.367591" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.367359" elapsed="0.000759"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.366877" elapsed="0.001270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.368902" 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-06-06T03:30:20.368375" elapsed="0.000564"/>
</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-06-06T03:30:20.369433" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.369037" elapsed="0.000480"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.370221" 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-06-06T03:30:20.369806" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.369552" elapsed="0.000754"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.369012" elapsed="0.001323"/>
</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-06-06T03:30:20.370529" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:20.371406" 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-06-06T03:30:20.371062" elapsed="0.000370"/>
</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-06-06T03:30:20.371597" elapsed="0.002307"/>
</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-06-06T03:30:20.357523" elapsed="0.016446"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.374147" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:20.374039" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.374020" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:20.377035" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:20.374365" elapsed="0.002699"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:20.377117" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:20.377309" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:20.345552" elapsed="0.031786"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.377402" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:20.377555" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:20.235769" elapsed="0.141811"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.406131" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.405580" elapsed="0.000584"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.407021" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.406716" elapsed="0.000432">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.407324" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.406343" elapsed="0.001006"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.407980" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.407522" elapsed="0.000486"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.408338" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.408503" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.408175" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.408978" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.408708" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:20.409781" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.409099" elapsed="0.000746"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.410541" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.410026" elapsed="0.000541"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.409873" elapsed="0.000807"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.409075" elapsed="0.001628"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.411351" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:20.410857" elapsed="0.000524"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.411432" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:20.404917" elapsed="0.006645"/>
</kw>
<msg time="2026-06-06T03:30:20.411616" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.392228" elapsed="0.019459"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.424357" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.436852" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.450910" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.451122" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.451307" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.451755" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.451558" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:20.451542" elapsed="0.000305"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.451997" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.452169" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.452339" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:20.451507" elapsed="0.000885"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.451391" elapsed="0.001028"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.452570" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.452662" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:20.452798" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:20.389566" elapsed="0.063307"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.453060" elapsed="0.002341"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:20.456547" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.456218" elapsed="0.000357"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:20.457027" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.456751" elapsed="0.000310"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.457250" elapsed="0.000353"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.455747" elapsed="0.001940"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.455483" elapsed="0.002240"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.457902" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.457748" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.455463" elapsed="0.002515"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:20.378738" elapsed="0.079287"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:20.377925" elapsed="0.080174"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.377679" elapsed="0.080465"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.377660" elapsed="0.080507"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.458200" elapsed="0.000030"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:20.229392" elapsed="0.228934"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:17.996316" elapsed="2.462068"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:20.458619" elapsed="0.003576"/>
</kw>
<arg>intra_vrf</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:15.162719" elapsed="5.299538"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:15.073953" elapsed="5.388426"/>
</test>
<test id="s1-s16-t22" name="Odl_To_Play_intra_source_as" line="142">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:20.465681" elapsed="0.000218"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:20.465315" elapsed="0.000639"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.466979" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:20.466860" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.466839" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.472952" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:20.472799" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.472773" elapsed="0.000276"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.474487" 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-06-06T03:30:20.473983" elapsed="0.000532"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.474996" 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-06-06T03:30:20.474697" elapsed="0.000375"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:20.475121" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:20.475280" 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-06-06T03:30:20.473417" elapsed="0.001888"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:20.480827" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:20.480718" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.480699" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:20.482142" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:20.482035" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.482016" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:20.482677" 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-06-06T03:30:20.482360" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:20.483090" level="INFO">${current_connection_index} = 7</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-06-06T03:30:20.482871" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:20.513595" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:20.483624" elapsed="0.030098"/>
</kw>
<msg time="2026-06-06T03:30:20.513893" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:20.513941" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:20.483280" elapsed="0.030697"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:20.544502" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "[K"
[?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-06-06T03:30:20.514536" elapsed="0.030077"/>
</kw>
<msg time="2026-06-06T03:30:20.544801" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:20.544848" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:30:20.514170" elapsed="0.030716"/>
</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-06-06T03:30:20.545218" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.544973" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.544949" elapsed="0.000351"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.545816" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "[K"
[?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-06-06T03:30:20.545480" elapsed="0.000411"/>
</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-06-06T03:30:20.546186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.545960" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.545940" elapsed="0.000327"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:20.546302" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:20.548927" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:30:20.549140" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.547853" elapsed="0.001424"/>
</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="NOT RUN" start="2026-06-06T03:30:20.549599" elapsed="0.000095"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.549965" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:20.547186" elapsed="0.002969"/>
</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-06-06T03:30:20.546610" elapsed="0.003612"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:20.481729" elapsed="0.068640"/>
</kw>
<msg time="2026-06-06T03:30:20.550471" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:20.550517" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:20.481052" elapsed="0.069503"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:20.550960" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:30:20.550635" elapsed="0.000390"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.550615" elapsed="0.000436"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.551472" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.551839" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.551914" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:20.480366" elapsed="0.071661"/>
</kw>
<msg time="2026-06-06T03:30:20.552128" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:20.552186" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:20.475704" elapsed="0.076522"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.552566" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.552305" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.552287" elapsed="0.000375"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:20.475539" elapsed="0.077149"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:20.475360" elapsed="0.077359"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:20.472263" elapsed="0.080512"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:20.466551" elapsed="0.086284"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:20.466112" elapsed="0.086770"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:20.463091" elapsed="0.089847"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.553875" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/announce_intra_source_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/announce_intra_source_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.554049" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.553664" elapsed="0.000413"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:20.554535" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.554288" elapsed="0.000276"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.555013" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/withdraw_intra_source_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/withdraw_intra_source_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.555167" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.554795" elapsed="0.000403"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:20.555567" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.555361" elapsed="0.000234"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:20.555906" elapsed="0.002533"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.555683" elapsed="0.002829"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.555663" elapsed="0.002878"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.593059" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.592674" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.593928" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.593674" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.594097" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.593261" elapsed="0.000861"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.594698" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.594294" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.595030" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.595171" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.594891" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.595609" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.595359" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.596629" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.596370" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.597131" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.596859" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.597859" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.597536" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.598860" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.598406" elapsed="0.000481"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.598940" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:20.599096" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.598079" elapsed="0.001042"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.599280" elapsed="0.000237"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:20.597382" elapsed="0.002177"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.600129" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.599828" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.601094" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.600688" elapsed="0.000434"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.601174" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:20.601326" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.600346" elapsed="0.001005"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.601534" elapsed="0.000242"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:20.599689" elapsed="0.002129"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.597210" elapsed="0.004644"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.601897" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:20.602097" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:20.596043" elapsed="0.006080"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.595743" elapsed="0.006413"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.602338" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.602181" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.595722" elapsed="0.006694"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.603164" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:20.602566" elapsed="0.000627"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.603243" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:20.592038" elapsed="0.011330"/>
</kw>
<msg time="2026-06-06T03:30:20.603424" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.579063" elapsed="0.024409"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.616416" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.629128" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.641768" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.642010" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.642207" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.642662" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.642487" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:20.642468" elapsed="0.000281"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.642902" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.643076" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.643247" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:20.642425" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.642294" elapsed="0.001035"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.643482" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.643721" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:30:20.643893" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:20.574726" elapsed="0.069196"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.668922" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.668514" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.669747" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.669475" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.669918" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.669122" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.670505" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.670112" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.670866" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.671065" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.670722" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.671509" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;source-as-extended-community&gt;
                &lt;global-administrator&gt;65&lt;/global-administrator&gt;
            &lt;/source-as-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.671260" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:20.671976" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.671667" elapsed="0.000369"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.672517" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.672214" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.672062" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.671618" elapsed="0.000984"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.673230" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:20.672772" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.673313" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:20.667896" elapsed="0.005546"/>
</kw>
<msg time="2026-06-06T03:30:20.673769" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.655065" elapsed="0.018758"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.686495" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.699011" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.711477" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.711689" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.711871" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.712237" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.712090" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:20.712074" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.712460" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.712630" elapsed="0.000034"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.712817" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:20.712046" elapsed="0.000824"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.711945" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.713045" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.713119" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:20.713249" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:20.654130" elapsed="0.059148"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.714581" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.714332" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.714792" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.713989" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.715141" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.714890" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.715722" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.715410" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.715222" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.714870" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.718169" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.715964" elapsed="0.002232"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:20.718247" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:20.718401" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:20.713658" elapsed="0.004767"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.719969" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.719719" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.720409" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;source-as-extended-community&gt;
                &lt;global-administrator&gt;65&lt;/global-administrator&gt;
            &lt;/source-as-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.720173" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.720881" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.720621" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.721318" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.721078" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:20.722240" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:20.722041" elapsed="0.000225"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:20.722596" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:20.722422" elapsed="0.000200"/>
</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-06-06T03:30:20.722792" elapsed="0.000215"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.723415" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.723168" elapsed="0.000291"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:20.723500" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:20.723669" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:20.721611" elapsed="0.002084"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:20.741227" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '960', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;egp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;source-as-extended-community&gt;
                &lt;global-administrator&gt;65&lt;/global-administrator&gt;
            &lt;/source-as-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:20.741448" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AQwAAQECAwQBAgoKCgo%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:20.741753" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:20.726049" elapsed="0.015766"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.723765" elapsed="0.018153"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.742335" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.741979" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.723747" elapsed="0.018788"/>
</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-06-06T03:30:20.748883" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.744939" elapsed="0.004087"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.744395" elapsed="0.004687"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.744353" elapsed="0.004768"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.752817" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.749568" elapsed="0.003315"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.749207" elapsed="0.003723"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.749181" elapsed="0.003784"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.753867" 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-06-06T03:30:20.753224" elapsed="0.000682"/>
</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-06-06T03:30:20.754344" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.754005" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.754933" 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-06-06T03:30:20.754616" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.754447" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.753979" elapsed="0.001037"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.755542" 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-06-06T03:30:20.755180" elapsed="0.000388"/>
</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-06-06T03:30:20.755898" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.755654" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.756442" 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-06-06T03:30:20.756143" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.755979" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.755620" elapsed="0.000903"/>
</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-06-06T03:30:20.756693" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:20.757521" 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-06-06T03:30:20.757210" elapsed="0.000338"/>
</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-06-06T03:30:20.757722" elapsed="0.002286"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:20.743375" elapsed="0.016699"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:20.760261" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:30:20.760149" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.760129" elapsed="0.000227"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:20.760509" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.760575" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:20.762879" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:20.718773" elapsed="0.044133"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.763035" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:20.763194" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:20.563431" elapsed="0.199789"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.763580" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.763326" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.763309" elapsed="0.000382"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.763724" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:20.558846" elapsed="0.205004"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:20.768137" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.764807" elapsed="0.003360"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.768355" elapsed="0.002359"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:20.770767" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:20.764507" elapsed="0.006386"/>
</kw>
<msg time="2026-06-06T03:30:20.770970" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:20.764029" elapsed="0.006966"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.771872" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:20.771949" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:20.771587" elapsed="0.000386"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.772384" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:20.772459" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:20.772133" elapsed="0.000349"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.772654" elapsed="0.000307"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:20.773302" level="INFO">${sum_1} = 1245</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:20.773119" elapsed="0.000208"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:20.773712" level="INFO">${sum_2} = 1245</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:20.773481" elapsed="0.000257"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.773896" elapsed="0.000303"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:20.771210" elapsed="0.003048"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:20.774427" elapsed="0.002038"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.821703" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.821246" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.822514" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.822265" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.822783" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.821911" elapsed="0.000898"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.823392" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.822985" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.823756" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.823919" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.823590" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.824358" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.824111" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.825824" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.825438" elapsed="0.000432"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.826313" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.826039" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.827167" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.826744" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.828308" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.827827" elapsed="0.000563"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.828534" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:20.828784" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.827389" elapsed="0.001421"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.828970" elapsed="0.000410"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:20.826575" elapsed="0.002846"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.830125" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.829716" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.831244" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.830777" elapsed="0.000549"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.831468" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:20.831706" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.830338" elapsed="0.001395"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.831890" elapsed="0.000399"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:20.829535" elapsed="0.002796"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.826395" elapsed="0.005971"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.832408" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:20.832567" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:20.824885" elapsed="0.007708"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.824490" elapsed="0.008135"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.832824" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.832667" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.824463" elapsed="0.008439"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.833666" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:20.833053" elapsed="0.000643"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.833753" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:20.820571" elapsed="0.013308"/>
</kw>
<msg time="2026-06-06T03:30:20.833977" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.807939" elapsed="0.026091"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.847339" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.859870" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.872467" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.872714" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.872908" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.873319" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.873162" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:20.873144" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.873550" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.873754" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.873927" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:20.873107" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.872990" elapsed="0.001018"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.874159" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:20.874237" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:20.874380" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:20.803605" elapsed="0.070803"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.875602" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.875315" elapsed="0.000408"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:20.886764" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:20.886869" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:20.887071" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:20.877896" elapsed="0.009233"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.875793" elapsed="0.011426"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.887630" elapsed="0.000081"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.887278" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.875774" elapsed="0.012079"/>
</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-06-06T03:30:20.895528" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.890173" elapsed="0.005453"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.889635" elapsed="0.006101"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.889565" elapsed="0.006229"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.899934" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.896423" elapsed="0.003558"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.895920" elapsed="0.004096"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.895882" elapsed="0.004158"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.900625" 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-06-06T03:30:20.900227" elapsed="0.000443"/>
</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-06-06T03:30:20.900991" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.900743" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.901547" 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-06-06T03:30:20.901241" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.901072" elapsed="0.000621"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.900724" elapsed="0.000996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.902266" 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-06-06T03:30:20.901896" elapsed="0.000397"/>
</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-06-06T03:30:20.902601" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.902363" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.903161" 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-06-06T03:30:20.902867" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.902701" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.902345" elapsed="0.000898"/>
</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-06-06T03:30:20.903394" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:20.904221" 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-06-06T03:30:20.903930" elapsed="0.000317"/>
</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-06-06T03:30:20.904405" elapsed="0.002615"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:20.888695" elapsed="0.018412"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:20.907171" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:30:20.910322" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:20.874701" elapsed="0.035658"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.910482" elapsed="0.000040"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:20.777970" elapsed="0.132710"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:20.777320" elapsed="0.133439"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:20.776798" elapsed="0.134044"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:20.914597" level="INFO">${update} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.912141" elapsed="0.002485"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.914838" elapsed="0.002098"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:20.916988" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:20.911756" elapsed="0.005357"/>
</kw>
<msg time="2026-06-06T03:30:20.917192" level="INFO">${update} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:20.911079" elapsed="0.006139"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.918152" level="INFO">Length is 150.</msg>
<msg time="2026-06-06T03:30:20.918231" level="INFO">${len_1} = 150</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:20.917879" elapsed="0.000377"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.918695" level="INFO">Length is 150.</msg>
<msg time="2026-06-06T03:30:20.918772" level="INFO">${len_2} = 150</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:20.918417" elapsed="0.000379"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.918959" elapsed="0.000312"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:20.919620" level="INFO">${sum_1} = 1094</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:20.919434" elapsed="0.000229"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:20.920005" level="INFO">${sum_2} = 1094</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:20.919822" elapsed="0.000208"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:20.920188" elapsed="0.000313"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:20.917444" elapsed="0.003116"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.974210" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:20.973788" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.975085" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.974800" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:20.975261" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:20.974428" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.975871" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:20.975458" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:20.976210" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:20.976374" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:20.976066" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.976834" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.976566" elapsed="0.000377"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.978020" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:20.977751" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.978509" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.978235" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.979469" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.978925" elapsed="0.000572"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.980676" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.980206" elapsed="0.000513"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.980840" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:20.981068" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.979716" elapsed="0.001379"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.981257" elapsed="0.000526"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:20.978784" elapsed="0.003043"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.982596" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:20.982082" elapsed="0.000541"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:20.983770" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.983310" elapsed="0.000510"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:20.983937" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:20.984155" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:20.982832" elapsed="0.001349"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:20.984337" elapsed="0.000515"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:20.981943" elapsed="0.002954"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.978590" elapsed="0.006343"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:20.984978" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:20.985138" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:20.977344" elapsed="0.007820"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.977022" elapsed="0.008175"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:20.985377" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:20.985223" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:20.976999" elapsed="0.008455"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:20.987659" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:20.985602" elapsed="0.002089"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:20.987742" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:20.973050" elapsed="0.014829"/>
</kw>
<msg time="2026-06-06T03:30:20.987933" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:20.950580" elapsed="0.037415"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.000831" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.013413" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.026008" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.026231" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.026417" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.026832" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.026678" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:21.026658" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.027063" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.027239" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.027414" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:21.026609" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.026499" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.027678" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.027760" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:21.027911" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:20.946083" elapsed="0.081856"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.029212" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:21.028914" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:21.037944" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:21.038093" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:21.038254" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:21.038298" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.031479" elapsed="0.007465">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:21.029335" elapsed="0.009723">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.039332" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.039106" elapsed="0.000314"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:21.029315" elapsed="0.010138">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:21.044568" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.040950" elapsed="0.003668">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:21.040608" elapsed="0.004120">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:21.040582" elapsed="0.004193">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.047872" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.045198" elapsed="0.002706">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:21.044876" elapsed="0.003091">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:21.044852" elapsed="0.003147">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.048601" 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-06-06T03:30:21.048196" elapsed="0.000432"/>
</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-06-06T03:30:21.048968" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.048718" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.049540" 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-06-06T03:30:21.049223" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:21.049053" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.048698" elapsed="0.000926"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.050190" 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-06-06T03:30:21.049820" elapsed="0.000397"/>
</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-06-06T03:30:21.050528" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.050287" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.051093" 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-06-06T03:30:21.050794" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:21.050611" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.050269" elapsed="0.000907"/>
</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-06-06T03:30:21.051340" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:21.052170" 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-06-06T03:30:21.051879" elapsed="0.000318"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:21.054631" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.052356" elapsed="0.002323">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:21.039997" elapsed="0.014820">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:21.054914" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:21.057301" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:21.057332" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:21.028241" elapsed="0.029121">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:21.057429" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:20.921680" elapsed="0.135920">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:20.921208" elapsed="0.136475"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:20.920808" elapsed="0.137043"/>
</kw>
<arg>intra_source_as</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:20.553232" elapsed="0.504671"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:20.462632" elapsed="0.595389"/>
</test>
<test id="s1-s16-t23" name="Play_To_Odl_intra_source_as" line="146">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:21.061463" elapsed="0.000244"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:21.061191" elapsed="0.000575"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.062789" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:21.062675" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.062653" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.068013" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:21.067905" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.067887" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.069107" 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-06-06T03:30:21.068723" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.069596" 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-06-06T03:30:21.069299" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:21.069682" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:30:21.069854" 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-06-06T03:30:21.068312" elapsed="0.001567"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:21.075361" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:21.075251" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.075231" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:21.076610" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:21.076502" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.076483" elapsed="0.000219"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:21.077155" 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-06-06T03:30:21.076855" elapsed="0.000326"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:21.077568" level="INFO">${current_connection_index} = 7</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-06-06T03:30:21.077344" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:21.108309" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:21.078136" elapsed="0.030280"/>
</kw>
<msg time="2026-06-06T03:30:21.108590" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:21.108637" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:21.077792" elapsed="0.030905"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:21.136842" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "[K"
[?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-06-06T03:30:21.109377" elapsed="0.027631"/>
</kw>
<msg time="2026-06-06T03:30:21.137172" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:21.137219" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:30:21.108880" elapsed="0.028377"/>
</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-06-06T03:30:21.137580" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.137339" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.137317" elapsed="0.000366"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.138190" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "[K"
[?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-06-06T03:30:21.137873" elapsed="0.000389"/>
</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-06-06T03:30:21.138555" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.138330" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.138311" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:21.138686" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:21.141187" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:30:21.141392" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:21.140159" elapsed="0.001363"/>
</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="NOT RUN" start="2026-06-06T03:30:21.141930" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.142275" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:21.139519" elapsed="0.002940"/>
</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-06-06T03:30:21.138973" elapsed="0.003551"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:21.076199" elapsed="0.066425"/>
</kw>
<msg time="2026-06-06T03:30:21.142741" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:21.142786" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:21.075583" elapsed="0.067240"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:21.143010" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:21.142901" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.142882" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.143533" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.143896" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.143968" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:21.074914" elapsed="0.069162"/>
</kw>
<msg time="2026-06-06T03:30:21.144170" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:21.144214" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:21.070254" elapsed="0.073997"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.144582" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.144327" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.144309" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:21.070107" elapsed="0.074592"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:21.069935" elapsed="0.074838"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:21.067528" elapsed="0.077304"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:21.062362" elapsed="0.082526"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:21.061924" elapsed="0.083010"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:21.058872" elapsed="0.086113"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.146119" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.145616" elapsed="0.000532"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.146796" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.146319" elapsed="0.000505"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.147375" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.146993" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:21.147788" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/announce_intra_source_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/announce_intra_source_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:21.147945" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:21.147566" elapsed="0.000406"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:21.148322" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/withdraw_intra_source_as.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/withdraw_intra_source_as.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:21.148443" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:21.148133" elapsed="0.000336"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:21.148624" elapsed="0.002413"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:21.151198" elapsed="0.001974"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.205458" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:21.205078" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:21.206262" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.206026" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:21.206430" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:21.205670" elapsed="0.000784"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.207026" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:21.206622" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:21.207354" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:21.207504" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:21.207219" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.207998" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:21.207744" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.209059" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:21.208768" elapsed="0.000337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.209536" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.209270" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.210390" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:21.209984" elapsed="0.000433"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:21.211636" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.211087" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:21.211838" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:21.212130" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:21.210613" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.212319" elapsed="0.000422"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:21.209841" elapsed="0.002954"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.213635" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:21.213068" elapsed="0.000611"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:21.214891" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.214337" elapsed="0.000653"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:21.215068" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:21.215358" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:21.213886" elapsed="0.001498"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:21.215542" elapsed="0.000385"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:21.212928" elapsed="0.003041"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:21.209613" elapsed="0.006391"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:21.216047" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:21.216204" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:21.208420" elapsed="0.007810"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:21.208117" elapsed="0.008145"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.216442" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.216287" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.208096" elapsed="0.008422"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.217310" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:21.216724" elapsed="0.000615"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:21.217389" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:21.204442" elapsed="0.013071"/>
</kw>
<msg time="2026-06-06T03:30:21.217568" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:21.191701" elapsed="0.025915"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.230268" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.242905" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.255257" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.255487" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.255691" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.256112" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.255955" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:21.255937" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.256341" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.256513" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.256698" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:21.255896" elapsed="0.000857"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.255777" elapsed="0.001003"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.256931" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.257009" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:21.257165" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:21.187404" elapsed="0.069789"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:21.258672" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.258319" elapsed="0.000430">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:21.258845" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:21.257923" elapsed="0.000947"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.259215" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.258941" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.259795" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:21.259483" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:21.259299" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.258921" elapsed="0.000957"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.262431" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:21.260034" elapsed="0.002425"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:21.262556" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:21.262766" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:21.257530" elapsed="0.005264"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:21.264081" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.263836" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:21.264241" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:21.263456" elapsed="0.000811"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:21.264482" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:21.264339" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:21.264320" elapsed="0.000249"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.264741" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.264924" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.264993" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:21.266972" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:21.263115" elapsed="0.003883"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.268407" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:21.268151" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:21.268871" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:21.268610" elapsed="0.000304"/>
</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-06-06T03:30:21.276249" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:21.276392" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:21.276489" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:30:21.271196" elapsed="0.005695">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:21.268981" elapsed="0.007996">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:21.277169" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.277010" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:21.268962" elapsed="0.008296">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:21.277685" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.277906" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:21.277860" elapsed="0.000090"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:21.277766" elapsed="0.000207"/>
</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-06-06T03:30:21.278125" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.278197" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:21.267312" elapsed="0.010992">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.278380" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.162385" elapsed="0.116126">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:21.278925" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:21.278662" elapsed="0.000363"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:21.278618" elapsed="0.000440"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:21.279104" elapsed="0.000020"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:21.157950" elapsed="0.121289">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.336535" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.336132" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.337428" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.337162" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.337605" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.336768" elapsed="0.000861"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.338211" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.337822" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.338544" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:23.338730" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:23.338402" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.339239" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.338917" elapsed="0.000370"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.340345" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.340021" elapsed="0.000427"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.340931" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.340622" elapsed="0.000336"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.341766" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.341340" elapsed="0.000453"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:23.343023" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.342444" elapsed="0.000723"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:23.343252" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:23.343560" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:23.341985" elapsed="0.001601"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.343765" elapsed="0.000385"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:23.341193" elapsed="0.003000"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.345027" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.344446" elapsed="0.000608"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:23.346313" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.345743" elapsed="0.000670"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:23.346489" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:23.346806" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:23.345247" elapsed="0.001586"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.346992" elapsed="0.000403"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:23.344308" elapsed="0.003134"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:23.341014" elapsed="0.006463"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:23.347519" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:23.347695" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:23.339690" elapsed="0.008032"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.339365" elapsed="0.008389"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.347934" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.347780" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.339340" elapsed="0.008672"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.348781" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:23.348161" elapsed="0.000649"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.348860" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:23.335474" elapsed="0.013509"/>
</kw>
<msg time="2026-06-06T03:30:23.349038" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.322547" elapsed="0.026540"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.368547" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.380955" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.393417" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.393618" elapsed="0.000035"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.393816" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.394249" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.394078" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:23.394060" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.394484" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.394670" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.394842" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:23.394018" elapsed="0.000876"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.393891" elapsed="0.001029"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.395071" elapsed="0.000048"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.395176" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:23.395299" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:23.318226" elapsed="0.077099"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.396599" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.396354" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.396782" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.396002" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.397129" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.396877" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.397720" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.397394" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.397210" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.396858" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.400321" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.397957" elapsed="0.002391"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:23.400400" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:23.400589" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:23.395668" elapsed="0.004947"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.401876" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.401626" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.402031" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.401281" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:23.402262" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:30:23.402126" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.402107" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.402496" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.402689" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.402756" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:23.404697" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:23.400940" elapsed="0.003784"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.406160" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.405908" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.406612" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.406365" elapsed="0.000306"/>
</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-06-06T03:30:23.415946" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:23.416352" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '427'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:23.416451" 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-06-06T03:30:23.408835" elapsed="0.007642"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.406740" elapsed="0.009781"/>
</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-06-06T03:30:23.416720" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.416547" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.406722" elapsed="0.010085"/>
</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-06-06T03:30:23.420400" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.417822" elapsed="0.002628"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.417581" elapsed="0.002906"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.417562" elapsed="0.002951"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.423140" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.420828" elapsed="0.002359"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.420570" elapsed="0.002656"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.420553" elapsed="0.002730"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.424040" 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-06-06T03:30:23.423461" elapsed="0.000620"/>
</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-06-06T03:30:23.424554" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.424186" elapsed="0.000474"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.425390" 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-06-06T03:30:23.424949" elapsed="0.000480"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.424699" elapsed="0.000784"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.424159" elapsed="0.001354"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.426316" 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-06-06T03:30:23.425784" elapsed="0.000571"/>
</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-06-06T03:30:23.426838" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.426458" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.427607" 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-06-06T03:30:23.427197" elapsed="0.000465"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.426953" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.426431" elapsed="0.001313"/>
</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-06-06T03:30:23.427962" elapsed="0.000489"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:23.429105" 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-06-06T03:30:23.428713" elapsed="0.000429"/>
</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-06-06T03:30:23.429366" elapsed="0.002937"/>
</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-06-06T03:30:23.417162" elapsed="0.015205"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.432545" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:23.432438" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.432419" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.435691" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<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="PASS" start="2026-06-06T03:30:23.432782" elapsed="0.002940"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:23.435776" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:23.435942" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:23.405036" elapsed="0.030933"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.436033" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:23.436183" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:23.295162" elapsed="0.141048"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.464876" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.464365" elapsed="0.000540"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.465832" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.465419" elapsed="0.000547">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.466148" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.465076" elapsed="0.001098"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.466837" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.466355" elapsed="0.000525"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.467273" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:23.467446" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:23.467075" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.467960" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "source-as-extended-community": {
                "global-administrator": 65
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.467687" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:23.468528" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.468087" elapsed="0.000504"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.469298" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.468785" elapsed="0.000541"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.468618" elapsed="0.000744"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.468064" elapsed="0.001320"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.470059" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:23.469539" elapsed="0.000550"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.470140" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:23.463745" elapsed="0.006525"/>
</kw>
<msg time="2026-06-06T03:30:23.470329" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.450822" elapsed="0.019557"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.483100" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.495636" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.509670" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.509874" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.510058" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.510449" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.510299" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:23.510283" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.510688" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.510861" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.511029" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:23.510251" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.510140" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.511297" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.511374" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:23.511518" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:23.448042" elapsed="0.063504"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.511742" elapsed="0.002260"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.515456" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.514907" elapsed="0.000578"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.516155" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.515672" elapsed="0.000512"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:23.516345" elapsed="0.000497"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:23.514327" elapsed="0.002577"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.514083" elapsed="0.002854"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.517116" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.516963" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.514063" elapsed="0.003128"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:23.437402" elapsed="0.079836"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:23.436550" elapsed="0.080763"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.436293" elapsed="0.081099"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.436275" elapsed="0.081142"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.517450" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:23.289489" elapsed="0.228088"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:21.153348" elapsed="2.364286"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.567583" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.567169" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.568377" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.568139" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.568546" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.567799" elapsed="0.000771"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.569136" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.568753" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.569462" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:23.569614" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:23.569326" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.570060" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.569816" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.571094" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.570808" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.571608" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.571334" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.572420" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.572023" elapsed="0.000423"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:23.573677" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.573107" elapsed="0.000671"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:23.573855" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:23.574147" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:23.572637" elapsed="0.001535"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.574330" elapsed="0.000396"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:23.571885" elapsed="0.002883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.575435" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.575016" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:23.576717" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.576118" elapsed="0.000700"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:23.576894" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:23.577185" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:23.575668" elapsed="0.001543"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.577367" elapsed="0.000378"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:23.574880" elapsed="0.002908"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:23.571710" elapsed="0.006113"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:23.577866" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:23.578020" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:23.570469" elapsed="0.007576"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.570174" elapsed="0.007903"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.578254" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.578102" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.570153" elapsed="0.008176"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.579063" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:23.578476" elapsed="0.000616"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.579141" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:23.566529" elapsed="0.012776"/>
</kw>
<msg time="2026-06-06T03:30:23.579360" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.553510" elapsed="0.025898"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.592417" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.604958" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.617403" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.617616" elapsed="0.000040"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.617823" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.618211" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.618060" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:23.618043" elapsed="0.000298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.618490" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.618678" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.618855" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:23.618010" elapsed="0.001036"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.617902" elapsed="0.001171"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.619238" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.619316" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:23.619449" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:23.549160" elapsed="0.070317"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.620820" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.620536" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.620986" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.620165" elapsed="0.000846"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.621341" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.621081" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.621924" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.621612" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.621422" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.621062" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.624385" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.622161" elapsed="0.002251"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:23.624463" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:23.624617" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:23.619823" elapsed="0.004832"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.625881" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.625633" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.626037" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.625295" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:23.626267" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:30:23.626131" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.626112" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.626501" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.626691" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.626758" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:23.628847" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:23.624968" elapsed="0.003939"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.630323" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.630071" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.630788" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.630528" elapsed="0.000304"/>
</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-06-06T03:30:23.640250" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:23.640418" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '427'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:23.640553" 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-06-06T03:30:23.633034" elapsed="0.007548"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.630899" elapsed="0.009735"/>
</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-06-06T03:30:23.640902" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.640698" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.630880" elapsed="0.010109"/>
</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-06-06T03:30:23.645112" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.642131" elapsed="0.003052"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.641892" elapsed="0.003338"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.641870" elapsed="0.003395"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.648950" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.645689" elapsed="0.003325"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.645345" elapsed="0.003735"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.645321" elapsed="0.003822"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.650010" 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-06-06T03:30:23.649421" elapsed="0.000627"/>
</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-06-06T03:30:23.650512" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.650148" elapsed="0.000450"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.651374" 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-06-06T03:30:23.650904" elapsed="0.000509"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.650633" elapsed="0.000831"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.650121" elapsed="0.001372"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.652098" 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-06-06T03:30:23.651730" elapsed="0.000395"/>
</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-06-06T03:30:23.652442" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.652196" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.653009" 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-06-06T03:30:23.652708" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.652523" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.652177" elapsed="0.000971"/>
</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-06-06T03:30:23.653313" elapsed="0.000384"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:23.654174" 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-06-06T03:30:23.653872" elapsed="0.000330"/>
</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-06-06T03:30:23.654365" elapsed="0.002361"/>
</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-06-06T03:30:23.641398" elapsed="0.015396"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.656982" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:23.656868" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.656849" elapsed="0.000203"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.660114" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<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="PASS" start="2026-06-06T03:30:23.657206" elapsed="0.002938"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:23.660199" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:23.660367" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:23.629228" elapsed="0.031166"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.660459" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:23.660618" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:23.526586" elapsed="0.134075"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.698410" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.697244" elapsed="0.001236"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.700049" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.699732" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.700358" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.698939" elapsed="0.001445"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.701025" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.700559" elapsed="0.000493"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.701387" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:23.701561" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:23.701220" elapsed="0.000368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.702041" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "source-as-extended-community": {
                "global-administrator": 65
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.701766" elapsed="0.000399"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:23.702748" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.702249" elapsed="0.000562"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.703521" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.702992" elapsed="0.000557"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.702838" elapsed="0.000748"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.702224" elapsed="0.001384"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.704287" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:23.703785" elapsed="0.000531"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.704371" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:23.695514" elapsed="0.008990"/>
</kw>
<msg time="2026-06-06T03:30:23.704569" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.675594" elapsed="0.029026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.717216" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.729968" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.742575" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.742788" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.742970" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.743383" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.743210" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:23.743195" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.743610" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.743800" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.743972" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:23.743164" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.743053" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.744245" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.744322" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:23.744463" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:23.672827" elapsed="0.071663"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.744686" elapsed="0.002223"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.748232" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.747707" elapsed="0.000553"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.748921" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.748422" elapsed="0.000528"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:23.749112" elapsed="0.000330"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:23.747236" elapsed="0.002266"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.746991" elapsed="0.002545"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.749733" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.749561" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.746971" elapsed="0.002840"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:23.661827" elapsed="0.088032"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:23.660996" elapsed="0.088941"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.660746" elapsed="0.089237"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.660729" elapsed="0.089279"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.750042" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:23.522158" elapsed="0.228011"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:23.517827" elapsed="0.232401"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.800047" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.799634" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.800883" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.800597" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.801175" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.800256" elapsed="0.000944"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.801787" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.801373" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.802127" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:23.802283" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:23.801982" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.802740" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.802471" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.803885" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.803560" elapsed="0.000371"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.804370" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.804096" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.805197" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.804795" elapsed="0.000428"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:23.806446" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.805890" elapsed="0.000657"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:23.806627" elapsed="0.000068"/>
</return>
<msg time="2026-06-06T03:30:23.806969" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:23.805414" elapsed="0.001581"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.807154" elapsed="0.000403"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:23.804630" elapsed="0.002969"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.808273" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.807863" elapsed="0.000436"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:23.809511" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.808962" elapsed="0.000652"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:23.809712" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:23.810006" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:23.808488" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:23.810188" elapsed="0.000373"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:23.807727" elapsed="0.002875"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:23.804450" elapsed="0.006187"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:23.810699" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:23.810858" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:23.803172" elapsed="0.007711"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.802863" elapsed="0.008053"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.811096" elapsed="0.000188"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.810942" elapsed="0.000410"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.802840" elapsed="0.008544"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.812176" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:23.811552" elapsed="0.000653"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.812255" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:23.798984" elapsed="0.013393"/>
</kw>
<msg time="2026-06-06T03:30:23.812469" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.786235" elapsed="0.026285"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.825163" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.837795" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.850262" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.850462" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.850656" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.851029" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.850879" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:23.850864" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.851253" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.851464" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.851656" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:23.850836" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.850733" elapsed="0.001005"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.851889" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.851963" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:23.852081" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:23.781912" elapsed="0.070196"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.853367" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.853132" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.853561" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.852788" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.853928" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.853673" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.854491" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.854199" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.854011" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.853638" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.856978" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.854747" elapsed="0.002258"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:23.857058" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:23.857210" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:23.852435" elapsed="0.004800"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.858460" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.858227" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.858617" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.857886" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:23.858866" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:23.858730" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.858711" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.859101" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.859278" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.859367" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:23.861467" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:23.857540" elapsed="0.003954"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.862918" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.862665" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.863388" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.863125" elapsed="0.000309"/>
</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-06-06T03:30:23.872001" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:23.872245" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '427'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:23.872453" 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-06-06T03:30:23.865580" elapsed="0.006923"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.863500" elapsed="0.009052"/>
</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-06-06T03:30:23.872789" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.872578" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.863482" elapsed="0.009396"/>
</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-06-06T03:30:23.876359" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.873913" elapsed="0.002495"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.873686" elapsed="0.002757"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.873667" elapsed="0.002801"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.880145" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.876865" elapsed="0.003344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.876524" elapsed="0.003733"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.876507" elapsed="0.003784"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.881071" 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-06-06T03:30:23.880525" elapsed="0.000584"/>
</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-06-06T03:30:23.881546" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.881207" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.882332" 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-06-06T03:30:23.881919" elapsed="0.000449"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.881683" elapsed="0.000734"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.881181" elapsed="0.001265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.883198" 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-06-06T03:30:23.882695" elapsed="0.000540"/>
</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-06-06T03:30:23.883751" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.883332" elapsed="0.000500"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.884502" 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-06-06T03:30:23.884094" elapsed="0.000435"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.883866" elapsed="0.000698"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.883306" elapsed="0.001278"/>
</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-06-06T03:30:23.884752" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:23.885542" 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-06-06T03:30:23.885265" elapsed="0.000303"/>
</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-06-06T03:30:23.885742" elapsed="0.002300"/>
</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-06-06T03:30:23.873247" elapsed="0.014857"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.888280" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:23.888174" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.888155" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.891318" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<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="PASS" start="2026-06-06T03:30:23.888496" elapsed="0.002852"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:23.891426" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:23.891590" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:23.861830" elapsed="0.029786"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.891728" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:23.891886" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:23.759059" elapsed="0.132855"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.920406" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.919961" elapsed="0.000473"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.921220" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.920963" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:23.921512" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:23.920602" elapsed="0.000935"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.922168" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:23.921725" elapsed="0.000470"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:23.922521" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:23.922676" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:23.922362" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.923132" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "source-as-extended-community": {
                "global-administrator": 65
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "egp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:23.922866" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:23.923702" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.923249" elapsed="0.000514"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.924435" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:23.923938" elapsed="0.000523"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.923789" elapsed="0.000708"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.923230" elapsed="0.001288"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:23.925159" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:23.924682" elapsed="0.000506"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.925237" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:23.919314" elapsed="0.006047"/>
</kw>
<msg time="2026-06-06T03:30:23.925419" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.906674" elapsed="0.018793"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.938053" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.950526" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.963140" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.963341" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.963570" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.963961" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.963813" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:23.963798" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.964185" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.964357" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.964528" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:23.963769" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.963666" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.964777" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:23.964852" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:23.964988" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:23.903929" elapsed="0.061086"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:23.965195" elapsed="0.002194"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.968665" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.968160" elapsed="0.000536"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:23.969328" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-extended-community": {
        "global-administrator": 65
   ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:23.968856" elapsed="0.000531"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:23.969556" elapsed="0.000345"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:23.967747" elapsed="0.002215"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.967487" elapsed="0.002508"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:23.970173" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:23.970021" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.967468" elapsed="0.002781"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:23.893061" elapsed="0.077234"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:23.892239" elapsed="0.078131"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:23.891998" elapsed="0.078417"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:23.891981" elapsed="0.078458"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:23.970472" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:23.754695" elapsed="0.215901"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:23.750408" elapsed="0.220263"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:23.970842" elapsed="0.002938"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.025694" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:24.025304" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.026433" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.026225" elapsed="0.000272">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:24.026589" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:24.025891" elapsed="0.000723"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.027178" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:24.026798" elapsed="0.000407"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.027550" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:24.027696" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:24.027367" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.028128" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.027885" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.029158" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.028878" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.029658" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:24.029367" elapsed="0.000320"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.030436" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:24.030041" elapsed="0.000421"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:24.031738" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:24.031161" elapsed="0.000677"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:24.031916" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:24.032203" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:24.030709" elapsed="0.001520"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:24.032387" elapsed="0.000383"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:24.029904" elapsed="0.002908"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.033456" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:24.033059" elapsed="0.000423"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:24.034693" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:24.034138" elapsed="0.000656"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:24.034871" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:24.035157" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:24.033686" elapsed="0.001498"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:24.035340" elapsed="0.000412"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:24.032924" elapsed="0.002870"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:24.029736" elapsed="0.006093"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:24.035870" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:24.036025" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:24.028529" elapsed="0.007522"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.028239" elapsed="0.007844"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.036259" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.036107" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.028220" elapsed="0.008114"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.038187" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:24.036481" elapsed="0.001735"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:24.038266" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:24.024688" elapsed="0.013702"/>
</kw>
<msg time="2026-06-06T03:30:24.038443" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:24.012035" elapsed="0.026455"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.051183" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.063683" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.076184" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.076389" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.076571" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.076961" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.076810" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:24.076795" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.077188" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.077358" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.077533" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:24.076765" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.076661" elapsed="0.000951"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.077779" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.077856" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:24.077975" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:24.007499" elapsed="0.070502"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.079272" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.079030" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:24.079429" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:24.078675" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.079821" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.079546" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.080370" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:24.080079" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.079904" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.079525" elapsed="0.000928"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.082813" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:24.080613" elapsed="0.002227"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:24.082892" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:24.083045" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:24.078324" elapsed="0.004745"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.084297" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:24.084102" elapsed="0.000288"/>
</kw>
<msg time="2026-06-06T03:30:24.084479" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:24.083759" elapsed="0.000744"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.084733" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:24.084577" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.084556" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.085113" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:24.085250" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:24.084947" elapsed="0.000328"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:24.085680" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:24.085433" elapsed="0.000274"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:24.085755" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:24.085906" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:24.083373" elapsed="0.002558"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.087318" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.087071" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.087801" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.087537" elapsed="0.000308"/>
</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-06-06T03:30:24.095939" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:24.096404" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '572'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:24.096518" 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-06-06T03:30:24.090167" elapsed="0.006378"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.087912" elapsed="0.008677"/>
</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-06-06T03:30:24.096791" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.096615" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.087893" elapsed="0.008985"/>
</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-06-06T03:30:24.100353" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"egp"},"extended-communities":[{"transitive":true,"source-as-extended-community":{"global-administrator":65}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.097900" elapsed="0.002503"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.097674" elapsed="0.002765"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.097636" elapsed="0.002828"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.104095" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.100876" elapsed="0.003283"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.100530" elapsed="0.003677"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.100504" elapsed="0.003737"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.105018" 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-06-06T03:30:24.104475" elapsed="0.000580"/>
</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-06-06T03:30:24.105538" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.105154" elapsed="0.000466"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.106333" 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-06-06T03:30:24.105914" elapsed="0.000456"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.105676" elapsed="0.000743"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.105128" elapsed="0.001321"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.107204" 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-06-06T03:30:24.106698" elapsed="0.000543"/>
</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-06-06T03:30:24.107752" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.107338" elapsed="0.000500"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.108520" 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-06-06T03:30:24.108106" elapsed="0.000444"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.107872" elapsed="0.000714"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.107313" elapsed="0.001294"/>
</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-06-06T03:30:24.108940" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:24.109748" 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-06-06T03:30:24.109455" elapsed="0.000320"/>
</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-06-06T03:30:24.109934" elapsed="0.002298"/>
</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-06-06T03:30:24.097235" elapsed="0.015061"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.112472" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:24.112367" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.112348" elapsed="0.000191"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:24.115592" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:30:24.112706" elapsed="0.002920"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:24.115696" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:24.115856" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:24.086237" elapsed="0.029646"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:24.115945" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:24.116093" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:23.982592" elapsed="0.133528"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.144738" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:24.144259" elapsed="0.000507"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.145546" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.145272" elapsed="0.000419">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:24.145907" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:24.144934" elapsed="0.000999"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.146552" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:24.146104" elapsed="0.000489"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:24.146938" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:24.147070" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:24.146779" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.147553" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:24.147258" elapsed="0.000352"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:24.148113" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.147701" elapsed="0.000473"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.148879" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:24.148350" elapsed="0.000556"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:24.148198" elapsed="0.000744"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:24.147680" elapsed="0.001284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.149609" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:24.149115" elapsed="0.000546"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:24.149714" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:24.143612" elapsed="0.006229"/>
</kw>
<msg time="2026-06-06T03:30:24.149895" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:24.130882" elapsed="0.019063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.162500" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.175011" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.187689" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.187922" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.188106" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.188481" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.188334" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:24.188319" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.188728" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.188902" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.189071" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:24.188291" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.188185" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.189301" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.189376" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:24.189492" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:24.128167" elapsed="0.061353"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:24.189715" elapsed="0.002210"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:24.192961" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:24.192675" elapsed="0.000314"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:24.193795" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:24.193147" elapsed="0.000677"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:24.194313" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "source-as-extended-community": {
          "global-administrator": 65
         },
         "transitive": true
        }
       ],
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "egp"
       }
      },
      "intra-as-i-pmsi-a-d": {
       "orig-route-ip": "10.10.10.10",
       "route-distinguisher": "1.2.3.4:258"
      },
      "path-id": 0,
      "route-key": "AQwAAQECAwQBAgoKCgo="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:24.194536" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.193985" elapsed="0.000621">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.192250" elapsed="0.002584">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:24.192007" elapsed="0.002921">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:24.195119" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:24.194964" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:24.191987" elapsed="0.003210">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.117329" elapsed="0.078016">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:24.116442" elapsed="0.079074">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:24.116202" elapsed="0.079467">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:24.116185" elapsed="0.079523">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:24.195791" elapsed="0.000018"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:23.978245" elapsed="0.217695">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-extended-community": {
+          "global-administrator": 65
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "egp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.251668" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.251259" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.252480" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.252229" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.252664" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.251887" elapsed="0.000831"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.253282" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.252891" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.253620" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.253797" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.253477" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.254235" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.253985" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.255490" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.255175" elapsed="0.000361"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.255999" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.255726" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.256851" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.256396" elapsed="0.000481"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.258090" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.257522" elapsed="0.000669"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.258272" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:26.258573" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.257069" elapsed="0.001529"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.258776" elapsed="0.000381"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:26.256255" elapsed="0.002944"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.259874" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.259449" elapsed="0.000451"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.261204" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.260543" elapsed="0.000761"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.261440" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:26.261756" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.260092" elapsed="0.001690"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.261940" elapsed="0.000362"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:26.259313" elapsed="0.003032"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.256078" elapsed="0.006303"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.262424" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:26.262582" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:26.254679" elapsed="0.007929"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.254360" elapsed="0.008300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.262842" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.262688" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.254335" elapsed="0.008585"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.263856" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:26.263068" elapsed="0.000817"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.263936" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:26.250622" elapsed="0.013440"/>
</kw>
<msg time="2026-06-06T03:30:26.264117" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.237817" elapsed="0.026349"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.276806" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.289251" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.301744" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.301980" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.302173" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.302598" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.302438" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:26.302419" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.302845" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.303104" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.303276" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:26.302377" elapsed="0.000953"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.302258" elapsed="0.001099"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.303510" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.303593" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:30:26.303762" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:26.233518" elapsed="0.070274"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.305252" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.304935" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.305424" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.304489" elapsed="0.000960"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.305813" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.305520" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.306395" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.306096" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.305897" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.305501" elapsed="0.000978"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.308916" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.306635" elapsed="0.002309"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:26.308997" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:26.309151" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:26.304132" elapsed="0.005043"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.310368" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.310167" elapsed="0.000256"/>
</kw>
<msg time="2026-06-06T03:30:26.310507" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.309828" elapsed="0.000703"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.310753" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:26.310600" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.310581" elapsed="0.000266"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.311169" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.311397" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.311001" elapsed="0.000422"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:26.311841" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.311583" elapsed="0.000283"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:26.311949" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:26.312105" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:26.309482" elapsed="0.002648"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.313566" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.313315" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.314031" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.313788" elapsed="0.000287"/>
</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-06-06T03:30:26.322816" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:26.322996" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:26.323129" 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-06-06T03:30:26.316469" elapsed="0.006696"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.314156" elapsed="0.009069"/>
</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-06-06T03:30:26.323486" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.323263" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.314137" elapsed="0.009469"/>
</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-06-06T03:30:26.328516" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.325094" elapsed="0.003490"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.324773" elapsed="0.003861"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.324711" elapsed="0.003983"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.332449" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.329128" elapsed="0.003390"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.328809" elapsed="0.003758"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.328784" elapsed="0.003818"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.333475" 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-06-06T03:30:26.332928" elapsed="0.000585"/>
</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-06-06T03:30:26.333871" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.333607" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.334421" 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-06-06T03:30:26.334121" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.333954" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.333587" elapsed="0.000916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.335040" 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-06-06T03:30:26.334680" elapsed="0.000387"/>
</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-06-06T03:30:26.335374" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.335137" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.335934" 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-06-06T03:30:26.335625" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.335455" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.335118" elapsed="0.000898"/>
</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-06-06T03:30:26.336170" elapsed="0.000342"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:26.337002" 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-06-06T03:30:26.336699" elapsed="0.000369"/>
</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-06-06T03:30:26.337233" elapsed="0.002283"/>
</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-06-06T03:30:26.324129" elapsed="0.015452"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.339778" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:26.339667" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.339632" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:26.342630" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:26.339994" elapsed="0.002680"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:26.342729" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:26.342887" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:26.312443" elapsed="0.030470"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.342976" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:30:26.343124" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:26.210502" elapsed="0.132649"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.371860" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.371345" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.372701" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.372402" elapsed="0.000451">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.373034" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.372059" elapsed="0.001000"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.373694" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.373230" elapsed="0.000493"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.374050" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.374191" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.373891" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.374658" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.374378" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:26.375178" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.374774" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.375961" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.375414" elapsed="0.000575"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.375264" elapsed="0.000796"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.374755" elapsed="0.001328"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.376806" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:26.376236" elapsed="0.000611"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.376901" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:26.370731" elapsed="0.006303"/>
</kw>
<msg time="2026-06-06T03:30:26.377089" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.357843" elapsed="0.019296"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.389681" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.402106" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.414770" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.415023" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.415213" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.415652" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.415483" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:26.415464" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.415884" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.416057" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.416228" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:26.415425" elapsed="0.000857"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.415300" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.416460" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.416538" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:26.416789" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:26.355159" elapsed="0.061722"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.417074" elapsed="0.002283"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:26.420461" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.420152" elapsed="0.000338"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:26.420970" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.420668" elapsed="0.000330"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.421159" elapsed="0.000337"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.419718" elapsed="0.001839"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.419439" elapsed="0.002151"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.421792" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.421618" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.419419" elapsed="0.002451"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:26.344290" elapsed="0.077627"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:26.343478" elapsed="0.078516"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.343235" elapsed="0.078805"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.343218" elapsed="0.078847"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.422099" elapsed="0.000035"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:26.204496" elapsed="0.217740"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:23.973980" elapsed="2.448317"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:26.422520" elapsed="0.002863"/>
</kw>
<arg>intra_source_as</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:21.145235" elapsed="5.280209"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:21.058385" elapsed="5.367179"/>
</test>
<test id="s1-s16-t24" name="Odl_To_Play_intra_source_as_4" line="150">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:26.428937" elapsed="0.000220"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:26.428610" elapsed="0.000602"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.430245" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:26.430127" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.430106" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.435527" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:26.435416" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.435398" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.436699" 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-06-06T03:30:26.436272" elapsed="0.000455"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.437265" 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-06-06T03:30:26.436930" elapsed="0.000472"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:26.437454" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:26.437621" 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-06-06T03:30:26.435851" elapsed="0.001817"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:26.443296" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:26.443183" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.443162" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:26.444571" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:26.444462" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.444442" elapsed="0.000218"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:26.445163" 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-06-06T03:30:26.444851" elapsed="0.000340"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:26.445580" level="INFO">${current_connection_index} = 7</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-06-06T03:30:26.445358" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:26.483496" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:26.446135" elapsed="0.037483"/>
</kw>
<msg time="2026-06-06T03:30:26.483809" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:26.483856" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:26.445791" elapsed="0.038103"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:26.512314" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "_ "4 "[K"
[?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-06-06T03:30:26.484442" elapsed="0.028060"/>
</kw>
<msg time="2026-06-06T03:30:26.512745" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:26.512797" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</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-06-06T03:30:26.484080" elapsed="0.028796"/>
</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-06-06T03:30:26.513315" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.512990" elapsed="0.000386"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.512957" elapsed="0.000446"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.513953" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "_ "4 "[K"
[?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-06-06T03:30:26.513554" elapsed="0.000472"/>
</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-06-06T03:30:26.514332" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.514098" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.514078" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:26.514452" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:26.517288" elapsed="0.000376"/>
</kw>
<msg time="2026-06-06T03:30:26.517735" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.516081" elapsed="0.001791"/>
</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="NOT RUN" start="2026-06-06T03:30:26.518159" elapsed="0.000082"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.518573" 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-06-06T03:30:26.515391" elapsed="0.003412"/>
</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-06-06T03:30:26.514803" elapsed="0.004068"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:26.444156" elapsed="0.074873"/>
</kw>
<msg time="2026-06-06T03:30:26.519127" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:26.519174" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:26.443524" elapsed="0.075689"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:26.519406" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:26.519294" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.519273" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.519929" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.520278" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.520351" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:26.442834" elapsed="0.077627"/>
</kw>
<msg time="2026-06-06T03:30:26.520557" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:26.520603" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "O "d "l "_ "T "o "_ "P "l "a...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:26.438053" elapsed="0.082606"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.521064" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.520749" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.520730" elapsed="0.000414"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:26.437904" elapsed="0.083264"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:26.437726" elapsed="0.083473"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:26.435045" elapsed="0.086210"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:26.429833" elapsed="0.091480"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:26.429371" elapsed="0.091988"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:26.426437" elapsed="0.094976"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.522358" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/announce_intra_source_as_4.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/announce_intra_source_as_4.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.522529" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.522151" elapsed="0.000405"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:26.522955" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.522737" elapsed="0.000246"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.523337" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/withdraw_intra_source_as_4.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/withdraw_intra_source_as_4.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.523467" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.523145" elapsed="0.000350"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:26.523876" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.523670" elapsed="0.000233"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:26.524195" elapsed="0.002256"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.523975" elapsed="0.002546"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.523956" elapsed="0.002592"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.561225" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.560799" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.562047" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.561789" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.562217" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.561429" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.562817" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.562410" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.563145" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.563289" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.563008" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.563733" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.563474" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.564755" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.564480" elapsed="0.000320"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.565246" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.564978" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.565953" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.565636" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.566975" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.566494" elapsed="0.000509"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.567058" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:26.567220" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.566169" elapsed="0.001078"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.567410" elapsed="0.000266"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:26.565497" elapsed="0.002222"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.568290" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.567980" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.569302" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.568879" elapsed="0.000452"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.569384" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:26.569540" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.568511" elapsed="0.001055"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.569745" elapsed="0.000232"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:26.567837" elapsed="0.002182"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.565323" elapsed="0.004731"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.570100" elapsed="0.000068"/>
</return>
<msg time="2026-06-06T03:30:26.570304" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:26.564151" elapsed="0.006178"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.563850" elapsed="0.006512"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.570544" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.570387" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.563830" elapsed="0.006792"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.572819" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:26.570800" elapsed="0.002075"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.572932" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:26.560151" elapsed="0.012912"/>
</kw>
<msg time="2026-06-06T03:30:26.573119" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.547340" elapsed="0.025828"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.585771" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.598617" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.611466" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.611715" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.611909" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.612321" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.612162" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:26.612145" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.612555" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.612753" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.612948" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:26.612108" elapsed="0.000897"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.611993" elapsed="0.001039"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.613186" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.613352" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:30:26.613497" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:26.543013" elapsed="0.070513"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.638894" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.638477" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.639720" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.639452" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.639893" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.639101" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.640483" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.640091" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.640846" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.641046" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.640700" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.641498" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;source-as-4-extended-community&gt;
                &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
            &lt;/source-as-4-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.641246" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:26.641987" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.641667" elapsed="0.000381"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.642524" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.642225" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.642074" elapsed="0.000512"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.641623" elapsed="0.000985"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.643239" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:26.642778" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.643321" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:26.637850" elapsed="0.005603"/>
</kw>
<msg time="2026-06-06T03:30:26.643614" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.624974" elapsed="0.018711"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.656465" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.669137" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.681760" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.681963" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.682145" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.682521" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.682372" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:26.682357" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.682763" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.682941" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.683114" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:26.682327" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.682221" elapsed="0.000976"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.683351" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.683429" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:26.683563" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-nex...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:26.623987" elapsed="0.059605"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.685006" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.684663" elapsed="0.000418">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.685232" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.684291" elapsed="0.000967"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.685584" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.685331" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.686172" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.685868" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.685684" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.685311" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.688667" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.686415" elapsed="0.002280"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:26.688747" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:26.688903" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:26.683952" elapsed="0.004995"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.690493" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.690237" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.690952" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;source-as-4-extended-community&gt;
                &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
            &lt;/source-as-4-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.690712" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.691407" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.691164" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.691864" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.691605" elapsed="0.000302"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:26.692731" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:26.692517" elapsed="0.000240"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:26.693119" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:26.692940" elapsed="0.000205"/>
</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-06-06T03:30:26.693299" elapsed="0.000210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.693937" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.693687" elapsed="0.000295"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:26.694024" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:26.694181" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:26.692108" elapsed="0.002098"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:26.710492" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '967', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;mvpn-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:mvpn:ipv4"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;AQwAAQECAwQBAgoKCgo=&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.1.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;multi-exit-disc&gt;
            &lt;med&gt;0&lt;/med&gt;
        &lt;/multi-exit-disc&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;source-as-4-extended-community&gt;
                &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
            &lt;/source-as-4-extended-community&gt;
        &lt;/extended-communities&gt;
    &lt;/attributes&gt;
    &lt;intra-as-i-pmsi-a-d&gt;
        &lt;route-distinguisher&gt;1.2.3.4:258&lt;/route-distinguisher&gt;
        &lt;orig-route-ip&gt;10.10.10.10&lt;/orig-route-ip&gt;
    &lt;/intra-as-i-pmsi-a-d&gt;
&lt;/mvpn-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:26.710598" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4/mvpn-route=AQwAAQECAwQBAgoKCgo%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:26.710876" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:26.696564" elapsed="0.014372"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.694276" elapsed="0.016761"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.711451" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.711096" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.694259" elapsed="0.017433"/>
</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-06-06T03:30:26.719571" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.714075" elapsed="0.005559"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.713529" elapsed="0.006162"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.713487" elapsed="0.006230"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.722313" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.720002" elapsed="0.002357"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.719774" elapsed="0.002620"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.719757" elapsed="0.002661"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.722992" 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-06-06T03:30:26.722588" elapsed="0.000432"/>
</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-06-06T03:30:26.723333" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.723090" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.723898" 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-06-06T03:30:26.723582" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.723415" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.723072" elapsed="0.000909"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.724505" 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-06-06T03:30:26.724145" elapsed="0.000386"/>
</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-06-06T03:30:26.724861" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.724601" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.725414" 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-06-06T03:30:26.725121" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.724956" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.724582" elapsed="0.000912"/>
</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-06-06T03:30:26.725667" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:26.726464" 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-06-06T03:30:26.726186" elapsed="0.000304"/>
</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-06-06T03:30:26.726663" elapsed="0.002331"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:26.712491" elapsed="0.016568"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:26.729243" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:26.729133" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.729114" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:26.729481" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.729549" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:26.731836" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:26.689276" elapsed="0.042587"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.731970" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:26.732128" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:26.531465" elapsed="0.200688"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.732499" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.732259" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.732241" elapsed="0.000356"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.732632" elapsed="0.000042"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:26.526846" elapsed="0.205928"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:26.735954" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.733724" elapsed="0.002261"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.736167" elapsed="0.002716"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:26.738957" elapsed="0.000041"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:26.733433" elapsed="0.005702"/>
</kw>
<msg time="2026-06-06T03:30:26.739241" level="INFO">${update} = ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:26.732965" elapsed="0.006311"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.740500" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:26.740608" level="INFO">${len_1} = 162</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:26.740127" elapsed="0.000534"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.741263" level="INFO">Length is 162.</msg>
<msg time="2026-06-06T03:30:26.741370" level="INFO">${len_2} = 162</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:26.740889" elapsed="0.000515"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.741627" elapsed="0.000462"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:26.742573" level="INFO">${sum_1} = 1872</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:26.742314" elapsed="0.000297"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:26.743107" level="INFO">${sum_2} = 1872</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:26.742854" elapsed="0.000289"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.743363" elapsed="0.000451"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:26.739577" elapsed="0.004320"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:26.744114" elapsed="0.002258"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.789960" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.789561" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.790763" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.790498" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.790972" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.790155" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.791558" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.791167" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.791913" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.792050" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.791774" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.792483" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.792237" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.793754" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.793422" elapsed="0.000378"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.794242" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.793966" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.795083" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.794664" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.796228" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.795746" elapsed="0.000562"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.796446" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:26.796695" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.795304" elapsed="0.001418"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.796881" elapsed="0.000429"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:26.794501" elapsed="0.002851"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.798048" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.797607" elapsed="0.000467"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.799175" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.798704" elapsed="0.000551"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.799392" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:26.799615" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.798262" elapsed="0.001395"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.799817" elapsed="0.000395"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:26.797469" elapsed="0.002785"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.794319" elapsed="0.005969"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.800330" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:26.800487" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:26.792922" elapsed="0.007590"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.792602" elapsed="0.007942"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.800737" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.800568" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.792579" elapsed="0.008235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.801543" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:26.800963" elapsed="0.000609"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.801626" elapsed="0.000097"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:26.788915" elapsed="0.012908"/>
</kw>
<msg time="2026-06-06T03:30:26.801914" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.776165" elapsed="0.025798"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.814592" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.828059" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.840565" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.840793" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.840983" elapsed="0.000035"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.841389" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.841236" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:26.841220" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.841616" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.841806" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.841982" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:26.841186" elapsed="0.000850"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.841076" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.842216" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.842293" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:26.842427" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:26.771839" elapsed="0.070616"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.843620" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.843342" elapsed="0.000408"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:26.853913" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:26.853978" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:26.854103" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:26.846121" elapsed="0.008019"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.843820" elapsed="0.010378"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.854456" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.854235" elapsed="0.000309"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.843801" elapsed="0.010773"/>
</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-06-06T03:30:26.859349" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.856019" elapsed="0.003391"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.855702" elapsed="0.003757"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.855674" elapsed="0.003821"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.862727" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.859916" elapsed="0.002858"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.859573" elapsed="0.003235"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.859549" elapsed="0.003284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.863400" 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-06-06T03:30:26.863012" elapsed="0.000415"/>
</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-06-06T03:30:26.863760" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.863499" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.864322" 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-06-06T03:30:26.864017" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.863843" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.863480" elapsed="0.000925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.864958" 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-06-06T03:30:26.864571" elapsed="0.000414"/>
</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-06-06T03:30:26.865314" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.865075" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.865875" 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-06-06T03:30:26.865561" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.865396" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.865056" elapsed="0.000901"/>
</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-06-06T03:30:26.866113" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:26.866935" 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-06-06T03:30:26.866630" elapsed="0.000332"/>
</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-06-06T03:30:26.867121" elapsed="0.002340"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:26.855100" elapsed="0.014425"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:26.869572" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:26.871849" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:26.842743" elapsed="0.029133"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.871964" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:26.747466" elapsed="0.124626"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:26.747044" elapsed="0.125103"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:26.746667" elapsed="0.125539"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:26.876538" level="INFO">${update} = ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.873161" elapsed="0.003406"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.876768" elapsed="0.002644"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:26.879482" elapsed="0.000040"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:26.872868" elapsed="0.006807"/>
</kw>
<msg time="2026-06-06T03:30:26.879785" level="INFO">${update} = ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:26.872383" elapsed="0.007437"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.881038" level="INFO">Length is 150.</msg>
<msg time="2026-06-06T03:30:26.881146" level="INFO">${len_1} = 150</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:26.880632" elapsed="0.000547"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.881782" level="INFO">Length is 150.</msg>
<msg time="2026-06-06T03:30:26.881887" level="INFO">${len_2} = 150</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:26.881399" elapsed="0.000521"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.882142" elapsed="0.000430"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:26.883070" level="INFO">${sum_1} = 1721</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:26.882814" elapsed="0.000291"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:26.883567" level="INFO">${sum_2} = 1721</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:26.883319" elapsed="0.000282"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:26.883839" elapsed="0.000429"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:26.880117" elapsed="0.004234"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.928832" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:26.928437" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.929877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.929400" elapsed="0.000550">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:26.930044" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:26.929027" elapsed="0.001041"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.930633" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:26.930238" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:26.930993" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:26.931146" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:26.930854" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.931577" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.931333" elapsed="0.000343"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.932678" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.932399" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.933183" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.932886" elapsed="0.000323"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.934126" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.933568" elapsed="0.000584"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.935298" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.934847" elapsed="0.000495"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.935462" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:26.935704" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.934341" elapsed="0.001388"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.935886" elapsed="0.000502"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:26.933430" elapsed="0.003000"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.937263" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:26.936696" elapsed="0.000595"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:26.938593" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.938141" elapsed="0.000496"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:26.938779" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:26.939009" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:26.937484" elapsed="0.001551"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:26.939196" elapsed="0.000537"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:26.936543" elapsed="0.003233"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.933259" elapsed="0.006553"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:26.939856" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:26.940022" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:26.932045" elapsed="0.008004"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.931747" elapsed="0.008335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.940266" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.940108" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:26.931727" elapsed="0.008619"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.941120" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:26.940497" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:26.941206" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:26.927765" elapsed="0.013575"/>
</kw>
<msg time="2026-06-06T03:30:26.941396" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:26.914853" elapsed="0.026606"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.954331" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.966902" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.979393" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.979592" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.979826" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.980202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.980051" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:26.980035" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.980426" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.980600" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.980788" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:26.980006" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.979902" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.981016" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:26.981116" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:26.981235" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:26.910463" elapsed="0.070799"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:26.982398" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:26.982143" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:26.990200" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:26.990342" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-mvpn:mcast-vpn-subsequent-address-family']/bgp-mvpn-ipv4:mvpn-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:26.990473" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:26.990514" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.984574" elapsed="0.006504">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:26.982510" elapsed="0.008680">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:26.991469" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:26.991238" elapsed="0.000319"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:26.982492" elapsed="0.009099">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:26.996697" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.993113" elapsed="0.003634">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:26.992775" elapsed="0.004060">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:26.992748" elapsed="0.004133">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.000551" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.997315" elapsed="0.003286">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:26.996981" elapsed="0.003730">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:26.996956" elapsed="0.003801">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.001585" 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-06-06T03:30:27.001020" elapsed="0.000598"/>
</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-06-06T03:30:27.002068" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.001707" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.002621" 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-06-06T03:30:27.002319" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:27.002151" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.001687" elapsed="0.001035"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.003254" 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-06-06T03:30:27.002889" 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-06-06T03:30:27.003598" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.003352" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.004165" 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-06-06T03:30:27.003868" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:27.003700" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.003333" elapsed="0.000914"/>
</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-06-06T03:30:27.004402" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:27.005228" 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-06-06T03:30:27.004933" elapsed="0.000321"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:27.007709" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:27.005413" elapsed="0.002329">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:26.992139" elapsed="0.015737">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:27.007971" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:27.010365" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:27.010395" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:26.981522" elapsed="0.028902">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:27.010490" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:26.886011" elapsed="0.124663">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:26.885283" elapsed="0.125455"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:26.884694" elapsed="0.126105"/>
</kw>
<arg>intra_source_as_4</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:26.521766" elapsed="0.489084"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:26.425962" elapsed="0.585002"/>
</test>
<test id="s1-s16-t25" name="Play_To_Odl_intra_source_as_4" line="154">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:27.014409" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:27.014140" elapsed="0.000558"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.015708" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:27.015581" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.015562" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.020771" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:27.020661" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.020629" elapsed="0.000210"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.021863" 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-06-06T03:30:27.021465" elapsed="0.000425"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.022348" 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-06-06T03:30:27.022055" elapsed="0.000319"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:27.022418" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:27.022570" 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-06-06T03:30:27.021065" elapsed="0.001529"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:27.028064" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:27.027951" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.027932" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:27.029298" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:27.029191" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.029172" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:27.029861" 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-06-06T03:30:27.029514" elapsed="0.000374"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:27.030270" level="INFO">${current_connection_index} = 7</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-06-06T03:30:27.030053" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:27.062182" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:27.030822" elapsed="0.031482"/>
</kw>
<msg time="2026-06-06T03:30:27.062487" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:27.062537" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:27.030459" elapsed="0.032115"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:27.095553" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "_ "4 "[K"
[?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-06-06T03:30:27.063342" elapsed="0.032393"/>
</kw>
<msg time="2026-06-06T03:30:27.095895" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:27.095941" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:30:27.062798" elapsed="0.033180"/>
</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-06-06T03:30:27.096306" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.096064" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.096040" elapsed="0.000347"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.096865" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "s "o "u "r "c "e "_ "a "s "_ "4 "[K"
[?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-06-06T03:30:27.096536" elapsed="0.000402"/>
</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-06-06T03:30:27.097243" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.097006" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.096987" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:27.097357" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:27.100313" elapsed="0.000181"/>
</kw>
<msg time="2026-06-06T03:30:27.100568" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:27.098945" elapsed="0.001805"/>
</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="NOT RUN" start="2026-06-06T03:30:27.101086" elapsed="0.000124"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.101514" elapsed="0.000092"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:27.098227" elapsed="0.003555"/>
</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-06-06T03:30:27.097676" elapsed="0.004178"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:27.028877" elapsed="0.073087"/>
</kw>
<msg time="2026-06-06T03:30:27.102068" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:27.102117" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:27.028286" elapsed="0.073874"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:27.102357" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:27.102246" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.102225" elapsed="0.000216"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.102870" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.103218" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.103290" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:27.027604" elapsed="0.075795"/>
</kw>
<msg time="2026-06-06T03:30:27.103493" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:27.103543" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:27.022979" elapsed="0.080603"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.103933" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.103674" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.103655" elapsed="0.000357"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:27.022833" elapsed="0.081202"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:27.022662" elapsed="0.081439"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:27.020283" elapsed="0.083877"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:27.015293" elapsed="0.088923"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:27.014855" elapsed="0.089407"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:27.011836" elapsed="0.092480"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.105492" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.104978" elapsed="0.000544"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.106354" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.105888" elapsed="0.000495"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.106966" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.106557" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:27.107370" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/announce_intra_source_as_4.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/announce_intra_source_as_4.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:27.107533" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:27.107163" elapsed="0.000397"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:27.107933" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/withdraw_intra_source_as_4.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/withdraw_intra_source_as_4.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:27.108058" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:27.107740" elapsed="0.000345"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:27.108253" elapsed="0.002375"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:27.110822" elapsed="0.001923"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.163184" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:27.162807" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:27.164023" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:27.163752" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:27.164204" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:27.163380" elapsed="0.000856"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.164809" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:27.164404" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:27.165134" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:27.165296" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:27.165000" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.165791" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:27.165527" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.166829" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:27.166527" elapsed="0.000347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.167304" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.167037" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.168122" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:27.167719" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:27.169425" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.168815" elapsed="0.000711"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:27.169605" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:27.169918" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:27.168340" elapsed="0.001604"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.170103" elapsed="0.000383"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:27.167556" elapsed="0.002972"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.172741" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:27.170791" elapsed="0.001978"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:27.174006" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.173442" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:27.174190" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:27.174484" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:27.172966" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:27.174685" elapsed="0.000371"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:27.170653" elapsed="0.004445"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:27.167382" elapsed="0.007752"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:27.175178" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:27.175336" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:27.166203" elapsed="0.009158"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:27.165906" elapsed="0.009488"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.175573" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.175419" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.165886" elapsed="0.009779"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.176393" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:27.175813" elapsed="0.000609"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:27.176472" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:27.162172" elapsed="0.014423"/>
</kw>
<msg time="2026-06-06T03:30:27.176714" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:27.149298" elapsed="0.027467"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.189327" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.201954" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.214461" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.214678" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.214862" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.215230" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.215082" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:27.215066" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.215454" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.215626" elapsed="0.000034"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.215814" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:27.215038" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.214938" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.216042" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.216116" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:27.216236" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:27.144919" elapsed="0.071343"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:27.217561" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:27.217299" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:27.217737" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:27.216923" elapsed="0.000838"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.218081" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.217831" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.218636" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:27.218343" elapsed="0.000367"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:27.218163" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.217812" elapsed="0.000959"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.221327" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:27.218928" elapsed="0.002426"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:27.221407" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:27.221562" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:27.216581" elapsed="0.005006"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:27.222834" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:27.222579" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:27.222991" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:27.222238" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:27.223222" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:27.223086" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:27.223067" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.223455" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.223631" elapsed="0.000036"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.223713" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:27.225670" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:27.221908" elapsed="0.003789"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.227089" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:27.226835" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:27.227534" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:27.227295" elapsed="0.000282"/>
</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-06-06T03:30:27.236022" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:27.236156" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:27.236262" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</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="FAIL" start="2026-06-06T03:30:27.229826" elapsed="0.006809">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:27.227656" elapsed="0.009087">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</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-06-06T03:30:27.236937" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.236777" elapsed="0.000226"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:27.227624" elapsed="0.009402">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:27.237485" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.237623" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:27.237582" elapsed="0.000099"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:27.237564" elapsed="0.000141"/>
</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-06-06T03:30:27.237855" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.237926" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:27.226007" elapsed="0.012025">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.238107" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:27.122055" elapsed="0.116149">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:27.238488" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:27.238297" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:27.238280" elapsed="0.000305"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:27.238618" elapsed="0.000015"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:27.117592" elapsed="0.121140">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.316715" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.316051" elapsed="0.000717"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.317930" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.317545" elapsed="0.000490">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.318171" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.317027" elapsed="0.001178"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.319162" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.318549" elapsed="0.000640"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.319516" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:29.319712" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:29.319366" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.320264" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.320010" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.321467" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.321146" elapsed="0.000367"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.321989" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.321712" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.322866" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.322427" elapsed="0.000466"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:29.324127" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.323546" elapsed="0.000685"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:29.324313" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:29.324618" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:29.323087" elapsed="0.001572"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.324823" elapsed="0.000393"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:29.322255" elapsed="0.003002"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.326132" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.325509" elapsed="0.000650"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:29.327627" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.327071" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:29.327826" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:29.328121" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:29.326540" elapsed="0.001607"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.328305" elapsed="0.000396"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:29.325372" elapsed="0.003372"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:29.322071" elapsed="0.006708"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:29.328825" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:29.328982" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:29.320810" elapsed="0.008197"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.320401" elapsed="0.008638"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.329224" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.329066" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.320371" elapsed="0.008929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.330069" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:29.329453" elapsed="0.000645"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.330147" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:29.314774" elapsed="0.015497"/>
</kw>
<msg time="2026-06-06T03:30:29.330351" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.293623" elapsed="0.036789"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.343113" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.355609" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.368159" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.368400" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.368587" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.369035" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.368877" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:29.368858" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.369275" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.369448" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.369674" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:29.368817" elapsed="0.000919"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.368690" elapsed="0.001074"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.369926" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.370007" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:29.370172" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:29.286796" elapsed="0.083406"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.371732" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.371406" elapsed="0.000406">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.371907" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.370998" elapsed="0.000933"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.372311" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.372015" elapsed="0.000356"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.372973" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.372593" elapsed="0.000414"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.372397" elapsed="0.000652"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.371989" elapsed="0.001083"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.375814" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.373232" elapsed="0.002610"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:29.375965" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:29.376136" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:29.370608" elapsed="0.005553"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.377548" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.377284" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.377734" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.376893" elapsed="0.000867"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:29.377980" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:29.377837" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.377816" elapsed="0.000249"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.378221" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.378443" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.378513" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:29.380471" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:29.376492" elapsed="0.004006"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.381991" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.381723" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.382484" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.382202" elapsed="0.000327"/>
</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-06-06T03:30:29.391563" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:29.392019" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '432'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:29.392129" 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-06-06T03:30:29.384818" elapsed="0.007338"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.382600" elapsed="0.009603"/>
</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-06-06T03:30:29.392405" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.392233" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.382580" elapsed="0.009913"/>
</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-06-06T03:30:29.397050" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.393636" elapsed="0.003490"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.393386" elapsed="0.003791"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.393366" elapsed="0.003847"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.401354" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.397631" elapsed="0.003795"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.397296" elapsed="0.004255"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.397270" elapsed="0.004322"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.402549" 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-06-06T03:30:29.401900" elapsed="0.000691"/>
</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-06-06T03:30:29.402957" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.402702" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.403516" 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-06-06T03:30:29.403213" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.403041" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.402681" elapsed="0.000922"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.404157" 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-06-06T03:30:29.403786" elapsed="0.000399"/>
</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-06-06T03:30:29.404502" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.404257" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.405094" 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-06-06T03:30:29.404779" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.404583" elapsed="0.000575"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.404238" elapsed="0.000942"/>
</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-06-06T03:30:29.405343" elapsed="0.000380"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:29.406247" 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-06-06T03:30:29.405898" elapsed="0.000382"/>
</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-06-06T03:30:29.406487" elapsed="0.002353"/>
</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-06-06T03:30:29.392918" elapsed="0.016005"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.409133" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:29.409016" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.408991" elapsed="0.000212"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.412310" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<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="PASS" start="2026-06-06T03:30:29.409354" elapsed="0.002992"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:29.412413" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:30:29.412601" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:29.380845" elapsed="0.031783"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.412714" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:29.412874" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:29.252903" elapsed="0.160000"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.441860" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.441355" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.442830" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.442508" elapsed="0.000449">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.443136" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.442069" elapsed="0.001093"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.443800" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.443333" elapsed="0.000495"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.444160" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:29.444326" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:29.443994" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.444802" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "source-as-4-extended-community": {
                "global-administrator": 64496
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.444515" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:29.445361" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.444929" elapsed="0.000494"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.446121" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.445600" elapsed="0.000548"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.445450" elapsed="0.000733"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.444906" elapsed="0.001298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.446911" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:29.446388" elapsed="0.000552"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.446993" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:29.440706" elapsed="0.006424"/>
</kw>
<msg time="2026-06-06T03:30:29.447189" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.427709" elapsed="0.019530"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.460255" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.473094" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.485889" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.486113" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.486308" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.486767" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.486590" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:29.486573" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.486998" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.487171" elapsed="0.000026"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.487349" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:29.486538" elapsed="0.000863"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.486419" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.487597" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.487690" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:29.487846" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:29.425031" elapsed="0.062851"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.488190" elapsed="0.002529"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.492029" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.491482" elapsed="0.000576"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.492715" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.492217" elapsed="0.000527"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:29.492906" elapsed="0.000330"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:29.491051" elapsed="0.002245"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.490802" elapsed="0.002527"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.493507" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.493354" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.490782" elapsed="0.002800"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:29.414127" elapsed="0.079504"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:29.413264" elapsed="0.080464"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.412991" elapsed="0.080822"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.412973" elapsed="0.080866"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.493874" elapsed="0.000030"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:29.245964" elapsed="0.248043"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:27.112942" elapsed="2.381126"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.543964" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.543540" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.544793" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.544511" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.544967" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.544169" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.545544" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.545161" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.545894" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:29.546057" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:29.545752" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.546500" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.546242" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.547776" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.547275" elapsed="0.000547"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.548269" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.547994" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.549135" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.548721" elapsed="0.000441"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:29.550379" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.549833" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:29.550585" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:29.550905" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:29.549357" elapsed="0.001574"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.551093" elapsed="0.000383"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:29.548544" elapsed="0.002973"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.552184" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.551785" elapsed="0.000425"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:29.553480" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.552870" elapsed="0.000712"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:29.553680" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:29.553971" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:29.552398" elapsed="0.001599"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.554154" elapsed="0.000392"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:29.551632" elapsed="0.002956"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:29.548366" elapsed="0.006257"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:29.554683" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:29.554842" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:29.546943" elapsed="0.007924"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.546617" elapsed="0.008282"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.555079" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.554925" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.546596" elapsed="0.008558"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.555899" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:29.555301" elapsed="0.000628"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.555978" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:29.542907" elapsed="0.013194"/>
</kw>
<msg time="2026-06-06T03:30:29.556155" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.529892" elapsed="0.026310"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.568799" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.581181" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.593604" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.593829" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.594010" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.594374" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.594226" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:29.594211" elapsed="0.000302"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.594679" elapsed="0.000025"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.594858" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.595029" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:29.594183" elapsed="0.000898"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.594084" elapsed="0.001023"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.595255" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.595329" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:29.595449" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:29.525568" elapsed="0.069908"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.596754" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.596495" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.596911" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.596151" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.597255" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.597005" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.597837" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.597523" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.597335" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.596987" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.600513" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.598079" elapsed="0.002461"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:29.600593" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:29.600762" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:29.595817" elapsed="0.004970"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.602014" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.601783" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.602168" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.601422" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:29.602396" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:30:29.602261" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.602242" elapsed="0.000269"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.602677" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.602855" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.602919" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:29.604870" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:29.601094" elapsed="0.003802"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.606286" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.606038" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.606783" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.606515" elapsed="0.000312"/>
</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-06-06T03:30:29.614978" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:29.615121" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '432'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:29.615219" 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-06-06T03:30:29.608991" elapsed="0.006255"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.606893" elapsed="0.008396"/>
</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-06-06T03:30:29.615473" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.615315" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.606875" elapsed="0.008682"/>
</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-06-06T03:30:29.619215" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.616598" elapsed="0.002668"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.616369" elapsed="0.002932"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.616350" elapsed="0.002977"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.621905" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.619611" elapsed="0.002341"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.619384" elapsed="0.002603"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.619366" elapsed="0.002645"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.622573" 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-06-06T03:30:29.622181" elapsed="0.000420"/>
</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-06-06T03:30:29.622945" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.622700" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.623490" 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-06-06T03:30:29.623192" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.623026" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.622677" elapsed="0.000895"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.624111" 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-06-06T03:30:29.623753" elapsed="0.000385"/>
</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-06-06T03:30:29.624446" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.624208" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.625001" 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-06-06T03:30:29.624708" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.624527" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.624190" elapsed="0.000935"/>
</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-06-06T03:30:29.625281" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:29.626093" 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-06-06T03:30:29.625815" elapsed="0.000304"/>
</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-06-06T03:30:29.626277" elapsed="0.002323"/>
</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-06-06T03:30:29.615947" elapsed="0.012733"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.628860" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:29.628754" elapsed="0.000149"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.628735" elapsed="0.000191"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.632009" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<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="PASS" start="2026-06-06T03:30:29.629073" elapsed="0.002965"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:29.632090" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:29.632245" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:29.605210" elapsed="0.027061"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.632333" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:29.632481" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:29.502981" elapsed="0.129526"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.660778" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.660314" elapsed="0.000493"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.661572" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.661313" elapsed="0.000399">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.661888" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.660975" elapsed="0.000939"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.662538" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.662083" elapsed="0.000485"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.662911" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:29.663057" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:29.662750" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.663509" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "source-as-4-extended-community": {
                "global-administrator": 64496
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.663244" elapsed="0.000357"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:29.664087" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.663686" elapsed="0.000461"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.664845" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.664320" elapsed="0.000552"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.664171" elapsed="0.000738"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.663666" elapsed="0.001264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.665561" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:29.665079" elapsed="0.000511"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.665663" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:29.659693" elapsed="0.006099"/>
</kw>
<msg time="2026-06-06T03:30:29.665850" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.646907" elapsed="0.018992"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.678360" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.690877" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.703423" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.703621" elapsed="0.000034"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.703815" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.704183" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.704036" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:29.704021" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.704406" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.704577" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.704767" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:29.703993" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.703892" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.705032" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.705109" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:29.705245" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:29.644241" elapsed="0.061031"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.705451" elapsed="0.003491"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.710190" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.709693" elapsed="0.000526"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.710912" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.710378" elapsed="0.000563"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:29.711101" elapsed="0.000326"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:29.709265" elapsed="0.002222"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.709023" elapsed="0.002497"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.711715" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.711545" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.709004" elapsed="0.002789"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:29.633654" elapsed="0.078186"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:29.632846" elapsed="0.079069"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.632590" elapsed="0.079370"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.632573" elapsed="0.079411"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.712016" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:29.498564" elapsed="0.213576"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:29.494249" elapsed="0.217948"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.763056" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.762655" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.763894" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.763608" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.764137" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.763265" elapsed="0.000899"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.764746" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.764335" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.765090" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:29.765246" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:29.764941" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.765702" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.765435" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.816666" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.766465" elapsed="0.050275"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.817291" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.816977" elapsed="0.000341"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.818146" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.817730" elapsed="0.000442"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:29.819483" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.818923" elapsed="0.000662"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:29.819684" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:30:29.819992" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:29.818383" elapsed="0.001635"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.820179" elapsed="0.000386"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:29.817563" elapsed="0.003044"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.821288" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.820880" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:29.822527" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.821982" elapsed="0.000683"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:29.822746" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:29.823039" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:29.821504" elapsed="0.001561"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:29.823221" elapsed="0.000363"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:29.820742" elapsed="0.002885"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:29.817374" elapsed="0.006306"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:29.823729" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:29.823887" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:29.766136" elapsed="0.057776"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.765823" elapsed="0.058121"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.824128" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.823971" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.765800" elapsed="0.058403"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.824982" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:29.824350" elapsed="0.000661"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.825060" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:29.761972" elapsed="0.063211"/>
</kw>
<msg time="2026-06-06T03:30:29.825300" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.748655" elapsed="0.076697"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.838161" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.850699" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.863148" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.863346" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.863527" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.863915" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.863767" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:29.863751" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.864140" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.864309" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.864476" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:29.863720" elapsed="0.000809"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.863602" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.864727" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.864804" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:29.864925" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:29.744248" elapsed="0.120703"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.866244" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.865975" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.866445" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.865607" elapsed="0.000863"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.866842" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.866541" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.867393" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.867101" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.866924" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.866522" elapsed="0.000954"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.869834" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.867632" elapsed="0.002228"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:29.869913" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:29.870065" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:29.865279" elapsed="0.004811"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.871339" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.871109" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.871495" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.870767" elapsed="0.000753"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:29.871753" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:29.871590" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.871572" elapsed="0.000264"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.871986" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.872158" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.872223" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:29.874275" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:29.870393" elapsed="0.003908"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.875755" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.875485" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.876200" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.875959" elapsed="0.000284"/>
</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-06-06T03:30:29.884431" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:29.884574" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv4:mvpn-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '432'} 
 body={"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}} 
 </msg>
<msg time="2026-06-06T03:30:29.884713" 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-06-06T03:30:29.878393" elapsed="0.006348"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.876308" elapsed="0.008506"/>
</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-06-06T03:30:29.885001" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.884843" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.876290" elapsed="0.008795"/>
</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-06-06T03:30:29.888546" level="INFO">{"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.886096" elapsed="0.002500"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.885874" elapsed="0.002757"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.885855" elapsed="0.002818"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.891292" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.888963" elapsed="0.002375"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.888736" elapsed="0.002637"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.888718" elapsed="0.002680"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.891970" 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-06-06T03:30:29.891569" elapsed="0.000428"/>
</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-06-06T03:30:29.892312" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.892068" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.892882" 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-06-06T03:30:29.892563" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.892395" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.892049" elapsed="0.000918"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.893493" 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-06-06T03:30:29.893131" elapsed="0.000388"/>
</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-06-06T03:30:29.893847" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.893590" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.894391" 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-06-06T03:30:29.894094" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.893929" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.893571" elapsed="0.000902"/>
</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-06-06T03:30:29.894667" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:29.895461" 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-06-06T03:30:29.895183" elapsed="0.000304"/>
</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-06-06T03:30:29.895660" elapsed="0.002289"/>
</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-06-06T03:30:29.885439" elapsed="0.012572"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.898188" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:29.898081" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.898062" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.901255" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<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="PASS" start="2026-06-06T03:30:29.898405" elapsed="0.002880"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:29.901338" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:29.901496" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:29.874652" elapsed="0.026871"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.901620" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:29.901791" level="INFO">${response_text} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:29.721070" elapsed="0.180748"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.930501" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.930017" elapsed="0.000514"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.931381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.931095" elapsed="0.000406">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:29.931698" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:29.930747" elapsed="0.000978"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.932344" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:29.931897" elapsed="0.000474"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:29.932720" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_source_as_4/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:29.932878" level="INFO">${template} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:29.932538" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.933336" level="INFO">{
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
            "med": 0
          },
          "extended-communities": [
            {
              "transitive": true,
              "source-as-4-extended-community": {
                "global-administrator": 64496
              }
            }
          ],
          "ipv4-next-hop": {
            "global": "127.1.1.1"
          },
          "origin": {
            "value": "igp"
          },
          "local-pref": {
            "pref": 100
          }
        },
        "intra-as-i-pmsi-a-d": {
          "route-distinguisher": "1.2.3.4:258",
          "orig-route-ip": "10.10.10.10"
        }
      }
    ]
  }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:29.933067" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:29.933903" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.933460" elapsed="0.000505"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.934698" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:29.934141" elapsed="0.000590"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.933991" elapsed="0.000776"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.933439" elapsed="0.001350"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:29.935432" level="INFO">${final_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:29.934941" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.935512" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:29.929343" elapsed="0.006316"/>
</kw>
<msg time="2026-06-06T03:30:29.935722" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.916584" elapsed="0.019188"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.948550" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.961368" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_source_as_4/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.973964" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.974167" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.974347" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.974763" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.974584" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:29.974567" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.974989" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.975161" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.975330" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:29.974537" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.974430" elapsed="0.000981"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.975560" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:29.975636" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:29.975805" level="INFO">${expected_text} = {
  "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
      {
        "route-key": "AQwAAQECAwQBAgoKCgo=",
        "path-id": 0,
        "attributes": {
          "multi-exit-disc": {
          ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:29.913892" elapsed="0.061942"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:29.976021" elapsed="0.002212"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.979538" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.979029" elapsed="0.000538"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:29.980233" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
  "mvpn-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "source-as-4-extended-community": {
        "global-administrator": 6449...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:29.979753" elapsed="0.000543"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:29.980462" elapsed="0.000351"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:29.978560" elapsed="0.002317"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.978314" elapsed="0.002598"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:29.981092" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:29.980938" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.978295" elapsed="0.002875"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:29.903002" elapsed="0.078216"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:29.902142" elapsed="0.079166"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:29.901901" elapsed="0.079459"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:29.901883" elapsed="0.079502"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:29.981419" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:29.716690" elapsed="0.264858"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:29.712373" elapsed="0.269249"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:29.981822" elapsed="0.003453"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.043792" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:30.043386" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.044618" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.044340" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:30.044806" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:30.043998" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.045424" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:30.045031" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.045780" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:30.045943" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:30.045619" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.046398" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.046130" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.047510" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.047212" elapsed="0.000344"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.048022" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:30.047748" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.048912" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:30.048476" elapsed="0.000463"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:30.050170" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:30.049596" elapsed="0.000678"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:30.050354" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:30.050697" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:30.049133" elapsed="0.001597"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:30.050896" elapsed="0.000416"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:30.048335" elapsed="0.003022"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.052034" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:30.051610" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:30.053340" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:30.052729" elapsed="0.000717"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:30.053527" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:30.053836" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:30.052252" elapsed="0.001610"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:30.054021" elapsed="0.000366"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:30.051470" elapsed="0.002961"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:30.048158" elapsed="0.006308"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:30.054509" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:30.054939" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:30.046881" elapsed="0.008086"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.046518" elapsed="0.008483"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.055186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.055027" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.046496" elapsed="0.008769"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.056011" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:30.055414" elapsed="0.000625"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:30.056093" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:30.042762" elapsed="0.013456"/>
</kw>
<msg time="2026-06-06T03:30:30.056272" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:30.029737" elapsed="0.026583"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.068921" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.081316" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.094062" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.094284" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.094480" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.094904" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.094749" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:30.094729" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.095130" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.095302" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.095470" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:30.094689" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.094556" elapsed="0.000992"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.095723" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.095801" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:30.095920" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:30.025415" elapsed="0.070531"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.097209" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.096968" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:30.097371" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:30.096604" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.097740" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.097472" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.098307" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:30.098009" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.097824" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.097448" elapsed="0.000941"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.100794" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:30.098544" elapsed="0.002277"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:30.100873" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:30.101025" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:30.096275" elapsed="0.004776"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.102245" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:30.102060" elapsed="0.000274"/>
</kw>
<msg time="2026-06-06T03:30:30.102420" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:30.101714" elapsed="0.000730"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.102666" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:30.102515" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.102496" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.103065" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:30.103193" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:30.102899" elapsed="0.000319"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:30.103609" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:30.103378" elapsed="0.000257"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:30.103700" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:30.103854" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:30.101366" elapsed="0.002513"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.105282" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.105035" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.105917" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.105486" elapsed="0.000476"/>
</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-06-06T03:30:30.116788" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:30.118466" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '577'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:30.118926" 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-06-06T03:30:30.108137" elapsed="0.010898"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.106029" elapsed="0.013149"/>
</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-06-06T03:30:30.119792" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.119294" elapsed="0.000606"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.106011" elapsed="0.013930"/>
</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-06-06T03:30:30.125419" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv4:mvpn-routes-ipv4":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAQECAwQBAgoKCgo=","attributes":{"local-pref":{"pref":100},"ipv4-next-hop":{"global":"127.1.1.1"},"multi-exit-disc":{"med":0},"origin":{"value":"igp"},"extended-communities":[{"transitive":true,"source-as-4-extended-community":{"global-administrator":64496}}]},"intra-as-i-pmsi-a-d":{"route-distinguisher":"1.2.3.4:258","orig-route-ip":"10.10.10.10"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.121634" elapsed="0.003859"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.121284" elapsed="0.004260"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.121254" elapsed="0.004325"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.129677" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.126038" elapsed="0.003748"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.125683" elapsed="0.004169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.125634" elapsed="0.004266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.131069" 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-06-06T03:30:30.130252" elapsed="0.000872"/>
</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-06-06T03:30:30.131759" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.131247" elapsed="0.000576"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.132390" 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-06-06T03:30:30.132028" elapsed="0.000390"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.131849" elapsed="0.000607"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.131215" elapsed="0.001263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.133059" 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-06-06T03:30:30.132671" elapsed="0.000415"/>
</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-06-06T03:30:30.133421" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.133160" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.134002" 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-06-06T03:30:30.133697" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.133507" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.133140" elapsed="0.000948"/>
</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-06-06T03:30:30.134259" elapsed="0.000380"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:30.135162" 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-06-06T03:30:30.134857" elapsed="0.000332"/>
</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-06-06T03:30:30.135354" elapsed="0.002550"/>
</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-06-06T03:30:30.120566" elapsed="0.017412"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.138177" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:30.138053" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.138033" elapsed="0.000217"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:30.141817" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:30:30.138415" elapsed="0.003432"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:30.141914" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:30:30.142161" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:30.104196" elapsed="0.038003"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:30.142279" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:30.142440" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:30.002591" elapsed="0.139876"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.172105" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:30.171604" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.172980" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.172673" elapsed="0.000436">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:30.173338" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:30.172304" elapsed="0.001061"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.174010" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:30.173538" elapsed="0.000501"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:30.174372" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:30.174527" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:30.174208" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.175035" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:30.174759" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:30.175571" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.175153" elapsed="0.000479"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.176348" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:30.175834" elapsed="0.000542"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:30.175675" elapsed="0.000737"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:30.175133" elapsed="0.001301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.177092" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:30.176585" elapsed="0.000537"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:30.177173" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:30.170982" elapsed="0.006318"/>
</kw>
<msg time="2026-06-06T03:30:30.177355" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:30.158062" elapsed="0.019343"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.190179" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.202873" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.215704" elapsed="0.000045"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.216041" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.216238" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.216691" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.216518" elapsed="0.000232"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:30.216499" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.216927" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.217103" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.217276" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:30.216459" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.216330" elapsed="0.001030"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.217514" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.217594" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:30.217758" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:30.155352" elapsed="0.062436"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:30.217978" elapsed="0.002340"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:30.221435" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:30.221122" elapsed="0.000341"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:30.222297" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:30.221622" elapsed="0.000704"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:30.222857" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
    "mvpn-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "source-as-4-extended-community": {
          "global-administrator": 64496
         },
         "transitive": true
        }
       ],
       "ipv4-next-hop": {
        "global": "127.1.1.1"
       },
       "local-pref": {
        "pref": 100
       },
       "multi-exit-disc": {
        "med": 0
       },
       "origin": {
        "value": "igp"
       }
      },
      "intra-as-i-pmsi-a-d": {
       "orig-route-ip": "10.10.10.10",
       "route-distinguisher": "1.2.3.4:258"
      },
      "path-id": 0,
      "route-key": "AQwAAQECAwQBAgoKCgo="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:30.223091" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "127.1.1.1"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.222489" elapsed="0.000683">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.220680" elapsed="0.002694">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:30.220399" elapsed="0.003070">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:30.223682" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:30.223506" elapsed="0.000234"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:30.220380" elapsed="0.003383">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.143812" elapsed="0.080102">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:30.142896" elapsed="0.081192">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:30.142556" elapsed="0.081638">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:30.142537" elapsed="0.081695">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:30.224308" elapsed="0.000018"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:29.996194" elapsed="0.228265">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,40 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv4:mvpn-routes-ipv4": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "source-as-4-extended-community": {
+          "global-administrator": 64496
+         },
+         "transitive": true
+        }
+       ],
+       "ipv4-next-hop": {
    [ Message content over the limit has been removed. ]
+       },
+       "multi-exit-disc": {
+        "med": 0
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "10.10.10.10",
+       "route-distinguisher": "1.2.3.4:258"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAQECAwQBAgoKCgo="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.275520" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:32.275098" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.276391" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.276132" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:32.276561" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.275772" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.277171" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:32.276776" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.277511" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:32.277694" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.277365" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.278133" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.277883" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.279298" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.278977" elapsed="0.000369"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.279854" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.279514" elapsed="0.000367"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.280690" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.280260" elapsed="0.000457"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:32.281962" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.281380" elapsed="0.000684"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:32.282148" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:30:32.282454" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:32.280915" elapsed="0.001564"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.282658" elapsed="0.000391"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:32.280119" elapsed="0.002971"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.283791" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.283345" elapsed="0.000473"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:32.285040" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.284471" elapsed="0.000671"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:32.285288" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:32.285587" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:32.284009" elapsed="0.001605"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.285792" elapsed="0.000555"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:32.283208" elapsed="0.003182"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:32.279938" elapsed="0.006488"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:32.286472" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:32.286634" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:32.278622" elapsed="0.008054"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.278258" elapsed="0.008452"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.286898" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.286739" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.278233" elapsed="0.008743"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.287785" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:32.287125" elapsed="0.000691"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:32.287867" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:32.274390" elapsed="0.013604"/>
</kw>
<msg time="2026-06-06T03:30:32.288051" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:32.261376" elapsed="0.026727"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.301010" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.313572" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.326072" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.326314" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.326507" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.326960" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.326801" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:32.326779" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.327196" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.327453" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.327626" elapsed="0.000042"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:32.326734" elapsed="0.000968"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.326595" elapsed="0.001136"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.327898" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.327978" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:32.328129" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:32.256875" elapsed="0.071282"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.329597" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.329309" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:32.329786" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.328899" elapsed="0.000913"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.330159" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.329886" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.330742" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:32.330428" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.330241" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.329866" elapsed="0.000959"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.333216" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:32.330982" elapsed="0.002260"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:32.333296" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:32.333454" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:32.328501" elapsed="0.004978"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.334714" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.334489" elapsed="0.000283"/>
</kw>
<msg time="2026-06-06T03:30:32.334856" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.334144" elapsed="0.000736"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.335090" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.334951" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.334932" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.335473" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:32.335657" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.335307" elapsed="0.000377"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:32.336107" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.335866" elapsed="0.000267"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:32.336234" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:32.336397" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:32.333809" elapsed="0.002613"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.337855" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.337587" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.339821" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.338058" elapsed="0.001812"/>
</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-06-06T03:30:32.348908" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:32.349055" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:32.349171" 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-06-06T03:30:32.342181" elapsed="0.007017"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.339941" elapsed="0.009303"/>
</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-06-06T03:30:32.349437" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.349272" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.339921" elapsed="0.009602"/>
</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-06-06T03:30:32.353243" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.350607" elapsed="0.002706"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.350375" elapsed="0.002989"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.350355" elapsed="0.003047"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.357303" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.353849" elapsed="0.003523"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.353486" elapsed="0.003938"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.353461" elapsed="0.004000"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.358338" 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-06-06T03:30:32.357748" elapsed="0.000630"/>
</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-06-06T03:30:32.358868" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.358483" elapsed="0.000471"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.359705" 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-06-06T03:30:32.359239" elapsed="0.000507"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.358990" elapsed="0.000848"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.358456" elapsed="0.001417"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.360814" 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-06-06T03:30:32.360260" elapsed="0.000581"/>
</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-06-06T03:30:32.361154" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.360913" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.361716" 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-06-06T03:30:32.361400" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.361235" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.360895" elapsed="0.000906"/>
</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-06-06T03:30:32.361959" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:32.362791" 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-06-06T03:30:32.362478" elapsed="0.000396"/>
</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-06-06T03:30:32.363039" elapsed="0.002327"/>
</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-06-06T03:30:32.349932" elapsed="0.015502"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.365618" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.365507" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.365487" elapsed="0.000218"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:32.368559" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:32.365858" elapsed="0.002731"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:32.368663" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:32.368835" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:32.336755" elapsed="0.032108"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:32.368929" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:32.369082" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:32.233761" elapsed="0.135347"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.398172" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:32.397669" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.399067" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.398760" elapsed="0.000434">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:32.399373" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.398383" elapsed="0.001016"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.400051" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:32.399570" elapsed="0.000510"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.400410" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:32.400602" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.400248" elapsed="0.000381"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.401085" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.400814" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:32.401665" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.401208" elapsed="0.000519"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.402412" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:32.401912" elapsed="0.000528"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.401754" elapsed="0.000781"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.401185" elapsed="0.001373"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.403230" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:32.402728" elapsed="0.000531"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:32.403311" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:32.397000" elapsed="0.006447"/>
</kw>
<msg time="2026-06-06T03:30:32.403502" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:32.384169" elapsed="0.019384"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.416296" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.428875" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.443018" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.443247" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.443437" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.443908" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.443718" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:32.443701" elapsed="0.000292"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.444142" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.444315" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.444487" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:32.443661" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.443526" elapsed="0.001041"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.444736" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.444816" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:32.444955" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:32.381413" elapsed="0.063640"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:32.445242" elapsed="0.002370"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:32.448753" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.448418" elapsed="0.000364"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:32.449214" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.448942" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:32.449404" elapsed="0.000352"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:32.447979" elapsed="0.001844"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.447709" elapsed="0.002148"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.450039" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.449882" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.447689" elapsed="0.002426"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:32.370293" elapsed="0.079971"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:32.369451" elapsed="0.080898"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.369193" elapsed="0.081203"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.369175" elapsed="0.081247"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:32.450457" elapsed="0.000032"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:32.229113" elapsed="0.221477"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:29.985748" elapsed="2.464926"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:32.450932" elapsed="0.002665"/>
</kw>
<arg>intra_source_as_4</arg>
<arg>${MVPN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:27.104576" elapsed="5.349106"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:27.011353" elapsed="5.442473"/>
</test>
<test id="s1-s16-t26" name="Play_To_Odl_intra_ipv6" line="158">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:32.457110" elapsed="0.000219"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:32.456841" elapsed="0.000543"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.458429" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.458307" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.458286" elapsed="0.000214"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.463886" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.463746" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.463727" elapsed="0.000229"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.464979" 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-06-06T03:30:32.464569" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.465468" 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-06-06T03:30:32.465173" elapsed="0.000378"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:32.465599" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:32.465779" 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-06-06T03:30:32.464188" elapsed="0.001616"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:32.471300" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.471191" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.471170" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:32.472744" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.472610" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.472591" elapsed="0.000221"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:32.473263" 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-06-06T03:30:32.472961" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:32.473690" level="INFO">${current_connection_index} = 7</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-06-06T03:30:32.473455" elapsed="0.000262"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:32.504843" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:32.474222" elapsed="0.030818"/>
</kw>
<msg time="2026-06-06T03:30:32.505256" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:32.505305" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:32.473883" elapsed="0.031457"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:32.531376" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "i "p "v "6 "[K"
[?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-06-06T03:30:32.506067" elapsed="0.025472"/>
</kw>
<msg time="2026-06-06T03:30:32.531753" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:32.531800" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</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-06-06T03:30:32.505578" elapsed="0.026259"/>
</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-06-06T03:30:32.532263" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.531962" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.531931" elapsed="0.000415"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.532858" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "i "n "t "r "a "_ "i "p "v "6 "[K"
[?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-06-06T03:30:32.532496" elapsed="0.000430"/>
</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-06-06T03:30:32.533219" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.532995" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.532976" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:32.533335" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:32.536068" elapsed="0.000358"/>
</kw>
<msg time="2026-06-06T03:30:32.536493" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:32.534921" elapsed="0.001708"/>
</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="NOT RUN" start="2026-06-06T03:30:32.536934" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.537277" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:32.534251" elapsed="0.003214"/>
</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-06-06T03:30:32.533678" elapsed="0.003851"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:32.472309" elapsed="0.065393"/>
</kw>
<msg time="2026-06-06T03:30:32.537804" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:32.537850" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:32.471525" elapsed="0.066362"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:32.538081" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:30:32.537968" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.537947" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.538604" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.538975" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.539047" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:32.470850" elapsed="0.068306"/>
</kw>
<msg time="2026-06-06T03:30:32.539251" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:32.539296" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "P "l "a "y "_ "T "o "_ "O "d...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:32.466182" elapsed="0.073149"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.539678" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.539407" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.539390" elapsed="0.000367"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:32.466035" elapsed="0.073746"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:32.465861" elapsed="0.073952"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:32.463369" elapsed="0.076541"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:32.458011" elapsed="0.081960"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:32.457542" elapsed="0.082475"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:32.454622" elapsed="0.085449"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.541244" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.540758" elapsed="0.000515"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.541908" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.541445" elapsed="0.000491"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.542482" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.542104" elapsed="0.000405"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.542899" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/announce_intra_ipv6.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/announce_intra_ipv6.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:32.543076" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004b02000000344001010040020040050400000064800e230002051020010db800010000000000000000000600010c0001ac10002c0065c0a86401
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.542689" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.543450" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/withdraw_intra_ipv6.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/withdraw_intra_ipv6.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:32.543612" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003902000000224001010040020040050400000064800f11000205010c0001ac10002c0065c0a86401</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.543261" elapsed="0.000376"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:32.543849" elapsed="0.002262"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:32.546272" elapsed="0.001928"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.601965" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:32.601526" elapsed="0.000474"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.602874" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.602543" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:32.603049" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.602190" elapsed="0.000884"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.603655" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:32.603248" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.604023" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:32.604197" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:32.603860" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.604656" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.604390" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.605812" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.605466" elapsed="0.000393"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.606297" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.606027" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.607134" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.606726" elapsed="0.000438"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:32.608634" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.608004" elapsed="0.000778"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:32.608887" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:30:32.609227" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:32.607398" elapsed="0.001856"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.609420" elapsed="0.000414"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:32.606555" elapsed="0.003322"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.610543" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:32.610133" elapsed="0.000439"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:32.611821" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.611246" elapsed="0.000699"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:32.612026" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:32.612335" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:32.610785" elapsed="0.001577"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:32.612519" elapsed="0.000391"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:32.609995" elapsed="0.003014"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:32.606377" elapsed="0.006669"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:32.613092" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:32.613252" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:32.605133" elapsed="0.008145"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.604786" elapsed="0.008524"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.613496" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.613337" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.604762" elapsed="0.008810"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.614559" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:32.613737" elapsed="0.000851"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:32.614654" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:32.600827" elapsed="0.013954"/>
</kw>
<msg time="2026-06-06T03:30:32.614838" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:32.587471" elapsed="0.027419"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.627636" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.640392" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.652935" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.653171" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.653363" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.653801" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.653628" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:32.653610" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.654030" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.654203" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.654375" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:32.653569" elapsed="0.000934"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.653449" elapsed="0.001085"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.654708" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.654789" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:32.654940" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:32.583031" elapsed="0.071938"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.656445" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.656128" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:32.656618" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.655693" elapsed="0.000965"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.657010" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.656734" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.657580" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:32.657284" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.657095" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.656714" elapsed="0.000969"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.660105" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:32.657843" elapsed="0.002288"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:32.660185" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:32.660347" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:32.655317" elapsed="0.005055"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:32.661759" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.661393" elapsed="0.000434">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:32.661923" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:32.661048" elapsed="0.000899"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:32.662160" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:32.662021" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:32.662001" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.662396" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.662573" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.662637" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:32.664853" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:32.660707" elapsed="0.004172"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.666321" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.666058" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:32.666795" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:32.666528" elapsed="0.000372"/>
</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-06-06T03:30:32.675812" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:32.675979" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:32.676094" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</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="FAIL" start="2026-06-06T03:30:32.669095" elapsed="0.007441">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:32.666969" elapsed="0.009657">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</status>
</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-06-06T03:30:32.676859" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.676681" elapsed="0.000255"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:32.666950" elapsed="0.010011">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:32.677374" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.677515" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:32.677474" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:32.677455" elapsed="0.000125"/>
</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-06-06T03:30:32.677745" elapsed="0.000027"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.677824" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:32.665209" elapsed="0.012723">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.678010" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.559952" elapsed="0.118155">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:32.678387" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:32.678202" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:32.678185" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:32.678517" elapsed="0.000014"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:32.554803" elapsed="0.123811">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.736988" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:34.736492" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.737838" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:34.737563" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:34.738008" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:34.737208" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.738593" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:34.738205" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.738952" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:34.739116" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:34.738805" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.739554" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.739306" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.740752" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.740404" elapsed="0.000394"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.741253" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.740980" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.742086" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:34.741670" elapsed="0.000442"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:34.743353" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.742783" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:34.743538" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:34.743863" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:34.742305" elapsed="0.001585"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.744052" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:34.741512" elapsed="0.002969"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.745214" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:34.744752" elapsed="0.000488"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:34.746605" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.746052" elapsed="0.000678"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:34.746811" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:34.747112" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:34.745527" elapsed="0.001611"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.747299" elapsed="0.000387"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:34.744598" elapsed="0.003132"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:34.741335" elapsed="0.006431"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:34.747876" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:34.748038" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:34.740069" elapsed="0.007995"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.739701" elapsed="0.008396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.748285" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.748126" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.739674" elapsed="0.008687"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.749425" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:34.748510" elapsed="0.000945"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:34.749506" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:34.735756" elapsed="0.013877"/>
</kw>
<msg time="2026-06-06T03:30:34.749731" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:34.722867" elapsed="0.026919"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.762567" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.775325" elapsed="0.000057"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.788166" elapsed="0.000055"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.788468" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.788675" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.789134" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.788976" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:34.788957" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.789366" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.789540" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.789730" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:34.788901" elapsed="0.000884"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:34.788763" elapsed="0.001048"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.790048" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:34.790130" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:34.790292" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:34.718365" elapsed="0.071957"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.791796" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:34.791490" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:34.791967" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:34.791079" elapsed="0.000914"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.792340" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.792066" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.792963" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:34.792612" elapsed="0.000379"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.792424" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.792047" elapsed="0.001002"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.795449" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:34.793208" elapsed="0.002268"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:34.795532" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:34.795713" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:34.790713" elapsed="0.005026"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.797098" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:34.796798" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:34.797266" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:34.796425" elapsed="0.000865"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:34.797510" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:34.797365" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.797345" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.797775" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.797956" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:34.798023" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:34.800210" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:34.796078" elapsed="0.004161"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.801810" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.801513" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.802266" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.802021" elapsed="0.000290"/>
</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-06-06T03:30:34.812343" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:34.812756" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '305'} 
 body={"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}} 
 </msg>
<msg time="2026-06-06T03:30:34.812947" 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-06-06T03:30:34.804601" elapsed="0.008389"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.802384" elapsed="0.010688"/>
</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-06-06T03:30:34.813426" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.813122" elapsed="0.000402"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.802362" elapsed="0.011195"/>
</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-06-06T03:30:34.819056" level="INFO">{"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.815237" elapsed="0.003904"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.814872" elapsed="0.004327"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.814843" elapsed="0.004397"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.822831" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.819721" elapsed="0.003165"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.819333" elapsed="0.003594"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.819305" elapsed="0.003650"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.823615" 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-06-06T03:30:34.823183" elapsed="0.000479"/>
</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-06-06T03:30:34.823998" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.823742" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.824555" 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-06-06T03:30:34.824250" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.824081" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.823721" elapsed="0.000938"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.825218" 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-06-06T03:30:34.824831" elapsed="0.000413"/>
</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-06-06T03:30:34.825556" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.825315" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.826122" 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-06-06T03:30:34.825824" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.825638" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.825297" elapsed="0.000907"/>
</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-06-06T03:30:34.826374" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:34.827216" 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-06-06T03:30:34.826918" elapsed="0.000325"/>
</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-06-06T03:30:34.827406" elapsed="0.002617"/>
</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-06-06T03:30:34.814171" elapsed="0.015926"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:34.830363" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:34.830247" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.830224" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:34.833468" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<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="PASS" start="2026-06-06T03:30:34.830596" elapsed="0.002903"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:34.833555" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:34.833748" level="INFO">${response_text} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:34.800593" elapsed="0.033181"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:34.833841" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:34.833997" level="INFO">${response_text} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:34.694284" elapsed="0.139740"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.863239" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:34.862694" elapsed="0.000579"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.864162" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:34.863855" elapsed="0.000434">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:34.864468" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:34.863462" elapsed="0.001031"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.865176" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:34.864689" elapsed="0.000515"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.865540" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:34.865736" level="INFO">${template} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:34.865372" elapsed="0.000392"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.866200" level="INFO">{
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d": {
                    "route-distinguisher": "172.16.0.44:101",
                    "orig-route-ip": "192.168.100.1"
                },
                "attributes": {
                    "ipv6-next-hop": {
                        "global": "2001:db8:1::6"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                      "pref": 100
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.865930" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:34.866824" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.866332" elapsed="0.000556"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.867579" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:34.867065" elapsed="0.000542"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.866914" elapsed="0.000744"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.866307" elapsed="0.001375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.868346" level="INFO">${final_text} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:34.867837" elapsed="0.000643"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:34.868538" elapsed="0.000038"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:34.861874" elapsed="0.006833"/>
</kw>
<msg time="2026-06-06T03:30:34.868767" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:34.848837" elapsed="0.019985"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.883478" elapsed="0.000065"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.896571" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.909153" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.909383" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.909579" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.910022" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.909865" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:34.909846" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.910259" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.910434" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.910605" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:34.909805" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:34.909682" elapsed="0.001021"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.910856" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:34.910936" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:34.911101" level="INFO">${expected_text} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:34.845979" elapsed="0.065151"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:34.911389" elapsed="0.002339"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:34.914942" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:34.914502" elapsed="0.000469"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:34.915508" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:34.915132" elapsed="0.000405"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:34.915717" elapsed="0.000339"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:34.914063" elapsed="0.002056"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.913812" elapsed="0.002344"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.916337" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.916181" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.913791" elapsed="0.002625"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:34.835246" elapsed="0.081219"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:34.834393" elapsed="0.082150"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.834111" elapsed="0.082481"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.834093" elapsed="0.082523"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:34.916666" elapsed="0.000034"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:34.687497" elapsed="0.229304"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:32.548393" elapsed="2.368470"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.966772" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:34.966376" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.967558" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:34.967313" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:34.967744" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:34.966972" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.968330" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:34.967940" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:34.968677" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:34.968835" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:34.968525" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.969285" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.969038" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.970413" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:34.970100" elapsed="0.000359"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.970923" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.970626" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.971737" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:34.971309" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:34.973013" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.972418" elapsed="0.000701"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:34.973199" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:34.973493" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:34.971958" elapsed="0.001562"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.973696" elapsed="0.000389"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:34.971171" elapsed="0.002958"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.974809" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:34.974384" elapsed="0.000452"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:34.976058" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.975489" elapsed="0.000670"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:34.976238" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:34.976554" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:34.975028" elapsed="0.001552"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:34.976755" elapsed="0.000386"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:34.974245" elapsed="0.002938"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:34.970998" elapsed="0.006221"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:34.977262" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:34.977423" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:34.969763" elapsed="0.007686"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:34.969444" elapsed="0.008038"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.977677" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:34.977507" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:34.969423" elapsed="0.008334"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:34.978689" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:34.977905" elapsed="0.000815"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:34.978770" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:34.965752" elapsed="0.013145"/>
</kw>
<msg time="2026-06-06T03:30:34.978953" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:34.952872" elapsed="0.026129"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:34.992617" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.005403" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.017947" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.018148" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.018329" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.018716" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.018551" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:35.018536" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.018944" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.019119" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.019289" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:35.018506" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.018405" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.019520" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.019597" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:35.019734" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:34.948564" elapsed="0.071198"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.021081" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.020825" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.021242" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.020459" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.021587" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.021338" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.022162" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.021869" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.021686" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.021319" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.024599" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.022401" elapsed="0.002225"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:35.024725" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:35.024886" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:35.020097" elapsed="0.004815"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.026180" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.025945" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.026338" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.025581" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:35.026570" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:35.026435" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.026416" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.026823" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.027000" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.027067" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:35.029194" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:35.025249" elapsed="0.003973"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.030656" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.030388" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.031113" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.030867" elapsed="0.000291"/>
</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-06-06T03:30:35.039272" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:35.039408" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '305'} 
 body={"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}} 
 </msg>
<msg time="2026-06-06T03:30:35.039518" 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-06-06T03:30:35.033342" elapsed="0.006204"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.031227" elapsed="0.008363"/>
</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-06-06T03:30:35.039798" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.039617" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.031208" elapsed="0.008683"/>
</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-06-06T03:30:35.044161" level="INFO">{"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.040921" elapsed="0.003313"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.040689" elapsed="0.003597"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.040669" elapsed="0.003655"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.048230" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.044768" elapsed="0.003530"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.044408" elapsed="0.003941"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.044382" elapsed="0.004004"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.049253" 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-06-06T03:30:35.048637" elapsed="0.000704"/>
</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-06-06T03:30:35.049839" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.049451" elapsed="0.000447"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.050400" 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-06-06T03:30:35.050093" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.049923" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.049423" elapsed="0.001063"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.051039" 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-06-06T03:30:35.050670" elapsed="0.000396"/>
</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-06-06T03:30:35.051380" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.051138" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.051944" 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-06-06T03:30:35.051630" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.051462" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.051119" 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-06-06T03:30:35.052183" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:35.053001" 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-06-06T03:30:35.052719" elapsed="0.000321"/>
</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-06-06T03:30:35.053203" elapsed="0.002294"/>
</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-06-06T03:30:35.040251" elapsed="0.015309"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.055754" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:35.055631" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.055612" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.058744" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<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="PASS" start="2026-06-06T03:30:35.055974" elapsed="0.002800"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:35.058827" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:35.058991" level="INFO">${response_text} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:35.029534" elapsed="0.029485"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.059083" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:35.059234" level="INFO">${response_text} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:34.925820" elapsed="0.133441"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.087998" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.087517" elapsed="0.000511"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.088830" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.088544" elapsed="0.000443">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.089189" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.088197" elapsed="0.001018"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.089860" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.089387" elapsed="0.000502"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.090216" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:35.090354" level="INFO">${template} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.090058" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.090833" level="INFO">{
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d": {
                    "route-distinguisher": "172.16.0.44:101",
                    "orig-route-ip": "192.168.100.1"
                },
                "attributes": {
                    "ipv6-next-hop": {
                        "global": "2001:db8:1::6"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                      "pref": 100
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.090544" elapsed="0.000339"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:35.091354" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.090953" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.092113" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.091593" elapsed="0.000547"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.091441" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.090933" elapsed="0.001266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.092851" level="INFO">${final_text} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:35.092351" elapsed="0.000530"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.092931" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:35.086775" elapsed="0.006308"/>
</kw>
<msg time="2026-06-06T03:30:35.093141" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.074079" elapsed="0.019111"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.105721" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.118220" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.130852" elapsed="0.000057"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.131086" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.131272" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.131660" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.131498" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:35.131483" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.131913" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.132108" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.132279" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:35.131454" elapsed="0.000879"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.131350" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.132508" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.132584" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:35.132733" level="INFO">${expected_text} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:35.071402" elapsed="0.061359"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.132979" elapsed="0.002246"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.136377" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.135990" elapsed="0.000416"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.136953" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.136566" elapsed="0.000416"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:35.137154" elapsed="0.000326"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:35.135549" elapsed="0.001992"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.135306" elapsed="0.002270"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.137770" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.137601" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.135287" elapsed="0.002563"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:35.060403" elapsed="0.077500"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:35.059586" elapsed="0.078394"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.059344" elapsed="0.078717"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.059326" elapsed="0.078761"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.138122" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:34.921422" elapsed="0.216829"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:34.917071" elapsed="0.221239"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.187953" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.187561" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.188717" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.188486" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.188877" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.188150" elapsed="0.000751"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.189486" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.189069" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.189833" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:35.189971" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.189696" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.190402" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.190160" elapsed="0.000288"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.191441" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.191157" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.191941" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.191672" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.192740" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.192321" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:35.193992" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.193431" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:35.194182" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:35.194473" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:35.192961" elapsed="0.001538"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.194670" elapsed="0.000369"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:35.192183" elapsed="0.002898"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.195810" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.195389" elapsed="0.000447"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:35.197042" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.196482" elapsed="0.000682"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:35.197242" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:35.197567" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:35.196028" elapsed="0.001565"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.197776" elapsed="0.000363"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:35.195252" elapsed="0.002929"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:35.192015" elapsed="0.006201"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:35.198257" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:35.198413" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:35.190828" elapsed="0.007610"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.190515" elapsed="0.007955"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.198688" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.198495" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.190496" elapsed="0.008271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.199629" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:35.198913" elapsed="0.000762"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.199726" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:35.186945" elapsed="0.012905"/>
</kw>
<msg time="2026-06-06T03:30:35.199904" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.174251" elapsed="0.025701"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.212484" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.224880" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.237334" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.237535" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.237730" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.238104" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.237955" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:35.237940" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.238329" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.238503" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.238724" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:35.237911" elapsed="0.000870"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.237807" elapsed="0.000999"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.238962" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.239039" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:35.239158" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:35.169832" elapsed="0.069353"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.240443" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.240209" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.240601" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.239860" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.240967" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.240714" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.241531" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.241237" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.241051" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.240694" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.243976" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.241785" elapsed="0.002218"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:35.244055" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:35.244208" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:35.239511" elapsed="0.004723"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.245487" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.245254" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.245659" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.244883" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:35.245894" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:35.245758" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.245739" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.246130" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.246304" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.246370" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:35.248453" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:35.244538" elapsed="0.003942"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.249956" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.249704" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.250449" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.250203" elapsed="0.000291"/>
</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-06-06T03:30:35.258158" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:35.258272" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family/bgp-mvpn-ipv6:mvpn-routes-ipv6 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '305'} 
 body={"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}} 
 </msg>
<msg time="2026-06-06T03:30:35.258380" 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-06-06T03:30:35.252634" elapsed="0.005773"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.250561" elapsed="0.007890"/>
</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-06-06T03:30:35.258637" elapsed="0.000044"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.258479" elapsed="0.000247"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.250543" elapsed="0.008204"/>
</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-06-06T03:30:35.262385" level="INFO">{"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.259778" elapsed="0.002677"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.259534" elapsed="0.002969"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.259516" elapsed="0.003023"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.266184" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.262964" elapsed="0.003284"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.262619" elapsed="0.003679"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.262595" elapsed="0.003737"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.267115" 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-06-06T03:30:35.266567" elapsed="0.000586"/>
</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-06-06T03:30:35.267593" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.267252" elapsed="0.000445"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.268391" 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-06-06T03:30:35.267969" elapsed="0.000460"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.267733" elapsed="0.000746"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.267226" elapsed="0.001282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.269284" 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-06-06T03:30:35.268758" elapsed="0.000565"/>
</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-06-06T03:30:35.269780" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.269422" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.270544" 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-06-06T03:30:35.270131" elapsed="0.000450"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.269896" elapsed="0.000734"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.269396" elapsed="0.001284"/>
</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-06-06T03:30:35.270897" elapsed="0.000484"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:35.272025" 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-06-06T03:30:35.271620" elapsed="0.000441"/>
</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-06-06T03:30:35.272344" elapsed="0.002843"/>
</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-06-06T03:30:35.259110" elapsed="0.016142"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.275430" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:35.275324" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.275304" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.278426" level="INFO">${text_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<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="PASS" start="2026-06-06T03:30:35.275665" elapsed="0.002790"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:35.278509" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:35.278684" level="INFO">${response_text} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:35.248804" elapsed="0.029909"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.278777" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:35.278929" level="INFO">${response_text} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:35.147178" elapsed="0.131778"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.307712" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.307243" elapsed="0.000498"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.308508" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.308252" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.308815" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.307912" elapsed="0.000929"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.309477" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.309019" elapsed="0.000485"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.309846" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/intra_ipv6/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:35.309982" level="INFO">${template} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.309687" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.310439" level="INFO">{
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d": {
                    "route-distinguisher": "172.16.0.44:101",
                    "orig-route-ip": "192.168.100.1"
                },
                "attributes": {
                    "ipv6-next-hop": {
                        "global": "2001:db8:1::6"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                      "pref": 100
                    }
                }
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.310171" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:35.310970" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.310558" elapsed="0.000473"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.311722" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.311206" elapsed="0.000574"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.311056" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.310538" elapsed="0.001303"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.312488" level="INFO">${final_text} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:35.312000" elapsed="0.000518"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.312569" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:35.306603" elapsed="0.006115"/>
</kw>
<msg time="2026-06-06T03:30:35.312777" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.293670" elapsed="0.019156"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.325369" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.337851" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/intra_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.350539" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.350752" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.350939" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.351306" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.351158" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:35.351143" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.351531" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.351719" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.351891" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:35.351115" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.351015" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.352121" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.352197" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:35.352331" level="INFO">${expected_text} = {
    "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
        "mvpn-route": [
            {
                "route-key": "AQwAAawQACwAZcCoZAE=",
                "path-id": 0,
                "intra-as-i-pmsi-a-d"...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:35.290972" elapsed="0.061418"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.352576" elapsed="0.002242"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.355961" level="INFO">${expected_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.355560" elapsed="0.000430"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.356521" level="INFO">${actual_normalized} = {
 "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
  "mvpn-route": [
   {
    "attributes": {
     "ipv6-next-hop": {
      "global": "2001:db8:1::6"
     },
     "local-pref": {
      "pref": 100
     },
     "o...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.356151" elapsed="0.000399"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:35.356725" elapsed="0.000324"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:35.355144" elapsed="0.001967"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.354903" elapsed="0.002242"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.357341" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.357188" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.354884" elapsed="0.002535"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:35.280097" elapsed="0.077369"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:35.279282" elapsed="0.078260"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.279040" elapsed="0.078547"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.279023" elapsed="0.078589"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.357665" elapsed="0.000030"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:35.142803" elapsed="0.214992"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:35.138488" elapsed="0.219369"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:35.358029" elapsed="0.002732"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.414254" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.413875" elapsed="0.000407"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.415046" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.414805" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.415206" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.414451" elapsed="0.000779"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.415799" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.415396" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.416181" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:35.416314" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.416043" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.416764" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.416501" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.417835" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.417533" elapsed="0.000347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.418310" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.418045" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.419123" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.418710" elapsed="0.000439"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:35.420379" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.419820" elapsed="0.000660"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:35.420559" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:35.420869" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:35.419339" elapsed="0.001556"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.421053" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:35.418552" elapsed="0.002931"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.422145" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.421747" elapsed="0.000425"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:35.423381" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.422829" elapsed="0.000653"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:35.423561" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:35.423872" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:35.422361" elapsed="0.001537"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:35.424056" elapsed="0.000365"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:35.421596" elapsed="0.002866"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:35.418385" elapsed="0.006111"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:35.424539" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:35.424712" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:35.417181" elapsed="0.007557"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.416884" elapsed="0.007887"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.424947" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.424796" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.416861" elapsed="0.008163"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.426795" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:35.425171" elapsed="0.001654"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.426881" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:35.413234" elapsed="0.013774"/>
</kw>
<msg time="2026-06-06T03:30:35.427063" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.400254" elapsed="0.026890"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.439817" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.452335" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.464823" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.465027" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.465220" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.465591" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.465441" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:35.465426" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.465837" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.466013" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.466186" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:35.465397" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.465297" elapsed="0.000968"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.466416" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.466493" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:35.466611" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:35.395828" elapsed="0.070810"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.467928" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.467677" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.468087" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.467312" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.468472" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.468185" elapsed="0.000346"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.469049" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.468748" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.468556" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.468166" elapsed="0.000969"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.471532" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.469319" elapsed="0.002241"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:35.471613" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:35.471785" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:35.466978" elapsed="0.004833"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.473004" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.472813" elapsed="0.000245"/>
</kw>
<msg time="2026-06-06T03:30:35.473144" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.472452" elapsed="0.000717"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.473394" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:35.473254" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.473235" elapsed="0.000228"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.473795" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:35.473930" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.473612" elapsed="0.000343"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:35.474346" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.474115" elapsed="0.000257"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:35.474419" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:35.474573" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:35.472119" elapsed="0.002479"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.476002" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.475751" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.476449" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.476207" elapsed="0.000287"/>
</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-06-06T03:30:35.485096" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:35.485522" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '450'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:35.485632" 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-06-06T03:30:35.478883" elapsed="0.006796"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.476560" elapsed="0.009163"/>
</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-06-06T03:30:35.485936" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.485750" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.476541" elapsed="0.009566"/>
</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-06-06T03:30:35.490984" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-mvpn-ipv6:mvpn-routes-ipv6":{"mvpn-route":[{"path-id":0,"route-key":"AQwAAawQACwAZcCoZAE=","intra-as-i-pmsi-a-d":{"orig-route-ip":"192.168.100.1","route-distinguisher":"172.16.0.44:101"},"attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv6-next-hop":{"global":"2001:db8:1::6"}}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.487548" elapsed="0.003506"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.487230" elapsed="0.003873"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.487204" elapsed="0.003935"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.494798" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.491539" elapsed="0.003324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.491219" elapsed="0.003692"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.491195" elapsed="0.003752"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.495727" 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-06-06T03:30:35.495184" elapsed="0.000582"/>
</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-06-06T03:30:35.496205" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.495865" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.496996" 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-06-06T03:30:35.496554" elapsed="0.000481"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.496321" elapsed="0.000764"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.495839" elapsed="0.001276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.497902" 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-06-06T03:30:35.497386" elapsed="0.000543"/>
</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-06-06T03:30:35.498241" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.498000" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.498807" 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-06-06T03:30:35.498492" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.498324" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.497982" elapsed="0.000914"/>
</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-06-06T03:30:35.499052" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:35.499863" 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-06-06T03:30:35.499570" elapsed="0.000320"/>
</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-06-06T03:30:35.500050" elapsed="0.002317"/>
</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-06-06T03:30:35.486610" elapsed="0.015820"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.502607" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:35.502502" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.502483" elapsed="0.000210"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.505677" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<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="PASS" start="2026-06-06T03:30:35.502844" elapsed="0.002864"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:35.505761" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:35.505919" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:35.474920" elapsed="0.031026"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.506010" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:35.506159" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:35.372768" elapsed="0.133461"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.535192" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.534735" elapsed="0.000486"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.536014" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.535754" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:35.536304" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:35.535390" elapsed="0.000940"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.536967" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:35.536502" elapsed="0.000494"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:35.537335" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:35.537473" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:35.537165" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.537950" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:35.537680" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:35.538461" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.538064" elapsed="0.000457"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.539219" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:35.538713" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:35.538547" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:35.538045" elapsed="0.001259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.539946" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:35.539455" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:35.540026" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:35.533935" elapsed="0.006216"/>
</kw>
<msg time="2026-06-06T03:30:35.540205" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.521146" elapsed="0.019108"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.552891" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.565566" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.578827" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.579036" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.579217" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.579595" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.579447" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:35.579431" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.579840" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.580014" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.580185" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:35.579401" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.579296" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.580415" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.580491" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:35.580612" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:35.518476" elapsed="0.062176"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:35.580838" elapsed="0.002269"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.584154" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.583871" elapsed="0.000311"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:35.584908" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
    "mvpn-route": [
     {
      "attributes":...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:35.584339" elapsed="0.000598"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:35.585447" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
    "mvpn-route": [
     {
      "attributes": {
       "ipv6-next-hop": {
        "global": "2001:db8:1::6"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "intra-as-i-pmsi-a-d": {
       "orig-route-ip": "192.168.100.1",
       "route-distinguisher": "172.16.0.44:101"
      },
      "path-id": 0,
      "route-key": "AQwAAawQACwAZcCoZAE="
     }
    ]
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:35.585693" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.585096" elapsed="0.000670">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.583435" elapsed="0.002473">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:35.583188" elapsed="0.002799">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:35.586178" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:35.586021" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:35.583169" elapsed="0.003088">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.507486" elapsed="0.078892">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.506558" elapsed="0.079963">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:35.506316" elapsed="0.080293">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:35.506299" elapsed="0.080360">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:35.586744" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:35.366687" elapsed="0.220180">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,29 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-mvpn-ipv6:mvpn-routes-ipv6": {
+    "mvpn-route": [
+     {
+      "attributes": {
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::6"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "intra-as-i-pmsi-a-d": {
+       "orig-route-ip": "192.168.100.1",
+       "route-distinguisher": "172.16.0.44:101"
+      },
+      "path-id": 0,
+      "route-key": "AQwAAawQACwAZcCoZAE="
+     }
+    ]
+   },
    "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.648325" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:37.647921" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.649158" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:37.648903" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:37.649331" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:37.648540" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.649936" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:37.649528" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.650288" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:37.650452" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:37.650132" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.650907" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.650655" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.652011" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.651693" elapsed="0.000366"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.652495" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:37.652224" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.653324" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:37.652920" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:37.654606" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:37.654026" elapsed="0.000699"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:37.654807" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:37.655105" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:37.653541" elapsed="0.001591"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:37.655294" elapsed="0.000397"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:37.652779" elapsed="0.002954"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.656390" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:37.655987" elapsed="0.000430"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:37.657614" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:37.657076" elapsed="0.000674"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:37.657831" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:37.658195" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:37.656605" elapsed="0.001617"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:37.658384" elapsed="0.000386"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:37.655849" elapsed="0.002962"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:37.652576" elapsed="0.006271"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:37.658891" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:37.659050" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:37.651347" elapsed="0.007729"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.651032" elapsed="0.008076"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.659286" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.659133" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.651008" elapsed="0.008355"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.660338" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:37.659511" elapsed="0.000857"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:37.660420" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:37.647276" elapsed="0.013269"/>
</kw>
<msg time="2026-06-06T03:30:37.660600" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:37.634440" elapsed="0.026224"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.673249" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.685680" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.698082" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.698307" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.698491" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.698880" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.698731" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:37.698715" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.699103" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.699276" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.699499" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:37.698685" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.698568" elapsed="0.001012"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.699746" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.699824" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:37.699946" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:37.629716" elapsed="0.070257"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.701262" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:37.701005" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:37.701426" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:37.700634" elapsed="0.000815"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.701790" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.701520" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.702382" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:37.702058" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.701874" elapsed="0.000570"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.701502" elapsed="0.000963"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.704828" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:37.702619" elapsed="0.002235"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:37.704906" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:37.705059" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:37.700302" elapsed="0.004781"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.706289" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:37.706073" elapsed="0.000270"/>
</kw>
<msg time="2026-06-06T03:30:37.706428" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:37.705732" elapsed="0.000719"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.706675" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:37.706522" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.706503" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.707056" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:37.707264" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:37.706891" elapsed="0.000399"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:37.707708" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:37.707451" elapsed="0.000283"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:37.707781" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:37.707933" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:37.705390" elapsed="0.002602"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.709400" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.709151" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.709904" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.709606" elapsed="0.000343"/>
</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-06-06T03:30:37.729880" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:37.730136" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-mvpn%3Amcast-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '146'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:37.730254" 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-06-06T03:30:37.712328" elapsed="0.017953"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.710017" elapsed="0.020310"/>
</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-06-06T03:30:37.730520" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.730354" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.709998" elapsed="0.020608"/>
</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-06-06T03:30:37.734315" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.731673" elapsed="0.002691"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.731429" elapsed="0.002970"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.731411" elapsed="0.003013"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.737055" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.734725" elapsed="0.002377"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.734481" elapsed="0.002660"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.734464" elapsed="0.002708"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.737777" 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-06-06T03:30:37.737355" elapsed="0.000450"/>
</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-06-06T03:30:37.738122" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.737876" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.738722" 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-06-06T03:30:37.738406" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.738234" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.737858" elapsed="0.000948"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.739337" 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-06-06T03:30:37.738976" elapsed="0.000388"/>
</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-06-06T03:30:37.739689" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.739435" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.740231" 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-06-06T03:30:37.739937" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.739771" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.739415" elapsed="0.000898"/>
</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-06-06T03:30:37.740470" elapsed="0.000374"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:37.741305" 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-06-06T03:30:37.741015" elapsed="0.000316"/>
</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-06-06T03:30:37.741550" elapsed="0.002380"/>
</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-06-06T03:30:37.730999" elapsed="0.012998"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.744179" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:37.744069" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.744050" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:37.747760" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:30:37.744400" elapsed="0.003390"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:37.747846" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:37.748017" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:37.708313" elapsed="0.039730"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:37.748108" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:37.748260" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:37.604080" elapsed="0.144207"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.777133" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:37.776632" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.778007" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:37.777709" elapsed="0.000425">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:37.778334" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:37.777336" elapsed="0.001024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.778995" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:37.778534" elapsed="0.000488"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:37.779352" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/empty_routes/ipv6/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:37.779510" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:37.779190" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.779994" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.779715" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:37.780520" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.780112" elapsed="0.000469"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.781278" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:37.780774" elapsed="0.000531"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.780606" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.780092" elapsed="0.001270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.782080" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:37.781564" elapsed="0.000545"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:37.782160" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:37.776010" elapsed="0.006302"/>
</kw>
<msg time="2026-06-06T03:30:37.782367" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:37.763272" elapsed="0.019144"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.794958" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.807389" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.820351" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.820570" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.820771" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.821175" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.821018" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:37.821002" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.821401" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.821574" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.821759" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:37.820971" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.820857" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.821990" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.822066" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:37.822188" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:37.760550" elapsed="0.061665"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:37.822473" elapsed="0.002260"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:37.825817" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:37.825494" elapsed="0.000351"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:37.826299" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:37.826003" elapsed="0.000324"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:37.826491" elapsed="0.000349"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:37.825071" elapsed="0.001830"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.824816" elapsed="0.002122"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.827123" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.826966" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.824796" elapsed="0.002404"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:37.749516" elapsed="0.077731"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:37.748628" elapsed="0.078703"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:37.748373" elapsed="0.079005"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.748355" elapsed="0.079047"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:37.827496" elapsed="0.000034"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:37.595295" elapsed="0.232339"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:35.360963" elapsed="2.466757"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:37.827946" elapsed="0.002823"/>
</kw>
<arg>intra_ipv6</arg>
<arg>${MVPN_DIR}</arg>
<arg>ipv6</arg>
<status status="PASS" start="2026-06-06T03:30:32.540331" elapsed="5.290507"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:32.454158" elapsed="5.376804"/>
</test>
<test id="s1-s16-t27" name="Kill_Talking_BGP_Speaker" line="162">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:37.834109" elapsed="0.000267"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:37.833842" elapsed="0.000590"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.835708" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:37.835525" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.835497" elapsed="0.000308"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.842977" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:37.842825" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.842799" elapsed="0.000275"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.844494" 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-06-06T03:30:37.843952" elapsed="0.000580"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.845202" 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-06-06T03:30:37.844786" elapsed="0.000452"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:37.845369" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:30:37.845594" 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-06-06T03:30:37.843398" elapsed="0.002230"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:37.851623" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:37.851511" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.851491" elapsed="0.000219"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:37.852937" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:37.852828" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.852809" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:37.853475" 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-06-06T03:30:37.853161" elapsed="0.000343"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:37.853924" level="INFO">${current_connection_index} = 7</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-06-06T03:30:37.853696" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:37.885437" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:37.854535" elapsed="0.031057"/>
</kw>
<msg time="2026-06-06T03:30:37.885818" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:37.885867" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:37.854122" elapsed="0.031781"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:37.935549" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:30:37.886567" elapsed="0.049132"/>
</kw>
<msg time="2026-06-06T03:30:37.935878" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:37.935925" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "K "i "l "l "_ "T "a "l "k "i...</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-06-06T03:30:37.886127" elapsed="0.049833"/>
</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-06-06T03:30:37.936339" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.936060" elapsed="0.000335"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.936030" elapsed="0.000392"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.936920" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:30:37.936574" elapsed="0.000421"/>
</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-06-06T03:30:37.937289" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.937065" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.937045" elapsed="0.000321"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:37.937404" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:37.940060" elapsed="0.000346"/>
</kw>
<msg time="2026-06-06T03:30:37.940470" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:37.939015" elapsed="0.001592"/>
</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="NOT RUN" start="2026-06-06T03:30:37.941006" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.941347" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:37.938342" elapsed="0.003190"/>
</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-06-06T03:30:37.937749" elapsed="0.003847"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:37.852492" elapsed="0.089279"/>
</kw>
<msg time="2026-06-06T03:30:37.941867" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:37.941912" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "K "i "l "l "_ "T "a "l "k "i...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:37.851871" elapsed="0.090076"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:37.942136" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:37.942026" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.942006" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.942686" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.943026" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:37.943097" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:37.851162" elapsed="0.092040"/>
</kw>
<msg time="2026-06-06T03:30:37.943296" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:37.943339" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "K "i "l "l "_ "T "a "l "k "i...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:37.846178" elapsed="0.097196"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.943734" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:37.943450" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.943433" elapsed="0.000379"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:37.845972" elapsed="0.097865"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:37.845728" elapsed="0.098141"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:37.842293" elapsed="0.101631"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:37.835117" elapsed="0.108863"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:37.834592" elapsed="0.109433"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:37.831674" elapsed="0.112403"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.945280" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:37.944966" elapsed="0.000341"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:37.945463" elapsed="0.000302"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:30:37.944697" elapsed="0.001140"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:30:37.965699" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:30:37.946350" elapsed="0.019482"/>
</kw>
<msg time="2026-06-06T03:30:37.965972" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:37.966016" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:37.946001" elapsed="0.020041"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:30:37.966875" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:30:37.979707" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:30:37.979952" level="INFO">${output_log} = 2026-06-06 03:29:18,667 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:29:18,667 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:30:37.966718" elapsed="0.013309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:37.981099" level="INFO">2026-06-06 03:29:18,667 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:29:18,669 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:29:18,674 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:29:18,674 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Length=61 (0x003d)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=32 (0x20)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x020601040001000102060104000100050206010400020005020641040000fbf0
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100050206010400020005020641040000fbf0'
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100050206010400020005020641040000fbf0
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:29:18,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:18,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:18,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:18,687 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:29:18,687 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:18,689 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:18,689 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:18,689 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:19,690 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.010s
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:20,692 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:20,692 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.011s
2026-06-06 03:29:20,693 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:20,693 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:20,693 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.012s
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.013s
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.014s
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:24,699 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.016s
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:24] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:24,903 INFO BGP-Thread-1 (job): ... idle for 0.203s
2026-06-06 03:29:24,903 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.218s
2026-06-06 03:29:24,903 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
2026-06-06 03:29:24,903 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:24,904 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:24,904 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:24,904 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:24] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:24] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:25,027 INFO BGP-Thread-1 (job): ... idle for 0.123s
2026-06-06 03:29:25,027 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.341s
2026-06-06 03:29:25,027 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:29:25,027 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:25,027 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0040' (64)
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:25,028 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:25,028 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:25,028 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.343s
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.344s
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.345s
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.346s
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:29,037 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.348s
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:30,837 INFO BGP-Thread-1 (job): ... idle for 0.798s
2026-06-06 03:29:30,837 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.146s
2026-06-06 03:29:30,837 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:29:30,837 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0
2026-06-06 03:29:30,837 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:30,838 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:30,838 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:30,838 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:30,965 INFO BGP-Thread-1 (job): ... idle for 0.127s
2026-06-06 03:29:30,966 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.272s
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0040' (64)
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:30,967 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:30,967 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:30,967 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:31] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:31,968 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:31,968 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.274s
2026-06-06 03:29:31,968 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0
2026-06-06 03:29:31,969 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:31,969 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:31,969 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:32,969 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.274s
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.275s
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:33,972 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:34,973 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:34,973 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.277s
2026-06-06 03:29:34,973 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
2026-06-06 03:29:34,974 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:34,974 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:34,974 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:35,975 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:35,975 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.278s
2026-06-06 03:29:35,976 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:35,976 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:35,976 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:36,831 INFO BGP-Thread-1 (job): ... idle for 0.855s
2026-06-06 03:29:36,831 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.132s
2026-06-06 03:29:36,831 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:36,832 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:36,832 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:36,832 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:36,832 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:36,832 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:36,963 INFO BGP-Thread-1 (job): ... idle for 0.131s
2026-06-06 03:29:36,963 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.263s
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:36,964 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:36,964 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:36,964 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:37,965 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:37,965 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 19.264s
2026-06-06 03:29:37,965 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:37,966 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:37,966 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:37,966 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:38,967 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:38,967 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.265s
2026-06-06 03:29:38,968 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:38,968 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:38,968 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:39,969 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:39,969 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.266s
2026-06-06 03:29:39,969 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:39,970 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:39,970 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:40] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 22.268s
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 23.269s
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:42,737 INFO BGP-Thread-1 (job): ... idle for 0.764s
2026-06-06 03:29:42,737 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.033s
2026-06-06 03:29:42,737 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:42,738 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:42,738 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:42,738 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:42,862 INFO BGP-Thread-1 (job): ... idle for 0.125s
2026-06-06 03:29:42,863 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.157s
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:42,863 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:42,863 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:42,864 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:43] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:43] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 25.158s
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:44,866 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:44,866 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.159s
2026-06-06 03:29:44,867 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:44,867 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:44,867 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 27.161s
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:45] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 28.162s
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.163s
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:48,644 INFO BGP-Thread-1 (job): ... idle for 0.772s
2026-06-06 03:29:48,644 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.935s
2026-06-06 03:29:48,644 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:48,645 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:48,645 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:48,645 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:48,645 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:48,645 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:48,645 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:48,776 INFO BGP-Thread-1 (job): ... idle for 0.131s
2026-06-06 03:29:48,776 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.066s
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:48,777 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:48,777 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:48,777 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:48,777 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:48,777 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:49] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:49] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:49,778 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:49,778 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 31.067s
2026-06-06 03:29:49,778 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002
2026-06-06 03:29:49,779 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:49,779 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:49,779 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 32.068s
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:51,781 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 33.069s
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:52,783 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 34.070s
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:53,785 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:53,785 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.071s
2026-06-06 03:29:53,786 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:53,786 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:53,786 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:54,678 INFO BGP-Thread-1 (job): ... idle for 0.892s
2026-06-06 03:29:54,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.963s
2026-06-06 03:29:54,678 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
2026-06-06 03:29:54,678 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002
2026-06-06 03:29:54,678 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:54,678 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:54,679 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:54,679 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:54,679 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:54,816 INFO BGP-Thread-1 (job): ... idle for 0.137s
2026-06-06 03:29:54,816 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 36.100s
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:54,817 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:54,817 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:54,817 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:55,819 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:55,819 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 37.101s
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:56,821 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 38.102s
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 39.103s
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:57,824 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:57] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.103s
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:59,825 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 41.104s
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:00,682 INFO BGP-Thread-1 (job): ... idle for 0.856s
2026-06-06 03:30:00,682 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 41.959s
2026-06-06 03:30:00,682 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:00,683 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:00,683 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:00,683 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:00,683 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:00,683 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:00,683 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:00,839 INFO BGP-Thread-1 (job): ... idle for 0.156s
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:00,843 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 42.115s
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:00,844 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:00,844 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:00,844 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:00,844 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:00,844 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:00,844 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:01,845 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:01,845 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 43.116s
2026-06-06 03:30:01,845 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:01,846 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:01,846 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.118s
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:02] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:03] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:03] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:03,848 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 45.119s
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:04,850 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:04,850 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 46.120s
2026-06-06 03:30:04,851 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:04,851 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:04,851 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:05,852 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 47.121s
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 48.122s
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:07,856 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.123s
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:08,708 INFO BGP-Thread-1 (job): ... idle for 0.851s
2026-06-06 03:30:08,709 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.974s
2026-06-06 03:30:08,709 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00570200000040400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:08,710 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:08,710 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:08,710 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:08,866 INFO BGP-Thread-1 (job): ... idle for 0.156s
2026-06-06 03:30:08,866 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 50.130s
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:08,867 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:08,867 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:08,867 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:09,868 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 51.132s
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00570200000040c01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:10,870 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 52.132s
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.133s
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:12] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:12,874 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:12,874 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 54.134s
2026-06-06 03:30:12,874 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:30:12,875 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:12,875 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:12,875 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 55.135s
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:13,877 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:14,783 INFO BGP-Thread-1 (job): ... idle for 0.906s
2026-06-06 03:30:14,783 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 56.041s
2026-06-06 03:30:14,783 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:30:14,783 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:14,783 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:14,784 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:14,784 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:14,784 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:14,927 INFO BGP-Thread-1 (job): ... idle for 0.142s
2026-06-06 03:30:14,927 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 56.184s
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:14,928 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:14,928 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:14,928 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:14,928 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:14,928 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:15] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:15] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:15,929 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 57.185s
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 58.186s
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:17,933 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:17,933 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 59.187s
2026-06-06 03:30:17,934 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:17,934 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:17,934 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 60.188s
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:18,936 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:18,936 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 61.189s
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:20,766 INFO BGP-Thread-1 (job): ... idle for 0.829s
2026-06-06 03:30:20,767 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.018s
2026-06-06 03:30:20,767 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:20,768 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:20,768 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:20,768 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:20,768 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:20,905 INFO BGP-Thread-1 (job): ... idle for 0.137s
2026-06-06 03:30:20,905 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.154s
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:20,906 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:20,906 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:20,906 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:20,906 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:21] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:21] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:21,907 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:21,907 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 63.155s
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 64.156s
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 65.157s
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:24,912 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:24,912 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 66.158s
2026-06-06 03:30:24,912 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:24,913 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:24,913 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:24,913 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.159s
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:26,734 INFO BGP-Thread-1 (job): ... idle for 0.820s
2026-06-06 03:30:26,735 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.979s
2026-06-06 03:30:26,735 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:26,736 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:26,736 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:26,736 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:26,872 INFO BGP-Thread-1 (job): ... idle for 0.136s
2026-06-06 03:30:26,872 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 68.115s
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:26,873 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:26,873 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:26,873 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:27,874 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:27,874 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 69.116s
2026-06-06 03:30:27,874 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:27,875 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:27,875 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:27,875 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:28,876 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:28,876 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 70.117s
2026-06-06 03:30:28,877 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:28,877 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:28,877 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.119s
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:29] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:30,879 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 72.119s
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 73.121s
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:32,883 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 74.122s
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b02000000344001010040020040050400000064800e230002051020010db800010000000000000000000600010c0001ac10002c0065c0a86401
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:33,885 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:33,885 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 75.123s
2026-06-06 03:30:33,886 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:33,886 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:33,886 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.124s
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:35] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:35,888 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 77.125s
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003902000000224001010040020040050400000064800f11000205010c0001ac10002c0065c0a86401
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:36,890 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:36,891 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 78.126s
2026-06-06 03:30:36,891 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:36,891 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:36,892 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 79.127s
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003902000000224001010040020040050400000064800f11000205010c0001ac10002c0065c0a86401
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:37.980434" elapsed="0.003046"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:30:37.966340" elapsed="0.017295"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:30:37.984176" elapsed="0.000078"/>
</return>
<status status="PASS" start="2026-06-06T03:30:37.983832" elapsed="0.000494"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:37.983782" elapsed="0.000603"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.984790" elapsed="0.000052"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:37.985184" elapsed="0.000047"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:30:37.944356" elapsed="0.041020"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:30:37.997787" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:30:38.028336" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:30:38.028579" level="INFO">${output_log} = 2026-06-06 03:29:18,667 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:29:18,667 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:30:37.997575" elapsed="0.031099"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.029737" level="INFO">2026-06-06 03:29:18,667 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:29:18,667 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:29:18,669 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:29:18,673 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:29:18,674 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:29:18,674 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:29:18,674 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Length=61 (0x003d)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=32 (0x20)
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x020601040001000102060104000100050206010400020005020641040000fbf0
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100050206010400020005020641040000fbf0'
2026-06-06 03:29:18,675 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100050206010400020005020641040000fbf0
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:29:18,678 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:29:18,678 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:18,678 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:18,678 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:18,687 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:29:18,687 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:18,687 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:18,688 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:18,689 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:18,689 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:18,689 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:18,689 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:19,690 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.010s
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:19,691 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:20,692 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:20,692 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.011s
2026-06-06 03:29:20,693 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:20,693 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:20,693 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.012s
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:21,694 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.013s
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:22,696 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.014s
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:23,698 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:24,699 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.016s
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:24,700 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:24] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:24,903 INFO BGP-Thread-1 (job): ... idle for 0.203s
2026-06-06 03:29:24,903 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.218s
2026-06-06 03:29:24,903 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
2026-06-06 03:29:24,903 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:24,904 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:24,904 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:24,904 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:24,904 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:24] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:24] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:25,027 INFO BGP-Thread-1 (job): ... idle for 0.123s
2026-06-06 03:29:25,027 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.341s
2026-06-06 03:29:25,027 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:29:25,027 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:25,027 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0040' (64)
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:25,028 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:25,028 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:25,028 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:25,028 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.343s
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:26,030 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.344s
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:27,032 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.345s
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:28,034 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:28] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.346s
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:29,036 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:29,037 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.348s
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:30,038 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:30,837 INFO BGP-Thread-1 (job): ... idle for 0.798s
2026-06-06 03:29:30,837 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.146s
2026-06-06 03:29:30,837 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:29:30,837 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0
2026-06-06 03:29:30,837 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:30,838 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:30,838 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:30,838 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:30,838 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:30,965 INFO BGP-Thread-1 (job): ... idle for 0.127s
2026-06-06 03:29:30,966 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.272s
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0040' (64)
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:30,966 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:30,967 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:30,967 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:30,967 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:30] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:31] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:31] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:31,968 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:31,968 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.274s
2026-06-06 03:29:31,968 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800e17000105047f01010100020c00010102030401020000fbf0
2026-06-06 03:29:31,969 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:31,969 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:31,969 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:32,969 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.274s
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:32,970 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.275s
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:33,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:33,972 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:34,973 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:34,973 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.277s
2026-06-06 03:29:34,973 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
2026-06-06 03:29:34,974 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:34,974 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:34,974 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:35,975 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:35,975 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.278s
2026-06-06 03:29:35,976 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:35,976 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:35,976 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:36,831 INFO BGP-Thread-1 (job): ... idle for 0.855s
2026-06-06 03:29:36,831 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.132s
2026-06-06 03:29:36,831 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00400200000029400101014002008004040000000040050400000064800f11000105020c00010102030401020000fbf0
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:36,831 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:36,832 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:36,832 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:36,832 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:36,832 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:36,832 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:36,963 INFO BGP-Thread-1 (job): ... idle for 0.131s
2026-06-06 03:29:36,963 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.263s
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:36,963 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:36,964 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:36,964 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:36,964 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:36] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:37] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:37,965 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:37,965 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 19.264s
2026-06-06 03:29:37,965 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f0101010003160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:37,966 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:37,966 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:37,966 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:38,967 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:38,967 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.265s
2026-06-06 03:29:38,968 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:38,968 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:38,968 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:39,969 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:39,969 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.266s
2026-06-06 03:29:39,969 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:39,970 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:39,970 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:40] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 22.268s
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:40,971 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 23.269s
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:41,973 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:42,737 INFO BGP-Thread-1 (job): ... idle for 0.764s
2026-06-06 03:29:42,737 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.033s
2026-06-06 03:29:42,737 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b00010503160001010203040102200a00000a200c00000c01000001
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:42,737 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:42,738 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:42,738 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:42,738 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:42,738 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:42,862 INFO BGP-Thread-1 (job): ... idle for 0.125s
2026-06-06 03:29:42,863 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.157s
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:42,863 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:42,863 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:42,863 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:42,864 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:42] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:43] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:43] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 25.158s
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000412020c00010102030401020000000101000001
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:43,865 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:44,866 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:44,866 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.159s
2026-06-06 03:29:44,867 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:44,867 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:44,867 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 27.161s
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:45,868 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:45] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 28.162s
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:46,870 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.163s
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:47,872 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:48,644 INFO BGP-Thread-1 (job): ... idle for 0.772s
2026-06-06 03:29:48,644 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.935s
2026-06-06 03:29:48,644 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050412020c00010102030401020000000101000001
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004c' (76)
2026-06-06 03:29:48,644 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:48,645 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:48,645 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:48,645 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:48,645 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:48,645 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:48,645 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:48,776 INFO BGP-Thread-1 (job): ... idle for 0.131s
2026-06-06 03:29:48,776 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 30.066s
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0046' (70)
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:48,776 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:48,777 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:48,777 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:48,777 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:48,777 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:48,777 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:49] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:49] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:49,778 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:49,778 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 31.067s
2026-06-06 03:29:49,778 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004c0200000035400101014002008004040000000040050400000064800e1d000105047f010101000512000101020304010220010000012002000002
2026-06-06 03:29:49,779 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:49,779 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:49,779 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 32.068s
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:50,780 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:51,781 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 33.069s
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:51,782 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:51] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:52,783 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 34.070s
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:52,784 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:53,785 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:53,785 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.071s
2026-06-06 03:29:53,786 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:53,786 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:53,786 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:54,678 INFO BGP-Thread-1 (job): ... idle for 0.892s
2026-06-06 03:29:54,678 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 35.963s
2026-06-06 03:29:54,678 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0046020000002f400101014002008004040000000040050400000064800f170001050512000101020304010220010000012002000002
2026-06-06 03:29:54,678 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002
2026-06-06 03:29:54,678 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:54,678 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:54,679 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:54,679 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:54,679 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:54,679 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:54,816 INFO BGP-Thread-1 (job): ... idle for 0.137s
2026-06-06 03:29:54,816 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 36.100s
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:29:54,817 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:29:54,817 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:54,817 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:54,817 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:54] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:55] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:29:55] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:55,819 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:55,819 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 37.101s
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100061600010102030401020000001020010000012002000002
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:55,821 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:56,821 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 38.102s
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:56,822 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 39.103s
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:57,823 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:57,824 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:29:57] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 40.103s
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:58,824 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:29:59,825 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 41.104s
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:29:59,826 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:00,682 INFO BGP-Thread-1 (job): ... idle for 0.856s
2026-06-06 03:30:00,682 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 41.959s
2026-06-06 03:30:00,682 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105061600010102030401020000001020010000012002000002
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0050' (80)
2026-06-06 03:30:00,682 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:00,683 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:00,683 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:00,683 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:00,683 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:00,683 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:00,683 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:00,839 INFO BGP-Thread-1 (job): ... idle for 0.156s
10.30.170.78 - - [06/Jun/2026 03:30:00] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:00,843 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 42.115s
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004a' (74)
2026-06-06 03:30:00,843 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:00,844 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:00,844 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:00,844 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:00,844 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:00,844 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:00,844 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:01,845 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:01,845 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 43.116s
2026-06-06 03:30:01,845 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:01,846 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:01,846 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 44.118s
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:02,847 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:02] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:03] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:03] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:03,848 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 45.119s
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00500200000039400101014002008004040000000040050400000064800e21000105047f01010100071600010102030401020000000a20010000012002000002
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:03,849 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:04,850 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:04,850 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 46.120s
2026-06-06 03:30:04,851 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:04,851 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:04,851 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:05,852 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 47.121s
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:05,853 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:05] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 48.122s
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:06,855 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:07,856 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.123s
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:07,857 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:08,708 INFO BGP-Thread-1 (job): ... idle for 0.851s
2026-06-06 03:30:08,709 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 49.974s
2026-06-06 03:30:08,709 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004a0200000033400101014002008004040000000040050400000064800f1b000105071600010102030401020000000a20010000012002000002
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00570200000040400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0057' (87)
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:08,709 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:08,710 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:08,710 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:08,710 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:08,866 INFO BGP-Thread-1 (job): ... idle for 0.156s
2026-06-06 03:30:08,866 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 50.130s
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01b0e0a0a0a0104e3800a0a140204e3c0
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:08,866 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:08,867 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:08,867 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:08,867 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:08,867 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:09] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:09] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:09,868 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 51.132s
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff00570200000040c01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0a
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:09,869 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:10,870 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 52.132s
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:10,871 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 53.133s
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:11,873 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:12] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:12,874 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:12,874 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 54.134s
2026-06-06 03:30:12,874 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:30:12,875 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:12,875 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:12,875 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 55.135s
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:13,876 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:13,877 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:14,783 INFO BGP-Thread-1 (job): ... idle for 0.906s
2026-06-06 03:30:14,783 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 56.041s
2026-06-06 03:30:14,783 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003ac01b0e0a0a0a0104e3800a0a140204e3c0400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0a
2026-06-06 03:30:14,783 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:14,783 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:14,784 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:14,784 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:14,784 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:14,784 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:14,927 INFO BGP-Thread-1 (job): ... idle for 0.142s
2026-06-06 03:30:14,927 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 56.184s
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:14,927 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:14,928 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:14,928 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:14,928 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:14,928 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:14,928 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:15] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:15] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:15,929 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 57.185s
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:15,930 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 58.186s
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:16,932 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:17,933 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:17,933 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 59.187s
2026-06-06 03:30:17,934 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:17,934 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:17,934 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:18] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 60.188s
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:18,935 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:18,936 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:18,936 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 61.189s
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:19,937 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:20,766 INFO BGP-Thread-1 (job): ... idle for 0.829s
2026-06-06 03:30:20,767 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.018s
2026-06-06 03:30:20,767 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac01008010b0a0000013130
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:20,767 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:20,768 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:20,768 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:20,768 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:20,768 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:20,905 INFO BGP-Thread-1 (job): ... idle for 0.137s
2026-06-06 03:30:20,905 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 62.154s
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:20,905 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:20,906 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:20,906 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:20,906 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:20,906 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:21] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:21] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:21,907 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:21,907 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 63.155s
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a400101014002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:21,908 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 64.156s
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:22,909 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 65.157s
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:23,911 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:24,912 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:24,912 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 66.158s
2026-06-06 03:30:24,912 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:24,913 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:24,913 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:24,913 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.159s
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:25,914 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:26,734 INFO BGP-Thread-1 (job): ... idle for 0.820s
2026-06-06 03:30:26,735 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 67.979s
2026-06-06 03:30:26,735 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101014002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac010080009004100000000
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0051' (81)
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:26,735 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:26,736 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:26,736 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:26,736 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:26,872 INFO BGP-Thread-1 (job): ... idle for 0.136s
2026-06-06 03:30:26,872 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 68.115s
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004b' (75)
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Mvpn True
2026-06-06 03:30:26,872 DEBUG BGP-Thread-1 (job): Skipping update decoding due to mvpn data expected
2026-06-06 03:30:26,873 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:26,873 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:26,873 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:27] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:27] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:27,874 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:27,874 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 69.116s
2026-06-06 03:30:27,874 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0051020000003a400101004002008004040000000040050400000064800e17000105047f01010100010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:27,875 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:27,875 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:27,875 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:28,876 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:28,876 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 70.117s
2026-06-06 03:30:28,877 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:28,877 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:28,877 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 71.119s
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:29,878 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:29] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:30,879 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 72.119s
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:30,880 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 73.121s
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:31,882 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:32] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:32] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:32,883 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 74.122s
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b0200000034400101004002008004040000000040050400000064800f11000105010c00010102030401020a0a0a0ac0100802d10000fbf00000
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004b02000000344001010040020040050400000064800e230002051020010db800010000000000000000000600010c0001ac10002c0065c0a86401
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:32,884 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:33,885 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:33,885 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 75.123s
2026-06-06 03:30:33,886 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:33,886 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:33,886 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 76.124s
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:34,887 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:35] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:35,888 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 77.125s
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003902000000224001010040020040050400000064800f11000205010c0001ac10002c0065c0a86401
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:35,889 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:36,890 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:36,891 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 78.126s
2026-06-06 03:30:36,891 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:36,891 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:36,892 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:37] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 79.127s
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003902000000224001010040020040050400000064800f11000205010c0001ac10002c0065c0a86401
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:37,893 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.029083" elapsed="0.002542"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:38.033077" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/mvpn_play.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/mvpn_play.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:30:38.032125" elapsed="0.001103"/>
</kw>
<arg>play.py.out</arg>
<arg>mvpn_play.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:37.997113" elapsed="0.036300"/>
</kw>
<doc>Abort the Python speaker</doc>
<status status="PASS" start="2026-06-06T03:30:37.831200" elapsed="0.202576"/>
</test>
<test id="s1-s16-t28" name="Delete_Bgp_Peer_Configuration" line="168">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:38.040588" elapsed="0.000255"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:38.040309" elapsed="0.000592"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.042020" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.041869" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.041843" elapsed="0.000255"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.047370" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.047263" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.047244" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.048559" 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-06-06T03:30:38.048159" elapsed="0.000434"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.049088" 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-06-06T03:30:38.048781" elapsed="0.000332"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:38.049159" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:38.049324" 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-06-06T03:30:38.047722" elapsed="0.001627"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:38.055091" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.054978" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.054957" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:38.056410" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.056299" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.056279" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:38.056997" 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-06-06T03:30:38.056679" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.057427" level="INFO">${current_connection_index} = 7</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-06-06T03:30:38.057194" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.092351" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:38.058153" elapsed="0.034471"/>
</kw>
<msg time="2026-06-06T03:30:38.092965" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:38.093035" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:38.057691" elapsed="0.035397"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.122530" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:30:38.094077" elapsed="0.028692"/>
</kw>
<msg time="2026-06-06T03:30:38.123005" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:38.123054" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "l "e "t "e "_ "B "g "p...</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-06-06T03:30:38.093440" elapsed="0.029653"/>
</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-06-06T03:30:38.123682" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.123209" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.123175" elapsed="0.000598"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.124305" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:30:38.123928" elapsed="0.000448"/>
</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-06-06T03:30:38.124693" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.124447" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.124427" elapsed="0.000347"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:38.124812" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:38.127549" elapsed="0.000170"/>
</kw>
<msg time="2026-06-06T03:30:38.127783" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.126414" elapsed="0.001503"/>
</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="NOT RUN" start="2026-06-06T03:30:38.128196" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.128538" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:38.125731" elapsed="0.003016"/>
</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-06-06T03:30:38.125136" elapsed="0.003676"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:38.055991" elapsed="0.072920"/>
</kw>
<msg time="2026-06-06T03:30:38.129004" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:38.129049" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "l "e "t "e "_ "B "g "p...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:38.055321" elapsed="0.073766"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:38.129274" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:38.129164" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.129145" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.129789" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.130136" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.130208" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:38.054607" elapsed="0.075709"/>
</kw>
<msg time="2026-06-06T03:30:38.130437" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:38.130482" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "l "e "t "e "_ "B "g "p...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:38.049772" elapsed="0.080748"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.130870" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.130596" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.130579" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:38.049598" elapsed="0.081375"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:38.049408" elapsed="0.081597"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:38.046901" elapsed="0.084159"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:38.041536" elapsed="0.089582"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:38.041072" elapsed="0.090092"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:38.036049" elapsed="0.095166"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.175214" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:38.174792" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:38.176062" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:38.175805" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:38.176237" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:38.175434" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.176847" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:38.176436" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:38.177195" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:38.177366" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:38.177051" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.177827" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.177556" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.178957" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.178691" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.179448" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.179174" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.180182" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.179877" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.180967" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.180738" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.181047" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:38.181209" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.180399" elapsed="0.000835"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.181394" elapsed="0.000242"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:30:38.179732" elapsed="0.001960"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.182244" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.181946" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.183029" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.182814" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.183105" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:38.183255" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.182472" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.183436" elapsed="0.000237"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:30:38.181808" elapsed="0.001907"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.184261" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.183964" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.185101" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.184887" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.185177" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:38.185327" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.184476" elapsed="0.000876"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.185508" elapsed="0.000239"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:30:38.183827" elapsed="0.001962"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.186577" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.186039" elapsed="0.000564"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.187343" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.187133" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.187420" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:38.187568" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.186812" elapsed="0.000780"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.187765" elapsed="0.000223"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:30:38.185902" elapsed="0.002129"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.188740" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.188426" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.189488" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.189279" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.189564" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:38.189730" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.188957" elapsed="0.000798"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.189912" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:38.188288" elapsed="0.001886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.190750" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.190434" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.191497" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.191287" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.191572" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:38.191741" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.190966" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.191923" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:30:38.190286" elapsed="0.001901"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:38.179530" elapsed="0.012691"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:38.192265" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:38.192425" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:38.178314" elapsed="0.014137"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.177954" elapsed="0.014530"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.192686" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.192513" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.177930" elapsed="0.014835"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.193611" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:38.192917" elapsed="0.000747"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:38.193717" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:38.174060" elapsed="0.019783"/>
</kw>
<msg time="2026-06-06T03:30:38.193950" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.160793" elapsed="0.033211"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.206889" elapsed="0.000052"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.219829" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.232689" elapsed="0.000050"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.232984" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.233179" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.233619" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.233460" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:38.233442" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.233872" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.234052" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.234227" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:38.233401" elapsed="0.000880"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.233268" elapsed="0.001041"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.234499" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.234582" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:38.234760" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:38.156198" elapsed="0.078591"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.236051" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.235744" elapsed="0.000434"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:38.254535" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:38.254595" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:38.254755" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:38.238377" elapsed="0.016407"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.236249" elapsed="0.018587"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.255064" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.254868" elapsed="0.000262"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.236230" elapsed="0.018922"/>
</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-06-06T03:30:38.258756" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.256288" elapsed="0.002513"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.256041" elapsed="0.002796"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.256019" elapsed="0.002843"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.261446" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.259150" elapsed="0.002344"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.258919" elapsed="0.002610"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.258902" elapsed="0.002652"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.262165" 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-06-06T03:30:38.261759" elapsed="0.000434"/>
</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-06-06T03:30:38.262547" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.262266" elapsed="0.000341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.263132" 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-06-06T03:30:38.262825" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.262632" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.262247" elapsed="0.000969"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.263761" 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-06-06T03:30:38.263380" elapsed="0.000408"/>
</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-06-06T03:30:38.264099" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.263858" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.264657" 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-06-06T03:30:38.264348" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.264182" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.263840" elapsed="0.000901"/>
</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-06-06T03:30:38.264899" elapsed="0.000353"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:38.265736" 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-06-06T03:30:38.265426" elapsed="0.000336"/>
</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-06-06T03:30:38.265927" elapsed="0.002487"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:38.255564" elapsed="0.012917"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:38.268531" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:38.270843" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:38.235098" elapsed="0.035772"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:38.270996" elapsed="0.000029"/>
</return>
<arg>${MVPN_DIR}/bgp_peer</arg>
<arg>mapping=${MVPN_ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:38.131554" elapsed="0.139571"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:30:38.034596" elapsed="0.236654"/>
</test>
<test id="s1-s16-t29" name="Deconfigure_App_Peer" line="176">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:38.274632" elapsed="0.000234"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:38.274343" elapsed="0.000579"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.275956" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.275839" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.275819" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.281295" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.281185" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.281166" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.282381" 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-06-06T03:30:38.281997" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.282901" 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-06-06T03:30:38.282589" elapsed="0.000338"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:38.282973" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:38.283126" 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-06-06T03:30:38.281597" elapsed="0.001553"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:38.288827" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.288718" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.288698" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:38.290097" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.289990" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.289971" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:38.290663" 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-06-06T03:30:38.290316" elapsed="0.000375"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.291075" level="INFO">${current_connection_index} = 7</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-06-06T03:30:38.290856" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.333907" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:38.291608" elapsed="0.042525"/>
</kw>
<msg time="2026-06-06T03:30:38.334371" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:38.334418" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:38.291266" elapsed="0.043224"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.363093" level="INFO">". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:38.335235" elapsed="0.028064"/>
</kw>
<msg time="2026-06-06T03:30:38.363516" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:38.363563" level="INFO">${message_wait} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "c "o "n "f "i "g "u "r...</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-06-06T03:30:38.334780" elapsed="0.028820"/>
</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-06-06T03:30:38.364072" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.363739" elapsed="0.000478"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.363707" elapsed="0.000541"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.364791" level="INFO"> ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:38.364404" elapsed="0.000455"/>
</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-06-06T03:30:38.365161" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.364929" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.364909" elapsed="0.000333"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:38.365279" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:38.368013" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:30:38.368227" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.366888" elapsed="0.001473"/>
</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="NOT RUN" start="2026-06-06T03:30:38.368663" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.369005" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:38.366200" elapsed="0.002992"/>
</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-06-06T03:30:38.365603" elapsed="0.003654"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:38.289687" elapsed="0.079671"/>
</kw>
<msg time="2026-06-06T03:30:38.369455" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:38.369500" level="INFO">${message} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:38.289052" elapsed="0.080485"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:38.369741" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:38.369615" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.369596" elapsed="0.000232"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.370239" elapsed="0.000024"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.370633" elapsed="0.000047"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.370731" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:38.288364" elapsed="0.082477"/>
</kw>
<msg time="2026-06-06T03:30:38.370938" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:38.370982" level="INFO">${output} =  ". "t "x "t ". "0 "6 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "M "v "p "n ". "D "e "c "o "n "f "i "g "u "r...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:38.283529" elapsed="0.087490"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.371354" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.371096" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.371078" elapsed="0.000354"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:38.283382" elapsed="0.088074"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:38.283208" elapsed="0.088282"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:38.280820" elapsed="0.090727"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:38.275530" elapsed="0.096076"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:38.275087" elapsed="0.096584"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:38.272178" elapsed="0.099552"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.415102" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:38.414682" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:38.415978" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:38.415688" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:38.416153" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:38.415320" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.416757" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:38.416351" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:38.417099" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/mvpn/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:38.417264" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:38.416956" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.417726" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.417457" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.418805" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.418528" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.419284" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.419017" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.419996" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.419698" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.420775" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.420535" elapsed="0.000267"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.420855" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:38.421012" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.420211" elapsed="0.000826"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.421198" elapsed="0.000237"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:38.419542" elapsed="0.001934"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.422041" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:38.421743" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:38.423010" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.422612" elapsed="0.000425"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:38.423089" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:38.423240" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:38.422255" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:38.423420" elapsed="0.000235"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:38.421591" elapsed="0.002108"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:38.419365" elapsed="0.004369"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:38.423777" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:38.423932" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:38.418189" elapsed="0.005769"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.417850" elapsed="0.006139"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.424221" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.424062" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.417827" elapsed="0.006470"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.425053" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:38.424445" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:38.425131" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:38.413953" elapsed="0.011300"/>
</kw>
<msg time="2026-06-06T03:30:38.425309" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.400976" elapsed="0.024381"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.437883" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.450312" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/mvpn/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.462717" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.462933" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.463121" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.463522" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.463368" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:38.463349" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.463768" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.463941" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.464141" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:38.463311" elapsed="0.000891"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.463204" elapsed="0.001026"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.464385" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.464464" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:38.464607" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:38.396611" elapsed="0.068098"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.465906" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.465603" elapsed="0.000353"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:38.484051" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01wm4bm63yxh9wucz5wbouslc125.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:38.484098" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:38.484190" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:38.468101" elapsed="0.016115"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.466024" elapsed="0.018233"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:38.484441" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.484283" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.466005" elapsed="0.018518"/>
</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-06-06T03:30:38.488128" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.485547" elapsed="0.002625"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.485320" elapsed="0.002889"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.485302" elapsed="0.002932"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.490850" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.488516" elapsed="0.002380"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.488290" elapsed="0.002642"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.488273" elapsed="0.002684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.491536" 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-06-06T03:30:38.491141" elapsed="0.000422"/>
</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-06-06T03:30:38.491896" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.491634" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.492444" 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-06-06T03:30:38.492143" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.491978" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.491616" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.493073" 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-06-06T03:30:38.492707" elapsed="0.000393"/>
</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-06-06T03:30:38.493408" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.493170" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.493961" 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-06-06T03:30:38.493667" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:38.493489" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.493152" elapsed="0.000890"/>
</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-06-06T03:30:38.494197" elapsed="0.000375"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:38.495053" 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-06-06T03:30:38.494759" elapsed="0.000360"/>
</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-06-06T03:30:38.495284" elapsed="0.002288"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:38.484906" elapsed="0.012748"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:38.497708" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:38.500168" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:38.464992" elapsed="0.035203"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:38.500250" elapsed="0.000028"/>
</return>
<arg>${MVPN_DIR}/app_peer</arg>
<arg>mapping=${MVPN_APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:38.371966" elapsed="0.128411"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:30:38.271586" elapsed="0.228919"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:30:38.501392" elapsed="0.000469"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:38.502109" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:30:38.502031" elapsed="0.000167"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:30:38.501148" elapsed="0.001103"/>
</kw>
<doc>Functional test for bgp - mvpn

Copyright (c) 2018 AT&amp;T Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distbmution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests advertising mvpn routes to odl. For advertising play.py is used,
and particular files are stored as *.hex files. There are 7 different
types of routes used for auto-discovery of multicast network. Also 4 more routes
with new attributes specific for mvpn.</doc>
<status status="PASS" start="2026-06-06T03:29:16.158546" elapsed="82.343735"/>
</suite>
<suite id="s1-s17" name="070 Bgp Functional L3Vpn Mcast" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/070_bgp_functional_l3vpn_mcast.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.590453" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:30:38.586150" elapsed="0.004358"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:30:38.585907" elapsed="0.004690"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.595449" 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-06-06T03:30:38.591758" elapsed="0.003718"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:30:38.595707" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.595564" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.595540" elapsed="0.000239"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.596298" 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-06-06T03:30:38.595939" elapsed="0.000403"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.596840" 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-06-06T03:30:38.596510" elapsed="0.000356"/>
</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-06-06T03:30:38.597391" elapsed="0.000307"/>
</kw>
<msg time="2026-06-06T03:30:38.597797" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:38.597845" 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-06-06T03:30:38.597043" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.598553" 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-06-06T03:30:38.598045" elapsed="0.000575"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.599629" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:30:38.599365" elapsed="0.000306"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.600090" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:30:38.599827" elapsed="0.000289"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.600690" 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-06-06T03:30:38.600307" elapsed="0.000413"/>
</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-06-06T03:30:38.606027" elapsed="0.000264"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.607004" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:30:38.606619" elapsed="0.000412"/>
</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-06-06T03:30:38.607192" elapsed="0.000230"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.608243" 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-06-06T03:30:38.607943" elapsed="0.000327"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:30:38.608319" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:30:38.608488" 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-06-06T03:30:38.607627" elapsed="0.000886"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:38.609177" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5a13d90&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-06-06T03:30:38.608690" elapsed="0.000629"/>
</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-06-06T03:30:38.609489" elapsed="0.000210"/>
</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-06-06T03:30:38.605380" elapsed="0.004381"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:38.605133" elapsed="0.004672"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:30:38.600781" elapsed="0.009056"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.610438" 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-06-06T03:30:38.610010" elapsed="0.000472"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.611086" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:30:38.610682" elapsed="0.000447"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.611696" 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-06-06T03:30:38.611296" elapsed="0.000444"/>
</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-06-06T03:30:38.598901" elapsed="0.012896"/>
</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-06-06T03:30:38.591377" elapsed="0.020476"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:38.612064" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:38.611941" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.611916" 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-06-06T03:30:38.615550" 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-06-06T03:30:38.615155" elapsed="0.000423"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.616061" 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-06-06T03:30:38.615764" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:38.616131" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:38.616289" 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-06-06T03:30:38.614806" elapsed="0.001507"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:38.617321" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:30:38.617055" elapsed="0.000292"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.618115" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:30:38.618216" 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-06-06T03:30:38.617945" elapsed="0.000297"/>
</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-06-06T03:30:38.621915" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:38.621313" elapsed="0.000689"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:38.621292" elapsed="0.000749"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.622891" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:30:38.622424" elapsed="0.000909"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.624267" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:38.623596" elapsed="0.000776"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.625554" 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-06-06T03:30:38.624665" elapsed="0.000942"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:38.627377" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:30:38.627553" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:38.627017" elapsed="0.000578"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.627959" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:30:38.629552" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:30:39.252785" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:30:38 UTC 2026

  System load:  0.16               Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:29:16 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:30:38.629229" elapsed="0.623713"/>
</kw>
<msg time="2026-06-06T03:30:39.253030" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.628780" elapsed="0.624415"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:30:38.626074" elapsed="0.627273"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.254244" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:30:39.267214" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:30:39.267618" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:30:39.267916" 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-06-06T03:30:39.253754" elapsed="0.014281"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:30:39.268762" elapsed="0.001116"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.272472" 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-06-06T03:30:39.271231" elapsed="0.001527"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:30:39.273689" elapsed="0.000118"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:39.273116" elapsed="0.000856"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.273062" elapsed="0.000993"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:30:39.274763" elapsed="0.000162"/>
</return>
<status status="PASS" start="2026-06-06T03:30:39.274237" elapsed="0.000871"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.274197" elapsed="0.001000"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:30:39.275329" elapsed="0.000037"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:39.281450" elapsed="0.000478"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:30:39.282212" elapsed="0.000289"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:30:39.282786" elapsed="0.000238"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:39.276408" elapsed="0.006688"/>
</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-06-06T03:30:38.620359" elapsed="0.662913"/>
</kw>
<msg time="2026-06-06T03:30:39.283330" 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-06-06T03:30:38.619515" elapsed="0.663869"/>
</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-06-06T03:30:38.619030" elapsed="0.664435"/>
</kw>
<msg time="2026-06-06T03:30:39.283508" 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-06-06T03:30:38.618464" elapsed="0.665089"/>
</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-06-06T03:30:39.286282" elapsed="0.000312"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:30:39.286779" elapsed="0.000179"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:30:39.287113" elapsed="0.000100"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:39.283865" elapsed="0.003399"/>
</kw>
<msg time="2026-06-06T03:30:39.287356" 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-06-06T03:30:38.617566" elapsed="0.669815"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.287837" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:39.287568" elapsed="0.000312"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:30:39.287922" elapsed="0.000031"/>
</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-06-06T03:30:38.616699" elapsed="0.671353"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:38.616504" elapsed="0.671585"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:38.616370" elapsed="0.671753"/>
</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-06-06T03:30:38.612361" elapsed="0.675819"/>
</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-06-06T03:30:39.288342" elapsed="0.000213"/>
</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-06-06T03:30:39.302437" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:39.302324" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.302304" elapsed="0.000202"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.302815" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:30:39.302947" 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-06-06T03:30:39.302679" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.303393" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:39.303138" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.303857" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:39.303595" elapsed="0.000306"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:39.304667" 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-06-06T03:30:39.304431" elapsed="0.000345">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:30:39.304881" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:30:39.304929" 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-06-06T03:30:39.304064" elapsed="0.000888"/>
</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-06-06T03:30:39.305303" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:39.305071" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.305050" elapsed="0.000351"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:39.306171" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:30:39.305900" elapsed="0.000297"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:30:39.306245" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:39.306395" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:30:39.305605" elapsed="0.000814"/>
</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-06-06T03:30:39.306580" elapsed="0.000436"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.307296" level="INFO">index=4
host=10.30.170.38
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-06-06T03:30:39.307396" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:30:39.307191" elapsed="0.000232"/>
</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-06-06T03:30:39.307577" elapsed="0.002395"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.310407" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:30:39.472890" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:30:39.310147" elapsed="0.162862"/>
</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-06-06T03:30:39.476631" elapsed="0.000369"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:30:39.477170" elapsed="0.000162"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:30:39.477487" elapsed="0.000100"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:39.474039" elapsed="0.003622"/>
</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-06-06T03:30:39.473371" elapsed="0.004341"/>
</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-06-06T03:30:39.302045" elapsed="0.175720"/>
</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-06-06T03:30:39.289299" elapsed="0.188515"/>
</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-06-06T03:30:39.288926" elapsed="0.188942"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:39.288780" elapsed="0.189130"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:30:39.288610" elapsed="0.189339"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:30:38.590925" elapsed="0.887088"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:39.480748" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:39.480611" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.480587" elapsed="0.000298"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:39.485807" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:39.485698" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.485679" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.486861" 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-06-06T03:30:39.486451" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.487368" 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-06-06T03:30:39.487068" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:39.487439" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:39.487601" 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-06-06T03:30:39.486111" elapsed="0.001514"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:39.493300" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:39.493192" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.493172" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:39.494579" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:39.494452" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.494433" elapsed="0.000240"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:39.495177" 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-06-06T03:30:39.494826" elapsed="0.000377"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.495591" 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-06-06T03:30:39.495367" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.529846" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:39.496308" elapsed="0.033677"/>
</kw>
<msg time="2026-06-06T03:30:39.530122" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:39.530168" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:30:39.495801" elapsed="0.034405"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.604611" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "7 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "l "3 "v "p "n "_ "m "c "a "s "t ". "r "o "b "o "t "[K"
[?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-06-06T03:30:39.530916" elapsed="0.073999"/>
</kw>
<msg time="2026-06-06T03:30:39.605054" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:39.605099" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:30:39.530387" elapsed="0.074750"/>
</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-06-06T03:30:39.605516" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:39.605227" elapsed="0.000458"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.605200" elapsed="0.000516"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.606269" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "7 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "l "3 "v "p "n "_ "m "c "a "s "t ". "r "o "b "o "t "[K"
[?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-06-06T03:30:39.605875" elapsed="0.000489"/>
</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-06-06T03:30:39.606712" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:39.606439" elapsed="0.000426"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.606419" elapsed="0.000474"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:39.606931" elapsed="0.000039"/>
</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-06-06T03:30:39.609301" elapsed="0.000485"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:30:39.610144" elapsed="0.000311"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:30:39.610815" elapsed="0.000286"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:39.608408" elapsed="0.002789"/>
</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-06-06T03:30:39.607378" elapsed="0.003956"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:39.494165" elapsed="0.117275"/>
</kw>
<msg time="2026-06-06T03:30:39.611539" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:39.611585" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:39.493528" elapsed="0.118097"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:39.611834" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:39.611722" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.611702" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:39.612339" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:39.612895" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:39.612970" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:39.492899" elapsed="0.120185"/>
</kw>
<msg time="2026-06-06T03:30:39.613183" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:39.613228" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:39.488026" elapsed="0.125241"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:39.613606" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:39.613346" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:39.613328" elapsed="0.000375"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:39.487877" elapsed="0.125850"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:39.487699" elapsed="0.126061"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:39.485391" elapsed="0.128432"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:30:39.478619" elapsed="0.135264"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:39.478178" elapsed="0.135750"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:30:38.585521" elapsed="1.028460"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.614527" level="INFO">${mininet_conn_id} = 7</msg>
<var>${mininet_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:30:39.614160" elapsed="0.000396"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:39.615201" level="INFO">${mininet_conn_id} = 7</msg>
<arg>${mininet_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:30:39.614790" elapsed="0.000458"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:30:39.617060" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:30:39.617138" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:39.616770" elapsed="0.000392"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:39.617325" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:30:39.618780" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:30:40.217270" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:30:39 UTC 2026

  System load:  0.08               Processes:             105
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:29:17 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:30:39.618442" elapsed="0.599290"/>
</kw>
<msg time="2026-06-06T03:30:40.217897" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:39.618078" elapsed="0.599967"/>
</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-06-06T03:30:39.616249" elapsed="0.602010"/>
</kw>
<msg time="2026-06-06T03:30:40.218372" 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-06-06T03:30:39.615851" elapsed="0.602617"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:30:39.615455" elapsed="0.603179"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:40.219877" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59c3e90&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:30:40.219111" elapsed="0.001105"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.229393" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:30:40.243181" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>${PLAY_SCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:30:40.220593" elapsed="0.022705"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.245295" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:30:40.288009" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:30:40.288313" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:30:40.288419" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:30:40.288518" 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-06-06T03:30:40.245030" elapsed="0.043543"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.290687" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:30:40.290030" elapsed="0.000766"/>
</kw>
<msg time="2026-06-06T03:30:40.291009" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:30:40.291108" 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-06-06T03:30:40.289092" elapsed="0.002066"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.292608" 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-06-06T03:30:40.291601" elapsed="0.001099"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.293733" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.292895" elapsed="0.000984"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.292841" elapsed="0.001097"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:30:40.294286" elapsed="0.000073"/>
</return>
<status status="PASS" start="2026-06-06T03:30:40.294062" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.294027" elapsed="0.000466"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.294727" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.294616" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:40.294582" 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-06-06T03:30:40.295198" elapsed="0.000048"/>
</kw>
<msg time="2026-06-06T03:30:40.295759" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:30:40.244470" elapsed="0.051348"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:30:40.296177" elapsed="0.000056"/>
</return>
<status status="PASS" start="2026-06-06T03:30:40.295975" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.295936" elapsed="0.000414"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.296722" elapsed="0.000050"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:30:40.243778" elapsed="0.053132"/>
</kw>
<doc>Initialize SetupUtils. Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:38.585145" elapsed="1.711882"/>
</kw>
<test id="s1-s17-t1" name="Configure_App_Peer" line="48">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:40.302110" elapsed="0.000214"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:40.301837" elapsed="0.000608"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.303483" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.303373" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.303353" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.308540" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.308433" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.308416" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.309620" 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-06-06T03:30:40.309240" elapsed="0.000422"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.310135" 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-06-06T03:30:40.309831" elapsed="0.000330"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:40.310205" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:40.310359" 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-06-06T03:30:40.308859" elapsed="0.001525"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:40.315866" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.315759" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.315740" elapsed="0.000194"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:40.317144" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.317035" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.317017" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:40.317690" 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-06-06T03:30:40.317366" elapsed="0.000352"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.318099" level="INFO">${current_connection_index} = 7</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-06-06T03:30:40.317882" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.351165" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:40.318628" elapsed="0.032711"/>
</kw>
<msg time="2026-06-06T03:30:40.351530" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:40.351577" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:40.318288" elapsed="0.033324"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.387075" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:40.352478" elapsed="0.034705"/>
</kw>
<msg time="2026-06-06T03:30:40.387377" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:40.387425" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "C "o "...</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-06-06T03:30:40.351851" elapsed="0.035610"/>
</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-06-06T03:30:40.387832" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.387554" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.387527" elapsed="0.000388"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.388381" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:40.388072" elapsed="0.000377"/>
</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-06-06T03:30:40.388761" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.388516" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.388497" elapsed="0.000402"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:40.388941" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:40.391656" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:30:40.391870" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:40.390486" elapsed="0.001516"/>
</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="NOT RUN" start="2026-06-06T03:30:40.392289" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.392627" elapsed="0.000097"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:40.389850" elapsed="0.002984"/>
</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-06-06T03:30:40.389270" elapsed="0.003631"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:40.316734" elapsed="0.076266"/>
</kw>
<msg time="2026-06-06T03:30:40.393094" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:40.393138" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "C "o "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:40.316107" elapsed="0.077066"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:40.393358" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:40.393251" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.393232" elapsed="0.000210"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.393872" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.394217" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.394287" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:40.315408" elapsed="0.078987"/>
</kw>
<msg time="2026-06-06T03:30:40.394488" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:40.394532" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "C "o "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:40.310781" elapsed="0.083787"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.394927" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.394669" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.394626" elapsed="0.000379"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:40.310618" elapsed="0.084411"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:40.310441" elapsed="0.084620"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:40.308074" elapsed="0.087043"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:40.303067" elapsed="0.092106"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:40.302603" elapsed="0.092617"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:40.298415" elapsed="0.096859"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.429096" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.428712" elapsed="0.000414"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.429937" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:40.429636" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:40.430172" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:40.429296" elapsed="0.000902"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.430776" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:40.430373" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.431111" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:40.431280" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:40.430972" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.431761" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.431497" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.432786" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.432511" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.433269" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.432995" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.433978" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.433681" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.434758" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.434518" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.434835" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:40.434989" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.434193" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.435279" elapsed="0.000258"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:40.433524" elapsed="0.002053"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.436138" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.435843" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.437000" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.436788" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.437080" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:40.437229" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.436453" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.437408" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:40.435705" elapsed="0.001980"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:40.433347" elapsed="0.004373"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:40.437763" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:40.437917" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:40.432186" elapsed="0.005757"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.431879" elapsed="0.006096"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.438157" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.438000" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.431857" elapsed="0.006375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.438988" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:40.438381" elapsed="0.000636"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.439099" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:40.428070" elapsed="0.011157"/>
</kw>
<msg time="2026-06-06T03:30:40.439282" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:40.415388" elapsed="0.023969"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.451999" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.464364" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.476729" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.476928" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.477113" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.477479" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.477331" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:40.477316" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.477717" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.477891" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.478061" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:40.477288" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.477187" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.478290" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.478364" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:40.478486" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:40.410900" elapsed="0.067612"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.505102" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.504729" elapsed="0.000401"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.505858" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:40.505632" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:40.506017" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:40.505296" elapsed="0.000745"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.506588" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:40.506208" elapsed="0.000407"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.506937" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:40.507080" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:40.506802" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.507537" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.507268" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:40.507963" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.507668" elapsed="0.000353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.508488" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.508197" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.508047" elapsed="0.000502"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.507634" elapsed="0.000936"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.509289" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:40.508735" elapsed="0.000584"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.509368" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:40.504098" elapsed="0.005395"/>
</kw>
<msg time="2026-06-06T03:30:40.509546" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:40.491490" elapsed="0.018103"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.522228" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.534666" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.547259" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.547494" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.547693" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.548086" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.547937" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:40.547919" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.548315" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.548487" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.548672" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:40.547886" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.547776" elapsed="0.000977"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.548902" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.548980" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:40.549119" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:40.488726" elapsed="0.060422"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.550652" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:40.550363" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:40.550817" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:40.549843" elapsed="0.000999"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.552225" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.551746" elapsed="0.000543"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.552874" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.552525" elapsed="0.000376"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.552314" elapsed="0.000622"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.551468" elapsed="0.001489"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.555336" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:40.553118" elapsed="0.002245"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:40.555444" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:40.555599" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:40.549482" elapsed="0.006142"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.557066" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.556811" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.557584" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.557345" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.558048" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.557805" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.558483" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.558245" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:40.559359" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:40.559157" elapsed="0.000239"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:40.559748" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:40.559555" elapsed="0.000219"/>
</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-06-06T03:30:40.559927" elapsed="0.000205"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.560536" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.560291" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:40.560622" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:30:40.560793" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:40.558745" elapsed="0.002074"/>
</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-06-06T03:30:40.582590" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:30:40.582752" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:30:40 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:40.582984" 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-06-06T03:30:40.563151" elapsed="0.019892"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.560889" elapsed="0.022254"/>
</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-06-06T03:30:40.583588" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.583204" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.560871" elapsed="0.022954"/>
</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-06-06T03:30:40.590667" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.585970" elapsed="0.004743"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.585434" elapsed="0.005314"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.585393" elapsed="0.005381"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.593373" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.591058" elapsed="0.002362"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.590830" elapsed="0.002624"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.590812" elapsed="0.002667"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.594047" 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-06-06T03:30:40.593664" elapsed="0.000411"/>
</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-06-06T03:30:40.594391" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.594147" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.594980" 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-06-06T03:30:40.594676" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.594480" elapsed="0.000607"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.594128" elapsed="0.000982"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.595680" 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-06-06T03:30:40.595280" elapsed="0.000428"/>
</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-06-06T03:30:40.596021" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.595779" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.596561" 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-06-06T03:30:40.596267" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.596101" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.595760" elapsed="0.000900"/>
</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-06-06T03:30:40.596815" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:40.597612" 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-06-06T03:30:40.597331" elapsed="0.000327"/>
</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-06-06T03:30:40.597822" elapsed="0.002346"/>
</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-06-06T03:30:40.584614" elapsed="0.015682"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:40.600476" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:40.600367" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.600348" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:40.600737" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.600807" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:30:40.603067" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:30:40.555984" elapsed="0.047109"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.603157" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:40.603309" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:40.400091" elapsed="0.203243"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.603705" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.603450" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.603431" elapsed="0.000367"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.603831" elapsed="0.000025"/>
</return>
<arg>${L3VPN_MCAST_DIR}/app_peer</arg>
<arg>mapping=${L3VPN_MCAST_APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:40.395562" elapsed="0.208391"/>
</kw>
<doc>Configures bgp application peer.</doc>
<status status="PASS" start="2026-06-06T03:30:40.297153" elapsed="0.306933"/>
</test>
<test id="s1-s17-t2" name="Reconfigure_ODL_To_Accept_Connection" line="56">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:40.609315" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:40.609047" elapsed="0.000534"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.610576" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.610467" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.610447" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.615629" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.615524" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.615505" elapsed="0.000243"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.616759" 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-06-06T03:30:40.616359" elapsed="0.000427"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.617254" 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-06-06T03:30:40.616950" elapsed="0.000330"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:40.617324" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:40.617477" 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-06-06T03:30:40.615981" elapsed="0.001522"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:40.623030" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.622923" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.622903" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:40.624314" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.624206" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.624187" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:40.624876" 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-06-06T03:30:40.624536" elapsed="0.000366"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.625292" level="INFO">${current_connection_index} = 7</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-06-06T03:30:40.625067" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.659084" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:40.625841" elapsed="0.033349"/>
</kw>
<msg time="2026-06-06T03:30:40.659357" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:40.659403" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:40.625481" elapsed="0.033987"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.698086" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:30:40.660021" elapsed="0.038180"/>
</kw>
<msg time="2026-06-06T03:30:40.698362" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:40.698409" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "R "e "...</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-06-06T03:30:40.659668" elapsed="0.038778"/>
</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-06-06T03:30:40.698778" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.698525" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.698504" elapsed="0.000355"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.699304" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:30:40.699003" elapsed="0.000378"/>
</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-06-06T03:30:40.699717" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.699476" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.699455" elapsed="0.000343"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:40.699831" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:40.702364" elapsed="0.000142"/>
</kw>
<msg time="2026-06-06T03:30:40.702568" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:40.701271" elapsed="0.001449"/>
</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="NOT RUN" start="2026-06-06T03:30:40.703052" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.703391" elapsed="0.000090"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:40.700636" elapsed="0.002955"/>
</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-06-06T03:30:40.700101" elapsed="0.003584"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:40.623904" elapsed="0.079882"/>
</kw>
<msg time="2026-06-06T03:30:40.703879" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:40.703923" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "R "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:40.623253" elapsed="0.080708"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:40.704144" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:40.704037" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.704018" elapsed="0.000209"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.704627" elapsed="0.000056"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.705003" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.705078" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:40.622572" elapsed="0.082613"/>
</kw>
<msg time="2026-06-06T03:30:40.705276" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:40.705320" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "R "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:40.617891" elapsed="0.087467"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.705698" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.705432" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.705415" elapsed="0.000362"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:40.617746" elapsed="0.088054"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:40.617556" elapsed="0.088273"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:40.615149" elapsed="0.090733"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:40.610179" elapsed="0.095758"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:40.609749" elapsed="0.096232"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:40.605088" elapsed="0.100946"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.742176" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.741704" elapsed="0.000507"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.743120" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:40.742781" elapsed="0.000419">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:40.743296" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:40.742404" elapsed="0.000917"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.743936" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:40.743526" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.744362" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:40.744547" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:40.744216" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.745015" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.744754" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.746146" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.745884" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.746630" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.746358" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.747357" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.747059" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.748174" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.747948" elapsed="0.000252"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.748255" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:40.748418" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.747607" elapsed="0.000835"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.748602" elapsed="0.000258"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:30:40.746914" elapsed="0.001988"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.749445" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.749149" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.750203" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.749993" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.750279" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:40.750426" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.749673" elapsed="0.000777"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.750604" elapsed="0.000240"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:30:40.749014" elapsed="0.001872"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.751427" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.751133" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.752384" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.752174" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.752460" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:40.752619" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.751684" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.752899" elapsed="0.000250"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:30:40.750999" elapsed="0.002192"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.753754" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.753440" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.754500" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.754292" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.754575" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:40.754742" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.753969" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.754959" elapsed="0.000220"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:30:40.753303" elapsed="0.001917"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.755801" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.755484" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.756537" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.756330" elapsed="0.000232"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.756612" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:30:40.756779" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.756012" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.756957" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:40.755332" elapsed="0.001892"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.757801" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:40.757470" elapsed="0.000357"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:40.758541" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.758333" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:40.758622" elapsed="0.000101"/>
</return>
<msg time="2026-06-06T03:30:40.758873" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:40.758014" elapsed="0.000890"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:40.759107" elapsed="0.000267"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:30:40.757334" elapsed="0.002090"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:40.746727" elapsed="0.012785"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:40.759571" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:40.759783" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:40.745529" elapsed="0.014286"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.745150" elapsed="0.014703"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.760076" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.759885" elapsed="0.000258"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.745123" elapsed="0.015045"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.761186" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:40.760356" elapsed="0.000864"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.761279" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:40.740843" elapsed="0.020584"/>
</kw>
<msg time="2026-06-06T03:30:40.761494" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:40.726261" elapsed="0.035291"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.774481" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.786990" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.800078" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.800308" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.800509" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.800921" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.800768" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:40.800753" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.801150" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.801340" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.801516" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:40.800719" elapsed="0.000851"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.800595" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.801767" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.801846" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:40.801978" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:40.721634" elapsed="0.080372"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.829289" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.828897" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.830113" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:40.829875" elapsed="0.000506">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:40.830480" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:40.829491" elapsed="0.001014"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.831090" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:40.830696" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.831429" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:40.831679" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:40.831289" elapsed="0.000421"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.832126" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.831876" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:40.832548" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.832244" elapsed="0.000363"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.833110" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.832802" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.832632" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.832224" elapsed="0.001077"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.834118" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:40.833451" elapsed="0.000698"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.834201" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:40.828223" elapsed="0.006106"/>
</kw>
<msg time="2026-06-06T03:30:40.834384" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:40.815013" elapsed="0.019418"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.847169" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.859661" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.872183" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.872385" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.872566" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.872952" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.872803" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:40.872788" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.873178" elapsed="0.000053"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.873391" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.873564" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:40.872759" elapsed="0.000857"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.872656" elapsed="0.001000"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.873810" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.873886" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:40.874006" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:40.812299" elapsed="0.061736"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:40.875327" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:40.875070" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:40.875483" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:40.874716" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.875865" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.875597" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.876421" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:40.876128" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.875947" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.875578" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.878863" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:40.876674" elapsed="0.002215"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:40.878942" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:40.879094" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:40.874371" elapsed="0.004748"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.880535" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.880287" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.880994" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.880755" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.881439" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.881198" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.881891" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.881635" elapsed="0.000299"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:40.882762" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:40.882548" elapsed="0.000240"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:40.883121" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:40.882946" elapsed="0.000201"/>
</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-06-06T03:30:40.883339" elapsed="0.000221"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.883989" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.883737" elapsed="0.000300"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:40.884083" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:40.884238" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:40.882142" elapsed="0.002122"/>
</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-06-06T03:30:40.898527" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '295', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:30:40.898583" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:40.898710" 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-06-06T03:30:40.886604" elapsed="0.012132"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.884336" elapsed="0.014446"/>
</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-06-06T03:30:40.898966" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.898808" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.884317" elapsed="0.014784"/>
</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-06-06T03:30:40.906577" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.901280" elapsed="0.005424"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.900777" elapsed="0.006008"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.900734" elapsed="0.006108"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.910169" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:40.907478" elapsed="0.002744"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.906969" elapsed="0.003288"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.906932" elapsed="0.003349"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.910849" 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-06-06T03:30:40.910452" elapsed="0.000425"/>
</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-06-06T03:30:40.911193" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.910948" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.911786" 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-06-06T03:30:40.911443" elapsed="0.000370"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.911276" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.910929" elapsed="0.000943"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.912408" 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-06-06T03:30:40.912038" elapsed="0.000397"/>
</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-06-06T03:30:40.912776" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.912505" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.913324" 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-06-06T03:30:40.913028" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:40.912860" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.912487" elapsed="0.000922"/>
</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-06-06T03:30:40.913564" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:40.914419" 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-06-06T03:30:40.914137" elapsed="0.000308"/>
</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-06-06T03:30:40.914604" elapsed="0.002331"/>
</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-06-06T03:30:40.899958" elapsed="0.017040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:40.917174" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:40.917067" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.917048" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:40.917411" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.917479" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:40.920321" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:30:40.879449" elapsed="0.040906"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.920433" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:40.920616" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:40.710668" elapsed="0.209988"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:40.921044" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:40.920771" elapsed="0.000345"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.920752" elapsed="0.000388"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:40.921172" elapsed="0.000027"/>
</return>
<arg>${L3VPN_MCAST_DIR}/bgp_peer</arg>
<arg>mapping=${L3VPN_MCAST_ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:40.706291" elapsed="0.215018"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:30:40.604498" elapsed="0.316951"/>
</test>
<test id="s1-s17-t3" name="Start_Bgp_Peer" line="64">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:40.925316" elapsed="0.000234"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:40.925012" elapsed="0.000596"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.926700" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.926565" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.926544" elapsed="0.000225"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:40.932273" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.932162" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.932143" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.933491" 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-06-06T03:30:40.932981" elapsed="0.000538"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:40.934003" 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-06-06T03:30:40.933703" elapsed="0.000330"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:40.934082" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:40.934238" 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-06-06T03:30:40.932576" elapsed="0.001686"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:40.939873" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.939760" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.939739" elapsed="0.000259"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:40.941229" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:40.941117" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:40.941098" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:40.941777" 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-06-06T03:30:40.941450" elapsed="0.000356"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.942201" level="INFO">${current_connection_index} = 7</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-06-06T03:30:40.941973" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:40.975068" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:40.942807" elapsed="0.032419"/>
</kw>
<msg time="2026-06-06T03:30:40.975423" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:40.975471" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:40.942426" elapsed="0.033083"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:41.010443" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:40.976177" elapsed="0.034541"/>
</kw>
<msg time="2026-06-06T03:30:41.010969" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:41.011018" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "S "t "...</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-06-06T03:30:40.975774" elapsed="0.035287"/>
</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-06-06T03:30:41.011548" elapsed="0.000061"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:41.011189" elapsed="0.000475"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:41.011150" elapsed="0.000544"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:41.012252" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:41.011851" elapsed="0.000474"/>
</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-06-06T03:30:41.012617" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:41.012394" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:41.012376" elapsed="0.000339"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:41.012755" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:41.015583" elapsed="0.000172"/>
</kw>
<msg time="2026-06-06T03:30:41.015819" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:41.014434" elapsed="0.001519"/>
</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="NOT RUN" start="2026-06-06T03:30:41.016460" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:41.016821" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:41.013708" elapsed="0.003302"/>
</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-06-06T03:30:41.013104" elapsed="0.003971"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:40.940804" elapsed="0.076371"/>
</kw>
<msg time="2026-06-06T03:30:41.017268" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:41.017314" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "S "t "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:40.940164" elapsed="0.077187"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:41.017537" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:41.017429" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:41.017410" elapsed="0.000281"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:41.018118" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:41.018465" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:41.018537" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:40.939358" elapsed="0.079301"/>
</kw>
<msg time="2026-06-06T03:30:41.018755" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:41.018799" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "S "t "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:40.934681" elapsed="0.084155"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:41.019167" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:41.018912" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:41.018895" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:40.934515" elapsed="0.084755"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:40.934332" elapsed="0.084971"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:40.931789" elapsed="0.087571"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:40.926241" elapsed="0.093176"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:40.925785" elapsed="0.093681"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:40.922754" elapsed="0.096768"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Start_Bgp_Peer">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:41.021371" level="INFO">${command} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --l3vpn_mcast --wfr 1 &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:41.021037" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:41.021821" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --l3vpn_mcast --wfr 1 &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:41.021562" elapsed="0.000305"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:41.026213" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --l3vpn_mcast --wfr 1 &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:30:41.026308" level="INFO">${output} =  python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --l3vpn_mcast --wfr 1 &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:41.022022" elapsed="0.004321"/>
</kw>
<arg>--amount 0 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug --l3vpn_mcast --wfr 1</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:30:41.020575" elapsed="0.005839"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.028781" level="FAIL">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:30:41.028121" elapsed="6.001506">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.030027" elapsed="0.000037"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:30:41.027846" elapsed="6.002355">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:30:41.027376" elapsed="6.002967"/>
</kw>
<msg time="2026-06-06T03:30:47.030477" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:41.027011" elapsed="6.003493"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:30:47.030729" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:30:47.030607" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.030577" elapsed="0.000370"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.031206" elapsed="0.000029"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.031393" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:30:41.026724" elapsed="6.004754"/>
</kw>
<doc>Starts bgp peer and verifies that the peer runs.</doc>
<status status="PASS" start="2026-06-06T03:30:41.020237" elapsed="6.011292"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>Start Bgp Peer</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:41.019756" elapsed="6.011830"/>
</kw>
<doc>Start Python speaker to connect to ODL. We need to do WUKS until odl really starts to accept incomming bgp connection. The failure happens if the incomming connection comes too quickly after configuring the peer in the previous test case.</doc>
<status status="PASS" start="2026-06-06T03:30:40.921840" elapsed="6.109904"/>
</test>
<test id="s1-s17-t4" name="Odl_To_Play_l3vpn_mcast" line="69">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:47.035732" elapsed="0.000272"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:47.035422" elapsed="0.000643"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.037317" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.037184" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.037162" elapsed="0.000228"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.042664" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.042524" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.042504" elapsed="0.000235"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.043841" 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-06-06T03:30:47.043404" elapsed="0.000466"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.044352" 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-06-06T03:30:47.044045" elapsed="0.000333"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:47.044425" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:47.044588" 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-06-06T03:30:47.042993" elapsed="0.001620"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:47.050327" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.050206" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.050182" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:47.051755" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.051608" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.051585" elapsed="0.000243"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:47.052337" 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-06-06T03:30:47.051991" elapsed="0.000374"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.052795" level="INFO">${current_connection_index} = 7</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-06-06T03:30:47.052541" elapsed="0.000281"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.083257" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:47.053359" elapsed="0.030063"/>
</kw>
<msg time="2026-06-06T03:30:47.083619" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:47.083691" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:47.052995" elapsed="0.030735"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.115490" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "3 "v "p "n "_ "m "c "a "s "t "[K"
[?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-06-06T03:30:47.084372" elapsed="0.031263"/>
</kw>
<msg time="2026-06-06T03:30:47.115858" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:47.115973" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "...</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-06-06T03:30:47.083960" elapsed="0.032055"/>
</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-06-06T03:30:47.116413" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.116123" elapsed="0.000350"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.116092" elapsed="0.000408"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.117048" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "3 "v "p "n "_ "m "c "a "s "t "[K"
[?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-06-06T03:30:47.116669" elapsed="0.000457"/>
</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-06-06T03:30:47.117442" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.117201" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.117179" elapsed="0.000344"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:47.117560" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:47.120477" elapsed="0.000208"/>
</kw>
<msg time="2026-06-06T03:30:47.120757" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.119282" elapsed="0.001619"/>
</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="NOT RUN" start="2026-06-06T03:30:47.121192" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.121544" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:47.118564" elapsed="0.003195"/>
</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-06-06T03:30:47.117947" elapsed="0.003881"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:47.051281" elapsed="0.070664"/>
</kw>
<msg time="2026-06-06T03:30:47.122043" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:47.122089" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:47.050570" elapsed="0.071559"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:47.122332" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:30:47.122215" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.122192" elapsed="0.000229"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.122897" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.123254" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.123327" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:47.049736" elapsed="0.073703"/>
</kw>
<msg time="2026-06-06T03:30:47.123536" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:47.123580" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:47.045034" elapsed="0.078585"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.123992" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.123719" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.123700" elapsed="0.000372"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:47.044880" elapsed="0.079216"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:47.044693" elapsed="0.079438"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:47.042132" elapsed="0.082060"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:47.036869" elapsed="0.087379"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:47.036239" elapsed="0.088114"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:47.032639" elapsed="0.091771"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.125399" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/announce_l3vpn_mcast.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/announce_l3vpn_mcast.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.125615" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.125179" elapsed="0.000479"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:47.126089" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.125831" elapsed="0.000286"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.126482" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/withdraw_l3vpn_mcast.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/withdraw_l3vpn_mcast.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.126620" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.126284" elapsed="0.000382"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:47.127039" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.126830" elapsed="0.000236"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:47.127368" elapsed="0.003104"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.127140" elapsed="0.003373"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.127120" elapsed="0.003421"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.170018" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.169561" elapsed="0.000492"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.170940" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.170598" elapsed="0.000424">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.171119" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.170240" elapsed="0.000904"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.171747" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.171323" elapsed="0.000452"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.172098" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.172280" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.171949" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.172897" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.172607" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.174038" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.173730" elapsed="0.000355"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.174537" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.174257" elapsed="0.000365"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.175362" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.175044" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.176400" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.175946" elapsed="0.000481"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.176483" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:47.176684" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.175590" elapsed="0.001120"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.176877" elapsed="0.000253"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:47.174896" elapsed="0.002275"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.177760" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.177428" elapsed="0.000358"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.180813" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.180338" elapsed="0.000505"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.180903" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:47.181070" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.178000" elapsed="0.003095"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.181261" elapsed="0.000237"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:47.177288" elapsed="0.004253"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.174702" elapsed="0.006877"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.181626" elapsed="0.000077"/>
</return>
<msg time="2026-06-06T03:30:47.181840" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:47.173363" elapsed="0.008503"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.173028" elapsed="0.008887"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.182109" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.181943" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.173002" elapsed="0.009185"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.182994" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:47.182336" elapsed="0.000688"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.183079" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:47.168881" elapsed="0.014329"/>
</kw>
<msg time="2026-06-06T03:30:47.183268" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.156027" elapsed="0.027293"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.196118" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.208925" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.221688" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.221943" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.222135" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.222549" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.222393" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.222375" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.222802" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.222976" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.223145" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:47.222339" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.222219" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.223379" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.223458" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:47.223604" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:47.151545" elapsed="0.072087"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.249035" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.248600" elapsed="0.000466"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.249893" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.249601" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.250095" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.249248" elapsed="0.000872"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.250722" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.250297" elapsed="0.000454"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.251075" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.251271" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;IAABrBAALABlGAoCIgAAAAA=&lt;/route-key&gt;
    &lt;route-distinguis...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.250926" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.251754" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;IAABrBAALABlGAoCIgAAAAA=&lt;/route-key&gt;
    &lt;route-distinguisher&gt;172.16.0.44:101&lt;/route-distinguisher&gt;
    &lt;prefix&gt;10.2.34.0/24&lt;/prefix&gt;
    &lt;attributes&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.16.0.44&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
&lt;/l3vpn-mcast-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.251471" elapsed="0.000406"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:47.252300" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.251957" elapsed="0.000404"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.252882" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.252543" elapsed="0.000366"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.252388" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.251934" elapsed="0.001034"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.253602" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;IAABrBAALABlGAoCIgAAAAA=&lt;/route-key&gt;
    &lt;route-distinguis...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:47.253126" elapsed="0.000507"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.253709" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:47.247930" elapsed="0.005915"/>
</kw>
<msg time="2026-06-06T03:30:47.253906" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.235037" elapsed="0.018951"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.266941" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.279515" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.292046" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.292275" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.292461" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.292879" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.292723" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.292706" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.293108" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.293281" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.293453" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:47.292672" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.292541" elapsed="0.001041"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.293764" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.293859" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:30:47.294050" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;IAABrBAALABlGAoCIgAAAAA=&lt;/route-key&gt;
    &lt;route-distinguis...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:47.234077" elapsed="0.060004"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.295564" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.295243" elapsed="0.000439">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.295788" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.294843" elapsed="0.000977"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.296205" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.295918" elapsed="0.000348"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.296836" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.296490" elapsed="0.000375"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.296291" elapsed="0.000612"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.295895" elapsed="0.001031"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.299393" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.297092" elapsed="0.002330"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:47.299482" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:47.299663" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:47.294452" elapsed="0.005239"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.301310" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.301039" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.301789" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;IAABrBAALABlGAoCIgAAAAA=&lt;/route-key&gt;
    &lt;route-distinguisher&gt;172.16.0.44:101&lt;/route-distinguisher&gt;
    &lt;prefix&gt;10.2.34.0/24&lt;/prefix&gt;
    &lt;attributes&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.16.0.44&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
&lt;/l3vpn-mcast-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.301524" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.302324" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.302065" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.302802" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.302532" elapsed="0.000315"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:47.303705" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:47.303483" elapsed="0.000249"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:47.304074" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:47.303894" elapsed="0.000258"/>
</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-06-06T03:30:47.304316" elapsed="0.000216"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.305070" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.304744" elapsed="0.000374"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:47.305165" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:47.305366" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:47.303063" elapsed="0.002332"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:47.321555" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '1045', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;IAABrBAALABlGAoCIgAAAAA=&lt;/route-key&gt;
    &lt;route-distinguisher&gt;172.16.0.44:101&lt;/route-distinguisher&gt;
    &lt;prefix&gt;10.2.34.0/24&lt;/prefix&gt;
    &lt;attributes&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;127.16.0.44&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
&lt;/l3vpn-mcast-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:47.321637" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4/l3vpn-mcast-route=IAABrBAALABlGAoCIgAAAAA%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:47.321800" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:47.307908" elapsed="0.013919"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.305474" elapsed="0.016409"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.322134" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.321913" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.305455" elapsed="0.016810"/>
</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-06-06T03:30:47.330298" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.324778" elapsed="0.005569"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.324162" elapsed="0.006226"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.324119" elapsed="0.006296"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.333109" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.330743" elapsed="0.002416"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.330477" elapsed="0.002720"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.330458" elapsed="0.002768"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.333865" 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-06-06T03:30:47.333426" elapsed="0.000467"/>
</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-06-06T03:30:47.334262" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.333991" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.334860" 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-06-06T03:30:47.334516" elapsed="0.000371"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.334346" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.333965" elapsed="0.000981"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.335501" 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-06-06T03:30:47.335121" elapsed="0.000407"/>
</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-06-06T03:30:47.335971" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.335601" elapsed="0.000435"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.336550" 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-06-06T03:30:47.336231" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.336061" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.335582" elapsed="0.001053"/>
</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-06-06T03:30:47.336825" elapsed="0.000362"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:47.337691" 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-06-06T03:30:47.337365" elapsed="0.000354"/>
</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-06-06T03:30:47.337886" elapsed="0.002445"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:47.323123" elapsed="0.017280"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:47.340602" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:30:47.340485" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.340464" elapsed="0.000251"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:47.340882" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.340951" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:47.343295" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:47.300048" elapsed="0.043276"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.343401" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:47.343563" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:47.136575" elapsed="0.207014"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.343990" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.343719" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.343700" elapsed="0.000386"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.344119" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:47.130875" elapsed="0.213372"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:47.347891" level="INFO">${update} = ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.345257" elapsed="0.002667"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:47.348105" elapsed="0.003219"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:47.351429" elapsed="0.000063"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:47.344963" elapsed="0.006729"/>
</kw>
<msg time="2026-06-06T03:30:47.351815" level="INFO">${update} = ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:47.344437" elapsed="0.007417"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.353302" level="INFO">Length is 154.</msg>
<msg time="2026-06-06T03:30:47.353414" level="INFO">${len_1} = 154</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:47.352863" elapsed="0.000587"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.354236" level="INFO">Length is 154.</msg>
<msg time="2026-06-06T03:30:47.354352" level="INFO">${len_2} = 154</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:47.353723" elapsed="0.000664"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:47.354637" elapsed="0.000500"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:47.355687" level="INFO">${sum_1} = 1699</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:47.355387" elapsed="0.000339"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:47.356234" level="INFO">${sum_2} = 1699</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:47.355963" elapsed="0.000308"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:47.356506" elapsed="0.000491"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:47.352240" elapsed="0.004849"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:47.357324" elapsed="0.002407"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.404101" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.403684" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.404954" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.404691" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.405130" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.404319" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.405756" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.405335" elapsed="0.000449"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.406124" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.406289" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.405957" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.406761" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.406481" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.408312" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.407764" elapsed="0.000597"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.408905" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.408542" elapsed="0.000392"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.409804" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.409337" elapsed="0.000494"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.411041" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.410528" elapsed="0.000596"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.411268" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:47.411509" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.410081" elapsed="0.001454"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.411727" elapsed="0.000420"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:47.409187" elapsed="0.003066"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.412986" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.412527" elapsed="0.000486"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.414177" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.413678" elapsed="0.000582"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.414400" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:47.414631" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.413217" elapsed="0.001459"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.414844" elapsed="0.000413"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:47.412380" elapsed="0.002922"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.408995" elapsed="0.006344"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.415386" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:47.415549" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:47.407227" elapsed="0.008348"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.406890" elapsed="0.008719"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.415841" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.415637" elapsed="0.000263"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.406865" elapsed="0.009056"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.416708" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:47.416070" elapsed="0.000669"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.416794" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:47.402983" elapsed="0.013941"/>
</kw>
<msg time="2026-06-06T03:30:47.416982" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.390120" elapsed="0.026915"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.429863" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.442396" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.454970" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.455198" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.455449" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.455872" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.455716" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.455699" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.456099" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.456277" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.456448" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:47.455664" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.455531" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.456697" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.456776" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:47.456913" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:47.385611" elapsed="0.071330"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.458594" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.457858" elapsed="0.000956"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:47.473745" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:47.473854" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:47.474111" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:47.464869" elapsed="0.009307"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.459035" elapsed="0.015219"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.474523" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.474295" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.458972" elapsed="0.015691"/>
</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-06-06T03:30:47.479541" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.476173" elapsed="0.003429"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.475852" elapsed="0.003817"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.475825" elapsed="0.003882"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.483036" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.480105" elapsed="0.002977"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.479788" elapsed="0.003328"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.479764" elapsed="0.003376"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.483754" 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-06-06T03:30:47.483333" elapsed="0.000448"/>
</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-06-06T03:30:47.484097" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.483853" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.484748" 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-06-06T03:30:47.484421" elapsed="0.000354"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.484248" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.483834" elapsed="0.000998"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.485360" 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-06-06T03:30:47.484996" elapsed="0.000391"/>
</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-06-06T03:30:47.485712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.485457" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.486273" 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-06-06T03:30:47.485959" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.485794" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.485438" elapsed="0.000918"/>
</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-06-06T03:30:47.486517" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:47.487357" 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-06-06T03:30:47.487054" elapsed="0.000329"/>
</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-06-06T03:30:47.487543" elapsed="0.002333"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:47.475223" elapsed="0.014719"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:47.489995" elapsed="0.000087"/>
</return>
<msg time="2026-06-06T03:30:47.492409" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:47.457220" elapsed="0.035217"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.492494" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:47.360942" elapsed="0.131681"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:47.360403" elapsed="0.132296"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:47.359961" elapsed="0.132804"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:47.496113" level="INFO">${update} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.493714" elapsed="0.002429"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:47.496324" elapsed="0.002205"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:47.498580" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:47.493423" elapsed="0.005299"/>
</kw>
<msg time="2026-06-06T03:30:47.498802" level="INFO">${update} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:47.492943" elapsed="0.005885"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.499701" level="INFO">Length is 142.</msg>
<msg time="2026-06-06T03:30:47.499778" level="INFO">${len_1} = 142</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:47.499418" elapsed="0.000384"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.500213" level="INFO">Length is 142.</msg>
<msg time="2026-06-06T03:30:47.500289" level="INFO">${len_2} = 142</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:47.499960" elapsed="0.000354"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:47.500476" elapsed="0.000325"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:47.501146" level="INFO">${sum_1} = 1491</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:47.500963" elapsed="0.000209"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:47.501502" level="INFO">${sum_2} = 1491</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:47.501327" elapsed="0.000201"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:47.501740" elapsed="0.000346"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:47.499046" elapsed="0.003102"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.547519" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.547135" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.548353" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.548084" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.548529" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.547739" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.549134" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.548743" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.549466" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.549615" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.549327" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.550088" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.549819" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.551140" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.550882" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.551622" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.551349" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.552582" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.552040" elapsed="0.000568"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.553766" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.553303" elapsed="0.000505"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.553929" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:47.554181" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.552822" elapsed="0.001385"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.554370" elapsed="0.000514"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:47.551900" elapsed="0.003025"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.555697" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.555177" elapsed="0.000547"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.556997" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.556388" elapsed="0.000650"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.557153" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:47.557370" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.555913" elapsed="0.001483"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.557554" elapsed="0.000588"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:47.555040" elapsed="0.003194"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.551720" elapsed="0.006555"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.558337" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:47.558539" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:47.550506" elapsed="0.008064"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.550206" elapsed="0.008397"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.558804" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.558628" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.550186" elapsed="0.008695"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.559600" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:47.559027" elapsed="0.000602"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.559694" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:47.546435" elapsed="0.013384"/>
</kw>
<msg time="2026-06-06T03:30:47.559874" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.533241" elapsed="0.026693"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.572957" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.585404" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.597913" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.598140" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.598332" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.598740" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.598568" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.598552" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.598971" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.599147" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.599317" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:47.598519" elapsed="0.000895"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.598412" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.599599" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.599697" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:47.599830" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:47.528618" elapsed="0.071240"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.601042" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.600769" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:47.611508" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:47.611931" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '402'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family']/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:47.612078" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:47.612122" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.603257" elapsed="0.009587">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:47.601157" elapsed="0.011867">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.613455" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.613099" elapsed="0.000496"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:47.601139" elapsed="0.012537">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</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-06-06T03:30:47.622138" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.616123" elapsed="0.006100">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:47.615552" elapsed="0.006817">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:47.615510" elapsed="0.006930">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.625532" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.623148" elapsed="0.002416">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:47.622600" elapsed="0.003027">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:47.622559" elapsed="0.003155">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.626345" 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-06-06T03:30:47.625921" elapsed="0.000452"/>
</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-06-06T03:30:47.626711" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.626447" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.627268" 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-06-06T03:30:47.626964" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.626795" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.626427" elapsed="0.000924"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.627898" 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-06-06T03:30:47.627517" elapsed="0.000409"/>
</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-06-06T03:30:47.628240" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.627995" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.628800" 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-06-06T03:30:47.628488" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.628323" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.627977" elapsed="0.000906"/>
</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-06-06T03:30:47.629039" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:47.629873" 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-06-06T03:30:47.629561" elapsed="0.000339"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:47.632334" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.630074" elapsed="0.002292">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:47.614531" elapsed="0.017972">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:47.632564" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:47.634983" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:47.635013" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:47.600127" elapsed="0.034915">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.635109" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.503407" elapsed="0.131873">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:47.502802" elapsed="0.132544"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:47.502386" elapsed="0.133021"/>
</kw>
<arg>l3vpn_mcast</arg>
<arg>${L3VPN_MCAST_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:47.124761" elapsed="0.510700"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.032152" elapsed="0.603434"/>
</test>
<test id="s1-s17-t5" name="Play_To_Odl_l3vpn_mcast" line="73">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:47.638982" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:47.638712" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.640241" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.640131" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.640112" elapsed="0.000234"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.645312" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.645204" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.645185" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.646421" 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-06-06T03:30:47.646018" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.646931" 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-06-06T03:30:47.646615" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:47.647002" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:47.647156" 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-06-06T03:30:47.645610" elapsed="0.001570"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:47.652702" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.652578" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.652558" elapsed="0.000213"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:47.653954" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.653847" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.653828" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:47.654492" 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-06-06T03:30:47.654192" elapsed="0.000326"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.654922" level="INFO">${current_connection_index} = 7</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-06-06T03:30:47.654699" elapsed="0.000249"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.685843" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:47.655451" elapsed="0.030504"/>
</kw>
<msg time="2026-06-06T03:30:47.686176" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:47.686231" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:47.655110" elapsed="0.031159"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:47.718195" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "l "3 "v "p "n "_ "m "c "a "s "t "[K"
[?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-06-06T03:30:47.686988" elapsed="0.031371"/>
</kw>
<msg time="2026-06-06T03:30:47.718603" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:47.718700" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "...</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-06-06T03:30:47.686454" elapsed="0.032304"/>
</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-06-06T03:30:47.719228" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.718879" elapsed="0.000437"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.718848" elapsed="0.000504"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.720050" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "l "3 "v "p "n "_ "m "c "a "s "t "[K"
[?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-06-06T03:30:47.719573" elapsed="0.000587"/>
</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-06-06T03:30:47.720599" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.720262" elapsed="0.000442"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.720234" elapsed="0.000507"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:47.720790" elapsed="0.000043"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:47.724160" elapsed="0.000183"/>
</kw>
<msg time="2026-06-06T03:30:47.724408" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.722992" elapsed="0.001549"/>
</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="NOT RUN" start="2026-06-06T03:30:47.724843" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.725189" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:47.722016" elapsed="0.003356"/>
</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-06-06T03:30:47.721192" elapsed="0.004243"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:47.653521" elapsed="0.072013"/>
</kw>
<msg time="2026-06-06T03:30:47.725629" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:47.725690" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:47.652926" elapsed="0.072803"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:47.725918" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:47.725807" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.725788" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.726432" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.726785" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.726857" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:47.652241" elapsed="0.074723"/>
</kw>
<msg time="2026-06-06T03:30:47.727057" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:47.727101" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:47.647559" elapsed="0.079579"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.727470" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.727213" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.727195" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:47.647414" elapsed="0.080156"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:47.647239" elapsed="0.080360"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:47.644843" elapsed="0.082831"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:47.639846" elapsed="0.087885"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:47.639401" elapsed="0.088375"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:47.636417" elapsed="0.091412"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.728952" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.728458" elapsed="0.000523"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.729605" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.729151" elapsed="0.000482"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.730217" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.729819" elapsed="0.000426"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.730618" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/announce_l3vpn_mcast.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/announce_l3vpn_mcast.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.730826" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.730413" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.731206" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/withdraw_l3vpn_mcast.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/withdraw_l3vpn_mcast.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.731329" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.731015" elapsed="0.000341"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:47.731513" elapsed="0.002702"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:47.734379" elapsed="0.001990"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.788791" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.788397" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.789566" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.789329" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.789748" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.788988" elapsed="0.000785"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.790343" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.789942" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.790684" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:47.790816" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:47.790534" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.791247" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.791002" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.792294" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.792004" elapsed="0.000336"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.792789" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.792502" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.793577" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.793175" elapsed="0.000428"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.794865" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.794300" elapsed="0.000664"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.795043" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:47.795336" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.793815" elapsed="0.001547"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.795523" elapsed="0.000397"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:47.793034" elapsed="0.002928"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.798176" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:47.796213" elapsed="0.002030"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:47.799460" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.798921" elapsed="0.000641"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:47.799652" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:47.799946" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:47.798443" elapsed="0.001529"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:47.800130" elapsed="0.000364"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:47.796075" elapsed="0.004462"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.792863" elapsed="0.007710"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:47.800616" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:47.800790" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:47.791674" elapsed="0.009142"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.791359" elapsed="0.009489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.801027" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.800873" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.791340" elapsed="0.009763"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.801881" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:47.801247" elapsed="0.000663"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:47.801960" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:47.787776" elapsed="0.014308"/>
</kw>
<msg time="2026-06-06T03:30:47.802171" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:47.775129" elapsed="0.027092"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.814819" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.827393" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.839827" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.840028" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.840208" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.840617" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.840467" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.840452" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.840860" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.841035" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.841206" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:47.840424" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.840324" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.841435" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.841511" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:47.841632" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:47.770739" elapsed="0.070934"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.842978" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.842728" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.843137" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.842360" elapsed="0.000802"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.843490" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.843235" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.844059" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:47.843763" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.843572" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.843214" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.846680" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:47.844297" elapsed="0.002410"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:47.846759" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:47.846915" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:47.841999" elapsed="0.004941"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:47.848257" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.848019" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:47.848414" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:47.847669" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:47.848663" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:47.848510" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:47.848491" elapsed="0.000266"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.848954" elapsed="0.000026"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.849179" elapsed="0.000088"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.849321" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:47.851316" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:47.847252" elapsed="0.004236"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.852922" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.852666" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:47.853381" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:47.853131" elapsed="0.000295"/>
</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-06-06T03:30:47.860754" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:47.860898" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:47.861005" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</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="FAIL" start="2026-06-06T03:30:47.855603" elapsed="0.005773">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:47.853493" elapsed="0.007969">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</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-06-06T03:30:47.861676" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.861496" elapsed="0.000249"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:47.853474" elapsed="0.008296">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:47.862175" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.862316" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:47.862279" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.862261" elapsed="0.000120"/>
</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-06-06T03:30:47.862532" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.862604" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:47.851829" elapsed="0.010898">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.862804" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.746714" elapsed="0.116187">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:47.863222" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:47.863032" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:47.863013" elapsed="0.000308"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:47.863355" elapsed="0.000014"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:47.741152" elapsed="0.122302">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.922007" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:49.921581" elapsed="0.000461"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:49.922884" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:49.922578" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:49.923060" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:49.922223" elapsed="0.000863"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.923675" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:49.923263" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:49.924019" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:49.924184" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:49.923874" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.924636" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:49.924379" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.925781" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:49.925446" elapsed="0.000383"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.926276" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:49.925998" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.927146" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:49.926712" elapsed="0.000461"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:49.928428" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:49.927857" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:49.928612" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:30:49.928933" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:49.927372" elapsed="0.001587"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:49.929122" elapsed="0.000387"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:49.926543" elapsed="0.003073"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.930492" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:49.929896" elapsed="0.000624"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:49.931792" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:49.931216" elapsed="0.000678"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:49.931971" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:49.932269" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:49.930733" elapsed="0.001563"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:49.932461" elapsed="0.000395"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:49.929754" elapsed="0.003146"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:49.926362" elapsed="0.006574"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:49.932979" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:49.933141" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:49.925109" elapsed="0.008059"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:49.924781" elapsed="0.008420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.933385" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:49.933226" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:49.924757" elapsed="0.008706"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.934261" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:49.933613" elapsed="0.000678"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:49.934344" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:49.920936" elapsed="0.013542"/>
</kw>
<msg time="2026-06-06T03:30:49.934536" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:49.907817" elapsed="0.026772"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.947531" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.960033" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.972486" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.972721" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.972995" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.973417" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:49.973258" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:49.973240" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.973664" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.973844" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.974018" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:49.973201" elapsed="0.000871"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:49.973083" elapsed="0.001017"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.974254" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:49.974331" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:49.974475" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:49.903177" elapsed="0.071326"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:49.975938" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:49.975633" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:49.976111" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:49.975238" elapsed="0.000898"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.976472" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:49.976208" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.977058" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:49.976759" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:49.976555" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:49.976189" elapsed="0.000953"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.979739" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:49.977299" elapsed="0.002468"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:49.979821" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:49.979977" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:49.974855" elapsed="0.005147"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:49.981245" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:49.981009" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:49.981402" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:49.980661" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:49.981635" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:30:49.981498" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:49.981479" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.981930" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:49.982111" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:49.982178" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:49.984141" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:49.980314" elapsed="0.003855"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.985676" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:49.985379" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:49.986138" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:49.985890" elapsed="0.000293"/>
</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-06-06T03:30:49.996103" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:49.996544" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}} 
 </msg>
<msg time="2026-06-06T03:30:49.996666" 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-06-06T03:30:49.988448" elapsed="0.008247"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:49.986257" elapsed="0.010483"/>
</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-06-06T03:30:49.996932" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:49.996769" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:49.986235" elapsed="0.010783"/>
</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-06-06T03:30:50.000760" level="INFO">{"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:49.998092" elapsed="0.002721"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:49.997862" elapsed="0.002986"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:49.997842" elapsed="0.003032"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.003497" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.001164" elapsed="0.002381"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.000933" elapsed="0.002647"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.000915" elapsed="0.002690"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.004202" 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-06-06T03:30:50.003806" elapsed="0.000424"/>
</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-06-06T03:30:50.004555" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.004304" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.005130" 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-06-06T03:30:50.004826" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.004651" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.004284" elapsed="0.000930"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.005766" 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-06-06T03:30:50.005381" elapsed="0.000412"/>
</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-06-06T03:30:50.006174" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.005928" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.006746" 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-06-06T03:30:50.006427" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.006257" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.005907" elapsed="0.000924"/>
</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-06-06T03:30:50.007024" elapsed="0.000364"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:50.007873" 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-06-06T03:30:50.007562" elapsed="0.000338"/>
</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-06-06T03:30:50.008063" elapsed="0.002318"/>
</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-06-06T03:30:49.997408" elapsed="0.013038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.010627" elapsed="0.000030"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:50.010518" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.010499" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.013728" level="INFO">${text_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<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="PASS" start="2026-06-06T03:30:50.010864" elapsed="0.002894"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:50.013811" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:50.013977" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:49.984498" elapsed="0.029506"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.014068" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:50.014222" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:49.879502" elapsed="0.134747"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.042819" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.042315" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.043705" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.043395" elapsed="0.000440">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.044016" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.043050" elapsed="0.000991"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.044675" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.044212" elapsed="0.000491"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.045030" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.045229" level="INFO">${template} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.044871" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.045712" level="INFO">{
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "127.16.0.44"
                    },
                    "extended-communities": [
                        {
                            "vrf-route-import-extended-community": {
                                "inet4-specific-extended-community-common": {
                                    "local-administrator": "MTA=",
                                    "global-administrator": "10.0.0.1"
                                }
                            },
                            "transitive": true
                        }
                    ],
                    "local-pref": {
                        "pref": 100
                    },
                    "origin": {
                        "value": "igp"
                    }
                },
                "route-distinguisher": "172.16.0.44:101",
                "prefix": "10.2.34.0/24"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.045421" elapsed="0.000346"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:50.046247" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.045839" elapsed="0.000469"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.047040" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.046490" elapsed="0.000577"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.046336" elapsed="0.000769"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.045818" elapsed="0.001309"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.047824" level="INFO">${final_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.047281" elapsed="0.000572"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.047904" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.041688" elapsed="0.006344"/>
</kw>
<msg time="2026-06-06T03:30:50.048093" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.028811" elapsed="0.019330"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.060653" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.073066" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.085487" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.085699" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.085923" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.086318" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.086164" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.086148" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.086544" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.086733" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.086906" elapsed="0.000047"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.086118" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.086008" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.087168" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.087243" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:50.087388" level="INFO">${expected_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.026129" elapsed="0.061287"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.087597" elapsed="0.002388"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.091258" level="INFO">${expected_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.090748" elapsed="0.000538"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.091929" level="INFO">${actual_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.091445" elapsed="0.000512"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:50.092120" elapsed="0.000326"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:50.090311" elapsed="0.002195"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.090066" elapsed="0.002474"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.092735" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.092565" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.090047" elapsed="0.002766"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:50.015439" elapsed="0.077423"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:50.014580" elapsed="0.078358"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.014334" elapsed="0.078650"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.014316" elapsed="0.078692"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.093041" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:49.874126" elapsed="0.219043"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:47.736545" elapsed="2.356684"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.143653" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.143147" elapsed="0.000546"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.144573" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.144294" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.144769" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.143912" elapsed="0.000881"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.145367" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.144971" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.145727" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.145916" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.145563" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.146376" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.146115" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.147936" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.147346" elapsed="0.000641"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.148448" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.148162" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.149320" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.148892" elapsed="0.000458"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:50.150606" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.150042" elapsed="0.000688"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:50.150816" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:50.151232" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:50.149552" elapsed="0.001708"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.151430" elapsed="0.000426"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:50.148744" elapsed="0.003158"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.152587" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.152162" elapsed="0.000452"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:50.153986" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.153352" elapsed="0.000750"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:50.154185" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:50.154492" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:50.152831" elapsed="0.001689"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.154717" elapsed="0.000450"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:50.152020" elapsed="0.003195"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:50.148532" elapsed="0.006773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:50.155356" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:50.155522" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:50.146975" elapsed="0.008574"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.146520" elapsed="0.009062"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.155782" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.155608" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.146488" elapsed="0.009375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.156617" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.156017" elapsed="0.000645"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.156715" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.142405" elapsed="0.014439"/>
</kw>
<msg time="2026-06-06T03:30:50.156902" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.129400" elapsed="0.027552"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.169459" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.181738" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.194331" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.194574" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.194780" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.195200" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.195047" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.195029" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.195426" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.195596" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.195786" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.194993" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.194864" elapsed="0.001064"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.196083" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.196161" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:50.196312" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.125119" elapsed="0.071221"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.197748" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.197449" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.197919" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.197058" elapsed="0.000886"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.198279" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.198015" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.198866" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.198551" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.198367" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.197996" elapsed="0.000985"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.201594" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.199141" elapsed="0.002480"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:50.201688" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:50.201847" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:50.196704" elapsed="0.005168"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.203121" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.202871" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.203276" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.202512" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:50.203513" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:30:50.203377" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.203358" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.203762" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.203940" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.204005" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:50.205926" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:50.202181" elapsed="0.003771"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.207365" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.207112" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.207827" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.207567" elapsed="0.000304"/>
</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-06-06T03:30:50.216457" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:50.216605" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}} 
 </msg>
<msg time="2026-06-06T03:30:50.216726" 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-06-06T03:30:50.210058" elapsed="0.006695"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.207982" elapsed="0.008815"/>
</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-06-06T03:30:50.216985" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.216824" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.207962" elapsed="0.009109"/>
</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-06-06T03:30:50.221280" level="INFO">{"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.218105" elapsed="0.003246"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.217879" elapsed="0.003522"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.217860" elapsed="0.003577"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.225146" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.221862" elapsed="0.003350"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.221518" elapsed="0.003744"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.221493" elapsed="0.003805"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.226096" 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-06-06T03:30:50.225538" elapsed="0.000597"/>
</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-06-06T03:30:50.226736" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.226236" elapsed="0.000582"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.227583" 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-06-06T03:30:50.227101" elapsed="0.000526"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.226852" elapsed="0.000852"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.226210" elapsed="0.001527"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.228516" 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-06-06T03:30:50.227994" elapsed="0.000561"/>
</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-06-06T03:30:50.229034" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.228683" elapsed="0.000434"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.229834" 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-06-06T03:30:50.229388" elapsed="0.000485"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.229152" elapsed="0.000773"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.228628" elapsed="0.001327"/>
</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-06-06T03:30:50.230177" elapsed="0.000602"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:50.231447" 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-06-06T03:30:50.231082" elapsed="0.000392"/>
</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-06-06T03:30:50.231699" elapsed="0.002333"/>
</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-06-06T03:30:50.217439" elapsed="0.016657"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.234274" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:50.234166" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.234147" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.237356" level="INFO">${text_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<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="PASS" start="2026-06-06T03:30:50.234494" elapsed="0.002891"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:50.237438" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:50.237599" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:50.206264" elapsed="0.031362"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.237706" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:50.237861" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:50.102276" elapsed="0.135611"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.266451" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.265983" elapsed="0.000497"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.267311" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.267036" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.267610" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.266670" elapsed="0.000966"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.268267" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.267826" elapsed="0.000469"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.268622" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.268792" level="INFO">${template} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.268462" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.269252" level="INFO">{
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "127.16.0.44"
                    },
                    "extended-communities": [
                        {
                            "vrf-route-import-extended-community": {
                                "inet4-specific-extended-community-common": {
                                    "local-administrator": "MTA=",
                                    "global-administrator": "10.0.0.1"
                                }
                            },
                            "transitive": true
                        }
                    ],
                    "local-pref": {
                        "pref": 100
                    },
                    "origin": {
                        "value": "igp"
                    }
                },
                "route-distinguisher": "172.16.0.44:101",
                "prefix": "10.2.34.0/24"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.268982" elapsed="0.000359"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:50.269836" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.269413" elapsed="0.000484"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.270587" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.270075" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.269923" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.269392" elapsed="0.001296"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.271345" level="INFO">${final_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.270841" elapsed="0.000538"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.271429" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.265347" elapsed="0.006209"/>
</kw>
<msg time="2026-06-06T03:30:50.271617" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.252378" elapsed="0.019310"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.284188" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.296667" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.309142" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.309370" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.309556" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.309975" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.309824" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.309808" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.310202" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.310378" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.310548" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.309774" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.309653" elapsed="0.001040"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.310853" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.310932" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:50.311108" level="INFO">${expected_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.249705" elapsed="0.061431"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.311319" elapsed="0.003528"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.316195" level="INFO">${expected_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.315670" elapsed="0.000556"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.316872" level="INFO">${actual_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.316387" elapsed="0.000514"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:50.317063" elapsed="0.000423"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:50.315225" elapsed="0.002323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.314929" elapsed="0.002653"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.317780" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.317608" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.314910" elapsed="0.002949"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:50.239078" elapsed="0.078830"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:50.238218" elapsed="0.079767"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.237973" elapsed="0.080059"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.237955" elapsed="0.080101"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.318089" elapsed="0.000033"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:50.097803" elapsed="0.220416"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:50.093458" elapsed="0.224819"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.369484" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.369035" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.370337" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.370077" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.370664" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.369722" elapsed="0.000979"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.371401" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.370943" elapsed="0.000487"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.371770" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.371930" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.371604" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.372383" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.372124" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.373784" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.373232" elapsed="0.000602"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.374323" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.374008" elapsed="0.000346"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.375285" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.374780" elapsed="0.000532"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:50.376549" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.375997" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:50.376747" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:50.377045" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:50.375514" elapsed="0.001558"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.377235" elapsed="0.000553"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:50.374609" elapsed="0.003222"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.378661" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.378087" elapsed="0.000602"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:50.380074" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.379471" elapsed="0.000704"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:50.380257" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:50.380580" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:50.378881" elapsed="0.001727"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.380788" elapsed="0.000395"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:50.377947" elapsed="0.003281"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:50.374422" elapsed="0.006843"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:50.381311" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:50.381497" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:50.372890" elapsed="0.008634"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.372510" elapsed="0.009049"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.381780" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.381587" elapsed="0.000256"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.372485" elapsed="0.009379"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.382661" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.382020" elapsed="0.000673"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.382745" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.368377" elapsed="0.014498"/>
</kw>
<msg time="2026-06-06T03:30:50.382985" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.354962" elapsed="0.028126"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.398570" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.411493" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.424691" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.424962" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.425161" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.425589" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.425432" elapsed="0.000233"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.425413" elapsed="0.000280"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.425845" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.426017" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.426186" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.425373" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.425248" elapsed="0.001019"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.426443" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.426530" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:30:50.426724" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.350328" elapsed="0.076428"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.428275" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.427964" elapsed="0.000403">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.428473" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.427483" elapsed="0.001017"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.428873" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.428576" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.429458" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.429154" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.428960" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.428555" elapsed="0.000990"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.432336" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.429724" elapsed="0.002642"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:50.432422" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:50.432585" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:50.427119" elapsed="0.005493"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.433977" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.433734" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.434144" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.433348" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:50.434391" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:50.434245" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.434226" elapsed="0.000251"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.434633" elapsed="0.000039"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.434855" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.434929" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:50.437111" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:50.432952" elapsed="0.004188"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.438626" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.438362" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.439131" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.438856" elapsed="0.000322"/>
</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-06-06T03:30:50.447833" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:50.448014" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '484'} 
 body={"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}} 
 </msg>
<msg time="2026-06-06T03:30:50.448190" 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-06-06T03:30:50.441482" elapsed="0.006736"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.439245" elapsed="0.009019"/>
</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-06-06T03:30:50.448487" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.448301" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.439227" elapsed="0.009351"/>
</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-06-06T03:30:50.452990" level="INFO">{"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.449711" elapsed="0.003357"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.449423" elapsed="0.003698"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.449402" elapsed="0.003754"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.457494" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.453576" elapsed="0.003989"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.453237" elapsed="0.004381"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.453212" elapsed="0.004466"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.458587" 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-06-06T03:30:50.457992" elapsed="0.000644"/>
</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-06-06T03:30:50.459296" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.458808" elapsed="0.000566"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.459957" 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-06-06T03:30:50.459593" elapsed="0.000393"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.459400" elapsed="0.000624"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.458769" elapsed="0.001277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.460609" 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-06-06T03:30:50.460218" elapsed="0.000445"/>
</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-06-06T03:30:50.461057" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.460766" elapsed="0.000368"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.461667" 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-06-06T03:30:50.461344" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.461167" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.460740" elapsed="0.001016"/>
</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-06-06T03:30:50.461919" elapsed="0.000408"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:50.462867" 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-06-06T03:30:50.462524" elapsed="0.000377"/>
</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-06-06T03:30:50.463099" elapsed="0.002447"/>
</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-06-06T03:30:50.448980" elapsed="0.016636"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.465824" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:50.465709" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.465688" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.469119" level="INFO">${text_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<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="PASS" start="2026-06-06T03:30:50.466055" elapsed="0.003097"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:50.469209" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:30:50.469404" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:50.437467" elapsed="0.032012"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.469549" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:50.469729" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:50.327236" elapsed="0.142521"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.499411" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.498876" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.500268" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.499984" elapsed="0.000407">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.500598" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.499614" elapsed="0.001010"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.501289" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.500837" elapsed="0.000480"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.501670" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.501831" level="INFO">${template} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.501492" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.502336" level="INFO">{
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "127.16.0.44"
                    },
                    "extended-communities": [
                        {
                            "vrf-route-import-extended-community": {
                                "inet4-specific-extended-community-common": {
                                    "local-administrator": "MTA=",
                                    "global-administrator": "10.0.0.1"
                                }
                            },
                            "transitive": true
                        }
                    ],
                    "local-pref": {
                        "pref": 100
                    },
                    "origin": {
                        "value": "igp"
                    }
                },
                "route-distinguisher": "172.16.0.44:101",
                "prefix": "10.2.34.0/24"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.502026" elapsed="0.000369"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:50.502905" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.502468" elapsed="0.000502"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.503718" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.503183" elapsed="0.000563"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.502996" elapsed="0.000796"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.502447" elapsed="0.001376"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.504517" level="INFO">${final_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.503985" elapsed="0.000562"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.504598" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.498214" elapsed="0.006541"/>
</kw>
<msg time="2026-06-06T03:30:50.504857" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.484972" elapsed="0.019937"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.517933" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.531015" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.543888" elapsed="0.000036"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.544141" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.544343" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.544801" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.544620" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.544600" elapsed="0.000289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.545052" elapsed="0.000030"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.545259" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.545464" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.544557" elapsed="0.000966"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.544434" elapsed="0.001119"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.545733" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.545832" elapsed="0.000024"/>
</return>
<msg time="2026-06-06T03:30:50.546059" level="INFO">${expected_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
        "l3vpn-mcast-route": [
            {
                "route-key": "IAABrBAALABlGAoCIgAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.482178" elapsed="0.063917"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.546327" elapsed="0.002813"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.550712" level="INFO">${expected_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.550090" elapsed="0.000714"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.551476" level="INFO">${actual_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.550976" elapsed="0.000531"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:50.551704" elapsed="0.000385"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:50.549597" elapsed="0.002558"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.549244" elapsed="0.002947"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.552379" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.552219" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.549216" elapsed="0.003242"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:50.470965" elapsed="0.081550"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:50.470109" elapsed="0.082497"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.469845" elapsed="0.082828"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.469826" elapsed="0.082874"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.552738" elapsed="0.000035"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:50.322832" elapsed="0.230046"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:50.318454" elapsed="0.234485"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:50.553112" elapsed="0.002964"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.610738" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.610237" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.611739" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.611414" elapsed="0.000417">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.611932" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.610996" elapsed="0.000961"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.612608" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.612147" elapsed="0.000505"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.612974" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.613148" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.612826" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.613672" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.613368" elapsed="0.000359"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.615183" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.614792" elapsed="0.000442"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.615863" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.615525" elapsed="0.000366"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.616769" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.616274" elapsed="0.000533"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:50.618146" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.617513" elapsed="0.000735"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:50.618331" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:50.618695" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:50.617039" elapsed="0.001686"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.618910" elapsed="0.000421"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:50.616128" elapsed="0.003257"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.620233" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.619729" elapsed="0.000531"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:50.621598" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.621019" elapsed="0.000712"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:50.621825" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:50.622150" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:50.620474" elapsed="0.001706"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:50.622340" elapsed="0.000417"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:50.619553" elapsed="0.003259"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:50.615946" elapsed="0.006908"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:50.622899" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:50.623064" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:50.614177" elapsed="0.008945"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.613811" elapsed="0.009360"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.623366" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.623201" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.613786" elapsed="0.009658"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.624232" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.623593" elapsed="0.000668"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.624311" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.609352" elapsed="0.015087"/>
</kw>
<msg time="2026-06-06T03:30:50.624495" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.596061" elapsed="0.028487"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.637544" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.649888" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.662481" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.662705" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.662897" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.663321" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.663168" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.663150" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.663547" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.663734" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.663906" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.663087" elapsed="0.000871"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.662978" elapsed="0.001007"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.664134" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.664210" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:50.664343" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.591828" elapsed="0.072545"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.665735" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.665433" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.665907" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.665066" elapsed="0.000865"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.666260" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.666003" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.667086" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.666528" elapsed="0.000605"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.666342" elapsed="0.000829"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.665984" elapsed="0.001209"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.669561" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.667356" elapsed="0.002232"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:50.669655" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:50.669814" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:50.664721" elapsed="0.005118"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.671073" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.670884" elapsed="0.000350"/>
</kw>
<msg time="2026-06-06T03:30:50.671324" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.670524" elapsed="0.000825"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.671564" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:50.671426" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.671405" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.671998" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.672156" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.671828" elapsed="0.000353"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:50.672578" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.672343" elapsed="0.000261"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:50.672667" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:50.672825" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:50.670190" elapsed="0.002660"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.674251" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.673999" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.674718" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.674460" elapsed="0.000302"/>
</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-06-06T03:30:50.683100" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:50.683689" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '649'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:50.683799" 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-06-06T03:30:50.676925" elapsed="0.006900"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.674828" elapsed="0.009044"/>
</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-06-06T03:30:50.684069" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.683901" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.674810" elapsed="0.009346"/>
</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-06-06T03:30:50.687738" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"IAABrBAALABlGAoCIgAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv4-next-hop":{"global":"127.16.0.44"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"10.2.34.0/24"}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.685229" elapsed="0.002561"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.685000" elapsed="0.002824"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.684980" elapsed="0.002869"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.690674" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.688189" elapsed="0.002533"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.687907" elapsed="0.002851"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.687889" elapsed="0.002894"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.691409" 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-06-06T03:30:50.690971" elapsed="0.000465"/>
</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-06-06T03:30:50.691772" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.691507" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.692323" 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-06-06T03:30:50.692023" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.691854" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.691488" elapsed="0.000917"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.692950" 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-06-06T03:30:50.692571" elapsed="0.000406"/>
</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-06-06T03:30:50.693285" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.693046" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.693841" 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-06-06T03:30:50.693531" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.693366" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.693028" elapsed="0.000895"/>
</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-06-06T03:30:50.694082" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:50.694909" 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-06-06T03:30:50.694598" elapsed="0.000337"/>
</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-06-06T03:30:50.695094" elapsed="0.002339"/>
</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-06-06T03:30:50.684542" elapsed="0.012957"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.697697" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:50.697573" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.697553" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.700929" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<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="PASS" start="2026-06-06T03:30:50.697918" elapsed="0.003040"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:50.701012" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:50.701177" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:50.673167" elapsed="0.028037"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.701268" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:50.701421" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:50.568615" elapsed="0.132832"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.730161" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.729671" elapsed="0.000605"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.731170" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.730836" elapsed="0.000463">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:50.731481" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:50.730461" elapsed="0.001046"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.732147" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:50.731698" elapsed="0.000476"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:50.732509" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:50.732694" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:50.732342" elapsed="0.000380"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.733154" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:50.732884" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:50.733733" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.733277" elapsed="0.000519"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.734483" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:50.733972" elapsed="0.000538"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:50.733822" elapsed="0.000725"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:50.733254" elapsed="0.001314"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.735248" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:50.734737" elapsed="0.000540"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:50.735329" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:50.728990" elapsed="0.006471"/>
</kw>
<msg time="2026-06-06T03:30:50.735516" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.716104" elapsed="0.019461"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.748150" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.760771" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.773331" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.773561" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.773769" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.774202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.774043" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:50.774024" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.774434" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.774606" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.774794" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:50.773983" elapsed="0.000864"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.773860" elapsed="0.001015"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.775026" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.775106" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:50.775274" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:50.713428" elapsed="0.061875"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:50.775491" elapsed="0.002487"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.779073" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.778758" elapsed="0.000343"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:50.779951" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:50.779290" elapsed="0.000690"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:50.780473" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
    "l3vpn-mcast-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "transitive": true,
         "vrf-route-import-extended-community": {
          "inet4-specific-extended-community-common": {
           "global-administrator": "10.0.0.1",
           "local-administrator": "MTA="
          }
         }
        }
       ],
       "ipv4-next-hop": {
        "global": "127.16.0.44"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "path-id": 0,
      "prefix": "10.2.34.0/24",
      "route-distinguisher": "172.16.0.44:101",
      "route-key": "IAABrBAALABlGAoCIgAAAAA="
     }
    ]
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:50.780722" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
+        }
+       ],
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.780143" elapsed="0.000701">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.778309" elapsed="0.002708">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:50.778059" elapsed="0.003052">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:50.781305" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:50.781148" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:50.778039" elapsed="0.003346">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.702616" elapsed="0.078921">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.701803" elapsed="0.079927">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:50.701532" elapsed="0.080337">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:50.701514" elapsed="0.080395">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:50.781961" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:50.562741" elapsed="0.219367">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv4": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv4-next-hop": {
+        "global": "127.16.0.44"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "10.2.34.0/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "IAABrBAALABlGAoCIgAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.840241" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:52.839789" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.841093" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:52.840830" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:52.841266" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:52.840464" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.841873" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:52.841463" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.842211" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:52.842377" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:52.842067" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.842897" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.842566" elapsed="0.000381"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.844142" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.843771" elapsed="0.000418"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.844675" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:52.844359" elapsed="0.000351"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.845623" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:52.845206" elapsed="0.000480"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:52.846983" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:52.846382" elapsed="0.000706"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:52.847172" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:52.847586" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:52.845900" elapsed="0.001721"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:52.847888" elapsed="0.000486"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:52.845057" elapsed="0.003367"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.849176" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:52.848748" elapsed="0.000455"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:52.850451" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:52.849890" elapsed="0.000667"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:52.850651" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:52.850960" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:52.849398" elapsed="0.001590"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:52.851146" elapsed="0.000386"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:52.848542" elapsed="0.003032"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:52.844839" elapsed="0.006770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:52.851670" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:52.851945" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:52.843416" elapsed="0.008558"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.843036" elapsed="0.008975"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.852205" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.852041" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.843005" elapsed="0.009278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.854545" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:52.852434" elapsed="0.002142"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:52.854629" elapsed="0.000051"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:52.839110" elapsed="0.015674"/>
</kw>
<msg time="2026-06-06T03:30:52.854842" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:52.826269" elapsed="0.028627"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.867795" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.880265" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.892772" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.892992" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.893178" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.893584" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.893428" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:52.893410" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.893831" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.894003" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.894170" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:52.893373" elapsed="0.000849"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:52.893260" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.894401" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:52.894478" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:52.894611" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:52.821476" elapsed="0.073175"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.896065" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:52.895759" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:52.896238" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:52.895344" elapsed="0.000919"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.896816" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.896336" elapsed="0.000546"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.897403" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:52.897101" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.896908" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.896317" elapsed="0.001170"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.899918" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:52.897665" elapsed="0.002280"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:52.900000" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:52.900157" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:52.894987" elapsed="0.005195"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.901523" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:52.901321" elapsed="0.000306"/>
</kw>
<msg time="2026-06-06T03:30:52.901766" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:52.900878" elapsed="0.000947"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:52.902050" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:52.901907" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.901887" elapsed="0.000231"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.902451" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:52.902618" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:52.902270" elapsed="0.000394"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:52.903088" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:52.902834" elapsed="0.000281"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:52.903166" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:52.903336" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:52.900494" elapsed="0.002868"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.904994" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.904724" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.905451" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.905204" elapsed="0.000292"/>
</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-06-06T03:30:52.915384" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:52.915773" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '166'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:52.916107" 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-06-06T03:30:52.908285" elapsed="0.007898"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.905574" elapsed="0.010718"/>
</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-06-06T03:30:52.916836" elapsed="0.000078"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.916357" elapsed="0.000697"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.905553" elapsed="0.011559"/>
</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-06-06T03:30:52.924971" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.919906" elapsed="0.005117"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.919267" elapsed="0.005793"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.919217" elapsed="0.005868"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.927705" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.925381" elapsed="0.002373"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.925145" elapsed="0.002646"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.925127" elapsed="0.002689"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.928487" 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-06-06T03:30:52.928059" elapsed="0.000456"/>
</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-06-06T03:30:52.928865" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.928588" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.929440" 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-06-06T03:30:52.929128" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.928952" elapsed="0.000631"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.928569" elapsed="0.001037"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.930229" 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-06-06T03:30:52.929829" elapsed="0.000428"/>
</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-06-06T03:30:52.930583" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.930331" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.931176" 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-06-06T03:30:52.930864" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.930687" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.930312" elapsed="0.000952"/>
</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-06-06T03:30:52.931432" elapsed="0.000388"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:52.932335" 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-06-06T03:30:52.932027" 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-06-06T03:30:52.932555" elapsed="0.003359"/>
</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-06-06T03:30:52.918077" elapsed="0.017939"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:52.936282" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:52.936120" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.936092" elapsed="0.000287"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:52.939263" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<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="PASS" start="2026-06-06T03:30:52.936558" elapsed="0.002736"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:52.939348" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:52.939524" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:52.903729" elapsed="0.035822"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:52.939617" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:30:52.939815" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:52.797552" elapsed="0.142292"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.968873" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:52.968315" elapsed="0.000589"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.969765" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:52.969441" elapsed="0.000454">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:52.970075" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:52.969087" elapsed="0.001014"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.970746" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:52.970275" elapsed="0.000561"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:52.971181" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:52.971340" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:52.971013" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.971823" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:52.971532" elapsed="0.000374"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:52.972448" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:52.971988" elapsed="0.000527"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.973249" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:52.972733" elapsed="0.000544"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.972542" elapsed="0.000772"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.971964" elapsed="0.001371"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:52.974011" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:52.973494" elapsed="0.000547"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:52.974094" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:52.967630" elapsed="0.006597"/>
</kw>
<msg time="2026-06-06T03:30:52.974282" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:52.954855" elapsed="0.019477"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.987066" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:52.999683" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.012539" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.012785" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.012978" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.013465" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.013308" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.013291" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.013844" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.014019" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.014190" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:53.013252" elapsed="0.000991"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.013129" elapsed="0.001141"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.014422" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.014500" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:53.014654" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:52.952143" elapsed="0.062541"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.014869" elapsed="0.002303"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:53.018278" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.017959" elapsed="0.000348"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:53.018766" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.018472" elapsed="0.000322"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.018957" elapsed="0.000338"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.017504" elapsed="0.001853"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.017254" elapsed="0.002139"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.019574" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.019418" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.017235" elapsed="0.002432"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:52.941056" elapsed="0.078663"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:52.940214" elapsed="0.079585"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:52.939948" elapsed="0.079898"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:52.939930" elapsed="0.079941"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.019942" elapsed="0.000034"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:52.792435" elapsed="0.227646"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:50.556287" elapsed="2.463855"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:53.020365" elapsed="0.002567"/>
</kw>
<arg>l3vpn_mcast</arg>
<arg>${L3VPN_MCAST_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:47.728077" elapsed="5.294960"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:47.635948" elapsed="5.387234"/>
</test>
<test id="s1-s17-t6" name="Odl_To_Play_l3vpn_mcast_ipv6" line="77">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:53.026533" elapsed="0.000241"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:53.026262" elapsed="0.000568"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.027870" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.027751" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.027730" elapsed="0.000242"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.033206" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.033089" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.033067" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.034347" 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-06-06T03:30:53.033938" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.034868" 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-06-06T03:30:53.034547" elapsed="0.000347"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:53.034940" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:53.035102" 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-06-06T03:30:53.033529" elapsed="0.001598"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:53.040697" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.040570" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.040551" elapsed="0.000216"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:53.041970" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.041862" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.041842" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:53.042495" 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-06-06T03:30:53.042190" elapsed="0.000331"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:53.042927" level="INFO">${current_connection_index} = 7</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-06-06T03:30:53.042706" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:53.073055" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:53.043465" elapsed="0.029717"/>
</kw>
<msg time="2026-06-06T03:30:53.073366" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:53.073415" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:53.043119" elapsed="0.030332"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:53.104080" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "3 "v "p "n "_ "m "c "a "s "t "_ "i "p "v "6 "[K"
[?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-06-06T03:30:53.074053" elapsed="0.030150"/>
</kw>
<msg time="2026-06-06T03:30:53.104370" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:53.104416" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "...</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-06-06T03:30:53.073673" elapsed="0.030780"/>
</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-06-06T03:30:53.104827" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.104547" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.104521" elapsed="0.000391"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.105378" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "l "3 "v "p "n "_ "m "c "a "s "t "_ "i "p "v "6 "[K"
[?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-06-06T03:30:53.105063" elapsed="0.000463"/>
</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-06-06T03:30:53.105839" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.105595" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.105577" elapsed="0.000341"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:53.105953" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:53.108630" elapsed="0.000355"/>
</kw>
<msg time="2026-06-06T03:30:53.109049" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.107501" elapsed="0.001684"/>
</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="NOT RUN" start="2026-06-06T03:30:53.109469" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.109835" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:53.106853" elapsed="0.003169"/>
</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-06-06T03:30:53.106273" elapsed="0.003815"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:53.041534" elapsed="0.068654"/>
</kw>
<msg time="2026-06-06T03:30:53.110281" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:53.110326" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:53.040925" elapsed="0.069440"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:53.110559" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:53.110445" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.110424" elapsed="0.000237"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.111092" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.111438" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.111509" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:53.040223" elapsed="0.071397"/>
</kw>
<msg time="2026-06-06T03:30:53.111733" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:53.111778" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "O "d "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:53.035518" elapsed="0.076298"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.112198" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.111892" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.111875" elapsed="0.000401"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:53.035362" elapsed="0.076938"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:53.035184" elapsed="0.077150"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:53.032690" elapsed="0.079700"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:53.027437" elapsed="0.085009"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:53.026991" elapsed="0.085502"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:53.024084" elapsed="0.088467"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.113480" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/announce_l3vpn_mcast_ipv6.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/announce_l3vpn_mcast_ipv6.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.113855" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.113261" elapsed="0.000667"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:53.114314" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.114098" elapsed="0.000244"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.114715" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/withdraw_l3vpn_mcast_ipv6.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/withdraw_l3vpn_mcast_ipv6.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.114844" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.114506" elapsed="0.000365"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:30:53.115238" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.115032" elapsed="0.000234"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:53.115558" elapsed="0.002566"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.115337" elapsed="0.002824"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.115319" elapsed="0.002867"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.153505" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.153123" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.154324" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.154067" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.154496" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.153723" elapsed="0.000798"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.155151" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.154710" elapsed="0.000470"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.155491" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.155703" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.155348" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.156181" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.155894" elapsed="0.000333"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.157201" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.156944" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.157722" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.157413" elapsed="0.000336"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.158419" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.158122" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.159412" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.158974" elapsed="0.000466"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.159493" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:53.159670" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.158634" elapsed="0.001062"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.159901" elapsed="0.000257"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:53.157980" elapsed="0.002220"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.160775" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.160458" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.161748" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.161317" elapsed="0.000458"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.161825" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:53.161978" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.160993" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.162161" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:53.160315" elapsed="0.002112"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.157803" elapsed="0.004660"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.162507" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:53.162708" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:53.156599" elapsed="0.006144"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.156299" elapsed="0.006478"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.162961" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.162804" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.156278" elapsed="0.006760"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.163796" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:53.163188" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.163873" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:53.152472" elapsed="0.011560"/>
</kw>
<msg time="2026-06-06T03:30:53.164089" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.139653" elapsed="0.024486"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.176856" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.189408" elapsed="0.000050"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.202384" elapsed="0.000048"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.202773" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.202973" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.203410" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.203252" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.203234" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.203656" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.203857" elapsed="0.000026"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.204094" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:53.203193" elapsed="0.000960"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.203060" elapsed="0.001121"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.204337" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.204419" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:53.204592" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:53.135127" elapsed="0.069497"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.231263" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.230858" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.232230" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.231909" elapsed="0.000406">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.232414" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.231471" elapsed="0.000968"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.233029" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.232612" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.233400" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.233578" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;gAABrBAALABlGCABDQAAAAA=&lt;/route-key&gt;
    &lt;route-distinguis...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.233249" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.234044" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;gAABrBAALABlGCABDQAAAAA=&lt;/route-key&gt;
    &lt;route-distinguisher&gt;172.16.0.44:101&lt;/route-distinguisher&gt;
    &lt;prefix&gt;2001:d00::/24&lt;/prefix&gt;
    &lt;attributes&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;ipv6-next-hop&gt;
            &lt;global&gt;2001:db8:1::7&lt;/global&gt;
        &lt;/ipv6-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
&lt;/l3vpn-mcast-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.233793" elapsed="0.000361"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:53.234553" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.234229" elapsed="0.000386"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.235125" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.234817" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.234657" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.234207" elapsed="0.001004"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.235919" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;gAABrBAALABlGCABDQAAAAA=&lt;/route-key&gt;
    &lt;route-distinguis...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:53.235367" elapsed="0.000614"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.236037" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:53.230114" elapsed="0.006063"/>
</kw>
<msg time="2026-06-06T03:30:53.236239" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.216703" elapsed="0.019587"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.249078" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.261867" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.274210" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.274428" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.274614" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.275036" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.274881" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.274864" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.275266" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.275437" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.275605" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:53.274827" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.274712" elapsed="0.001043"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.275916" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.276017" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:30:53.276176" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;gAABrBAALABlGCABDQAAAAA=&lt;/route-key&gt;
    &lt;route-distinguis...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:53.215705" elapsed="0.060502"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.277601" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.277306" elapsed="0.000388">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.277791" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.276924" elapsed="0.000892"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.278152" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.277886" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.278743" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.278421" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.278234" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.277867" elapsed="0.000960"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.281200" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.278984" elapsed="0.002242"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:53.281277" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:53.281432" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:53.276552" elapsed="0.004905"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.283018" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.282763" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.283460" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;gAABrBAALABlGCABDQAAAAA=&lt;/route-key&gt;
    &lt;route-distinguisher&gt;172.16.0.44:101&lt;/route-distinguisher&gt;
    &lt;prefix&gt;2001:d00::/24&lt;/prefix&gt;
    &lt;attributes&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;ipv6-next-hop&gt;
            &lt;global&gt;2001:db8:1::7&lt;/global&gt;
        &lt;/ipv6-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
&lt;/l3vpn-mcast-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.283222" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.283932" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.283688" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.284407" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.284165" elapsed="0.000288"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:53.285282" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:30:53.285083" elapsed="0.000226"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:30:53.285655" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:30:53.285465" elapsed="0.000255"/>
</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-06-06T03:30:53.285880" elapsed="0.000214"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.286503" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.286255" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:30:53.286590" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:53.286763" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:30:53.284670" elapsed="0.002119"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:53.301058" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '1048', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;l3vpn-mcast-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:l3vpn:mcast"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-key&gt;gAABrBAALABlGCABDQAAAAA=&lt;/route-key&gt;
    &lt;route-distinguisher&gt;172.16.0.44:101&lt;/route-distinguisher&gt;
    &lt;prefix&gt;2001:d00::/24&lt;/prefix&gt;
    &lt;attributes&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;extended-communities&gt;
            &lt;transitive&gt;true&lt;/transitive&gt;
            &lt;vrf-route-import-extended-community&gt;
                &lt;inet4-specific-extended-community-common&gt;
                    &lt;global-administrator&gt;10.0.0.1&lt;/global-administrator&gt;
                    &lt;local-administrator&gt;MTA=&lt;/local-administrator&gt;
                &lt;/inet4-specific-extended-community-common&gt;
            &lt;/vrf-route-import-extended-community&gt;
        &lt;/extended-communities&gt;
        &lt;ipv6-next-hop&gt;
            &lt;global&gt;2001:db8:1::7&lt;/global&gt;
        &lt;/ipv6-next-hop&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;as-path/&gt;
    &lt;/attributes&gt;
&lt;/l3vpn-mcast-route&gt; 
 </msg>
<msg time="2026-06-06T03:30:53.301127" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6/l3vpn-mcast-route=gAABrBAALABlGCABDQAAAAA%3D,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:53.301226" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:53.289144" elapsed="0.012108"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.286859" elapsed="0.014441"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.301499" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.301328" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.286841" elapsed="0.014746"/>
</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-06-06T03:30:53.305163" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.302713" elapsed="0.002494"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.302467" elapsed="0.002776"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.302447" elapsed="0.002821"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.307854" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.305552" elapsed="0.002348"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.305325" elapsed="0.002609"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.305308" elapsed="0.002650"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.308582" 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-06-06T03:30:53.308175" elapsed="0.000434"/>
</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-06-06T03:30:53.308944" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.308697" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.309498" 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-06-06T03:30:53.309194" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.309027" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.308678" elapsed="0.000902"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.310136" 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-06-06T03:30:53.309772" elapsed="0.000391"/>
</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-06-06T03:30:53.310524" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.310232" elapsed="0.000350"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.311088" 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-06-06T03:30:53.310793" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.310607" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.310214" elapsed="0.000957"/>
</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-06-06T03:30:53.311328" elapsed="0.000364"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:53.312175" 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-06-06T03:30:53.311866" elapsed="0.000335"/>
</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-06-06T03:30:53.312364" elapsed="0.002309"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:30:53.301974" elapsed="0.012763"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:53.314921" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:30:53.314811" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.314792" elapsed="0.000217"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:30:53.315163" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.315231" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:53.317585" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:30:53.281803" elapsed="0.035809"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.317698" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:53.317853" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:53.123006" elapsed="0.194873"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.318225" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.317982" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.317965" elapsed="0.000352"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.318349" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:30:53.118477" elapsed="0.199997"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:53.322059" level="INFO">${update} = ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.319413" elapsed="0.002677"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.322248" elapsed="0.002427"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:53.324746" elapsed="0.000041"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:53.319137" elapsed="0.005788"/>
</kw>
<msg time="2026-06-06T03:30:53.325030" level="INFO">${update} = ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:53.318666" elapsed="0.006400"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.326281" level="INFO">Length is 178.</msg>
<msg time="2026-06-06T03:30:53.326386" level="INFO">${len_1} = 178</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:53.325910" elapsed="0.000510"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.327082" level="INFO">Length is 178.</msg>
<msg time="2026-06-06T03:30:53.327188" level="INFO">${len_2} = 178</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:53.326720" elapsed="0.000502"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.327447" elapsed="0.000460"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:53.328414" level="INFO">${sum_1} = 1895</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:53.328147" elapsed="0.000303"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:53.329055" level="INFO">${sum_2} = 1895</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:53.328792" elapsed="0.000298"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.329310" elapsed="0.000450"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:53.325365" elapsed="0.004480"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:53.330062" elapsed="0.002167"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.377714" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.377317" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.378502" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.378250" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.378687" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.377911" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.379272" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.378884" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.379605" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.379773" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.379466" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.380225" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.379961" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.381475" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.381161" elapsed="0.000360"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.381987" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.381709" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.382832" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.382388" elapsed="0.000471"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.384064" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.383534" elapsed="0.000614"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.384288" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:53.384515" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.383075" elapsed="0.001467"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.384719" elapsed="0.000409"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:53.382248" elapsed="0.002963"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.385903" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.385467" elapsed="0.000462"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.387035" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.386538" elapsed="0.000578"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.387252" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:53.387475" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.386120" elapsed="0.001380"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.387676" elapsed="0.000416"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:53.385328" elapsed="0.002807"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.382068" elapsed="0.006103"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.388214" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:53.388372" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:53.380667" elapsed="0.007730"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.380344" elapsed="0.008086"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.388609" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.388455" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.380321" elapsed="0.008381"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.389419" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:53.388849" elapsed="0.000599"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.389498" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:53.376697" elapsed="0.012924"/>
</kw>
<msg time="2026-06-06T03:30:53.389694" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.363973" elapsed="0.025772"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.402418" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.414836" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.427247" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.427464" elapsed="0.000084"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.427733" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.428155" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.427987" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.427969" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.428382" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.428556" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.428741" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:53.427931" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.427816" elapsed="0.001007"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.428975" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.429051" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:53.429190" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:53.359669" elapsed="0.069548"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.430401" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.430116" elapsed="0.000341"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:53.441721" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:53.441794" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:53.441944" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:53.434166" elapsed="0.007816"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.430524" elapsed="0.011520"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.442316" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.442083" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.430505" elapsed="0.011934"/>
</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-06-06T03:30:53.447345" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.443934" elapsed="0.003480"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.443584" elapsed="0.003893"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.443557" elapsed="0.003960"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.451459" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.448181" elapsed="0.003342"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.447816" elapsed="0.003755"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.447578" elapsed="0.004028"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.452516" 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-06-06T03:30:53.451899" elapsed="0.000645"/>
</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-06-06T03:30:53.452940" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.452682" elapsed="0.000392"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.453580" 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-06-06T03:30:53.453272" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.453100" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.452660" elapsed="0.001024"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.454218" 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-06-06T03:30:53.453854" elapsed="0.000391"/>
</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-06-06T03:30:53.454750" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.454314" elapsed="0.000495"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.455296" 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-06-06T03:30:53.454999" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.454833" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.454295" elapsed="0.001083"/>
</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-06-06T03:30:53.455541" elapsed="0.000372"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:53.456411" 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-06-06T03:30:53.456104" elapsed="0.000333"/>
</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-06-06T03:30:53.456606" elapsed="0.002338"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:53.442992" elapsed="0.016023"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:53.459067" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:53.461465" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:53.429490" elapsed="0.032008"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.461567" elapsed="0.000041"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:53.333678" elapsed="0.128054"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:53.333060" elapsed="0.128731"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:53.332485" elapsed="0.129369"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:53.465602" level="INFO">${update} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.462937" elapsed="0.002695"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.465817" elapsed="0.002157"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:30:53.468026" elapsed="0.000072"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:30:53.462625" elapsed="0.005572"/>
</kw>
<msg time="2026-06-06T03:30:53.468275" level="INFO">${update} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:53.462066" elapsed="0.006234"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.469490" level="INFO">Length is 142.</msg>
<msg time="2026-06-06T03:30:53.469596" level="INFO">${len_1} = 142</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:53.469107" elapsed="0.000522"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.470226" level="INFO">Length is 142.</msg>
<msg time="2026-06-06T03:30:53.470328" level="INFO">${len_2} = 142</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:53.469872" elapsed="0.000489"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.470590" elapsed="0.000456"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:53.471603" level="INFO">${sum_1} = 1588</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:53.471268" elapsed="0.000372"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:30:53.472149" level="INFO">${sum_2} = 1588</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:30:53.471882" elapsed="0.000303"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:53.472518" elapsed="0.000468"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:30:53.468566" elapsed="0.004507"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.569725" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.569311" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.570626" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.570281" elapsed="0.000439">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.570819" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.569938" elapsed="0.000906"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.571415" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.571019" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.571779" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.571994" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.571613" elapsed="0.000408"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.572463" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.572209" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.573666" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.573351" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.574163" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.573885" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.575155" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.574574" elapsed="0.000609"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.576545" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.576048" elapsed="0.000540"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.576730" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:53.576961" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.575377" elapsed="0.001610"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.577147" elapsed="0.000520"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:53.574431" elapsed="0.003279"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.578470" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.577964" elapsed="0.000533"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.579627" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.579185" elapsed="0.000500"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.579805" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:53.580025" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.578703" elapsed="0.001348"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.580231" elapsed="0.000528"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:53.577825" elapsed="0.003030"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.574247" elapsed="0.006645"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.580937" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:53.581097" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:53.572988" elapsed="0.008134"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.572596" elapsed="0.008558"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.581336" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.581181" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.572571" elapsed="0.008845"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.582167" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:53.581568" elapsed="0.000628"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.582246" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:53.568655" elapsed="0.013716"/>
</kw>
<msg time="2026-06-06T03:30:53.582427" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.555726" elapsed="0.026762"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.595652" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.608216" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.620940" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.621151" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.621367" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.621786" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.621613" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.621596" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.622020" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.622196" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.622421" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:53.621562" elapsed="0.000916"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.621454" elapsed="0.001051"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.622675" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.622755" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:53.622886" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:53.551236" elapsed="0.071678"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.624152" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.623844" elapsed="0.000359"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:53.632834" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:53.633327" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '402'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv6-address-family'][safi='bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family']/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:53.633550" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:30:53.633611" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.626575" elapsed="0.007559">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:53.624274" elapsed="0.009974">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.634519" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.634296" elapsed="0.000312"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:53.624253" elapsed="0.010409">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</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-06-06T03:30:53.639588" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.636199" elapsed="0.003437">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:53.635838" elapsed="0.003908">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:53.635810" elapsed="0.003981">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.643458" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.640229" elapsed="0.003276">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:53.639894" elapsed="0.003699">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:53.639869" elapsed="0.003838">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.644557" 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-06-06T03:30:53.643990" elapsed="0.000595"/>
</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-06-06T03:30:53.644925" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.644675" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.645480" 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-06-06T03:30:53.645176" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.645008" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.644639" elapsed="0.000925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.646108" 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-06-06T03:30:53.645744" elapsed="0.000391"/>
</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-06-06T03:30:53.646446" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.646206" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.647008" 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-06-06T03:30:53.646710" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.646528" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.646187" elapsed="0.000905"/>
</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-06-06T03:30:53.647249" elapsed="0.000355"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:53.648099" 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-06-06T03:30:53.647792" elapsed="0.000335"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:30:53.650713" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.648289" elapsed="0.002458">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:30:53.635196" elapsed="0.015692">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:53.650953" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:53.653425" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:30:53.653457" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:30:53.623191" elapsed="0.030302">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.653564" elapsed="0.000029"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.474689" elapsed="0.179073">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:53.474061" elapsed="0.179770"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:30:53.473398" elapsed="0.180500"/>
</kw>
<arg>l3vpn_mcast_ipv6</arg>
<arg>${L3VPN_MCAST_DIR}</arg>
<status status="PASS" start="2026-06-06T03:30:53.112862" elapsed="0.541091"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.023567" elapsed="0.630508"/>
</test>
<test id="s1-s17-t7" name="Play_To_Odl_l3vpn_mcast_ipv6" line="81">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:53.657993" elapsed="0.000281"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:53.657607" elapsed="0.000739"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.659555" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.659411" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.659305" elapsed="0.000326"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.664991" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.664847" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.664820" elapsed="0.000255"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.666234" 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-06-06T03:30:53.665785" elapsed="0.000478"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.666769" 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-06-06T03:30:53.666443" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:53.666843" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:53.667007" 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-06-06T03:30:53.665365" elapsed="0.001667"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:53.672892" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.672780" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.672759" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:53.674184" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.674077" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.674058" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:53.674725" 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-06-06T03:30:53.674404" elapsed="0.000348"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:53.675138" level="INFO">${current_connection_index} = 7</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-06-06T03:30:53.674919" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:53.707519" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:53.675681" elapsed="0.031946"/>
</kw>
<msg time="2026-06-06T03:30:53.707831" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:53.707879" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:53.675327" elapsed="0.032587"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:53.744585" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "l "3 "v "p "n "_ "m "c "a "s "t "_ "i "p "v "6 "[K"
[?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-06-06T03:30:53.708483" elapsed="0.036335"/>
</kw>
<msg time="2026-06-06T03:30:53.745045" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:53.745096" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "...</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-06-06T03:30:53.708098" elapsed="0.037036"/>
</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-06-06T03:30:53.745580" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.745252" elapsed="0.000412"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.745214" elapsed="0.000479"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.746219" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "l "3 "v "p "n "_ "m "c "a "s "t "_ "i "p "v "6 "[K"
[?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-06-06T03:30:53.745849" elapsed="0.000444"/>
</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-06-06T03:30:53.746590" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.746364" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.746344" elapsed="0.000347"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:53.746729" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:53.749664" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:30:53.749884" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.748499" elapsed="0.001523"/>
</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="NOT RUN" start="2026-06-06T03:30:53.750308" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.750675" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:53.747738" elapsed="0.003127"/>
</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-06-06T03:30:53.747129" elapsed="0.003805"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:53.673774" elapsed="0.077265"/>
</kw>
<msg time="2026-06-06T03:30:53.751139" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:53.751186" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:53.673121" elapsed="0.078103"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:53.751416" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:53.751304" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.751283" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.751935" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.752304" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.752379" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:53.672403" elapsed="0.080093"/>
</kw>
<msg time="2026-06-06T03:30:53.752604" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:53.752695" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "P "l "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:53.667429" elapsed="0.085308"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.753104" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.752822" elapsed="0.000339"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.752802" elapsed="0.000384"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:53.667279" elapsed="0.085932"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:53.667095" elapsed="0.086151"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:53.664307" elapsed="0.089000"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:53.659017" elapsed="0.094351"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:53.658517" elapsed="0.094898"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:53.655054" elapsed="0.098417"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.754675" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.754177" elapsed="0.000528"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.755336" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.754879" elapsed="0.000485"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.756165" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.755533" elapsed="0.000664"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.756578" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/announce_l3vpn_mcast_ipv6.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/announce_l3vpn_mcast_ipv6.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.756832" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.756370" elapsed="0.000501"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.757237" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/withdraw_l3vpn_mcast_ipv6.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/withdraw_l3vpn_mcast_ipv6.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.757366" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.757040" elapsed="0.000354"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:30:53.757553" elapsed="0.003157"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:53.760877" elapsed="0.002252"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.815291" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.814903" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.816115" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.815856" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.816310" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.815497" elapsed="0.000838"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.816910" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.816505" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.817243" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:53.817399" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:53.817104" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.817855" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.817589" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.818934" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.818616" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.819413" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.819143" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.820409" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.819980" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.821686" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.821107" elapsed="0.000680"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.821868" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:30:53.822169" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.820630" elapsed="0.001566"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.822358" elapsed="0.000393"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:53.819691" elapsed="0.003145"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.823493" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:53.823092" elapsed="0.000427"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:53.824778" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.824220" elapsed="0.000658"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:53.824954" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:53.825242" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:53.823724" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:53.825425" elapsed="0.000386"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:53.822953" elapsed="0.002900"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.819494" elapsed="0.006394"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:53.825931" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:53.826086" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:53.818284" elapsed="0.007827"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.817975" elapsed="0.008168"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.826321" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.826168" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.817953" elapsed="0.008443"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.827292" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:53.826708" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:53.827370" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:53.814257" elapsed="0.013237"/>
</kw>
<msg time="2026-06-06T03:30:53.827549" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:53.801558" elapsed="0.026040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.840146" elapsed="0.000054"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.852620" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.865161" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.865450" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.865637" elapsed="0.000035"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.866052" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.865899" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.865882" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.866277" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.866448" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.866616" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:53.865846" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.865735" elapsed="0.000975"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.866863" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.866939" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:53.867084" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:53.797269" elapsed="0.069842"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.868517" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.868219" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.868700" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.867812" elapsed="0.000914"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.869066" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.868799" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.869627" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:53.869334" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.869149" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.868780" elapsed="0.000945"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.872312" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:53.869881" elapsed="0.002458"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:53.872390" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:53.872546" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:53.867448" elapsed="0.005122"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:53.873848" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.873562" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:53.874006" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:53.873224" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:53.874239" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:53.874102" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:53.874083" elapsed="0.000285"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.874520" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.874715" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.874783" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:53.876718" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:53.872894" elapsed="0.003851"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.878145" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.877891" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:53.878597" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:53.878350" elapsed="0.000304"/>
</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-06-06T03:30:53.887734" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:53.887875" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:30:53.887977" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</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="FAIL" start="2026-06-06T03:30:53.880828" elapsed="0.007562">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:53.878724" elapsed="0.009752">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</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-06-06T03:30:53.888695" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.888512" elapsed="0.000251"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:53.878704" elapsed="0.010082">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:30:53.889177" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.889310" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:53.889272" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.889254" elapsed="0.000120"/>
</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-06-06T03:30:53.889528" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.889599" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:30:53.877056" elapsed="0.012663">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.889836" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.773739" elapsed="0.116196">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:53.890218" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:53.890031" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:53.890014" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:53.890349" elapsed="0.000015"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:53.767703" elapsed="0.122744">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.943486" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:55.943083" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:55.944333" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:55.944075" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:55.944504" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:55.943723" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.945143" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:55.944719" elapsed="0.000452"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:55.945483" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:55.945667" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:55.945340" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.946109" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:55.945859" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.947216" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:55.946899" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.947732" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:55.947431" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.948544" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:55.948128" elapsed="0.000442"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:55.949836" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:55.949264" elapsed="0.000674"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:55.950021" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:55.950322" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:55.948782" elapsed="0.001625"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:55.950573" elapsed="0.000401"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:55.947988" elapsed="0.003031"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.951867" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:55.951272" elapsed="0.000622"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:55.953143" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:55.952548" elapsed="0.000696"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:55.953322" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:55.953619" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:55.952088" elapsed="0.001574"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:55.953824" elapsed="0.000371"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:55.951134" elapsed="0.003104"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:55.947812" elapsed="0.006461"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:55.954317" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:55.954475" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:55.946553" elapsed="0.007953"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:55.946233" elapsed="0.008306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.954735" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:55.954564" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:55.946210" elapsed="0.008604"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.955550" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:55.954963" elapsed="0.000615"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:55.955629" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:55.942425" elapsed="0.013346"/>
</kw>
<msg time="2026-06-06T03:30:55.955827" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:55.929629" elapsed="0.026248"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.968538" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.980977" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.993389" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.993658" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.993846" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.994226" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:55.994076" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:55.994060" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.994450" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.994621" elapsed="0.000033"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.994809" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:55.994029" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:55.993926" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.995040" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:55.995114" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:55.995241" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:55.925303" elapsed="0.069966"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:55.996576" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:55.996315" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:55.996763" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:55.995952" elapsed="0.000836"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:55.997152" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:55.996893" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:55.997745" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:55.997423" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:55.997236" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:55.996873" elapsed="0.000956"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.000368" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:55.997988" elapsed="0.002407"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:56.000447" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:56.000601" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:55.995596" elapsed="0.005030"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.001902" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.001667" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.002057" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.001309" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:56.002288" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:56.002152" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.002133" elapsed="0.000275"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.002561" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.002754" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.002822" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:56.004733" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.000977" elapsed="0.003783"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.006209" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.005953" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.006676" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.006414" elapsed="0.000307"/>
</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-06-06T03:30:56.016135" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:56.016770" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}} 
 </msg>
<msg time="2026-06-06T03:30:56.016949" 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-06-06T03:30:56.008898" elapsed="0.008089"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.006789" elapsed="0.010259"/>
</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-06-06T03:30:56.017306" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.017084" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.006770" elapsed="0.010656"/>
</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-06-06T03:30:56.022480" level="INFO">{"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.018877" elapsed="0.003674"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.018538" elapsed="0.004063"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.018512" elapsed="0.004126"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.026333" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.023065" elapsed="0.003333"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.022743" elapsed="0.003704"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.022718" elapsed="0.003763"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.027280" 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-06-06T03:30:56.026744" elapsed="0.000574"/>
</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-06-06T03:30:56.027783" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.027419" elapsed="0.000448"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.028560" 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-06-06T03:30:56.028137" elapsed="0.000461"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.027901" elapsed="0.000766"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.027393" elapsed="0.001306"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.029461" 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-06-06T03:30:56.028951" elapsed="0.000596"/>
</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-06-06T03:30:56.030051" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.029682" elapsed="0.000455"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.030887" 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-06-06T03:30:56.030423" elapsed="0.000504"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.030174" elapsed="0.000806"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.029632" elapsed="0.001380"/>
</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-06-06T03:30:56.031244" elapsed="0.000538"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:56.032454" 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-06-06T03:30:56.032035" elapsed="0.000458"/>
</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-06-06T03:30:56.032752" elapsed="0.002589"/>
</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-06-06T03:30:56.017954" elapsed="0.017454"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.035586" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:56.035480" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.035461" elapsed="0.000208"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.038666" level="INFO">${text_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<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="PASS" start="2026-06-06T03:30:56.035819" elapsed="0.002878"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:56.038751" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:56.038910" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:56.005113" elapsed="0.033823"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.039000" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:56.039150" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:55.902762" elapsed="0.136413"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.069226" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.068718" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.070092" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.069800" elapsed="0.000414">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.070390" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.069429" elapsed="0.000987"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.071052" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.070588" elapsed="0.000492"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.071409" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.071622" level="INFO">${template} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.071247" elapsed="0.000419"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.072102" level="INFO">{
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "attributes": {
                    "ipv6-next-hop": {
                        "global": "2001:db8:1::7"
                    },
                    "extended-communities": [
                        {
                            "vrf-route-import-extended-community": {
                                "inet4-specific-extended-community-common": {
                                    "local-administrator": "MTA=",
                                    "global-administrator": "10.0.0.1"
                                }
                            },
                            "transitive": true
                        }
                    ],
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-distinguisher": "172.16.0.44:101",
                "prefix": "2001:d00::/24"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.071830" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:56.072656" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.072228" elapsed="0.000492"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.073432" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.072920" elapsed="0.000539"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.072746" elapsed="0.000749"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.072206" elapsed="0.001310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.074177" level="INFO">${final_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.073683" elapsed="0.000522"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.074257" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.068083" elapsed="0.006303"/>
</kw>
<msg time="2026-06-06T03:30:56.074446" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.055184" elapsed="0.019310"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.087114" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.099788" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.112237" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.112472" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.112670" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.113097" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.112939" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.112923" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.113324" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.113497" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.113682" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.112864" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.112755" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.113915" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.113991" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:56.114146" level="INFO">${expected_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.051075" elapsed="0.063098"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.114354" elapsed="0.002407"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.118077" level="INFO">${expected_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.117555" elapsed="0.000550"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.118757" level="INFO">${actual_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.118267" elapsed="0.000519"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:56.118949" elapsed="0.000328"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:56.117125" elapsed="0.002212"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.116844" elapsed="0.002528"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.119553" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.119398" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.116824" elapsed="0.002805"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:56.040336" elapsed="0.079362"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:56.039510" elapsed="0.080266"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.039260" elapsed="0.080564"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.039242" elapsed="0.080606"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.119882" elapsed="0.000030"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:55.896968" elapsed="0.223044"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:53.763308" elapsed="2.356802"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.170069" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.169669" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.170906" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.170624" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.171078" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.170282" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.171684" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.171276" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.172022" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.172186" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.171880" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.172622" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.172375" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.173976" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.173433" elapsed="0.000589"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.174471" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.174192" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.175306" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.174900" elapsed="0.000433"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:56.176560" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.176001" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:56.176758" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:56.177093" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:56.175526" elapsed="0.001595"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.177284" elapsed="0.000399"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:30:56.174757" elapsed="0.002968"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.178387" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.177981" elapsed="0.000432"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:56.179626" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.179087" elapsed="0.000661"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:56.179830" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:56.180121" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:56.178609" elapsed="0.001539"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.180306" elapsed="0.000385"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:56.177843" elapsed="0.002940"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:56.174552" elapsed="0.006268"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:56.180865" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:30:56.181046" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:56.173101" elapsed="0.007971"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.172764" elapsed="0.008341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.181287" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.181131" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.172739" elapsed="0.008625"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.182109" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.181513" elapsed="0.000626"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.182191" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.168919" elapsed="0.013396"/>
</kw>
<msg time="2026-06-06T03:30:56.182371" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.156112" elapsed="0.026307"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.195023" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.207588" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.220050" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.220271" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.220458" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.220888" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.220730" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.220711" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.221133" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.221305" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.221546" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.220671" elapsed="0.000932"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.220544" elapsed="0.001087"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.221802" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.221882" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:56.222026" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.151794" elapsed="0.070260"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.223424" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.223145" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.223593" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.222758" elapsed="0.000861"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.223977" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.223708" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.224538" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.224243" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.224060" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.223689" elapsed="0.001089"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.227425" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.224974" elapsed="0.002479"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:56.227506" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:56.227684" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.222385" elapsed="0.005325"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.228965" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.228718" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.229125" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.228354" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:56.229355" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:56.229221" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.229202" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.229594" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.229788" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.229855" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:56.231838" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.228023" elapsed="0.003842"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.233287" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.233031" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.233800" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.233536" elapsed="0.000308"/>
</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-06-06T03:30:56.243033" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:56.243178" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}} 
 </msg>
<msg time="2026-06-06T03:30:56.243290" 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-06-06T03:30:56.235998" elapsed="0.007319"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.233911" elapsed="0.009450"/>
</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-06-06T03:30:56.243552" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.243388" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.233892" elapsed="0.009769"/>
</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-06-06T03:30:56.247872" level="INFO">{"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.244698" elapsed="0.003246"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.244455" elapsed="0.003538"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.244436" elapsed="0.003592"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.251905" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.248427" elapsed="0.003543"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.248108" elapsed="0.003911"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.248084" elapsed="0.003971"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.252858" 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-06-06T03:30:56.252295" elapsed="0.000602"/>
</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-06-06T03:30:56.253388" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.253041" elapsed="0.000427"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.253989" 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-06-06T03:30:56.253688" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.253503" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.253008" elapsed="0.001064"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.254604" 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-06-06T03:30:56.254239" elapsed="0.000391"/>
</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-06-06T03:30:56.254961" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.254719" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.255499" 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-06-06T03:30:56.255207" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.255041" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.254700" elapsed="0.000881"/>
</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-06-06T03:30:56.255753" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:56.256595" 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-06-06T03:30:56.256267" elapsed="0.000354"/>
</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-06-06T03:30:56.256801" elapsed="0.002338"/>
</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-06-06T03:30:56.244031" elapsed="0.015172"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.259380" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:56.259274" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.259255" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.262467" level="INFO">${text_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<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="PASS" start="2026-06-06T03:30:56.259597" elapsed="0.002899"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:56.262551" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:30:56.262730" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:56.232182" elapsed="0.030574"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.262820" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:56.262971" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:56.129009" elapsed="0.133988"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.291864" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.291356" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.292719" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.292415" elapsed="0.000427">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.293269" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.292066" elapsed="0.001232"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.294008" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.293511" elapsed="0.000526"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.294374" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.294545" level="INFO">${template} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.294205" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.295024" level="INFO">{
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "attributes": {
                    "ipv6-next-hop": {
                        "global": "2001:db8:1::7"
                    },
                    "extended-communities": [
                        {
                            "vrf-route-import-extended-community": {
                                "inet4-specific-extended-community-common": {
                                    "local-administrator": "MTA=",
                                    "global-administrator": "10.0.0.1"
                                }
                            },
                            "transitive": true
                        }
                    ],
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-distinguisher": "172.16.0.44:101",
                "prefix": "2001:d00::/24"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.294754" elapsed="0.000379"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:56.295656" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.295208" elapsed="0.000512"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.296414" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.295898" elapsed="0.000543"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.295746" elapsed="0.000733"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.295187" elapsed="0.001313"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.297213" level="INFO">${final_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.296674" elapsed="0.000569"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.297295" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.290722" elapsed="0.006703"/>
</kw>
<msg time="2026-06-06T03:30:56.297487" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.277753" elapsed="0.019784"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.310178" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.322665" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.335124" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.335331" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.335514" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.335922" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.335772" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.335755" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.336147" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.336317" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.336486" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.335721" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.335599" elapsed="0.001019"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.336790" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.336869" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:56.337062" level="INFO">${expected_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.275040" elapsed="0.062051"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.337278" elapsed="0.002510"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.341157" level="INFO">${expected_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.340595" elapsed="0.000592"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.341835" level="INFO">${actual_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.341348" elapsed="0.000516"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:56.342026" elapsed="0.000335"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:56.340128" elapsed="0.002295"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.339874" elapsed="0.002583"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.342636" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.342482" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.339854" elapsed="0.002885"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:56.264140" elapsed="0.078649"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:56.263321" elapsed="0.079547"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.263081" elapsed="0.079834"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.263063" elapsed="0.079877"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.342976" elapsed="0.000033"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:56.124586" elapsed="0.218524"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:56.120292" elapsed="0.222879"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.392981" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.392553" elapsed="0.000461"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.393829" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.393536" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.394073" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.393188" elapsed="0.000910"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.394675" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.394270" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.395013" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.395169" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.394871" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.395604" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.395358" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.396908" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.396380" elapsed="0.000587"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.397420" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.397141" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.398268" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.397856" elapsed="0.000438"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:56.399525" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.398972" elapsed="0.000654"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:56.399728" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:56.400031" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:56.398488" elapsed="0.001569"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.400219" elapsed="0.000384"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:56.397713" elapsed="0.002947"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.401345" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.400913" elapsed="0.000458"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:56.402573" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.402033" elapsed="0.000661"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:56.402773" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:56.403064" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:56.401562" elapsed="0.001528"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.403246" elapsed="0.000364"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:56.400776" elapsed="0.002893"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:56.397501" elapsed="0.006205"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:56.403752" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:56.403910" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:56.396052" elapsed="0.007883"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.395741" elapsed="0.008226"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.404145" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.403992" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.395719" elapsed="0.008501"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.404976" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.404367" elapsed="0.000639"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.405057" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.391927" elapsed="0.013257"/>
</kw>
<msg time="2026-06-06T03:30:56.405279" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.379052" elapsed="0.026276"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.417997" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.430446" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.442889" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.443090" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.443271" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.443654" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.443493" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.443478" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.443882" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.444054" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.444224" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.443449" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.443348" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.444452" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.444528" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:56.444659" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.374725" elapsed="0.069962"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.446029" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.445788" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.446190" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.445423" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.446535" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.446285" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.447112" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.446818" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.446617" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.446266" elapsed="0.000928"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.449787" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.447348" elapsed="0.002467"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:56.449869" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:56.450022" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.445047" elapsed="0.005000"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.451280" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.451046" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.451437" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.450703" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:30:56.451686" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:56.451533" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.451514" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.451921" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.452097" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.452163" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:30:56.454113" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.450355" elapsed="0.003784"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.455537" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.455288" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.456019" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.455755" elapsed="0.000317"/>
</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-06-06T03:30:56.464934" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:56.465118" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family/bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '487'} 
 body={"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}} 
 </msg>
<msg time="2026-06-06T03:30:56.465258" 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-06-06T03:30:56.458294" elapsed="0.006991"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.456155" elapsed="0.009174"/>
</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-06-06T03:30:56.465529" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.465356" elapsed="0.000266"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.456132" elapsed="0.009548"/>
</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-06-06T03:30:56.471083" level="INFO">{"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.467200" elapsed="0.003957"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.466870" elapsed="0.004339"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.466841" elapsed="0.004406"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.475145" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.471685" elapsed="0.003528"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.471330" elapsed="0.003934"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.471305" elapsed="0.003996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.476158" 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-06-06T03:30:56.475569" elapsed="0.000629"/>
</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-06-06T03:30:56.476691" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.476304" elapsed="0.000475"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.477526" 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-06-06T03:30:56.477100" elapsed="0.000452"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.476815" elapsed="0.000774"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.476275" elapsed="0.001335"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.478153" 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-06-06T03:30:56.477792" elapsed="0.000387"/>
</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-06-06T03:30:56.478491" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.478250" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.479056" 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-06-06T03:30:56.478760" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.478577" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.478231" elapsed="0.000908"/>
</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-06-06T03:30:56.479296" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:56.480121" 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-06-06T03:30:56.479833" elapsed="0.000314"/>
</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-06-06T03:30:56.480306" elapsed="0.002328"/>
</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-06-06T03:30:56.466224" elapsed="0.016492"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.482897" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:56.482788" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.482768" elapsed="0.000197"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.486094" level="INFO">${text_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<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="PASS" start="2026-06-06T03:30:56.483115" elapsed="0.003008"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:56.486175" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:56.486336" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:56.454454" elapsed="0.031949"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.486470" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:56.486625" level="INFO">${response_text} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:56.352081" elapsed="0.134586"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.515160" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.514689" elapsed="0.000499"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.516031" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.515728" elapsed="0.000428">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.516336" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.515359" elapsed="0.001003"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.517021" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.516533" elapsed="0.000517"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.517376" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.517548" level="INFO">${template} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.517216" elapsed="0.000363"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.518027" level="INFO">{
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "attributes": {
                    "ipv6-next-hop": {
                        "global": "2001:db8:1::7"
                    },
                    "extended-communities": [
                        {
                            "vrf-route-import-extended-community": {
                                "inet4-specific-extended-community-common": {
                                    "local-administrator": "MTA=",
                                    "global-administrator": "10.0.0.1"
                                }
                            },
                            "transitive": true
                        }
                    ],
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-distinguisher": "172.16.0.44:101",
                "prefix": "2001:d00::/24"
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.517759" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:56.518549" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.518145" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.519307" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.518801" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.518634" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.518126" elapsed="0.001264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.520051" level="INFO">${final_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.519545" elapsed="0.000535"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.520129" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.514050" elapsed="0.006203"/>
</kw>
<msg time="2026-06-06T03:30:56.520357" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.501176" elapsed="0.019233"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.533095" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.545633" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/l3vpn_mcast_ipv6/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.558184" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.558397" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.558613" elapsed="0.000044"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.559040" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.558888" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.558871" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.559269" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.559444" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.559618" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.558838" elapsed="0.000851"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.558728" elapsed="0.000988"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.559869" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.559948" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:56.560104" level="INFO">${expected_text} = {
    "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
        "l3vpn-mcast-route": [
            {
                "route-key": "gAABrBAALABlGCABDQAAAAA=",
                "path-id": 0,
                "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.498503" elapsed="0.061629"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.560315" elapsed="0.002601"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.564208" level="INFO">${expected_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.563692" elapsed="0.000588"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.564940" level="INFO">${actual_normalized} = {
 "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
  "l3vpn-mcast-route": [
   {
    "attributes": {
     "extended-communities": [
      {
       "transitive": true,
       "vrf-route-import-extended-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.564445" elapsed="0.000523"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:56.565160" elapsed="0.000333"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:56.563246" elapsed="0.002311"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.562999" elapsed="0.002596"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.565795" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.565621" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.562980" elapsed="0.002893"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:56.487821" elapsed="0.078101"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:56.487000" elapsed="0.079001"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.486755" elapsed="0.079293"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.486736" elapsed="0.079336"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.566107" elapsed="0.000031"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:56.347687" elapsed="0.218553"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:56.343352" elapsed="0.222949"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:56.566471" elapsed="0.003502"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.624325" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.623940" elapsed="0.000414"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.625210" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.624930" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.625382" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.624525" elapsed="0.000882"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.625987" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.625578" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.626318" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.626557" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.626180" elapsed="0.000408"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.627024" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.626775" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.629294" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.628957" elapsed="0.000384"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.629861" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.629552" elapsed="0.000336"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.630689" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.630254" elapsed="0.000463"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:56.631951" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.631374" elapsed="0.000682"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:56.632136" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:56.632432" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:56.630912" elapsed="0.001547"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.632621" elapsed="0.000403"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:56.630112" elapsed="0.002972"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.633774" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.633342" elapsed="0.000460"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:56.635036" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.634455" elapsed="0.000686"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:56.635220" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:56.635518" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:56.633994" elapsed="0.001551"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:56.635720" elapsed="0.000375"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:56.633201" elapsed="0.002938"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:56.629938" elapsed="0.006236"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:56.636220" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:56.636382" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:56.627435" elapsed="0.008973"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.627138" elapsed="0.009303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.636625" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.636468" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.627118" elapsed="0.009602"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.637487" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.636871" elapsed="0.000645"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.637568" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.623290" elapsed="0.014423"/>
</kw>
<msg time="2026-06-06T03:30:56.637770" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.610575" elapsed="0.027246"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.651824" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.664228" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.676719" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.676922" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.677120" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.677491" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.677343" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.677327" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.677737" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.677912" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.678085" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.677298" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.677196" elapsed="0.000968"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.678314" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.678389" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:56.678509" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.606312" elapsed="0.072223"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.679833" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.679560" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.679997" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.679208" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.680349" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.680095" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.681174" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.680617" elapsed="0.000585"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.680431" elapsed="0.000808"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.680076" elapsed="0.001185"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.683619" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.681422" elapsed="0.002237"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:56.683714" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:56.683868" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.678874" elapsed="0.005019"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.685142" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.684938" elapsed="0.000262"/>
</kw>
<msg time="2026-06-06T03:30:56.685287" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.684572" elapsed="0.000739"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.685523" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:56.685383" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.685363" elapsed="0.000227"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.685928" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.686068" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.685758" elapsed="0.000335"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:56.686490" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.686257" elapsed="0.000259"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:56.686564" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:56.686736" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:56.684239" elapsed="0.002523"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.688148" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.687899" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.688596" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.688353" elapsed="0.000300"/>
</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-06-06T03:30:56.697632" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:56.698190" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '652'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}}]} 
 </msg>
<msg time="2026-06-06T03:30:56.698303" 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-06-06T03:30:56.690843" elapsed="0.007487"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.688723" elapsed="0.009650"/>
</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-06-06T03:30:56.698562" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.698400" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.688703" elapsed="0.009964"/>
</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-06-06T03:30:56.702139" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false},"bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6":{"l3vpn-mcast-route":[{"path-id":0,"route-key":"gAABrBAALABlGCABDQAAAAA=","attributes":{"extended-communities":[{"vrf-route-import-extended-community":{"inet4-specific-extended-community-common":{"global-administrator":"10.0.0.1","local-administrator":"MTA="}},"transitive":true}],"ipv6-next-hop":{"global":"2001:db8:1::7"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-distinguisher":"172.16.0.44:101","prefix":"2001:d00::/24"}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.699686" elapsed="0.002504"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.699443" elapsed="0.002781"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.699425" elapsed="0.002824"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.704912" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.702572" elapsed="0.002387"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.702306" elapsed="0.002687"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.702288" elapsed="0.002731"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.705613" 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-06-06T03:30:56.705224" elapsed="0.000430"/>
</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-06-06T03:30:56.705977" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.705728" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.706530" 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-06-06T03:30:56.706229" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.706060" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.705709" elapsed="0.000905"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.707161" 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-06-06T03:30:56.706796" 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-06-06T03:30:56.707501" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.707259" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.708061" 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-06-06T03:30:56.707765" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.707582" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.707240" elapsed="0.000905"/>
</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-06-06T03:30:56.708298" elapsed="0.000366"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:56.709130" 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-06-06T03:30:56.708836" elapsed="0.000321"/>
</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-06-06T03:30:56.709318" elapsed="0.002509"/>
</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-06-06T03:30:56.699025" elapsed="0.012867"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.712070" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:56.711963" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.711944" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.715210" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<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="PASS" start="2026-06-06T03:30:56.712290" elapsed="0.002949"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:56.715294" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:56.715451" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:56.687069" elapsed="0.028408"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.715541" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:30:56.715715" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:56.583246" elapsed="0.132496"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.744155" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.743714" elapsed="0.000503"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.745022" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.744761" elapsed="0.000393">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:56.745335" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:56.744392" elapsed="0.000968"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.745996" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:56.745532" elapsed="0.000492"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:56.746352" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:56.746485" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:56.746194" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.746961" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:56.746691" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:56.747509" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.747077" elapsed="0.000499"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.748270" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:56.747769" elapsed="0.000528"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:56.747601" elapsed="0.000734"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:56.747057" elapsed="0.001298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.748999" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:56.748507" elapsed="0.000521"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:56.749105" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:56.743078" elapsed="0.006158"/>
</kw>
<msg time="2026-06-06T03:30:56.749290" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.730317" elapsed="0.019021"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.762166" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.774703" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.787206" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.787417" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.787606" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.788021" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.787868" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:56.787852" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.788251" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.788429" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.788604" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:56.787819" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.787705" elapsed="0.001000"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.788859" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.788938" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:56.789066" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:56.727552" elapsed="0.061553"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:56.789290" elapsed="0.002238"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.792593" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.792295" elapsed="0.000326"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:56.793431" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
    "l3vpn-mcast-route": [
     {
   ...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:56.792796" elapsed="0.000664"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:30:56.793973" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
    "l3vpn-mcast-route": [
     {
      "attributes": {
       "extended-communities": [
        {
         "transitive": true,
         "vrf-route-import-extended-community": {
          "inet4-specific-extended-community-common": {
           "global-administrator": "10.0.0.1",
           "local-administrator": "MTA="
          }
         }
        }
       ],
       "ipv6-next-hop": {
        "global": "2001:db8:1::7"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "path-id": 0,
      "prefix": "2001:d00::/24",
      "route-distinguisher": "172.16.0.44:101",
      "route-key": "gAABrBAALABlGCABDQAAAAA="
     }
    ]
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:30:56.794203" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
+        }
+       ],
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.793625" elapsed="0.000701">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.791871" elapsed="0.002631">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:56.791610" elapsed="0.002988">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:56.794810" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:56.794636" elapsed="0.000232"/>
</branch>
<status status="FAIL" start="2026-06-06T03:30:56.791590" elapsed="0.003301">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.716882" elapsed="0.078162">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.716067" elapsed="0.079153">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:30:56.715825" elapsed="0.079537">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:30:56.715808" elapsed="0.079595">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:56.795456" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:30:56.578841" elapsed="0.216766">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,38 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-l3vpn-mcast:l3vpn-mcast-routes-ipv6": {
+    "l3vpn-mcast-route": [
+     {
+      "attributes": {
+       "extended-communities": [
+        {
+         "transitive": true,
+         "vrf-route-import-extended-community": {
+          "inet4-specific-extended-community-common": {
+           "global-administrator": "10.0.0.1",
+           "local-administrator": "MTA="
+          }
+         }
    [ Message content over the limit has been removed. ]
+       "ipv6-next-hop": {
+        "global": "2001:db8:1::7"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "prefix": "2001:d00::/24",
+      "route-distinguisher": "172.16.0.44:101",
+      "route-key": "gAABrBAALABlGCABDQAAAAA="
+     }
+    ]
+   },
    "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.852815" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:58.852378" elapsed="0.000471"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.853694" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:58.853415" elapsed="0.000405">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:58.853918" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:58.853034" elapsed="0.000909"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.854504" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:58.854116" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.854862" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:58.855933" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:58.854717" elapsed="0.001274"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.856533" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.856236" elapsed="0.000346"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.857720" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.857356" elapsed="0.000412"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.858212" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:58.857937" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.859132" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:58.858718" elapsed="0.000441"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:58.860394" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:58.859836" elapsed="0.000663"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:58.860583" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:30:58.860915" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:58.859358" elapsed="0.001582"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:58.861107" elapsed="0.000392"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:30:58.858549" elapsed="0.002993"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.862413" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:58.861839" elapsed="0.000600"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:58.863667" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:58.863110" elapsed="0.000658"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:58.863846" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:58.864136" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:58.862630" elapsed="0.001532"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:58.864321" elapsed="0.000378"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:58.861671" elapsed="0.003072"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:58.858364" elapsed="0.006415"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:58.864822" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:58.864979" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:58.857008" elapsed="0.007997"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.856677" elapsed="0.008360"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.865218" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.865063" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.856637" elapsed="0.008659"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.866084" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:58.865444" elapsed="0.000669"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:58.866163" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:58.851710" elapsed="0.014578"/>
</kw>
<msg time="2026-06-06T03:30:58.866343" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:58.838789" elapsed="0.027608"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.879119" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.891836" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.904240" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.904447" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.904633" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.905034" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.904882" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:58.904865" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.905261" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.905436" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.905608" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:58.904834" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:58.904728" elapsed="0.000978"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.905908" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:58.905987" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:30:58.906111" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:58.834444" elapsed="0.071693"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.907537" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:58.907225" elapsed="0.000393">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:58.907730" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:58.906829" elapsed="0.000926"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.908084" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.907828" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.908659" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:58.908350" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.908168" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.907808" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.911278" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:58.908900" elapsed="0.002406"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:30:58.911358" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:58.911511" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:58.906470" elapsed="0.005067"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.912744" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:30:58.912542" elapsed="0.000290"/>
</kw>
<msg time="2026-06-06T03:30:58.912919" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:58.912200" elapsed="0.000743"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:30:58.913151" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:58.913014" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.912995" elapsed="0.000223"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.913534" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:58.913690" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:58.913366" elapsed="0.000369"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:30:58.914154" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:30:58.913911" elapsed="0.000271"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:30:58.914231" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:58.914391" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:30:58.911868" elapsed="0.002549"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.915861" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.915589" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.916318" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.916069" elapsed="0.000295"/>
</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-06-06T03:30:58.925716" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:58.926022" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv6-address-family,bgp-l3vpn-mcast%3Amcast-mpls-labeled-vpn-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '166'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:30:58.926121" 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-06-06T03:30:58.918586" elapsed="0.007561"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.916433" elapsed="0.009758"/>
</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-06-06T03:30:58.926378" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.926217" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.916413" elapsed="0.010052"/>
</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-06-06T03:30:58.931239" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.927869" elapsed="0.003437"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.927523" elapsed="0.003831"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.927496" elapsed="0.003893"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.935221" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.931816" elapsed="0.003469"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.931469" elapsed="0.003865"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.931444" elapsed="0.003925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.936168" 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-06-06T03:30:58.935611" elapsed="0.000594"/>
</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-06-06T03:30:58.936666" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.936304" elapsed="0.000443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.937438" 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-06-06T03:30:58.937017" elapsed="0.000458"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.936782" elapsed="0.000795"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.936278" elapsed="0.001330"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.938394" 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-06-06T03:30:58.937880" elapsed="0.000551"/>
</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-06-06T03:30:58.938891" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.938530" elapsed="0.000442"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.939679" 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-06-06T03:30:58.939239" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.939006" elapsed="0.000760"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.938504" elapsed="0.001292"/>
</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-06-06T03:30:58.940013" elapsed="0.000489"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:58.941155" 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-06-06T03:30:58.940763" elapsed="0.000429"/>
</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-06-06T03:30:58.941417" elapsed="0.002688"/>
</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-06-06T03:30:58.926936" elapsed="0.017234"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:58.944348" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:58.944242" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.944222" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:58.947235" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<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="PASS" start="2026-06-06T03:30:58.944567" elapsed="0.002696"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:30:58.947315" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:58.947576" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:30:58.914759" elapsed="0.032847"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:58.947690" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:58.947845" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:30:58.810893" elapsed="0.136979"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.976294" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:58.975828" elapsed="0.000495"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.977144" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:58.976855" elapsed="0.000411">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:58.977443" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:58.976492" elapsed="0.000976"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.978119" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:58.977659" elapsed="0.000523"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:58.978514" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:58.978677" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:58.978352" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.979137" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:58.978868" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:30:58.979667" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:58.979251" elapsed="0.000478"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.980407" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:58.979904" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.979754" elapsed="0.000716"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.979231" elapsed="0.001260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:58.981144" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:58.980662" elapsed="0.000511"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:58.981223" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:58.975186" elapsed="0.006160"/>
</kw>
<msg time="2026-06-06T03:30:58.981400" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:58.962325" elapsed="0.019124"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:58.994070" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.006669" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/empty_routes/ipv6/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.019287" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.019536" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.019751" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.020262" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.020103" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:59.020084" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.020497" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.020692" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.020870" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:59.020042" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.019914" elapsed="0.001040"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.021108" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.021190" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:30:59.021335" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv6-address-family",
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family",
      "attributes": {
        "uptodate": ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:58.959669" elapsed="0.061695"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.021552" elapsed="0.002515"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:59.025217" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.024891" elapsed="0.000355"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:30:59.025702" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv6-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
  }
 ]
...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.025407" elapsed="0.000325"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:30:59.025939" elapsed="0.000344"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:30:59.024429" elapsed="0.001915"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.024150" elapsed="0.002228"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.026558" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.026404" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.024131" elapsed="0.002504"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:30:58.949018" elapsed="0.077698"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:30:58.948198" elapsed="0.078598"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:58.947955" elapsed="0.078888"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:58.947938" elapsed="0.078930"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:59.026902" elapsed="0.000034"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:30:58.804585" elapsed="0.222455"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:30:56.570431" elapsed="2.456678"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:30:59.027335" elapsed="0.003356"/>
</kw>
<arg>l3vpn_mcast_ipv6</arg>
<arg>${L3VPN_MCAST_DIR}</arg>
<arg>ipv6</arg>
<status status="PASS" start="2026-06-06T03:30:53.753771" elapsed="5.277059"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:53.654454" elapsed="5.376571"/>
</test>
<test id="s1-s17-t8" name="Kill_Talking_BGP_Speaker" line="85">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:59.035713" elapsed="0.000302"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:59.035310" elapsed="0.000786"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.037544" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.037382" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.037354" elapsed="0.000307"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.042986" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.042877" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.042859" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.044081" 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-06-06T03:30:59.043692" elapsed="0.000416"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.044573" 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-06-06T03:30:59.044274" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:59.044660" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:30:59.044820" 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-06-06T03:30:59.043289" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:59.050544" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.050436" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.050417" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:59.051816" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.051706" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.051686" elapsed="0.000199"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:59.052338" 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-06-06T03:30:59.052035" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.052855" level="INFO">${current_connection_index} = 7</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-06-06T03:30:59.052528" elapsed="0.000355"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.087444" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:59.053397" elapsed="0.034172"/>
</kw>
<msg time="2026-06-06T03:30:59.087793" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:59.087841" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:59.053053" elapsed="0.034825"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.122028" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:30:59.088466" elapsed="0.033700"/>
</kw>
<msg time="2026-06-06T03:30:59.122344" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:59.122391" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "K "i "...</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-06-06T03:30:59.088080" elapsed="0.034348"/>
</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-06-06T03:30:59.122803" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.122520" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.122495" elapsed="0.000392"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.123354" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:30:59.123037" elapsed="0.000458"/>
</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-06-06T03:30:59.123815" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.123567" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.123547" elapsed="0.000347"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:59.123930" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:59.126632" elapsed="0.000170"/>
</kw>
<msg time="2026-06-06T03:30:59.126865" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.125480" elapsed="0.001519"/>
</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="NOT RUN" start="2026-06-06T03:30:59.127280" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.127621" elapsed="0.000101"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:59.124822" elapsed="0.003011"/>
</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-06-06T03:30:59.124247" elapsed="0.003660"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:59.051380" elapsed="0.076627"/>
</kw>
<msg time="2026-06-06T03:30:59.128101" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.128146" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "K "i "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.050784" elapsed="0.077399"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:59.128370" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:30:59.128261" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.128242" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.128882" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.129249" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.129324" elapsed="0.000019"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:59.050096" elapsed="0.079344"/>
</kw>
<msg time="2026-06-06T03:30:59.129535" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.129580" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "K "i "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:59.045218" elapsed="0.084404"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.130009" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.129717" elapsed="0.000345"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.129698" elapsed="0.000388"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:59.045071" elapsed="0.085039"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:59.044899" elapsed="0.085249"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:59.042491" elapsed="0.087719"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:59.036971" elapsed="0.093296"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.036322" elapsed="0.093992"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:59.032225" elapsed="0.098142"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.131577" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:59.131257" elapsed="0.000347"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:59.131783" elapsed="0.000454"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:30:59.130987" elapsed="0.001312"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.152290" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:30:59.132866" elapsed="0.019490"/>
</kw>
<msg time="2026-06-06T03:30:59.152455" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.152498" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.132510" elapsed="0.020012"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.153181" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:30:59.166059" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:30:59.166291" level="INFO">${output_log} = 2026-06-06 03:30:41,114 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:30:41,114 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:30:59.153035" elapsed="0.013321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.167456" level="INFO">2026-06-06 03:30:41,114 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:30:41,115 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job):   Length=61 (0x003d)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=32 (0x20)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x020601040001000102060104000100810206010400020081020641040000fbf0
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100810206010400020081020641040000fbf0'
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100810206010400020081020641040000fbf0
2026-06-06 03:30:41,123 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:30:41,125 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:41,125 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:41,125 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:41,144 INFO BGP-Thread-1 (job): ... idle for 0.019s
2026-06-06 03:30:41,144 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.019s
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:41,146 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:41,146 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:41,146 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:42,148 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:42,148 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.020s
2026-06-06 03:30:42,150 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:42,150 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:42,150 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:43,151 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:43,151 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.021s
2026-06-06 03:30:43,151 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:43,152 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:43,152 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.022s
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.023s
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:46,156 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:46,156 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.024s
2026-06-06 03:30:46,156 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:46,157 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:46,157 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:47,158 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:47,158 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.025s
2026-06-06 03:30:47,160 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:47,160 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:47,160 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:47,349 INFO BGP-Thread-1 (job): ... idle for 0.188s
2026-06-06 03:30:47,349 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.213s
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004d' (77)
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:47,350 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:47,350 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:47,350 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:47,493 INFO BGP-Thread-1 (job): ... idle for 0.144s
2026-06-06 03:30:47,494 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.357s
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0047' (71)
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:47,494 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:47,495 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:47,495 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.358s
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.359s
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.360s
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:50] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:51,501 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.362s
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:52,504 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:52,504 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.363s
2026-06-06 03:30:52,505 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:52,505 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:52,506 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:53,325 INFO BGP-Thread-1 (job): ... idle for 0.819s
2026-06-06 03:30:53,325 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.182s
2026-06-06 03:30:53,325 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:53,325 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:53,325 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0059' (89)
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:53,326 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:53,326 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:53,326 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:53,461 INFO BGP-Thread-1 (job): ... idle for 0.135s
2026-06-06 03:30:53,461 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.317s
2026-06-06 03:30:53,461 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:53,461 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:53,461 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0047' (71)
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:53,462 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:53,462 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:53,462 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:54,463 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.318s
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:55,465 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.319s
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:56,467 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:56,467 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.320s
2026-06-06 03:30:56,468 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:56,468 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:56,468 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:57,469 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:57,469 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.321s
2026-06-06 03:30:57,469 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:57,470 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:57,470 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:57,470 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:58,471 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.323s
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:59] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.166827" elapsed="0.001348"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:30:59.152743" elapsed="0.015574"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:30:59.168789" elapsed="0.000069"/>
</return>
<status status="PASS" start="2026-06-06T03:30:59.168477" elapsed="0.000453"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.168429" elapsed="0.000562"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.169362" elapsed="0.000052"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.169864" elapsed="0.000054"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:30:59.130663" elapsed="0.039395"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.182898" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:30:59.216289" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:30:59.216547" level="INFO">${output_log} = 2026-06-06 03:30:41,114 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:30:41,114 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:30:59.182756" elapsed="0.033852"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.217729" level="INFO">2026-06-06 03:30:41,114 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:30:41,114 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:30:41,115 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:30:41,119 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:30:41,120 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:30:41,120 DEBUG BGP-Thread-1 (job):   Length=61 (0x003d)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=32 (0x20)
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x020601040001000102060104000100810206010400020081020641040000fbf0
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100810206010400020081020641040000fbf0'
2026-06-06 03:30:41,121 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff003d0104fbf000b40a1eabc220020601040001000102060104000100810206010400020081020641040000fbf0
2026-06-06 03:30:41,123 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:30:41,124 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:30:41,125 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:41,125 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:41,125 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:41,144 INFO BGP-Thread-1 (job): ... idle for 0.019s
2026-06-06 03:30:41,144 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.019s
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:41,144 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:41,145 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:41,146 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:41,146 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:41,146 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:41,146 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:42,148 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:42,148 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.020s
2026-06-06 03:30:42,150 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:42,150 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:42,150 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:43,151 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:43,151 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.021s
2026-06-06 03:30:43,151 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:43,152 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:43,152 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.022s
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:44,153 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.023s
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:45,155 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:46,156 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:46,156 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.024s
2026-06-06 03:30:46,156 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:46,157 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:46,157 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:47,158 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:47,158 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.025s
2026-06-06 03:30:47,160 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:47,160 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:47,160 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:47,349 INFO BGP-Thread-1 (job): ... idle for 0.188s
2026-06-06 03:30:47,349 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.213s
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'004d' (77)
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:47,349 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:47,350 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:47,350 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:47,350 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:47,493 INFO BGP-Thread-1 (job): ... idle for 0.144s
2026-06-06 03:30:47,494 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.357s
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0047' (71)
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:47,494 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:47,494 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:47,495 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:47,495 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:47] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.358s
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004d02000000364001010040020040050400000064800e1a000181047f10002c00200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:48,496 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.359s
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:49,498 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.360s
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:50,500 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:50] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:51,501 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.362s
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:51,502 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:52,504 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:52,504 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.363s
2026-06-06 03:30:52,505 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:52,505 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:52,506 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:53,325 INFO BGP-Thread-1 (job): ... idle for 0.819s
2026-06-06 03:30:53,325 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.182s
2026-06-06 03:30:53,325 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000181200001ac10002c0065180a022200000000c01008010b0a0000013130
2026-06-06 03:30:53,325 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:53,325 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0059' (89)
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:53,326 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:53,326 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:53,326 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:53,326 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:53,461 INFO BGP-Thread-1 (job): ... idle for 0.135s
2026-06-06 03:30:53,461 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.317s
2026-06-06 03:30:53,461 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:53,461 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:30:53,461 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0047' (71)
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): L3vpn-mcast True
2026-06-06 03:30:53,462 DEBUG BGP-Thread-1 (job): Skipping update decoding due to l3vpn_mcast data expected
2026-06-06 03:30:53,462 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:53,462 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:53,462 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:30:53] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:54,463 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.318s
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff005902000000424001010040020040050400000064800e260002811020010db800010000000000000000000700800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:54,464 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:55,465 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.319s
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:55,466 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:56,467 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:56,467 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.320s
2026-06-06 03:30:56,468 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:56,468 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:56,468 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:56] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:30:57,469 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:57,469 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.321s
2026-06-06 03:30:57,469 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff004702000000304001010040020040050400000064800f14000281800001ac10002c00651820010d00000000c01008010b0a0000013130
2026-06-06 03:30:57,470 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:57,470 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:57,470 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:30:58,471 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.323s
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:30:58,472 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:30:59] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.217067" elapsed="0.001329"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:59.219732" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/l3vpn_mcast_play.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/l3vpn_mcast_play.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:30:59.218872" elapsed="0.000989"/>
</kw>
<arg>play.py.out</arg>
<arg>l3vpn_mcast_play.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:59.182329" elapsed="0.037675"/>
</kw>
<doc>Abort the Python speaker</doc>
<status status="PASS" start="2026-06-06T03:30:59.031523" elapsed="0.188729"/>
</test>
<test id="s1-s17-t9" name="Delete_Bgp_Peer_Configuration" line="91">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:59.225902" elapsed="0.000297"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:59.225482" elapsed="0.000794"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.227768" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.227567" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.227535" elapsed="0.000335"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.235291" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.235176" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.235156" elapsed="0.000207"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.236417" 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-06-06T03:30:59.236011" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.236960" 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-06-06T03:30:59.236637" elapsed="0.000348"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:59.237031" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:59.237197" 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-06-06T03:30:59.235604" elapsed="0.001618"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:59.243073" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.242963" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.242943" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:59.244328" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.244221" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.244202" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:59.244875" 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-06-06T03:30:59.244546" elapsed="0.000356"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.245282" level="INFO">${current_connection_index} = 7</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-06-06T03:30:59.245066" elapsed="0.000242"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.282564" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:59.245920" elapsed="0.036785"/>
</kw>
<msg time="2026-06-06T03:30:59.282898" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:59.282945" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:59.245474" elapsed="0.037508"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.321118" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:30:59.283552" elapsed="0.037700"/>
</kw>
<msg time="2026-06-06T03:30:59.321431" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:59.321490" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "...</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-06-06T03:30:59.283182" elapsed="0.038348"/>
</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-06-06T03:30:59.322033" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.321629" elapsed="0.000465"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.321600" elapsed="0.000521"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.322599" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:30:59.322271" elapsed="0.000424"/>
</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-06-06T03:30:59.322993" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.322765" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.322746" elapsed="0.000328"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:59.323112" elapsed="0.000046"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:59.326311" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:30:59.326523" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.325084" elapsed="0.001606"/>
</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="NOT RUN" start="2026-06-06T03:30:59.326979" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.327326" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:59.324253" elapsed="0.003258"/>
</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-06-06T03:30:59.323516" elapsed="0.004060"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:59.243920" elapsed="0.083863"/>
</kw>
<msg time="2026-06-06T03:30:59.327883" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.327929" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.243299" elapsed="0.084671"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:59.328371" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:30:59.328049" elapsed="0.000384"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.328029" elapsed="0.000430"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.328890" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.329233" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.329306" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:59.242602" elapsed="0.086811"/>
</kw>
<msg time="2026-06-06T03:30:59.329507" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.329552" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:59.237663" elapsed="0.091927"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.329979" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.329683" elapsed="0.000352"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.329664" elapsed="0.000396"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:59.237465" elapsed="0.092619"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:59.237279" elapsed="0.092837"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:59.234755" elapsed="0.095415"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:59.227152" elapsed="0.103077"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.226500" elapsed="0.103776"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:59.222180" elapsed="0.108152"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.374123" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:59.373711" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:59.374967" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:59.374696" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:59.375143" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:59.374332" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.375746" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:59.375339" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:59.376086" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:59.376254" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:59.375942" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.376740" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.376451" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.377905" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.377578" elapsed="0.000379"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.378411" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.378130" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.379148" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.378843" elapsed="0.000331"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.379957" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.379717" elapsed="0.000273"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.380047" elapsed="0.000281"/>
</return>
<msg time="2026-06-06T03:30:59.380466" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.379370" elapsed="0.001123"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.380676" elapsed="0.000250"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:30:59.378698" elapsed="0.002271"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.381541" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.381228" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.382389" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.382172" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.382467" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:59.382620" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.381818" elapsed="0.000843"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.382825" elapsed="0.000226"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:30:59.381087" elapsed="0.002004"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.383660" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.383343" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.384509" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.384279" elapsed="0.000265"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.384611" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:30:59.384788" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.383951" elapsed="0.000862"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.384972" elapsed="0.000228"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:30:59.383204" elapsed="0.002039"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.385815" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.385496" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.386620" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.386401" elapsed="0.000262"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.386718" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:59.386885" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.386074" elapsed="0.000843"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.387080" elapsed="0.000229"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:30:59.385357" elapsed="0.002000"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.387940" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.387616" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.388722" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.388490" elapsed="0.000259"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.388800" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:59.388956" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.388159" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.389140" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:59.387472" elapsed="0.001938"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.390007" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.389681" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.390837" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.390561" elapsed="0.000304"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.390916" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:30:59.391071" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.390231" elapsed="0.000865"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.391253" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:30:59.389525" elapsed="0.001992"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:59.378492" elapsed="0.013061"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:59.391597" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:30:59.391781" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:59.377232" elapsed="0.014576"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.376867" elapsed="0.014974"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.392024" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.391868" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.376843" elapsed="0.015260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.393152" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:59.392253" elapsed="0.000929"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:59.393232" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:59.373058" elapsed="0.020301"/>
</kw>
<msg time="2026-06-06T03:30:59.393474" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.359993" elapsed="0.033535"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.406440" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.419198" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.432154" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.432374" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.432566" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.432992" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.432834" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:59.432816" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.433222" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.433394" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.433566" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:59.432779" elapsed="0.000840"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.432661" elapsed="0.001004"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.433821" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.433922" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:30:59.434072" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:59.355562" elapsed="0.078539"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.435441" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.435154" elapsed="0.000392"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:59.447412" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:59.447462" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:59.447574" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:59.437737" elapsed="0.009878"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.435616" elapsed="0.012149"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.448218" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.447832" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.435597" elapsed="0.012822"/>
</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-06-06T03:30:59.456844" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.451020" elapsed="0.005923"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.450402" elapsed="0.006622"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.450357" elapsed="0.006721"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.460736" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.457748" elapsed="0.003035"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.457205" elapsed="0.003613"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.457167" elapsed="0.003675"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.461425" 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-06-06T03:30:59.461028" elapsed="0.000424"/>
</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-06-06T03:30:59.461785" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.461523" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.462381" 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-06-06T03:30:59.462076" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.461899" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.461505" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.463015" 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-06-06T03:30:59.462631" elapsed="0.000411"/>
</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-06-06T03:30:59.463354" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.463113" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.463921" 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-06-06T03:30:59.463605" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.463436" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.463095" elapsed="0.000910"/>
</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-06-06T03:30:59.464163" elapsed="0.000356"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:59.465029" 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-06-06T03:30:59.464727" elapsed="0.000329"/>
</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-06-06T03:30:59.465224" elapsed="0.002571"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:59.449322" elapsed="0.018541"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:59.467910" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:30:59.470290" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:59.434374" elapsed="0.035944"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:59.470437" elapsed="0.000035"/>
</return>
<arg>${L3VPN_MCAST_DIR}/bgp_peer</arg>
<arg>mapping=${L3VPN_MCAST_ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:59.330690" elapsed="0.139896"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:30:59.220723" elapsed="0.250009"/>
</test>
<test id="s1-s17-t10" name="Deconfigure_App_Peer" line="99">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:30:59.474256" elapsed="0.000220"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:30:59.473975" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.475600" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.475482" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.475461" elapsed="0.000250"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.480837" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.480723" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.480704" elapsed="0.000203"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.482009" 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-06-06T03:30:59.481532" elapsed="0.000505"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.482514" 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-06-06T03:30:59.482208" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:59.482592" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:30:59.482771" 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-06-06T03:30:59.481144" elapsed="0.001653"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:30:59.489939" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.489759" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.489733" elapsed="0.000298"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:30:59.491535" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.491399" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.491375" elapsed="0.000247"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:59.492231" 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-06-06T03:30:59.491857" elapsed="0.000409"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.492777" level="INFO">${current_connection_index} = 7</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-06-06T03:30:59.492483" elapsed="0.000327"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.527807" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:30:59.493464" elapsed="0.034482"/>
</kw>
<msg time="2026-06-06T03:30:59.528132" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:30:59.528180" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:30:59.493028" elapsed="0.035188"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.563402" level="INFO">". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:59.528870" elapsed="0.034756"/>
</kw>
<msg time="2026-06-06T03:30:59.563887" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:30:59.563941" level="INFO">${message_wait} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "...</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-06-06T03:30:59.528430" elapsed="0.035550"/>
</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-06-06T03:30:59.564424" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.564096" elapsed="0.000478"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.564062" elapsed="0.000541"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.565160" level="INFO"> ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:30:59.564783" elapsed="0.000455"/>
</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-06-06T03:30:59.565570" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.565327" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.565306" elapsed="0.000371"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:30:59.565718" elapsed="0.000048"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:30:59.568537" elapsed="0.000170"/>
</kw>
<msg time="2026-06-06T03:30:59.568771" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.567422" elapsed="0.001483"/>
</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="NOT RUN" start="2026-06-06T03:30:59.569188" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.569526" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:30:59.566771" elapsed="0.002959"/>
</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-06-06T03:30:59.566141" elapsed="0.003653"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:30:59.491021" elapsed="0.078875"/>
</kw>
<msg time="2026-06-06T03:30:59.570041" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.570086" level="INFO">${message} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.490235" elapsed="0.079891"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:30:59.570316" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:30:59.570207" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.570187" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.570843" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.571189" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.571261" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:30:59.489316" elapsed="0.082055"/>
</kw>
<msg time="2026-06-06T03:30:59.571467" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.571512" level="INFO">${output} =  ". "t "x "t ". "0 "7 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "L "3 "V "p "n "[C "M "c "a "s "t ". "D "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:30:59.483179" elapsed="0.088374"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.571903" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.571630" elapsed="0.000329"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.571613" elapsed="0.000369"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:59.483029" elapsed="0.088978"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:59.482853" elapsed="0.089187"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:30:59.480317" elapsed="0.091781"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:30:59.475189" elapsed="0.096969"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:30:59.474714" elapsed="0.097491"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:30:59.471713" elapsed="0.100547"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.615974" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:30:59.615554" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:30:59.616819" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:30:59.616532" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:30:59.616993" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:30:59.616188" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.617577" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:30:59.617190" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:30:59.617958" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/l3vpn_mcast/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:30:59.618210" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:30:59.617789" elapsed="0.000449"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.618676" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.618403" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.619728" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.619445" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.620211" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.619941" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.620927" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.620608" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.621729" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.621484" elapsed="0.000272"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.621811" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:59.621990" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.621150" elapsed="0.000865"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.622176" elapsed="0.000242"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:30:59.620464" elapsed="0.001995"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.623028" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:30:59.622729" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:30:59.623975" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.623564" elapsed="0.000437"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:30:59.624052" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:30:59.624201" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:30:59.623244" elapsed="0.000981"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:30:59.624380" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:30:59.622574" elapsed="0.002086"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:30:59.620289" elapsed="0.004408"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:30:59.624741" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:30:59.624898" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:30:59.619118" elapsed="0.005805"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.618802" elapsed="0.006216"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.625202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.625045" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.618779" elapsed="0.006499"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.626055" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:30:59.625427" elapsed="0.000658"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:30:59.626134" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:30:59.614926" elapsed="0.011333"/>
</kw>
<msg time="2026-06-06T03:30:59.626316" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.601983" elapsed="0.024381"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.638823" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.651297" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/l3vpn_mcast/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.663766" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.663977" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.664165" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.664554" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.664402" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:30:59.664385" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.664802" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.664976" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.665146" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:30:59.664352" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.664245" elapsed="0.000981"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.665377" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.665452" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:30:59.665730" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:30:59.597381" elapsed="0.068378"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.666955" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.666685" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:59.677429" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01lx4srgn162t81q7blxqfnppvm26.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:59.677478" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:30:59.677570" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:30:59.669145" elapsed="0.008451"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.667071" elapsed="0.010566"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:30:59.677848" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.677689" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.667053" elapsed="0.010878"/>
</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-06-06T03:30:59.681537" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.678990" elapsed="0.002592"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.678761" elapsed="0.002861"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.678742" elapsed="0.002920"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.684281" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.681973" elapsed="0.002353"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.681720" elapsed="0.002640"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.681703" elapsed="0.002682"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.684989" 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-06-06T03:30:59.684570" elapsed="0.000447"/>
</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-06-06T03:30:59.685333" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.685087" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.685904" 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-06-06T03:30:59.685584" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.685416" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.685069" elapsed="0.000935"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.686529" 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-06-06T03:30:59.686170" elapsed="0.000386"/>
</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-06-06T03:30:59.686887" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.686626" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.687434" 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-06-06T03:30:59.687139" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:30:59.686971" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.686607" elapsed="0.000910"/>
</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-06-06T03:30:59.687696" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:30:59.688544" 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-06-06T03:30:59.688254" elapsed="0.000316"/>
</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-06-06T03:30:59.688745" elapsed="0.002343"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:30:59.678328" elapsed="0.012824"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:30:59.691198" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:30:59.693463" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:30:59.666059" elapsed="0.027431"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:30:59.693544" elapsed="0.000027"/>
</return>
<arg>${L3VPN_MCAST_DIR}/app_peer</arg>
<arg>mapping=${L3VPN_MCAST_APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:30:59.572495" elapsed="0.121195"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:30:59.471063" elapsed="0.222753"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:30:59.694603" elapsed="0.000471"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:59.695310" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:30:59.695234" elapsed="0.000156"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:30:59.694379" elapsed="0.001064"/>
</kw>
<doc>Functional test for bgp - l3vpn-mutlicast

Copyright (c) 2018 AT&amp;T Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distbmution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests advertising l3vpn_mcast routes to odl. For advertising play.py is used,
and particular files are stored as *.hex files.
There are L3vpn-ipv4-multicast routes and L3vpn-ipv6-multicast routes tested.</doc>
<status status="PASS" start="2026-06-06T03:30:38.503188" elapsed="21.192285"/>
</suite>
<suite id="s1-s18" name="080 Bgp Functional Rt Constrain" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/080_bgp_functional_rt_constrain.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.784029" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:30:59.779686" elapsed="0.004401"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:30:59.779425" elapsed="0.004735"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.789184" 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-06-06T03:30:59.785367" elapsed="0.003846"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:30:59.789437" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.789305" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.789278" elapsed="0.000232"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.790070" 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-06-06T03:30:59.789687" elapsed="0.000427"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.790593" 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-06-06T03:30:59.790281" elapsed="0.000338"/>
</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-06-06T03:30:59.791154" elapsed="0.000288"/>
</kw>
<msg time="2026-06-06T03:30:59.791540" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:30:59.791588" 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-06-06T03:30:59.790806" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.792177" 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-06-06T03:30:59.791805" elapsed="0.000398"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.793219" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:30:59.792956" elapsed="0.000289"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.793667" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:30:59.793397" elapsed="0.000297"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.794194" 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-06-06T03:30:59.793857" elapsed="0.000364"/>
</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-06-06T03:30:59.797511" elapsed="0.000240"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.798278" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:30:59.797918" elapsed="0.000386"/>
</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-06-06T03:30:59.798462" elapsed="0.000247"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.799501" 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-06-06T03:30:59.799208" elapsed="0.000320"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:30:59.799575" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:30:59.799756" 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-06-06T03:30:59.798909" elapsed="0.000873"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:30:59.801961" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5b01a50&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-06-06T03:30:59.799946" elapsed="0.002188"/>
</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-06-06T03:30:59.802313" elapsed="0.000201"/>
</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-06-06T03:30:59.796930" elapsed="0.005647"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:59.796723" elapsed="0.005900"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:30:59.794365" elapsed="0.008307"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.803269" 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-06-06T03:30:59.802846" elapsed="0.000467"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.803901" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:30:59.803482" elapsed="0.000462"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.804500" 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-06-06T03:30:59.804110" elapsed="0.000433"/>
</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-06-06T03:30:59.792474" elapsed="0.012126"/>
</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-06-06T03:30:59.785004" elapsed="0.019676"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:30:59.804889" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:30:59.804758" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.804735" elapsed="0.000223"/>
</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-06-06T03:30:59.808214" 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-06-06T03:30:59.807818" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.808728" 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-06-06T03:30:59.808409" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:30:59.808801" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:30:59.808966" 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-06-06T03:30:59.807454" elapsed="0.001536"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:30:59.810054" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:30:59.809747" elapsed="0.000334"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.810867" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:30:59.811048" 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-06-06T03:30:59.810694" elapsed="0.000381"/>
</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-06-06T03:30:59.814546" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:30:59.813916" elapsed="0.000716"/>
</branch>
<status status="PASS" start="2026-06-06T03:30:59.813893" elapsed="0.000797"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.815343" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:30:59.814900" elapsed="0.000730"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.816596" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:30:59.815921" elapsed="0.000799"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.817914" 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-06-06T03:30:59.816999" elapsed="0.000969"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:30:59.820020" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:30:59.820200" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:30:59.819409" elapsed="0.000833"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.820592" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:30:59.822357" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:31:00.151339" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:30:38 UTC 2026

  System load:  0.16               Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:30:39 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:30:59.822022" elapsed="0.329496"/>
</kw>
<msg time="2026-06-06T03:31:00.151608" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.821519" elapsed="0.330292"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:30:59.818446" elapsed="0.333517"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.152861" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:31:00.166169" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:31:00.166405" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:31:00.166549" 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-06-06T03:31:00.152351" elapsed="0.014266"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:00.167341" elapsed="0.001164"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.171165" 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-06-06T03:31:00.169895" elapsed="0.001501"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.172367" elapsed="0.000117"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.171816" elapsed="0.000944"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.171759" elapsed="0.001097"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:31:00.173537" elapsed="0.000170"/>
</return>
<status status="PASS" start="2026-06-06T03:31:00.173043" elapsed="0.000844"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.173002" elapsed="0.001182"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.174347" elapsed="0.000040"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:00.178054" elapsed="0.000497"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:00.178853" elapsed="0.000288"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:00.179407" elapsed="0.000226"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:00.175020" elapsed="0.004715"/>
</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-06-06T03:30:59.812938" elapsed="0.366977"/>
</kw>
<msg time="2026-06-06T03:31:00.179973" 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-06-06T03:30:59.812271" elapsed="0.367756"/>
</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-06-06T03:30:59.811782" elapsed="0.368327"/>
</kw>
<msg time="2026-06-06T03:31:00.180151" 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-06-06T03:30:59.811240" elapsed="0.368958"/>
</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-06-06T03:31:00.183076" elapsed="0.000315"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:00.183561" elapsed="0.000178"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:00.183893" elapsed="0.000098"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:00.180498" elapsed="0.003546"/>
</kw>
<msg time="2026-06-06T03:31:00.184137" 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-06-06T03:30:59.810306" elapsed="0.373857"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.184601" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:00.184350" elapsed="0.000364"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:31:00.184760" elapsed="0.000030"/>
</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-06-06T03:30:59.809366" elapsed="0.375521"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:30:59.809182" elapsed="0.375744"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:30:59.809046" elapsed="0.375915"/>
</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-06-06T03:30:59.805197" elapsed="0.379821"/>
</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-06-06T03:31:00.185181" elapsed="0.000213"/>
</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-06-06T03:31:00.199587" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.199477" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.199457" elapsed="0.000216"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.199971" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:31:00.200076" 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-06-06T03:31:00.199835" elapsed="0.000268"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.200526" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:00.200265" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.200999" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:00.200751" elapsed="0.000293"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:00.201825" 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-06-06T03:31:00.201583" elapsed="0.000344">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:31:00.202075" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:31:00.202136" 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-06-06T03:31:00.201209" elapsed="0.000951"/>
</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-06-06T03:31:00.202470" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:00.202239" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.202219" elapsed="0.000351"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:00.203336" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:31:00.203069" elapsed="0.000294"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:31:00.203412" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:00.203564" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:31:00.202792" elapsed="0.000797"/>
</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-06-06T03:31:00.203765" elapsed="0.000405"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.204454" level="INFO">index=4
host=10.30.170.38
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-06-06T03:31:00.204555" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:31:00.204347" elapsed="0.000234"/>
</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-06-06T03:31:00.204756" elapsed="0.002240"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.207430" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:31:00.406692" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:31:00.207168" elapsed="0.199616"/>
</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-06-06T03:31:00.410072" elapsed="0.000387"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:00.410634" elapsed="0.000172"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:00.410960" elapsed="0.000098"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:00.407622" elapsed="0.003487"/>
</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-06-06T03:31:00.407066" elapsed="0.004091"/>
</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-06-06T03:31:00.199192" elapsed="0.212016"/>
</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-06-06T03:31:00.186169" elapsed="0.225086"/>
</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-06-06T03:31:00.185765" elapsed="0.225541"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:00.185606" elapsed="0.225741"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:31:00.185459" elapsed="0.225920"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:30:59.784493" elapsed="0.626943"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.414215" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.414077" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.414057" elapsed="0.000236"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.419172" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.419064" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.419046" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.420217" 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-06-06T03:31:00.419829" elapsed="0.000415"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.420728" 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-06-06T03:31:00.420413" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:00.420801" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:00.420958" 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-06-06T03:31:00.419470" elapsed="0.001513"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:00.426397" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.426288" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.426268" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:00.427685" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.427531" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.427512" elapsed="0.000243"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:00.428220" 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-06-06T03:31:00.427904" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.428637" 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-06-06T03:31:00.428409" elapsed="0.000272"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.462029" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:00.429343" elapsed="0.032813"/>
</kw>
<msg time="2026-06-06T03:31:00.462316" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:00.462362" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:31:00.428847" elapsed="0.033552"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.541321" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "8 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n ". "r "o "b "o "t "[K"
[?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-06-06T03:31:00.463094" elapsed="0.078382"/>
</kw>
<msg time="2026-06-06T03:31:00.541605" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:00.541665" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:31:00.462576" elapsed="0.079128"/>
</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-06-06T03:31:00.542031" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:00.541780" elapsed="0.000398"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.541760" elapsed="0.000491"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.542785" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "8 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n ". "r "o "b "o "t "[K"
[?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-06-06T03:31:00.542413" elapsed="0.000459"/>
</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-06-06T03:31:00.543179" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:00.542940" elapsed="0.000421"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.542921" elapsed="0.000467"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:00.543423" elapsed="0.000029"/>
</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-06-06T03:31:00.545521" elapsed="0.000470"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:00.546367" elapsed="0.000308"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:00.547010" elapsed="0.000231"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:00.544763" elapsed="0.002568"/>
</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-06-06T03:31:00.543712" elapsed="0.003754"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:00.427246" elapsed="0.120322"/>
</kw>
<msg time="2026-06-06T03:31:00.547678" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:00.547723" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:00.426623" elapsed="0.121139"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:00.547950" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:00.547841" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.547821" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:00.548433" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:00.548792" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.548865" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:00.425967" elapsed="0.123005"/>
</kw>
<msg time="2026-06-06T03:31:00.549066" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:00.549110" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:00.421354" elapsed="0.127793"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:00.549476" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:00.549223" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.549205" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:00.421208" elapsed="0.128369"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:00.421035" elapsed="0.128571"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:00.418773" elapsed="0.131091"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:31:00.412113" elapsed="0.137810"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:00.411596" elapsed="0.138369"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:30:59.779101" elapsed="0.770914"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.550535" level="INFO">${mininet_conn_id} = 7</msg>
<var>${mininet_conn_id}</var>
<arg>${TOOLS_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:00.550172" elapsed="0.000389"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.551068" level="INFO">${mininet_conn_id} = 7</msg>
<arg>${mininet_conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:31:00.550750" elapsed="0.000361"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:31:00.552810" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:31:00.552888" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:00.552519" elapsed="0.000393"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:00.553076" elapsed="0.000316"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.554406" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:31:00.887615" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:30:39 UTC 2026

  System load:  0.08               Processes:             105
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:30:40 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:31:00.554051" elapsed="0.333737"/>
</kw>
<msg time="2026-06-06T03:31:00.887873" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:00.553606" elapsed="0.334344"/>
</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-06-06T03:31:00.552082" elapsed="0.335979"/>
</kw>
<msg time="2026-06-06T03:31:00.888116" 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-06-06T03:31:00.551696" elapsed="0.336466"/>
</kw>
<arg>${TOOLS_SYSTEM_USER}</arg>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:31:00.551318" elapsed="0.336922"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:00.888888" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5889fd0&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:31:00.888474" elapsed="0.000587"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.897047" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:31:00.910544" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>${PLAY_SCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:31:00.889238" elapsed="0.021399"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.912703" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:31:00.945158" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:00.945432" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:31:00.945535" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:31:00.945626" 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-06-06T03:31:00.912405" elapsed="0.033311"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.947720" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:31:00.947081" elapsed="0.000744"/>
</kw>
<msg time="2026-06-06T03:31:00.948036" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:31:00.948133" 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-06-06T03:31:00.946160" elapsed="0.002026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.949553" 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-06-06T03:31:00.948573" elapsed="0.001038"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:31:00.950682" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:00.949831" elapsed="0.000950"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.949780" elapsed="0.001042"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:31:00.951055" elapsed="0.000052"/>
</return>
<status status="PASS" start="2026-06-06T03:31:00.950904" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.950880" elapsed="0.000313"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.951328" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.951276" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:00.951252" elapsed="0.000166"/>
</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-06-06T03:31:00.951657" elapsed="0.000034"/>
</kw>
<msg time="2026-06-06T03:31:00.951884" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:31:00.911842" elapsed="0.040079"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:31:00.952241" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:31:00.952104" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.952077" elapsed="0.000283"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:00.952586" elapsed="0.000032"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:31:00.911121" elapsed="0.041616"/>
</kw>
<doc>Initialize SetupUtils. Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:30:59.778702" elapsed="1.174115"/>
</kw>
<test id="s1-s18-t1" name="Configure_App_Peer" line="48">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:00.957598" elapsed="0.000335"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:00.957198" elapsed="0.000818"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.959251" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.959140" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.959121" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:00.964497" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.964390" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.964372" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.965582" 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-06-06T03:31:00.965201" elapsed="0.000408"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:00.966089" 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-06-06T03:31:00.965793" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:00.966160" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:00.966313" 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-06-06T03:31:00.964815" elapsed="0.001538"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:00.971827" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.971718" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.971699" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:00.973084" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:00.972977" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:00.972959" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:00.973602" 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-06-06T03:31:00.973301" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:00.974026" level="INFO">${current_connection_index} = 7</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-06-06T03:31:00.973809" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.007716" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:00.974574" elapsed="0.033279"/>
</kw>
<msg time="2026-06-06T03:31:01.008040" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:01.008086" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:00.974216" elapsed="0.033907"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.039061" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:31:01.008750" elapsed="0.030421"/>
</kw>
<msg time="2026-06-06T03:31:01.039332" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:01.039378" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "C "...</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-06-06T03:31:01.008334" elapsed="0.031083"/>
</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-06-06T03:31:01.039773" elapsed="0.000091"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.039504" elapsed="0.000396"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.039480" elapsed="0.000447"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.040379" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:31:01.040076" elapsed="0.000373"/>
</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-06-06T03:31:01.040754" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.040516" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.040497" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:01.040868" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:01.043506" elapsed="0.000163"/>
</kw>
<msg time="2026-06-06T03:31:01.043733" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.042398" elapsed="0.001469"/>
</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="NOT RUN" start="2026-06-06T03:31:01.044145" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.044481" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:01.041742" elapsed="0.002949"/>
</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-06-06T03:31:01.041171" elapsed="0.003589"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:00.972675" elapsed="0.072185"/>
</kw>
<msg time="2026-06-06T03:31:01.044955" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:01.045000" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "C "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:00.972050" elapsed="0.072988"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:01.045422" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:31:01.045116" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.045097" elapsed="0.000414"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.045940" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.046284" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.046382" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:00.971367" elapsed="0.075124"/>
</kw>
<msg time="2026-06-06T03:31:01.046584" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:01.046628" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "C "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:00.966752" elapsed="0.079928"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.047014" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.046757" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.046739" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:00.966588" elapsed="0.080528"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:00.966410" elapsed="0.080737"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:00.964024" elapsed="0.083179"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:00.958848" elapsed="0.088411"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:00.958249" elapsed="0.089055"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:00.953727" elapsed="0.093631"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.080811" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.080415" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.081587" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.081347" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:01.081775" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.081008" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.082363" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:01.081968" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.082715" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:01.082908" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:01.082557" elapsed="0.000379"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.083337" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.083094" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.084460" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.084206" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.084957" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.084686" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.085655" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.085346" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.086661" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.086414" elapsed="0.000276"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.086743" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:01.086898" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.085872" elapsed="0.001051"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.087083" elapsed="0.000241"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:01.085207" elapsed="0.002159"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.087933" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.087617" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.088693" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.088467" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.088770" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:01.088918" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.088147" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.089098" elapsed="0.000219"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:01.087479" elapsed="0.001879"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:01.085033" elapsed="0.004359"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:01.089435" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:01.089631" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:01.083766" elapsed="0.005907"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.083451" elapsed="0.006255"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.089944" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.089731" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.083432" elapsed="0.006588"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.090778" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:01.090166" elapsed="0.000642"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.090858" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:01.079791" elapsed="0.011189"/>
</kw>
<msg time="2026-06-06T03:31:01.091034" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.067216" elapsed="0.023865"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.103436" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.115818" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.128529" elapsed="0.000061"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.128908" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.129159" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.129600" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.129441" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:01.129423" elapsed="0.000280"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.129854" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.130027" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.130197" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:01.129384" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.129253" elapsed="0.001024"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.130486" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.130653" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:31:01.130816" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:01.062982" elapsed="0.067862"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.157927" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.157509" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.158786" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.158516" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:01.158958" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.158134" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.159548" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:01.159156" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.159901" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:01.160066" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:01.159757" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.160501" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.160255" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:01.160959" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.160623" elapsed="0.000395"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.161489" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.161194" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.161043" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.160601" elapsed="0.000971"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.162326" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:01.161740" elapsed="0.000617"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.162434" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:01.156867" elapsed="0.005706"/>
</kw>
<msg time="2026-06-06T03:31:01.162630" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.143853" elapsed="0.018843"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.175092" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.187461" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.199910" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.200145" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.200338" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.200786" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.200613" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:01.200594" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.201020" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.201190" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.201359" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:01.200552" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.200425" elapsed="0.001013"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.201590" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.201684" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:31:01.201846" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:01.140968" elapsed="0.060909"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.203350" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.203063" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:01.203522" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.202625" elapsed="0.000922"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.203911" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.203618" elapsed="0.000414"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.204548" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.204249" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.204060" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.203599" elapsed="0.001033"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.207232" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:01.204810" elapsed="0.002448"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:01.207312" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:01.207470" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:01.202224" elapsed="0.005271"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.209054" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.208799" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.209496" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.209259" elapsed="0.000285"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.209967" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.209719" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.210418" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.210167" elapsed="0.000295"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:01.211301" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:01.211103" elapsed="0.000224"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:01.211679" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:01.211484" elapsed="0.000222"/>
</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-06-06T03:31:01.211861" elapsed="0.000209"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.212474" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.212228" elapsed="0.000290"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:01.212559" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:01.212731" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:01.210691" elapsed="0.002066"/>
</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-06-06T03:31:01.230198" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:31:01.230325" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:31:01 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:01.231016" 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-06-06T03:31:01.214942" elapsed="0.016148"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.212827" elapsed="0.018475"/>
</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-06-06T03:31:01.231876" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.231371" elapsed="0.000664"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.212809" elapsed="0.019275"/>
</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-06-06T03:31:01.237831" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.234346" elapsed="0.003548"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.233755" elapsed="0.004189"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.233712" elapsed="0.004267"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.241823" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.238376" elapsed="0.003513"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.238058" elapsed="0.003882"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.238034" elapsed="0.003941"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.242794" 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-06-06T03:31:01.242215" elapsed="0.000618"/>
</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-06-06T03:31:01.243280" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.242935" elapsed="0.000428"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.244081" 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-06-06T03:31:01.243632" elapsed="0.000486"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.243397" elapsed="0.000772"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.242908" elapsed="0.001291"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.244963" 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-06-06T03:31:01.244432" elapsed="0.000569"/>
</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-06-06T03:31:01.245439" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.245101" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.246223" 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-06-06T03:31:01.245808" elapsed="0.000453"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.245554" elapsed="0.000757"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.245074" elapsed="0.001267"/>
</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-06-06T03:31:01.246595" elapsed="0.000393"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:01.247455" 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-06-06T03:31:01.247163" elapsed="0.000319"/>
</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-06-06T03:31:01.247790" elapsed="0.002319"/>
</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-06-06T03:31:01.232923" elapsed="0.017252"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:01.250349" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:01.250242" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.250223" elapsed="0.000231"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:01.250608" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.250702" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:01.252942" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:31:01.207986" elapsed="0.044983"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.253032" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:01.253188" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:01.052052" elapsed="0.201160"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.253552" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.253312" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.253294" elapsed="0.000364"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.253693" elapsed="0.000028"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/app_peer</arg>
<arg>mapping=${RT_CONSTRAIN_APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:01.047676" elapsed="0.206182"/>
</kw>
<doc>Configures bgp application peer.</doc>
<status status="PASS" start="2026-06-06T03:31:00.952904" elapsed="0.301089"/>
</test>
<test id="s1-s18-t2" name="Reconfigure_ODL_To_Accept_Connection" line="56">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:01.257353" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:01.257083" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.258663" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.258538" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.258519" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.263689" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.263567" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.263549" elapsed="0.000209"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.264766" 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-06-06T03:31:01.264367" elapsed="0.000426"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.265253" 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-06-06T03:31:01.264959" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:01.265324" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:01.265477" 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-06-06T03:31:01.263986" elapsed="0.001516"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:01.272729" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.272604" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.272583" elapsed="0.000216"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:01.273998" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.273892" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.273873" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:01.274539" 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-06-06T03:31:01.274214" elapsed="0.000352"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.274972" level="INFO">${current_connection_index} = 7</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-06-06T03:31:01.274751" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.310472" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:01.275504" elapsed="0.035086"/>
</kw>
<msg time="2026-06-06T03:31:01.310787" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:01.310834" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:01.275162" elapsed="0.035709"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.346934" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:31:01.311411" elapsed="0.035649"/>
</kw>
<msg time="2026-06-06T03:31:01.347222" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:01.347267" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "R "...</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-06-06T03:31:01.311054" elapsed="0.036250"/>
</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-06-06T03:31:01.347623" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.347386" elapsed="0.000322"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.347362" elapsed="0.000371"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.348256" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "[K"
[?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-06-06T03:31:01.347948" elapsed="0.000385"/>
</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-06-06T03:31:01.348623" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.348401" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.348382" elapsed="0.000340"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:01.348757" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:01.351415" elapsed="0.000146"/>
</kw>
<msg time="2026-06-06T03:31:01.351623" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.350273" elapsed="0.001504"/>
</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="NOT RUN" start="2026-06-06T03:31:01.352058" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.352394" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:01.349594" elapsed="0.002986"/>
</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-06-06T03:31:01.349049" elapsed="0.003614"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:01.273561" elapsed="0.079202"/>
</kw>
<msg time="2026-06-06T03:31:01.352855" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:01.352900" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "R "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:01.272957" elapsed="0.079981"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:01.353121" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:01.353014" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.352996" elapsed="0.000208"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.353603" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.353974" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.354044" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:01.272257" elapsed="0.081895"/>
</kw>
<msg time="2026-06-06T03:31:01.354245" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:01.354288" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "R "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:01.265902" elapsed="0.088423"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.354705" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.354401" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.354383" elapsed="0.000401"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:01.265754" elapsed="0.089055"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:01.265556" elapsed="0.089284"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:01.263207" elapsed="0.091687"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:01.258232" elapsed="0.096717"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:01.257795" elapsed="0.097200"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:01.254927" elapsed="0.100121"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.392201" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.391778" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.393034" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.392776" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:01.393210" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.392413" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.393810" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:01.393407" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.394146" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:01.394311" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:01.394006" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.394795" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.394521" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.395862" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.395580" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.396345" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.396074" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.397080" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.396780" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.397865" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.397619" elapsed="0.000272"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.397945" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:01.398102" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.397297" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.398288" elapsed="0.000264"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:31:01.396619" elapsed="0.001974"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.399160" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.398862" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.400094" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.399881" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.400171" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:01.400321" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.399378" elapsed="0.000967"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.400501" elapsed="0.000238"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:01.398724" elapsed="0.002057"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.401327" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.401029" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.402088" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.401879" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.402214" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:01.402368" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.401541" elapsed="0.000852"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.402585" elapsed="0.000241"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:01.400893" elapsed="0.001975"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.403412" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.403116" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.404171" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.403961" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.404247" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:01.404394" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.403625" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.404574" elapsed="0.000237"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:01.402980" elapsed="0.001873"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.405393" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.405099" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.406149" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.405942" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.406226" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:01.406373" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.405605" elapsed="0.000793"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.406599" elapsed="0.000241"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:01.404965" elapsed="0.001917"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.407435" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:01.407134" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:01.408241" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.408020" elapsed="0.000248"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:01.408322" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:01.408475" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:01.407666" elapsed="0.000833"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:01.408679" elapsed="0.000226"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:01.406995" elapsed="0.001955"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:01.396425" elapsed="0.012560"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:01.409029" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:01.409190" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:01.395228" elapsed="0.013988"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.394920" elapsed="0.014329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.409432" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.409275" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.394895" elapsed="0.014615"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.410343" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:01.409677" elapsed="0.000695"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.410423" elapsed="0.000063"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:01.391024" elapsed="0.019565"/>
</kw>
<msg time="2026-06-06T03:31:01.410707" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.375560" elapsed="0.035199"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.423755" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.436251" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.448804" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.449008" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.449189" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.449560" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.449410" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:01.449395" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.449803" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.449976" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.450146" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:01.449366" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.449266" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.450373" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.450449" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:31:01.450600" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:01.371196" elapsed="0.079431"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.477408" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.477026" elapsed="0.000410"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.478177" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.477959" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:01.478383" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.477603" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.479019" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:01.478614" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.479351" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:01.479489" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:01.479214" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.479970" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.479721" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:01.480381" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.480086" elapsed="0.000353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.480924" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.480613" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.480464" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.480067" elapsed="0.000942"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.481814" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:01.481159" elapsed="0.000686"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.481896" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:01.476355" elapsed="0.005666"/>
</kw>
<msg time="2026-06-06T03:31:01.482075" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.463657" elapsed="0.018465"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.494792" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.507390" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.519768" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.520007" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.520189" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.520555" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.520407" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:01.520392" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.520797" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.520970" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.521139" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:01.520364" elapsed="0.000827"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.520264" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.521366" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.521440" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:01.521562" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/pee...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:01.460993" elapsed="0.060598"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:01.522884" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.522632" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:01.523042" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.522268" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.523387" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.523136" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.523963" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.523667" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.523467" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.523118" elapsed="0.000928"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.526545" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:01.524202" elapsed="0.002371"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:01.526625" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:01.526797" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:01.521938" elapsed="0.004884"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.528217" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.527968" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.528673" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.528421" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.529121" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.528879" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.529602" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.529360" elapsed="0.000301"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:01.530543" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:01.530312" elapsed="0.000259"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:01.530929" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:01.530751" elapsed="0.000204"/>
</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-06-06T03:31:01.531110" elapsed="0.000202"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.531740" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.531474" elapsed="0.000315"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:01.531841" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:01.531999" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:01.529867" elapsed="0.002157"/>
</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-06-06T03:31:01.544697" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '295', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.171.194&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:31:01.544759" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:01.544868" 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-06-06T03:31:01.534359" elapsed="0.010535"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.532095" elapsed="0.012846"/>
</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-06-06T03:31:01.545130" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.544968" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.532077" elapsed="0.013142"/>
</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-06-06T03:31:01.549852" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.546183" elapsed="0.003769"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.545956" elapsed="0.004075"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.545936" elapsed="0.004152"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.555880" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.550782" elapsed="0.005144"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.550216" elapsed="0.005745"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.550177" elapsed="0.005809"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.556629" 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-06-06T03:31:01.556159" elapsed="0.000519"/>
</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-06-06T03:31:01.556998" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.556752" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.557547" 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-06-06T03:31:01.557244" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.557079" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.556732" elapsed="0.000928"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.558195" 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-06-06T03:31:01.557829" elapsed="0.000393"/>
</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-06-06T03:31:01.558564" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.558293" elapsed="0.000394"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.559184" 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-06-06T03:31:01.558884" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:01.558713" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.558274" elapsed="0.000993"/>
</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-06-06T03:31:01.559423" elapsed="0.000371"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:01.560245" 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-06-06T03:31:01.559966" elapsed="0.000306"/>
</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-06-06T03:31:01.560431" elapsed="0.002608"/>
</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-06-06T03:31:01.545582" elapsed="0.017522"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:01.563307" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:31:01.563174" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.563153" elapsed="0.000245"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:01.563577" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.563666" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:01.566067" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:31:01.527153" elapsed="0.038943"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.566162" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:01.566319" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:01.360067" elapsed="0.206276"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.566785" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.566442" elapsed="0.000432"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.566424" elapsed="0.000477"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:01.566935" elapsed="0.000028"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/bgp_peer</arg>
<arg>mapping=${RT_CONSTRAIN_ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:01.355311" elapsed="0.211755"/>
</kw>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:31:01.254310" elapsed="0.312883"/>
</test>
<test id="s1-s18-t3" name="Start_Bgp_Peer" line="64">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:01.571021" elapsed="0.000213"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:01.570744" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.572369" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.572259" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.572239" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.577735" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.577604" elapsed="0.000179"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.577585" elapsed="0.000222"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.578860" 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-06-06T03:31:01.578418" elapsed="0.000469"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.579346" 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-06-06T03:31:01.579051" elapsed="0.000320"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:01.579459" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:01.579617" 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-06-06T03:31:01.578039" elapsed="0.001617"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:01.585110" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.585002" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.584982" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:01.586358" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:01.586251" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.586233" elapsed="0.000194"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:01.586912" 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-06-06T03:31:01.586589" elapsed="0.000350"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.587317" level="INFO">${current_connection_index} = 7</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-06-06T03:31:01.587102" elapsed="0.000241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.622190" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:01.587871" elapsed="0.034430"/>
</kw>
<msg time="2026-06-06T03:31:01.622471" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:01.622532" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:01.587507" elapsed="0.035063"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.653732" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:31:01.623136" elapsed="0.030712"/>
</kw>
<msg time="2026-06-06T03:31:01.654016" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:01.654062" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "S "...</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-06-06T03:31:01.622775" elapsed="0.031324"/>
</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-06-06T03:31:01.654448" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.654191" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.654164" elapsed="0.000379"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.655031" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "[K"
[?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-06-06T03:31:01.654717" elapsed="0.000384"/>
</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-06-06T03:31:01.655389" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.655168" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.655149" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:01.655505" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:01.658187" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:31:01.658400" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:01.657064" elapsed="0.001499"/>
</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="NOT RUN" start="2026-06-06T03:31:01.659076" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.659426" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:01.656396" elapsed="0.003217"/>
</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-06-06T03:31:01.655837" elapsed="0.003872"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:01.585948" elapsed="0.073910"/>
</kw>
<msg time="2026-06-06T03:31:01.659953" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:01.659998" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "S "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:01.585333" elapsed="0.074703"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:01.660221" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:01.660113" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.660094" elapsed="0.000211"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.660743" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.661084" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:01.661155" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:01.584663" elapsed="0.076600"/>
</kw>
<msg time="2026-06-06T03:31:01.661356" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:01.661399" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "S "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:01.580030" elapsed="0.081407"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:01.661844" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:01.661512" elapsed="0.000387"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:01.661494" elapsed="0.000428"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:01.579884" elapsed="0.082063"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:01.579712" elapsed="0.082267"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:01.577237" elapsed="0.084797"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:01.571955" elapsed="0.090137"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:01.571471" elapsed="0.090667"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:01.568422" elapsed="0.093769"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Start_Bgp_Peer">
<kw name="Start_BGP_Speaker" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.663960" level="INFO">${command} = python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --rt_constrain --wfr 1 &amp;&gt; play.py.out</msg>
<var>${command}</var>
<arg>python3 play.py ${arguments} &amp;&gt; ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:01.663613" elapsed="0.000376"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:01.664390" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --rt_constrain --wfr 1 &amp;&gt; play.py.out</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:01.664150" elapsed="0.000285"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:01.668278" level="INFO">python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --rt_constrain --wfr 1 &amp;&gt; play.py.out</msg>
<msg time="2026-06-06T03:31:01.668380" level="INFO">${output} =  python3 play.py --amount 0 --myip=10.30.171.194 --myport=17900 --peerip=10.30.170.38 --peerport=1790 --debug --rt_constrain --wfr 1 &amp;&gt; play.py.out
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:01.664589" elapsed="0.003820"/>
</kw>
<arg>--amount 0 --myip=${TOOLS_SYSTEM_IP} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --peerport=${ODL_BGP_PORT} --debug --rt_constrain --wfr 1</arg>
<doc>Start the BGP speaker python utility. Redirect its error output to a log file
so it can be dumped into the logs later, when stopping it. This also avoids polluting the
output seen by "Read Until Prompt" with false propmpts so it won't stop prematurely
leading to a spurious test failure, messy log content or other misbehavior.</doc>
<status status="PASS" start="2026-06-06T03:31:01.663171" elapsed="0.005306"/>
</kw>
<kw name="Read_And_Fail_If_Prompt_Is_Seen" owner="BGPcliKeywords">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="Run Keyword And Expect Error" owner="BuiltIn">
<kw name="Read_Text_Before_Prompt" owner="BGPcliKeywords">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:31:07.670669" level="FAIL">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</msg>
<var>${text}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.670166" elapsed="6.001273">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<kw name="Log" owner="BuiltIn">
<arg>${text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.671779" elapsed="0.000034"/>
</kw>
<doc>Log text gathered by SSHLibrary.Read_Until_Prompt.
This needs to be a separate keyword just because how Read_And_Fail_If_Prompt_Is_Seen is implemented.</doc>
<status status="FAIL" start="2026-06-06T03:31:01.669894" elapsed="6.002230">No match found for '&gt;' in 6 seconds
Output:
[?2004l.</status>
</kw>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the keyword and checks that the expected error occurred.</doc>
<status status="PASS" start="2026-06-06T03:31:01.669454" elapsed="6.002951"/>
</kw>
<msg time="2026-06-06T03:31:07.672532" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>BuiltIn.Run_Keyword_And_Expect_Error</arg>
<arg>No match found for '${ODL_SYSTEM_PROMPT}' in *.</arg>
<arg>Read_Text_Before_Prompt</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:01.669077" elapsed="6.003482"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:31:07.672775" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:31:07.672674" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.672632" elapsed="0.000235"/>
</if>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.673106" elapsed="0.000027"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was seen but it was not expected yet</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.673288" elapsed="0.000021"/>
</kw>
<doc>Try to read SSH to see prompt, but expect to see no prompt within SSHLibrary's timeout.</doc>
<status status="PASS" start="2026-06-06T03:31:01.668780" elapsed="6.004589"/>
</kw>
<doc>Starts bgp peer and verifies that the peer runs.</doc>
<status status="PASS" start="2026-06-06T03:31:01.662840" elapsed="6.010581"/>
</kw>
<arg>3x</arg>
<arg>1s</arg>
<arg>Start_Bgp_Peer</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:01.662370" elapsed="6.011095"/>
</kw>
<doc>Start Python speaker to connect to ODL. We need to do WUKS until odl really starts to accept incomming bgp connection. The failure happens if the incomming connection comes too quickly after configuring the peer in the previous test case.</doc>
<status status="PASS" start="2026-06-06T03:31:01.567572" elapsed="6.106027"/>
</test>
<test id="s1-s18-t4" name="Odl_To_Play_rt_constrain_default" line="69">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:07.677559" elapsed="0.000274"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:07.677282" elapsed="0.000611"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.678960" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:07.678836" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.678816" elapsed="0.000215"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.684039" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:07.683930" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.683911" elapsed="0.000293"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.685247" 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-06-06T03:31:07.684854" elapsed="0.000421"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.685763" 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-06-06T03:31:07.685444" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:07.685836" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:07.685993" 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-06-06T03:31:07.684443" elapsed="0.001575"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:07.691492" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:07.691382" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.691361" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:07.692801" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:07.692690" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.692670" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:07.693332" 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-06-06T03:31:07.693021" elapsed="0.000339"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:07.693761" level="INFO">${current_connection_index} = 7</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-06-06T03:31:07.693527" elapsed="0.000261"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:07.727410" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:07.694302" elapsed="0.033222"/>
</kw>
<msg time="2026-06-06T03:31:07.727709" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:07.727757" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:07.693954" elapsed="0.033877"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:07.765247" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "d "e "f "a "u "l "t "[K"
[?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-06-06T03:31:07.728384" elapsed="0.036993"/>
</kw>
<msg time="2026-06-06T03:31:07.765553" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:07.765617" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</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-06-06T03:31:07.728015" elapsed="0.037682"/>
</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-06-06T03:31:07.766072" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.765812" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.765783" elapsed="0.000372"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.766637" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "d "e "f "a "u "l "t "[K"
[?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-06-06T03:31:07.766309" elapsed="0.000424"/>
</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-06-06T03:31:07.767034" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.766805" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.766785" elapsed="0.000330"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:07.767151" elapsed="0.000032"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:07.769869" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:31:07.770086" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:07.768744" elapsed="0.001475"/>
</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="NOT RUN" start="2026-06-06T03:31:07.770507" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.770887" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:07.768023" elapsed="0.003060"/>
</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-06-06T03:31:07.767448" elapsed="0.003703"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:07.692359" elapsed="0.078892"/>
</kw>
<msg time="2026-06-06T03:31:07.771347" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:07.771392" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:07.691736" elapsed="0.079694"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:07.771618" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:31:07.771509" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.771490" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.772147" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.772520" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.772593" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:07.691040" elapsed="0.081678"/>
</kw>
<msg time="2026-06-06T03:31:07.772818" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:07.772867" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:07.686398" elapsed="0.086507"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.773282" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.772982" elapsed="0.000356"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.772964" elapsed="0.000399"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:07.686248" elapsed="0.087139"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:07.686074" elapsed="0.087345"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:07.683551" elapsed="0.089924"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:07.678517" elapsed="0.095016"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:07.678057" elapsed="0.095522"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:07.674702" elapsed="0.098932"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.774536" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/announce_rt_constrain_default.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/announce_rt_constrain_default.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:07.774806" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:07.774330" elapsed="0.000504"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:07.775222" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.775006" elapsed="0.000244"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.775607" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/withdraw_rt_constrain_default.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/withdraw_rt_constrain_default.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:07.775753" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:07.775416" elapsed="0.000364"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:07.776146" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.775942" elapsed="0.000231"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:07.776486" elapsed="0.003068"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.776260" elapsed="0.003339"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.776241" elapsed="0.003386"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.816946" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:07.816526" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.817788" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:07.817500" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:07.817962" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:07.817153" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.818559" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:07.818163" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.818921" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:07.819094" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:07.818773" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.819598" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.819340" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.820730" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.820444" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.821235" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.820955" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.821963" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:07.821652" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:07.822999" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.822519" elapsed="0.000508"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:07.823083" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:07.823245" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:07.822186" elapsed="0.001085"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.823436" elapsed="0.000263"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:07.821494" elapsed="0.002249"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.824331" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:07.823999" elapsed="0.000360"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:07.825494" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.825066" elapsed="0.000456"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:07.825576" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:07.825749" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:07.824556" elapsed="0.001220"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:07.825936" elapsed="0.000227"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:07.823859" elapsed="0.002346"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:07.821316" elapsed="0.004925"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:07.826286" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:07.826447" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:07.820056" elapsed="0.006417"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.819742" elapsed="0.006764"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.826707" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.826531" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.819719" elapsed="0.007069"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.827533" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:07.826941" elapsed="0.000621"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:07.827615" elapsed="0.000050"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:07.815877" elapsed="0.011889"/>
</kw>
<msg time="2026-06-06T03:31:07.827822" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:07.803142" elapsed="0.024729"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.840397" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.852826" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.865197" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.865395" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.865578" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.865980" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.865819" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:07.865805" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.866203" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.866375" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.866543" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:07.865776" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.865673" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.866787" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.866862" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:07.866982" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:07.798767" elapsed="0.068241"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.891701" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:07.891308" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.892500" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:07.892246" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:07.892678" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:07.891896" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.893260" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:07.892874" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.893624" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:07.893774" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-target-...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:07.893487" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.894209" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-target-constrain-default-route/&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.893964" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:07.894622" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.894328" elapsed="0.000370"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.896999" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:07.894878" elapsed="0.002150"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.894723" elapsed="0.002342"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.894309" elapsed="0.002778"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.897706" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-target-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:07.897241" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:07.897787" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:07.890690" elapsed="0.007222"/>
</kw>
<msg time="2026-06-06T03:31:07.897968" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:07.878091" elapsed="0.019924"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.910531" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.923046" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.935530" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.935748" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.935971" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.936379" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.936199" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:07.936183" elapsed="0.000282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.936615" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.936815" elapsed="0.000029"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.937000" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:07.936154" elapsed="0.000901"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.936050" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.937233" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.937310" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:07.937437" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-target-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:07.877221" elapsed="0.060246"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:07.938984" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:07.938724" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:07.939147" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:07.938353" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.939498" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.939245" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.940085" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:07.939784" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.939582" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.939225" elapsed="0.000945"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.942553" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:07.940344" elapsed="0.002236"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:07.942633" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:31:07.942806" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:07.937824" elapsed="0.005008"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.944392" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.944118" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.944870" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-target-constrain-default-route/&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.944607" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.945366" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.945120" elapsed="0.000290"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.945825" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.945565" elapsed="0.000304"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:07.946690" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:07.946481" elapsed="0.000237"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:07.947060" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:07.946875" elapsed="0.000211"/>
</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-06-06T03:31:07.947241" elapsed="0.000200"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.947870" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.947603" elapsed="0.000313"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:07.947963" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:07.948121" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:07.946072" elapsed="0.002074"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:07.963119" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '541', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;route-target-constrain-default-route/&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt; 
 </msg>
<msg time="2026-06-06T03:31:07.963206" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes/route-target-constrain-route=flow1,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:07.963351" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:07.950552" elapsed="0.012837"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.948216" elapsed="0.015239"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.963747" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.963491" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.948199" elapsed="0.015675"/>
</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-06-06T03:31:07.968727" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.965376" elapsed="0.003415"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.965056" elapsed="0.003785"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.965029" elapsed="0.003848"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.972555" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:07.969275" elapsed="0.003345"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.968958" elapsed="0.003737"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.968933" elapsed="0.003804"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.973514" 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-06-06T03:31:07.972987" elapsed="0.000565"/>
</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-06-06T03:31:07.974017" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.973671" elapsed="0.000428"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.974932" 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-06-06T03:31:07.974477" elapsed="0.000492"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.974225" elapsed="0.000843"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.973624" elapsed="0.001475"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.975866" 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-06-06T03:31:07.975333" elapsed="0.000570"/>
</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-06-06T03:31:07.976388" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.976001" elapsed="0.000469"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.977091" 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-06-06T03:31:07.976757" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.976503" elapsed="0.000650"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.975976" elapsed="0.001198"/>
</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-06-06T03:31:07.977327" elapsed="0.000370"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:07.978146" 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-06-06T03:31:07.977869" elapsed="0.000303"/>
</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-06-06T03:31:07.978331" elapsed="0.002346"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:31:07.964402" elapsed="0.016339"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:07.980923" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:07.980816" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.980796" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:07.981161" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:07.981229" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:07.983513" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:31:07.943160" elapsed="0.040380"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:07.983610" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:07.983778" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:07.785239" elapsed="0.198564"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:07.984143" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:07.983905" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:07.983888" elapsed="0.000348"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:07.984281" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:07.779959" elapsed="0.204445"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:07.988066" level="INFO">${update} = ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:07.985530" elapsed="0.002568"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:07.988307" elapsed="0.002417"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:07.990778" elapsed="0.000033"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:07.985207" elapsed="0.005706"/>
</kw>
<msg time="2026-06-06T03:31:07.990991" level="INFO">${update} = ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:07.984576" elapsed="0.006440"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.991967" level="INFO">Length is 100.</msg>
<msg time="2026-06-06T03:31:07.992044" level="INFO">${len_1} = 100</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:07.991688" elapsed="0.000380"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:07.992521" level="INFO">Length is 100.</msg>
<msg time="2026-06-06T03:31:07.992599" level="INFO">${len_2} = 100</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:07.992229" elapsed="0.000395"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:07.992810" elapsed="0.000327"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:07.993486" level="INFO">${sum_1} = 1099</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:07.993305" elapsed="0.000207"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:07.993871" level="INFO">${sum_2} = 1099</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:07.993694" elapsed="0.000203"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:07.994061" elapsed="0.000317"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:07.991291" elapsed="0.003149"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:07.994600" elapsed="0.002151"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.043458" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:08.043074" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.044332" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.044018" elapsed="0.000401">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:08.044517" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:08.043673" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.045131" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:08.044730" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.045478" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:08.045664" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:08.045334" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.046118" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.045863" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.047421" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.046894" elapsed="0.000574"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.047941" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.047659" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.048827" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.048377" elapsed="0.000481"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:08.050155" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.049674" elapsed="0.000563"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:08.050439" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:08.050684" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:08.049231" elapsed="0.001480"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.050873" elapsed="0.000419"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:08.048200" elapsed="0.003135"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.052016" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.051586" elapsed="0.000457"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:08.053183" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.052700" elapsed="0.000565"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:08.053402" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:08.053623" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:08.052232" elapsed="0.001433"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.053825" elapsed="0.000393"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:08.051448" elapsed="0.002812"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:08.048022" elapsed="0.006273"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:08.054343" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:08.054500" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:08.046546" elapsed="0.007979"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.046239" elapsed="0.008318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.054752" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.054583" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.046217" elapsed="0.008613"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.055556" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:08.054977" elapsed="0.000609"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:08.055635" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:08.042426" elapsed="0.013352"/>
</kw>
<msg time="2026-06-06T03:31:08.055835" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:08.029638" elapsed="0.026246"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.068434" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.080918" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.093278" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.093520" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.093720" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.094095" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.093943" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:08.093928" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.094322" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.094494" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.094694" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:08.093899" elapsed="0.000851"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.093798" elapsed="0.000978"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.094929" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.095005" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:08.095126" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:08.025195" elapsed="0.069958"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.096260" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.096012" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:08.107052" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:08.107101" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:08.107193" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:08.098686" elapsed="0.008533"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.096417" elapsed="0.010843"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.107450" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.107287" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.096398" elapsed="0.011137"/>
</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-06-06T03:31:08.112167" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.108883" elapsed="0.003344"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.108547" elapsed="0.003730"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.108520" elapsed="0.003810"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.115962" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.112746" elapsed="0.003280"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.112410" elapsed="0.003664"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.112386" elapsed="0.003723"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.116936" 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-06-06T03:31:08.116396" elapsed="0.000568"/>
</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-06-06T03:31:08.117322" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.117072" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.117897" 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-06-06T03:31:08.117576" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.117407" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.117051" elapsed="0.000930"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.118508" 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-06-06T03:31:08.118147" elapsed="0.000389"/>
</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-06-06T03:31:08.118865" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.118606" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.119411" 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-06-06T03:31:08.119117" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.118951" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.118588" elapsed="0.000906"/>
</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-06-06T03:31:08.119663" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:08.120480" 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-06-06T03:31:08.120179" elapsed="0.000328"/>
</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-06-06T03:31:08.120683" elapsed="0.002305"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:08.107947" elapsed="0.015106"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:08.123100" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:08.125386" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:08.095417" elapsed="0.029996"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:08.125468" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:07.998220" elapsed="0.127370"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:07.997581" elapsed="0.128076"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:07.997059" elapsed="0.128659"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:08.129028" level="INFO">${update} = ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.126628" elapsed="0.002432"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:08.129218" elapsed="0.002123"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:08.131392" elapsed="0.000028"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:08.126356" elapsed="0.005160"/>
</kw>
<msg time="2026-06-06T03:31:08.131591" level="INFO">${update} = ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:08.125890" elapsed="0.005726"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.132513" level="INFO">Length is 88.</msg>
<msg time="2026-06-06T03:31:08.132589" level="INFO">${len_1} = 88</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:08.132212" elapsed="0.000401"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.133139" level="INFO">Length is 88.</msg>
<msg time="2026-06-06T03:31:08.133245" level="INFO">${len_2} = 88</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:08.132790" elapsed="0.000488"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:08.133500" elapsed="0.000454"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:08.134412" level="INFO">${sum_1} = 652</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:08.134176" elapsed="0.000271"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:08.134979" level="INFO">${sum_2} = 652</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:08.134687" elapsed="0.000328"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:08.135235" elapsed="0.000451"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:08.131848" elapsed="0.003923"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.181486" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:08.181106" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.182292" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.182044" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:08.182453" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:08.181699" elapsed="0.000779"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.183052" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:08.182662" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.183381" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:08.183528" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:08.183245" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.183980" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.183736" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.185046" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.184783" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.185525" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.185255" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.186445" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.185922" elapsed="0.000549"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:08.187616" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.187174" elapsed="0.000501"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:08.187795" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:08.188020" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:08.186683" elapsed="0.001363"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.188203" elapsed="0.000665"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:08.185784" elapsed="0.003129"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.189705" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.189164" elapsed="0.000569"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:08.191024" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.190401" elapsed="0.000665"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:08.191184" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:08.191404" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:08.189925" elapsed="0.001537"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.191624" elapsed="0.000504"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:08.189026" elapsed="0.003145"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:08.185598" elapsed="0.006608"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:08.192248" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:08.192435" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:08.184401" elapsed="0.008059"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.184093" elapsed="0.008399"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.192689" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.192517" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.184074" elapsed="0.008694"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.193690" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:08.192979" elapsed="0.000743"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:08.193775" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:08.180437" elapsed="0.013472"/>
</kw>
<msg time="2026-06-06T03:31:08.193965" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:08.167611" elapsed="0.026417"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.206873" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.219375" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.231920" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.232143" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.232348" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.232771" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.232598" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:08.232581" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.233000" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.233247" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.233423" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:08.232545" elapsed="0.000932"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.232433" elapsed="0.001072"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.233673" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.233752" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:08.233881" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:08.163203" elapsed="0.070706"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.235084" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.234821" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:08.242812" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:08.243222" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '430'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-route-target-constrain:route-target-constrain-subsequent-address-family']/bgp-route-target-constrain:route-target-constrain-routes",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:08.243365" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:31:08.243407" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.237275" elapsed="0.006554">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:08.235199" elapsed="0.008716">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.244109" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.243949" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:08.235180" elapsed="0.009016">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:08.247845" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.245279" elapsed="0.002602">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:08.245044" elapsed="0.002899">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:08.245025" elapsed="0.002952">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.250692" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.248353" elapsed="0.002373">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:08.248093" elapsed="0.002696">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:08.248074" elapsed="0.002748">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.251418" 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-06-06T03:31:08.251026" elapsed="0.000419"/>
</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-06-06T03:31:08.251788" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.251524" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.252363" 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-06-06T03:31:08.252043" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.251872" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.251506" elapsed="0.000947"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.253006" 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-06-06T03:31:08.252621" elapsed="0.000412"/>
</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-06-06T03:31:08.253347" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.253105" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.253918" 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-06-06T03:31:08.253604" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.253429" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.253086" elapsed="0.000916"/>
</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-06-06T03:31:08.254158" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:08.254989" 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-06-06T03:31:08.254696" elapsed="0.000319"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:31:08.257450" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.255178" elapsed="0.002305">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:31:08.244588" elapsed="0.013031">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:08.257695" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:08.260056" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:31:08.260086" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:31:08.234175" elapsed="0.025941">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:08.260182" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.137544" elapsed="0.122839">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:08.136702" elapsed="0.123747"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:08.136103" elapsed="0.124408"/>
</kw>
<arg>rt_constrain_default</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:07.773945" elapsed="0.486619"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:07.674182" elapsed="0.586513"/>
</test>
<test id="s1-s18-t5" name="Play_To_Odl_rt_constrain_default" line="73">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:08.264108" elapsed="0.000209"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:08.263838" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.265421" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:08.265310" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.265290" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.270488" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:08.270381" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.270362" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.271573" 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-06-06T03:31:08.271188" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.272093" 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-06-06T03:31:08.271786" elapsed="0.000334"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:08.272166" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:08.272320" 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-06-06T03:31:08.270803" elapsed="0.001556"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:08.277853" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:08.277742" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.277722" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:08.279111" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:08.279002" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.278984" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:08.279626" 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-06-06T03:31:08.279330" elapsed="0.000339"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:08.280055" level="INFO">${current_connection_index} = 7</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-06-06T03:31:08.279836" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:08.314229" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:08.280765" elapsed="0.033567"/>
</kw>
<msg time="2026-06-06T03:31:08.314506" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:08.314552" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:08.280395" elapsed="0.034194"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:08.352489" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "d "e "f "a "u "l "t "[K"
[?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-06-06T03:31:08.315269" elapsed="0.037331"/>
</kw>
<msg time="2026-06-06T03:31:08.352784" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:08.352831" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</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-06-06T03:31:08.314786" elapsed="0.038083"/>
</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-06-06T03:31:08.353182" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.352947" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.352927" elapsed="0.000335"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.353725" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "d "e "f "a "u "l "t "[K"
[?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-06-06T03:31:08.353411" elapsed="0.000391"/>
</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-06-06T03:31:08.354130" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.353907" elapsed="0.000277"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.353886" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:08.354241" elapsed="0.000028"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:08.356776" elapsed="0.000141"/>
</kw>
<msg time="2026-06-06T03:31:08.356980" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:08.355712" elapsed="0.001405"/>
</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="NOT RUN" start="2026-06-06T03:31:08.357397" elapsed="0.000075"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.357754" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:08.355079" elapsed="0.002862"/>
</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-06-06T03:31:08.354509" elapsed="0.003496"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:08.278699" elapsed="0.079404"/>
</kw>
<msg time="2026-06-06T03:31:08.358194" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:08.358239" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:08.278077" elapsed="0.080199"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:08.358458" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:08.358352" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.358333" elapsed="0.000210"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.358961" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.359295" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.359366" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:08.277386" elapsed="0.082086"/>
</kw>
<msg time="2026-06-06T03:31:08.359565" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:08.359609" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:08.272750" elapsed="0.086912"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.359996" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.359740" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.359722" elapsed="0.000352"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:08.272589" elapsed="0.087509"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:08.272415" elapsed="0.087712"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:08.270018" elapsed="0.090161"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:08.265020" elapsed="0.095213"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:08.264549" elapsed="0.095728"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:08.261537" elapsed="0.098792"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.361470" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.361002" elapsed="0.000497"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.362137" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.361691" elapsed="0.000474"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.362775" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.362373" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.363171" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/announce_rt_constrain_default.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/announce_rt_constrain_default.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:08.363329" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:08.362970" elapsed="0.000385"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.363804" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/withdraw_rt_constrain_default.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/withdraw_rt_constrain_default.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:08.363928" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:08.363515" elapsed="0.000439"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:08.364110" elapsed="0.002306"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:08.366599" elapsed="0.002178"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.421022" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:08.420625" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.421835" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.421568" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:08.422010" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:08.421226" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.422597" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:08.422205" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.422951" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:08.423101" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:08.422811" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.423548" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.423292" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.424704" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.424337" elapsed="0.000415"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.425195" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.424922" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.426019" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.425597" elapsed="0.000448"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:08.427267" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.426710" elapsed="0.000659"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:08.427501" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:08.427822" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:08.426234" elapsed="0.001614"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.428012" elapsed="0.000395"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:08.425447" elapsed="0.003003"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.429304" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:08.428720" elapsed="0.000611"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:08.430550" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.430007" elapsed="0.000664"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:08.430757" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:08.431056" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:08.429527" elapsed="0.001556"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:08.431243" elapsed="0.000369"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:08.428565" elapsed="0.003106"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:08.425272" elapsed="0.006436"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:08.431752" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:08.431910" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:08.424004" elapsed="0.007932"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.423690" elapsed="0.008279"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.432150" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.431995" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.423666" elapsed="0.008561"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.433016" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:08.432402" elapsed="0.000643"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:08.433095" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:08.419991" elapsed="0.013228"/>
</kw>
<msg time="2026-06-06T03:31:08.433275" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:08.407212" elapsed="0.026112"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.446037" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.458501" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.470858" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.471093" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.471275" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.471658" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.471493" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:08.471478" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.471888" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.472066" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.472237" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:08.471450" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.471350" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.472481" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.472567" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:08.472703" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:08.402905" elapsed="0.069826"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.474012" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.473746" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:08.474176" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:08.473387" elapsed="0.000813"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.474521" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.474270" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.475102" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:08.474803" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.474604" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.474251" elapsed="0.000934"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.479204" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:08.475340" elapsed="0.003892"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:08.479284" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:08.479438" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:08.473059" elapsed="0.006405"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:08.480748" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.480492" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:08.480947" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:08.480125" elapsed="0.000854"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:08.481189" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:08.481051" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:08.481032" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.481425" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.481605" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.481687" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:08.483608" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:08.479791" elapsed="0.003843"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.485081" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.484817" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:08.485533" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:08.485289" elapsed="0.000288"/>
</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-06-06T03:31:08.493992" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:08.494127" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:08.494233" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</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="FAIL" start="2026-06-06T03:31:08.487741" elapsed="0.006859">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:08.485657" elapsed="0.009052">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:08.494910" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.494745" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:08.485624" elapsed="0.009375">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:08.495382" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.495516" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:08.495478" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:08.495460" elapsed="0.000119"/>
</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-06-06T03:31:08.495744" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.495816" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:08.483964" elapsed="0.011992">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.496033" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.379890" elapsed="0.116238">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:08.496443" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:08.496223" elapsed="0.000296"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:08.496206" elapsed="0.000337"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:08.496576" elapsed="0.000014"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:08.373784" elapsed="0.122904">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.555577" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.555144" elapsed="0.000467"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.556459" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.556175" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.556632" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.555814" elapsed="0.000859"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.557249" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:10.556847" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.557591" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:10.557786" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:10.557444" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.558233" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.557985" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.559423" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.559091" elapsed="0.000380"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.559944" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.559662" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.560863" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.560429" elapsed="0.000461"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:10.562166" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.561582" elapsed="0.000699"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:10.562365" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:10.562686" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:10.561117" elapsed="0.001596"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.562878" elapsed="0.000446"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:10.560286" elapsed="0.003086"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.564090" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.563670" elapsed="0.000616"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:10.565815" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.565208" elapsed="0.000709"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:10.566003" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:31:10.566418" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:10.564711" elapsed="0.001735"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.566611" elapsed="0.000396"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:10.563507" elapsed="0.003544"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:10.560102" elapsed="0.006985"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:10.567140" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:31:10.567321" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:10.558752" elapsed="0.008596"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.558361" elapsed="0.009021"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.567586" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.567417" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.558335" elapsed="0.009350"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.568460" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:10.567839" elapsed="0.000650"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.568540" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:10.554392" elapsed="0.014311"/>
</kw>
<msg time="2026-06-06T03:31:10.568762" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.541514" elapsed="0.027300"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.583340" elapsed="0.000056"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.596237" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.610565" elapsed="0.000067"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.610919" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.611124" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.611603" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.611440" elapsed="0.000239"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:10.611415" elapsed="0.000294"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.611866" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.612045" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.612223" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:10.611364" elapsed="0.000914"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.611216" elapsed="0.001090"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.612471" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.612556" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:10.612744" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:10.537179" elapsed="0.075597"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.614310" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.614006" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.614497" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.613569" elapsed="0.000953"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.614896" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.614596" elapsed="0.000365"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.615513" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.615182" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.614986" elapsed="0.000594"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.614576" elapsed="0.001026"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.618763" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:10.615815" elapsed="0.002977"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:10.618854" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:31:10.619040" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:10.613183" elapsed="0.005883"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.620757" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.620414" elapsed="0.000511">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.621077" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.619941" elapsed="0.001171"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:10.621401" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:31:10.621213" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.621187" elapsed="0.000334"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.621764" elapsed="0.000033"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.622030" elapsed="0.000026"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.622107" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:10.624129" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:10.619432" elapsed="0.004725"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.625658" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.625381" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.626160" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.625870" elapsed="0.000339"/>
</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-06-06T03:31:10.635220" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:10.635557" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '275'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}} 
 </msg>
<msg time="2026-06-06T03:31:10.635680" 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-06-06T03:31:10.628484" elapsed="0.007225"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.626278" elapsed="0.009475"/>
</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-06-06T03:31:10.635955" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.635780" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.626259" elapsed="0.009820"/>
</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-06-06T03:31:10.641282" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.637605" elapsed="0.003746"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.637283" elapsed="0.004118"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.637255" elapsed="0.004182"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.645145" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.641860" elapsed="0.003351"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.641516" elapsed="0.003744"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.641492" elapsed="0.003802"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.646077" 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-06-06T03:31:10.645544" elapsed="0.000560"/>
</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-06-06T03:31:10.646424" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.646176" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.646993" 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-06-06T03:31:10.646691" elapsed="0.000380"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.646507" elapsed="0.000604"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.646157" elapsed="0.000976"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.647688" 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-06-06T03:31:10.647302" elapsed="0.000414"/>
</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-06-06T03:31:10.648032" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.647788" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.648621" 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-06-06T03:31:10.648283" elapsed="0.000381"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.648114" elapsed="0.000589"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.647769" elapsed="0.000955"/>
</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-06-06T03:31:10.648883" elapsed="0.000379"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:10.649751" 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-06-06T03:31:10.649436" elapsed="0.000341"/>
</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-06-06T03:31:10.649941" elapsed="0.002327"/>
</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-06-06T03:31:10.636617" elapsed="0.015716"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.652512" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:10.652404" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.652385" elapsed="0.000196"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:10.655561" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:10.652750" elapsed="0.002841"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:10.655661" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:10.655827" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:10.624481" elapsed="0.031373"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.655920" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:31:10.656073" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:10.511402" elapsed="0.144697"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.688506" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.687977" elapsed="0.000563"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.689460" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.689147" elapsed="0.000445">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.689797" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.688759" elapsed="0.001065"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.690537" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:10.690003" elapsed="0.000562"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.690929" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:10.691104" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:10.690756" elapsed="0.000377"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.691582" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-constrain-default-route": {}
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.691301" elapsed="0.000333"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:10.692196" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.691734" elapsed="0.000527"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.693075" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.692461" elapsed="0.000642"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.692288" elapsed="0.000851"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.691709" elapsed="0.001452"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.693860" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:10.693318" elapsed="0.000572"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.693943" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:10.687266" elapsed="0.006816"/>
</kw>
<msg time="2026-06-06T03:31:10.694141" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.672386" elapsed="0.021804"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.706874" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.719464" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.732273" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.732567" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.732781" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.733274" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.733114" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:10.733095" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.733509" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.733700" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.733874" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:10.733054" elapsed="0.000874"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.732886" elapsed="0.001074"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.734114" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.734193" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:10.734340" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:10.668373" elapsed="0.065996"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.734555" elapsed="0.002504"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:10.738263" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.737842" elapsed="0.000450"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:10.738833" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.738451" elapsed="0.000411"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:10.739023" elapsed="0.000334"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:10.737390" elapsed="0.002028"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.737142" elapsed="0.002312"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.739635" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.739480" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.737123" elapsed="0.002606"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:10.657274" elapsed="0.082506"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:10.656429" elapsed="0.083431"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.656183" elapsed="0.083725"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.656166" elapsed="0.083768"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.739969" elapsed="0.000032"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:10.505108" elapsed="0.234995"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:08.368953" elapsed="2.371264"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.790445" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.790059" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.791254" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.791008" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.791423" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.790657" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.792033" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:10.791619" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.792367" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:10.792525" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:10.792229" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.793062" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.792780" elapsed="0.000335"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.794348" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.793844" elapsed="0.000551"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.794869" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.794564" elapsed="0.000332"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.795686" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.795264" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:10.796927" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.796367" elapsed="0.000700"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:10.797149" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:10.797452" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:10.795908" elapsed="0.001572"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.797666" elapsed="0.000391"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:10.795123" elapsed="0.002977"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.798854" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.798360" elapsed="0.000522"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:10.800131" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.799564" elapsed="0.000668"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:10.800313" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:10.800605" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:10.799080" elapsed="0.001552"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:10.800809" elapsed="0.000448"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:10.798220" elapsed="0.003083"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:10.794947" elapsed="0.006393"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:10.801384" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:10.801548" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:10.793494" elapsed="0.008079"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.793187" elapsed="0.008420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.801845" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.801633" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.793167" elapsed="0.008757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.802678" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:10.802073" elapsed="0.000636"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.802760" elapsed="0.000047"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:10.789415" elapsed="0.013504"/>
</kw>
<msg time="2026-06-06T03:31:10.802977" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.776455" elapsed="0.026572"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.815919" elapsed="0.000065"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.828578" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.841275" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.841513" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.841725" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.842159" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.842001" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:10.841982" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.842393" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.842567" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.842836" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:10.841938" elapsed="0.000954"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.841816" elapsed="0.001105"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.843076" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.843158" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:10.843318" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:10.772164" elapsed="0.071184"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.844788" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.844476" elapsed="0.000388">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.844963" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.844072" elapsed="0.000922"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.845367" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.845090" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.845964" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.845653" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.845450" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.845069" elapsed="0.000980"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.848702" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:10.846206" elapsed="0.002524"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:10.848785" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:10.848975" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:10.843705" elapsed="0.005332"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.850314" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.850073" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.850477" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.849724" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:10.850736" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:10.850578" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.850557" elapsed="0.000267"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.850983" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.851165" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.851235" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:10.853217" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:10.849365" elapsed="0.003888"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.854747" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.854430" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.855209" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.854958" elapsed="0.000295"/>
</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-06-06T03:31:10.862812" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:10.862954" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '275'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}} 
 </msg>
<msg time="2026-06-06T03:31:10.863055" 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-06-06T03:31:10.857429" elapsed="0.005654"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.855321" elapsed="0.007806"/>
</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-06-06T03:31:10.863319" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.863155" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.855302" elapsed="0.008106"/>
</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-06-06T03:31:10.867145" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.864467" elapsed="0.002728"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.864235" elapsed="0.002996"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.864215" elapsed="0.003042"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.869889" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.867548" elapsed="0.002388"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.867315" elapsed="0.002656"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.867297" elapsed="0.002707"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.870807" 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-06-06T03:31:10.870249" elapsed="0.000616"/>
</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-06-06T03:31:10.871430" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.871002" elapsed="0.000524"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.872379" 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-06-06T03:31:10.871881" elapsed="0.000544"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.871564" elapsed="0.000915"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.870968" elapsed="0.001545"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.873414" 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-06-06T03:31:10.872795" elapsed="0.000676"/>
</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-06-06T03:31:10.874027" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.873609" elapsed="0.000502"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.874844" 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-06-06T03:31:10.874395" elapsed="0.000486"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.874146" elapsed="0.000785"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.873571" elapsed="0.001390"/>
</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-06-06T03:31:10.875184" elapsed="0.000579"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:10.876460" 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-06-06T03:31:10.876028" elapsed="0.000529"/>
</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-06-06T03:31:10.876829" elapsed="0.002963"/>
</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-06-06T03:31:10.863798" elapsed="0.016067"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.880067" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:10.879943" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.879920" elapsed="0.000215"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:10.883388" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:10.880298" elapsed="0.003122"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:10.883476" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:31:10.883679" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:10.853585" elapsed="0.030129"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.883781" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:10.883940" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:10.749458" elapsed="0.134517"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.913206" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.912707" elapsed="0.000529"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.914064" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:10.913774" elapsed="0.000417">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:10.914367" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:10.913408" elapsed="0.000984"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.915036" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:10.914564" elapsed="0.000500"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:10.915393" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:10.915555" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:10.915230" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.916029" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-constrain-default-route": {}
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:10.915760" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:10.916600" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.916154" elapsed="0.000523"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.917406" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:10.916857" elapsed="0.000577"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.916704" elapsed="0.000767"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.916133" elapsed="0.001360"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:10.918150" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:10.917659" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.918230" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:10.912068" elapsed="0.006289"/>
</kw>
<msg time="2026-06-06T03:31:10.918415" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.899113" elapsed="0.019351"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.930887" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.943337" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.955684" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.955900" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.956087" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.956495" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.956341" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:10.956324" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.956741" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.956920" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.957105" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:10.956288" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.956174" elapsed="0.001014"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.957395" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:10.957474" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:10.957616" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:10.896413" elapsed="0.061246"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.957848" elapsed="0.002421"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:10.961486" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.961080" elapsed="0.000435"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:10.962057" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:10.961692" elapsed="0.000393"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:10.962247" elapsed="0.000335"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:10.960599" elapsed="0.002060"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.960351" elapsed="0.002345"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:10.962876" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:10.962721" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.960332" elapsed="0.002621"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:10.885390" elapsed="0.077612"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:10.884400" elapsed="0.078680"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:10.884088" elapsed="0.079039"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:10.884064" elapsed="0.079087"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:10.963186" elapsed="0.000031"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:10.744912" elapsed="0.218406"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:10.740404" elapsed="0.222977"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.012480" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.012106" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.013282" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.013027" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.013453" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.012691" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.014095" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:11.013707" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.014428" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:11.014581" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:11.014289" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.015039" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.014784" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.017394" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.015797" elapsed="0.001644"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.017909" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.017611" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.018726" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.018305" elapsed="0.000448"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:11.019968" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.019402" elapsed="0.000666"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:11.020148" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:11.020444" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:11.018947" elapsed="0.001522"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.020627" elapsed="0.000399"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:11.018166" elapsed="0.002917"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.021754" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.021336" elapsed="0.000445"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:11.022988" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.022428" elapsed="0.000661"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:11.023170" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:11.023465" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:11.021972" elapsed="0.001519"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.023668" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:11.021197" elapsed="0.002884"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:11.017988" elapsed="0.006129"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:11.024160" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:11.024320" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:11.015452" elapsed="0.008894"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.015155" elapsed="0.009224"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.024561" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.024404" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.015136" elapsed="0.009518"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.025414" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:11.024804" elapsed="0.000640"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.025495" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:11.011472" elapsed="0.014147"/>
</kw>
<msg time="2026-06-06T03:31:11.025732" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:10.998917" elapsed="0.026867"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.038410" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.050971" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.063473" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.063729" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.063926" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.064343" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.064188" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:11.064169" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.064576" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.064767" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.064942" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:11.064131" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.064011" elapsed="0.001013"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.065194" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.065275" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:11.065421" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:10.994668" elapsed="0.070781"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.066936" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.066635" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.067107" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.066238" elapsed="0.000894"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.067476" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.067205" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.068060" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.067761" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.067560" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.067185" elapsed="0.000960"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.070820" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:11.068305" elapsed="0.002543"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:11.070902" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:11.071062" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:11.065877" elapsed="0.005211"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.072339" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.072102" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.072498" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.071754" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:11.072752" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:11.072596" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.072576" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.072992" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.073189" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.073258" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:11.075195" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:11.071400" elapsed="0.003822"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.076655" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.076383" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.077142" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.076867" elapsed="0.000321"/>
</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-06-06T03:31:11.084444" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:11.084587" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '275'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}} 
 </msg>
<msg time="2026-06-06T03:31:11.084785" 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-06-06T03:31:11.079349" elapsed="0.005465"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.077256" elapsed="0.007605"/>
</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-06-06T03:31:11.085099" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.084890" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.077237" elapsed="0.007953"/>
</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-06-06T03:31:11.088743" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.086269" elapsed="0.002524"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.086037" elapsed="0.002791"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.086017" elapsed="0.002837"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.091655" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.089158" elapsed="0.002546"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.088910" elapsed="0.002829"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.088893" elapsed="0.002872"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.092346" 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-06-06T03:31:11.091951" elapsed="0.000423"/>
</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-06-06T03:31:11.092709" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.092446" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.093352" 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-06-06T03:31:11.093022" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.092795" elapsed="0.000621"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.092427" elapsed="0.001011"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.093992" 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-06-06T03:31:11.093606" elapsed="0.000413"/>
</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-06-06T03:31:11.094333" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.094090" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.094896" 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-06-06T03:31:11.094582" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.094414" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.094071" elapsed="0.000908"/>
</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-06-06T03:31:11.095137" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:11.095965" 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-06-06T03:31:11.095670" elapsed="0.000321"/>
</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-06-06T03:31:11.096152" elapsed="0.002356"/>
</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-06-06T03:31:11.085576" elapsed="0.012998"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.098771" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:11.098660" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.098626" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:11.101771" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:11.098991" elapsed="0.002809"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:11.101852" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:11.102014" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:11.075540" elapsed="0.026501"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.102154" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:11.102309" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:10.972199" elapsed="0.130136"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.131323" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.130797" elapsed="0.000561"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.132241" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.131928" elapsed="0.000443">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.132546" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.131544" elapsed="0.001028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.133222" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:11.132763" elapsed="0.000487"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.133583" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:11.133767" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:11.133418" elapsed="0.000377"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.134229" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-constrain-default-route": {}
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.133958" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:11.134849" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.134362" elapsed="0.000549"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.135597" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.135092" elapsed="0.000533"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.134939" elapsed="0.000739"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.134336" elapsed="0.001365"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.136352" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:11.135856" elapsed="0.000525"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.136436" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:11.130063" elapsed="0.006507"/>
</kw>
<msg time="2026-06-06T03:31:11.136626" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:11.117106" elapsed="0.019647"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.149356" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.161897" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_default/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.174389" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.174602" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.174804" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.175206" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.175053" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:11.175037" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.175432" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.175603" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.175791" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:11.175002" elapsed="0.000843"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.174890" elapsed="0.000983"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.176030" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.176109" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:11.176248" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "",
                "path-id": 0,
             ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:11.114386" elapsed="0.061889"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:11.176458" elapsed="0.002504"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:11.180187" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.179778" elapsed="0.000493"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:11.180815" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.180435" elapsed="0.000409"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:11.181008" elapsed="0.000388"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:11.179300" elapsed="0.002160"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.179049" elapsed="0.002446"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.181696" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.181521" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.179030" elapsed="0.002747"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:11.103497" elapsed="0.078332"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:11.102685" elapsed="0.079226"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.102420" elapsed="0.079542"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.102401" elapsed="0.079588"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.182024" elapsed="0.000033"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:10.967857" elapsed="0.214303"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:10.963563" elapsed="0.218659"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:11.182394" elapsed="0.003316"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.241721" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.241291" elapsed="0.000465"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.242577" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.242298" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.242765" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.241942" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.243356" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:11.242964" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.243709" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:11.243884" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:11.243550" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.244329" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.244080" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.245781" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.245444" elapsed="0.000383"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.246325" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.246050" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.247162" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.246752" elapsed="0.000436"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:11.248409" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.247860" elapsed="0.000649"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:11.248591" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:11.248906" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:11.247384" elapsed="0.001548"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.249114" elapsed="0.000396"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:11.246586" elapsed="0.002967"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.250243" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.249827" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:11.251698" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.251108" elapsed="0.000694"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:11.251880" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:11.252181" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:11.250542" elapsed="0.001665"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:11.252367" elapsed="0.000421"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:11.249685" elapsed="0.003149"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:11.246408" elapsed="0.006462"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:11.252916" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:11.253076" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:11.244812" elapsed="0.008303"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.244453" elapsed="0.008698"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.253337" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.253178" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.244430" elapsed="0.008982"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.254175" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:11.253559" elapsed="0.000645"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.254253" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:11.240595" elapsed="0.013782"/>
</kw>
<msg time="2026-06-06T03:31:11.254433" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:11.227532" elapsed="0.026952"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.267169" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.279680" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.292447" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.292668" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.292854" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.293289" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.293094" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:11.293078" elapsed="0.000293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.293517" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.293704" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.293876" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:11.293046" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.292934" elapsed="0.001022"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.294105" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.294181" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:11.294305" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:11.223113" elapsed="0.071219"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.295669" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.295378" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.295837" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.295018" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.296194" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.295934" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.297000" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.296459" elapsed="0.000568"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.296275" elapsed="0.000788"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.295915" elapsed="0.001170"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.299459" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:11.297266" elapsed="0.002220"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:11.299538" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:11.299709" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:11.294681" elapsed="0.005054"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.301013" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:11.300809" elapsed="0.000260"/>
</kw>
<msg time="2026-06-06T03:31:11.301200" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.300428" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.301438" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:11.301301" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.301281" elapsed="0.000224"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.301844" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:11.302076" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:11.301673" elapsed="0.000429"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:11.302500" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.302265" elapsed="0.000261"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:11.302573" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:11.302746" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:11.300093" elapsed="0.002678"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.304165" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.303916" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.304609" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.304368" elapsed="0.000300"/>
</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-06-06T03:31:11.312868" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:11.313418" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '451'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}}]} 
 </msg>
<msg time="2026-06-06T03:31:11.313557" 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-06-06T03:31:11.307033" elapsed="0.006560"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.304735" elapsed="0.008939"/>
</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-06-06T03:31:11.313936" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.313713" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.304716" elapsed="0.009340"/>
</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-06-06T03:31:11.318903" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"route-target-constrain-default-route":{}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.315486" elapsed="0.003486"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.315171" elapsed="0.003850"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.315145" elapsed="0.003911"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.322742" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.319506" elapsed="0.003282"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.319134" elapsed="0.003689"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.319110" elapsed="0.003738"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.323425" 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-06-06T03:31:11.323030" elapsed="0.000422"/>
</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-06-06T03:31:11.323789" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.323524" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.324339" 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-06-06T03:31:11.324040" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.323872" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.323505" elapsed="0.000916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.324964" 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-06-06T03:31:11.324585" elapsed="0.000405"/>
</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-06-06T03:31:11.325316" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.325059" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.325875" 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-06-06T03:31:11.325563" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.325397" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.325041" elapsed="0.000915"/>
</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-06-06T03:31:11.326111" elapsed="0.000387"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:11.327054" 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-06-06T03:31:11.326735" elapsed="0.000346"/>
</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-06-06T03:31:11.327240" elapsed="0.002463"/>
</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-06-06T03:31:11.314560" elapsed="0.015208"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.329950" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:11.329840" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.329821" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:11.333056" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<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="PASS" start="2026-06-06T03:31:11.330169" elapsed="0.002916"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:11.333155" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:11.333319" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:11.303084" elapsed="0.030262"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.333440" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:11.333606" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:11.197226" elapsed="0.136406"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.362936" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.362428" elapsed="0.000604"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.363896" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.363565" elapsed="0.000458">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:11.364204" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:11.363215" elapsed="0.001014"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.364866" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:11.364402" elapsed="0.000492"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:11.365255" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:11.365476" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:11.365064" elapsed="0.000440"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.365957" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:11.365684" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:11.366494" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.366082" elapsed="0.000474"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.367255" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:11.366748" elapsed="0.000534"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:11.366582" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:11.366060" elapsed="0.001280"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.368026" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:11.367512" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:11.368107" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:11.361804" elapsed="0.006434"/>
</kw>
<msg time="2026-06-06T03:31:11.368293" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:11.348879" elapsed="0.019463"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.381091" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.393661" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.406095" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.406295" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.406475" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.406881" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.406731" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:11.406715" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.407104" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.407322" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.407497" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:11.406683" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.406557" elapsed="0.001021"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.407746" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.407824" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:11.407942" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:11.346062" elapsed="0.061907"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:11.408149" elapsed="0.002664"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:11.412185" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.411789" elapsed="0.000431"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:11.412968" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:11.412393" elapsed="0.000606"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:31:11.413522" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-constrain-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "path-id": 0,
      "route-key": "",
      "route-target-constrain-default-route": {}
     }
    ]
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:31:11.413729" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.413182" elapsed="0.000624">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.411312" elapsed="0.002676">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:11.410958" elapsed="0.003110">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:11.414263" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:11.414103" elapsed="0.000218"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:11.410932" elapsed="0.003412">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.334823" elapsed="0.079649">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.333992" elapsed="0.080624">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:11.333737" elapsed="0.080987">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:11.333719" elapsed="0.081040">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:11.414809" elapsed="0.000018"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:11.190874" elapsed="0.224055">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,26 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "path-id": 0,
+      "route-key": "",
+      "route-target-constrain-default-route": {}
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.473200" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.472801" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.474077" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:13.473806" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:13.474250" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.473416" elapsed="0.000860"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.474859" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:13.474448" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.475198" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.475422" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.475056" elapsed="0.000394"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.475883" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.475615" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.476987" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.476663" elapsed="0.000373"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.477482" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.477208" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.478329" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.477917" elapsed="0.000439"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:13.479608" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.479036" elapsed="0.000697"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:13.479815" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:13.480133" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:13.478549" elapsed="0.001612"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.480346" elapsed="0.000418"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:13.477772" elapsed="0.003035"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.481628" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.481061" elapsed="0.000643"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:13.482939" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.482371" elapsed="0.000671"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:13.483128" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:13.483421" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:13.481910" elapsed="0.001537"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.483605" elapsed="0.000390"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:13.480922" elapsed="0.003116"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:13.477561" elapsed="0.006512"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:13.484117" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:13.484275" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:13.476317" elapsed="0.008033"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.476009" elapsed="0.008376"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.484566" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.484411" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.475985" elapsed="0.008675"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.485562" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:13.484810" elapsed="0.000782"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.485670" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:13.472156" elapsed="0.013644"/>
</kw>
<msg time="2026-06-06T03:31:13.485856" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:13.459317" elapsed="0.026588"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.498580" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.511085" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.523621" elapsed="0.000066"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.523930" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.524131" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.524567" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.524409" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:13.524391" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.524817" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.524992" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.525164" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:13.524352" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.524221" elapsed="0.001023"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.525395" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.525551" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:13.525734" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:13.454814" elapsed="0.070949"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.527215" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:13.526924" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:13.527384" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.526503" elapsed="0.000907"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.527771" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.527482" elapsed="0.000349"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.528348" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.528048" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.527856" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.527463" elapsed="0.000970"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.530825" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:13.528591" elapsed="0.002261"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:13.530905" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:13.531062" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:13.526143" elapsed="0.004945"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.532282" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.532089" elapsed="0.000247"/>
</kw>
<msg time="2026-06-06T03:31:13.532422" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.531744" elapsed="0.000702"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.532674" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:13.532516" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.532497" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.533073" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.533227" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.532900" elapsed="0.000353"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:13.533695" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.533415" elapsed="0.000308"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:13.533771" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:13.533924" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:13.531398" elapsed="0.002552"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.535404" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.535150" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.535909" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.535620" elapsed="0.000376"/>
</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-06-06T03:31:13.544864" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:13.545136" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '177'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:31:13.545246" 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-06-06T03:31:13.539565" elapsed="0.005708"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.536064" elapsed="0.009252"/>
</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-06-06T03:31:13.545503" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.545342" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.536045" elapsed="0.009543"/>
</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-06-06T03:31:13.549066" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.546659" elapsed="0.002461"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.546419" elapsed="0.002736"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.546400" elapsed="0.002781"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.551792" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.549465" elapsed="0.002374"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.549238" elapsed="0.002635"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.549221" elapsed="0.002677"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.552464" 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-06-06T03:31:13.552074" elapsed="0.000417"/>
</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-06-06T03:31:13.552823" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.552561" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.553372" 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-06-06T03:31:13.553073" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.552905" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.552543" elapsed="0.000913"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.554029" 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-06-06T03:31:13.553620" elapsed="0.000436"/>
</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-06-06T03:31:13.554366" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.554125" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.554924" 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-06-06T03:31:13.554613" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.554447" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.554107" elapsed="0.000899"/>
</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-06-06T03:31:13.555161" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:13.555984" 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-06-06T03:31:13.555690" elapsed="0.000321"/>
</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-06-06T03:31:13.556177" elapsed="0.002316"/>
</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-06-06T03:31:13.545990" elapsed="0.012567"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.558792" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:13.558629" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.558610" elapsed="0.000254"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:13.561655" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<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="PASS" start="2026-06-06T03:31:13.559014" elapsed="0.002693"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:13.561762" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:13.561921" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:13.534260" elapsed="0.027688"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.562011" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:31:13.562168" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:13.432119" elapsed="0.130075"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.590696" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.590156" elapsed="0.000570"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.591532" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:13.591243" elapsed="0.000431">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:13.591855" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.590897" elapsed="0.000984"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.592496" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:13.592052" elapsed="0.000472"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.592868" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.593015" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.592707" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.593476" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.593207" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:13.594040" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.593594" elapsed="0.000513"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.594806" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.594283" elapsed="0.000551"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.594132" elapsed="0.000739"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.593573" elapsed="0.001319"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.595742" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:13.595043" elapsed="0.000728"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.595863" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:13.589504" elapsed="0.006492"/>
</kw>
<msg time="2026-06-06T03:31:13.596057" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:13.576791" elapsed="0.019317"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.608795" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.621452" elapsed="0.000053"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.634510" elapsed="0.000053"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.634816" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.635014" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.635444" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.635289" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:13.635270" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.635689" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.635865" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.636036" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:13.635232" elapsed="0.000857"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.635103" elapsed="0.001013"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.636267" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.636346" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:13.636495" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:13.574132" elapsed="0.062392"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:13.636796" elapsed="0.002325"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:13.640253" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.639936" elapsed="0.000346"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:13.640732" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.640441" elapsed="0.000320"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:13.640924" elapsed="0.000341"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:13.639478" elapsed="0.001848"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.639203" elapsed="0.002156"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.641538" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.641385" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.639184" elapsed="0.002431"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:13.563334" elapsed="0.078344"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:13.562515" elapsed="0.079268"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.562275" elapsed="0.079555"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.562258" elapsed="0.079598"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.641891" elapsed="0.000034"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:13.424593" elapsed="0.217434"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:11.185942" elapsed="2.456147"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:13.642311" elapsed="0.002850"/>
</kw>
<arg>rt_constrain_default</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:08.360604" elapsed="5.284617"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:08.261104" elapsed="5.384261"/>
</test>
<test id="s1-s18-t6" name="Odl_To_Play_rt_constrain_type_0" line="77">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:13.648606" elapsed="0.000233"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:13.648338" elapsed="0.000558"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.649953" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:13.649839" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.649818" elapsed="0.000203"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.657199" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:13.657050" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.657024" elapsed="0.000272"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.658599" 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-06-06T03:31:13.658215" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.659109" 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-06-06T03:31:13.658809" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:13.659181" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:13.659335" 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-06-06T03:31:13.657618" elapsed="0.001741"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:13.664970" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:13.664858" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.664838" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:13.666268" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:13.666158" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.666139" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:13.666807" 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-06-06T03:31:13.666487" elapsed="0.000347"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:13.667218" level="INFO">${current_connection_index} = 7</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-06-06T03:31:13.667000" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:13.699531" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:13.667774" elapsed="0.031863"/>
</kw>
<msg time="2026-06-06T03:31:13.699852" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:13.699899" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:13.667411" elapsed="0.032524"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:13.747028" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "0 "[K"
[?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-06-06T03:31:13.700482" elapsed="0.046743"/>
</kw>
<msg time="2026-06-06T03:31:13.747442" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:13.747489" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</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-06-06T03:31:13.700122" elapsed="0.047407"/>
</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-06-06T03:31:13.747994" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.747667" elapsed="0.000385"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.747610" elapsed="0.000470"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.748590" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "0 "[K"
[?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-06-06T03:31:13.748230" elapsed="0.000459"/>
</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-06-06T03:31:13.748982" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.748758" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.748739" elapsed="0.000322"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:13.749097" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:13.751857" elapsed="0.000362"/>
</kw>
<msg time="2026-06-06T03:31:13.752286" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:13.750713" elapsed="0.001706"/>
</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="NOT RUN" start="2026-06-06T03:31:13.752727" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.753069" elapsed="0.000073"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:13.750034" elapsed="0.003223"/>
</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-06-06T03:31:13.749418" elapsed="0.003906"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:13.665853" elapsed="0.087572"/>
</kw>
<msg time="2026-06-06T03:31:13.753519" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:13.753565" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:13.665199" elapsed="0.088405"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:13.753880" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:13.753768" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.753747" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.754383" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.754745" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.754818" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:13.664500" elapsed="0.090426"/>
</kw>
<msg time="2026-06-06T03:31:13.755021" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:13.755065" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:13.659813" elapsed="0.095289"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.755432" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.755178" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.755160" elapsed="0.000349"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:13.659664" elapsed="0.095869"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:13.659472" elapsed="0.096093"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:13.656528" elapsed="0.099092"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:13.649498" elapsed="0.106198"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:13.649053" elapsed="0.106691"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:13.646142" elapsed="0.109656"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.756694" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.756868" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.756468" elapsed="0.000427"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:13.757273" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.757056" elapsed="0.000244"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.757667" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/withdraw_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/withdraw_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.757826" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.757462" elapsed="0.000391"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:13.758218" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.758014" elapsed="0.000231"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:13.758537" elapsed="0.002252"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.758318" elapsed="0.002508"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.758298" elapsed="0.002576"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.794909" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.794515" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.795740" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:13.795488" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:13.795911" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.795146" elapsed="0.000790"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.796490" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:13.796106" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.796833" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.796963" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.796698" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.797391" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.797148" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.798435" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.798180" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.798932" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.798661" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.799616" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.799319" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:13.800575" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.800170" elapsed="0.000432"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:13.800674" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:13.800829" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:13.799849" elapsed="0.001005"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.801011" elapsed="0.000246"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:13.799180" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.801869" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.801544" elapsed="0.000351"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:13.802875" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.802452" elapsed="0.000450"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:13.802955" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:13.803107" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:13.802105" elapsed="0.001027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:13.803289" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:13.801409" elapsed="0.002146"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:13.799010" elapsed="0.004581"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:13.803634" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:13.803808" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:13.797848" elapsed="0.005985"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.797505" elapsed="0.006361"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.804045" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.803891" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.797485" elapsed="0.006671"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.804899" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:13.804307" elapsed="0.000622"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.804978" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:13.793890" elapsed="0.011217"/>
</kw>
<msg time="2026-06-06T03:31:13.805161" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:13.781173" elapsed="0.024037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.817838" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.830207" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.842627" elapsed="0.000046"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.842865" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.843051" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.843446" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.843293" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:13.843276" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.843689" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.843864" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.844035" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:13.843243" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.843133" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.844265" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.844342" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:13.844476" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:13.776734" elapsed="0.067816"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.869399" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.869013" elapsed="0.000415"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.870229" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:13.869991" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:13.870398" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.869599" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.871000" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:13.870592" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.871340" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:13.871491" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:13.871202" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.871947" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;route-target-extended-community&gt;
        &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
        &lt;local-administrator&gt;AAAAZQ==&lt;/local-administrator&gt;
    &lt;/route-target-extended-community&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.871700" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:13.872375" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.872076" elapsed="0.000359"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.872923" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.872612" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.872460" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.872057" elapsed="0.000950"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.873608" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:13.873160" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.873706" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:13.868377" elapsed="0.005473"/>
</kw>
<msg time="2026-06-06T03:31:13.873908" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:13.855721" elapsed="0.018248"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.886621" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.899068" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.911482" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.911699" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.911884" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.912254" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.912104" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:13.912089" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.912481" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.912668" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.912878" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:13.912061" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.911959" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.913113" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.913188" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:13.913318" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:13.854814" elapsed="0.058533"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:13.914655" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:13.914394" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:13.914816" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:13.914047" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.915205" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.914946" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.915777" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:13.915468" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.915286" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.914926" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.918223" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:13.916018" elapsed="0.002232"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:13.918302" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:13.918455" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:13.913702" elapsed="0.004778"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.920026" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.919777" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.920469" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;route-target-extended-community&gt;
        &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
        &lt;local-administrator&gt;AAAAZQ==&lt;/local-administrator&gt;
    &lt;/route-target-extended-community&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.920231" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.920938" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.920693" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.921375" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.921136" elapsed="0.000282"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:13.922255" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:13.922059" elapsed="0.000222"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:13.922614" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:13.922439" elapsed="0.000213"/>
</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-06-06T03:31:13.922810" elapsed="0.000203"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.923417" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.923173" elapsed="0.000288"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:13.923504" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:13.923674" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:13.921619" elapsed="0.002081"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:13.937615" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '726', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;route-target-extended-community&gt;
        &lt;global-administrator&gt;64496&lt;/global-administrator&gt;
        &lt;local-administrator&gt;AAAAZQ==&lt;/local-administrator&gt;
    &lt;/route-target-extended-community&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt; 
 </msg>
<msg time="2026-06-06T03:31:13.937950" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes/route-target-constrain-route=flow1,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:13.938181" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:13.926071" elapsed="0.012170"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.923772" elapsed="0.014577"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.938820" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.938411" elapsed="0.000565"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.923754" elapsed="0.015271"/>
</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-06-06T03:31:13.946524" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.941433" elapsed="0.005152"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.940916" elapsed="0.005718"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.940873" elapsed="0.005819"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.950312" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:13.947091" elapsed="0.003285"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.946773" elapsed="0.003652"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.946749" elapsed="0.003710"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.951266" 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-06-06T03:31:13.950728" elapsed="0.000576"/>
</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-06-06T03:31:13.951773" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.951402" elapsed="0.000454"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.952544" 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-06-06T03:31:13.952129" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.951890" elapsed="0.000740"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.951376" elapsed="0.001303"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.953418" 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-06-06T03:31:13.952910" elapsed="0.000545"/>
</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-06-06T03:31:13.953945" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.953551" elapsed="0.000476"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.954537" 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-06-06T03:31:13.954242" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.954061" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.953526" elapsed="0.001093"/>
</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-06-06T03:31:13.954790" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:13.955597" 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-06-06T03:31:13.955309" elapsed="0.000314"/>
</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-06-06T03:31:13.955801" elapsed="0.002376"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:31:13.939880" elapsed="0.018361"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:13.958424" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:31:13.958315" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.958295" elapsed="0.000221"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:13.958688" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:13.958764" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:13.961030" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:31:13.918823" elapsed="0.042234"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.961165" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:13.961325" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:13.765632" elapsed="0.195719"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:13.961715" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:13.961458" elapsed="0.000355"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:13.961440" elapsed="0.000399"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:13.961873" elapsed="0.000035"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:13.761134" elapsed="0.200874"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:13.965087" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:13.962960" elapsed="0.002161"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:13.965301" elapsed="0.002413"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:13.967765" elapsed="0.000030"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:13.962676" elapsed="0.005219"/>
</kw>
<msg time="2026-06-06T03:31:13.967972" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:13.962191" elapsed="0.005807"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.968869" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:31:13.968945" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:13.968586" elapsed="0.000382"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:13.969384" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:31:13.969458" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:13.969133" elapsed="0.000349"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:13.969654" elapsed="0.000353"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:13.970460" level="INFO">${sum_1} = 2331</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:13.970211" elapsed="0.000285"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:13.970988" level="INFO">${sum_2} = 2331</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:13.970742" elapsed="0.000281"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:13.971242" elapsed="0.000450"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:13.968218" elapsed="0.003561"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:13.971997" elapsed="0.002510"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.021814" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:14.021412" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.022589" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.022353" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:14.022817" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:14.022013" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.023403" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:14.023015" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.023751" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:14.023892" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:14.023596" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.024326" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.024082" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.025541" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.025230" elapsed="0.000356"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.026086" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.025773" elapsed="0.000339"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.026936" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.026483" elapsed="0.000479"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:14.028062" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.027570" elapsed="0.000573"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:14.028278" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:14.028499" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:14.027155" elapsed="0.001369"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.028701" elapsed="0.000399"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:14.026343" elapsed="0.002799"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.029867" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.029393" elapsed="0.000501"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:14.030992" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.030505" elapsed="0.000568"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:14.031208" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:14.031429" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:14.030086" elapsed="0.001370"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.031613" elapsed="0.000411"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:14.029256" elapsed="0.002810"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:14.026166" elapsed="0.005935"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:14.032145" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:14.032303" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:14.024758" elapsed="0.007571"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.024440" elapsed="0.007921"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.032540" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.032387" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.024420" elapsed="0.008197"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.033352" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:14.032784" elapsed="0.000597"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:14.033430" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:14.020796" elapsed="0.012795"/>
</kw>
<msg time="2026-06-06T03:31:14.033664" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:14.008289" elapsed="0.025426"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.046203" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.058550" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.070973" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.071178" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.071362" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.071759" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.071593" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:14.071577" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.071987" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.072161" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.072331" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:14.071545" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.071440" elapsed="0.000971"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.072561" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.072637" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:14.072780" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:14.004030" elapsed="0.068778"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.074017" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.073727" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:14.084019" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:14.084068" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:14.084158" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:14.076531" elapsed="0.007653"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.074134" elapsed="0.010092"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.084411" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.084252" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.074115" elapsed="0.010382"/>
</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-06-06T03:31:14.090272" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.085524" elapsed="0.004849"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.085297" elapsed="0.005155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.085278" elapsed="0.005232"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.095145" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.091182" elapsed="0.004010"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.090666" elapsed="0.004561"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.090599" elapsed="0.004653"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.095838" 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-06-06T03:31:14.095429" elapsed="0.000436"/>
</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-06-06T03:31:14.096181" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.095937" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.096749" 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-06-06T03:31:14.096432" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.096264" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.095918" elapsed="0.000915"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.097361" 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-06-06T03:31:14.096999" elapsed="0.000388"/>
</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-06-06T03:31:14.097712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.097458" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.098283" 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-06-06T03:31:14.097983" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.097793" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.097439" elapsed="0.000926"/>
</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-06-06T03:31:14.098519" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:14.099337" 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-06-06T03:31:14.099051" elapsed="0.000313"/>
</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-06-06T03:31:14.099522" elapsed="0.002332"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:14.084882" elapsed="0.017037"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:14.102008" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:14.104278" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:14.073120" elapsed="0.031185"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:14.104359" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:13.975950" elapsed="0.128532"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:13.975337" elapsed="0.129200"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:13.974823" elapsed="0.129772"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:14.108095" level="INFO">${update} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.105523" elapsed="0.002603"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:14.108283" elapsed="0.002123"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:14.110457" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:14.105249" elapsed="0.005333"/>
</kw>
<msg time="2026-06-06T03:31:14.110674" level="INFO">${update} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:14.104783" elapsed="0.005918"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.111560" level="INFO">Length is 112.</msg>
<msg time="2026-06-06T03:31:14.111636" level="INFO">${len_1} = 112</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:14.111292" elapsed="0.000385"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.112095" level="INFO">Length is 112.</msg>
<msg time="2026-06-06T03:31:14.112170" level="INFO">${len_2} = 112</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:14.111837" elapsed="0.000358"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:14.112353" elapsed="0.000326"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:14.113019" level="INFO">${sum_1} = 1884</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:14.112843" elapsed="0.000202"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:14.113370" level="INFO">${sum_2} = 1884</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:14.113199" elapsed="0.000196"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:14.113551" elapsed="0.000360"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:14.110916" elapsed="0.003056"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.161742" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:14.161330" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.162614" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.162324" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:14.162838" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:14.161969" elapsed="0.000898"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.163435" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:14.163042" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.163789" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:14.164078" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:14.163630" elapsed="0.000476"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.164519" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.164269" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.165673" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.165391" elapsed="0.000330"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.166197" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.165919" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.167167" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.166599" elapsed="0.000595"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:14.168362" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.167908" elapsed="0.000495"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:14.168524" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:14.168766" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:14.167389" elapsed="0.001403"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.168954" elapsed="0.000503"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:14.166458" elapsed="0.003041"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.170308" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.169771" elapsed="0.000564"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:14.171637" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.171188" elapsed="0.000506"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:14.171816" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:14.172042" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:14.170528" elapsed="0.001544"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.172233" elapsed="0.000526"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:14.169615" elapsed="0.003187"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:14.166280" elapsed="0.006558"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:14.172882" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:14.173043" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:14.165025" elapsed="0.008049"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.164692" elapsed="0.008417"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.173290" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.173135" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.164661" elapsed="0.008706"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.174140" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:14.173515" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:14.174219" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:14.160668" elapsed="0.013675"/>
</kw>
<msg time="2026-06-06T03:31:14.174398" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:14.147682" elapsed="0.026777"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.187206" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.199876" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.212442" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.212659" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.212843" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.213214" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.213065" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:14.213049" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.213438" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.213610" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.213796" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:14.213021" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.212919" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.214060" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.214135" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:14.214256" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:14.143203" elapsed="0.071080"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.215424" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.215173" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:14.223227" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:14.223484" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '430'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-route-target-constrain:route-target-constrain-subsequent-address-family']/bgp-route-target-constrain:route-target-constrain-routes",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:14.223732" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:31:14.223802" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.217632" elapsed="0.006661">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:14.215538" elapsed="0.008867">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.224699" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.224453" elapsed="0.000335"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:14.215520" elapsed="0.009301">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:14.229935" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.226326" elapsed="0.003659">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:14.226011" elapsed="0.004062">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:14.225985" elapsed="0.004134">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.233922" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.230538" elapsed="0.003432">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:14.230218" elapsed="0.003841">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:14.230193" elapsed="0.003907">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.234708" 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-06-06T03:31:14.234299" elapsed="0.000436"/>
</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-06-06T03:31:14.235054" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.234808" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.235603" 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-06-06T03:31:14.235303" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.235136" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.234789" elapsed="0.000912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.236229" 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-06-06T03:31:14.235865" elapsed="0.000391"/>
</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-06-06T03:31:14.236564" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.236325" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.237127" 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-06-06T03:31:14.236827" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.236660" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.236307" elapsed="0.000902"/>
</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-06-06T03:31:14.237364" elapsed="0.000363"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:14.238255" 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-06-06T03:31:14.237962" elapsed="0.000320"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:31:14.240893" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.238445" elapsed="0.002482">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:31:14.225352" elapsed="0.015714">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:14.241129" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:14.243514" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:31:14.243544" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:31:14.214547" elapsed="0.029025">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:14.243653" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.117210" elapsed="0.126615">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:14.114830" elapsed="0.129058"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:14.114253" elapsed="0.129697"/>
</kw>
<arg>rt_constrain_type_0</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:13.756090" elapsed="0.487911"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:13.645689" elapsed="0.598429"/>
</test>
<test id="s1-s18-t7" name="Play_To_Odl_rt_constrain_type_0" line="81">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:14.247964" elapsed="0.000251"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:14.247665" elapsed="0.000613"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.249373" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:14.249242" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.249219" elapsed="0.000225"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.254516" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:14.254404" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.254386" elapsed="0.000200"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.255621" 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-06-06T03:31:14.255229" elapsed="0.000435"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.256142" 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-06-06T03:31:14.255837" elapsed="0.000331"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:14.256214" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:14.256373" 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-06-06T03:31:14.254840" elapsed="0.001558"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:14.261978" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:14.261822" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.261802" elapsed="0.000249"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:14.263279" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:14.263167" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.263146" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:14.263853" 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-06-06T03:31:14.263502" elapsed="0.000379"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:14.264365" level="INFO">${current_connection_index} = 7</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-06-06T03:31:14.264126" elapsed="0.000266"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:14.299948" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:14.264971" elapsed="0.035084"/>
</kw>
<msg time="2026-06-06T03:31:14.300272" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:14.300320" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:14.264566" elapsed="0.035793"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:14.336831" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "0 "[K"
[?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-06-06T03:31:14.301080" elapsed="0.035886"/>
</kw>
<msg time="2026-06-06T03:31:14.337150" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:14.337198" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</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-06-06T03:31:14.300544" elapsed="0.036692"/>
</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-06-06T03:31:14.337604" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.337332" elapsed="0.000354"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.337304" elapsed="0.000410"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.338250" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "0 "[K"
[?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-06-06T03:31:14.337903" elapsed="0.000426"/>
</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-06-06T03:31:14.338624" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.338398" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.338379" elapsed="0.000344"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:14.338759" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:14.341449" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:31:14.341678" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:14.340323" elapsed="0.001491"/>
</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="NOT RUN" start="2026-06-06T03:31:14.342122" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.342462" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:14.339674" elapsed="0.002994"/>
</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-06-06T03:31:14.339082" elapsed="0.003654"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:14.262853" elapsed="0.079984"/>
</kw>
<msg time="2026-06-06T03:31:14.342931" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:14.342977" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:14.262216" elapsed="0.080800"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:14.343204" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:14.343094" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.343074" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.343717" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.344060" elapsed="0.000070"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.344181" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:14.261463" elapsed="0.082828"/>
</kw>
<msg time="2026-06-06T03:31:14.344388" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:14.344432" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:14.256805" elapsed="0.087665"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.344828" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.344547" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.344530" elapsed="0.000378"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:14.256638" elapsed="0.088294"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:14.256459" elapsed="0.088505"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:14.254035" elapsed="0.090985"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:14.248932" elapsed="0.096144"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:14.248443" elapsed="0.096680"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:14.245061" elapsed="0.100116"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.346356" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.345864" elapsed="0.000521"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.347030" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.346558" elapsed="0.000500"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.347610" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.347229" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.348026" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:14.348191" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:14.347821" elapsed="0.000397"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.348567" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/withdraw_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/withdraw_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:14.348792" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:14.348377" elapsed="0.000442"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:14.348977" elapsed="0.004068"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:14.353227" elapsed="0.002045"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.408914" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:14.408517" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.409708" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.409452" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:14.409950" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:14.409114" elapsed="0.000862"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.410542" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:14.410152" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.410893" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:14.411027" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:14.410753" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.411465" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.411217" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.412538" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.412237" elapsed="0.000347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.413088" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.412772" elapsed="0.000343"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.413943" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.413484" elapsed="0.000487"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:14.415197" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.414624" elapsed="0.000676"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:14.415379" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:14.415694" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:14.414164" elapsed="0.001556"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.415882" elapsed="0.000385"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:14.413341" elapsed="0.002968"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.417182" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:14.416604" elapsed="0.000605"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:14.418464" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.417902" elapsed="0.000663"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:14.418662" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:14.418957" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:14.417403" elapsed="0.001580"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:14.419143" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:14.416463" elapsed="0.003091"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:14.413167" elapsed="0.006422"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:14.419632" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:31:14.419812" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:14.411906" elapsed="0.007932"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.411584" elapsed="0.008287"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.420051" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.419895" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.411562" elapsed="0.008566"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.420877" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:14.420278" elapsed="0.000628"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:14.420995" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:14.407899" elapsed="0.013224"/>
</kw>
<msg time="2026-06-06T03:31:14.421179" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:14.395268" elapsed="0.025960"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.433767" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.446252" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.458604" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.458831" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.459016" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.459402" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.459247" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:14.459231" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.459629" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.459821" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.459995" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:14.459199" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.459094" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.460231" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.460307" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:14.460436" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:14.391021" elapsed="0.069443"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.461831" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.461557" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:14.462029" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:14.461198" elapsed="0.000855"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.462380" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.462124" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.462955" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:14.462661" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.462462" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.462105" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.465547" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:14.463192" elapsed="0.002382"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:14.465625" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:14.465795" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:14.460857" elapsed="0.004963"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:14.467085" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.466852" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:14.467241" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:14.466492" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:14.467474" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:14.467337" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:14.467318" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.467726" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.467904" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.467969" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:14.469889" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:14.466163" elapsed="0.003782"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.471349" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.471097" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:14.471817" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:14.471556" elapsed="0.000305"/>
</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-06-06T03:31:14.480436" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:14.480572" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:14.480723" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</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="FAIL" start="2026-06-06T03:31:14.474030" elapsed="0.007061">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:14.471927" elapsed="0.009286">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:14.481501" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.481264" elapsed="0.000333"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:14.471909" elapsed="0.009723">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:14.482254" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.482451" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:14.482396" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:14.482370" elapsed="0.000176"/>
</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-06-06T03:31:14.482791" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.482897" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:14.470261" elapsed="0.012791">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.483163" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.367331" elapsed="0.115973">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:14.483734" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:14.483442" elapsed="0.000399"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:14.483417" elapsed="0.000460"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:14.483925" elapsed="0.000021"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:14.360766" elapsed="0.123301">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.540148" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.539717" elapsed="0.000470"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.540995" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.540739" elapsed="0.000406">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.541243" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.540371" elapsed="0.000898"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.541851" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:16.541442" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.542191" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:16.542349" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:16.542047" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.542911" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.542632" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.544110" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.543752" elapsed="0.000409"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.544602" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.544329" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.545444" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.545036" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:16.546761" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.546142" elapsed="0.000725"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:16.546950" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:31:16.547255" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:16.545682" elapsed="0.001599"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.547442" elapsed="0.000405"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:16.544894" elapsed="0.002996"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.548747" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.548143" elapsed="0.000630"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:16.550068" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.549423" elapsed="0.000748"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:16.550249" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:16.550577" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:16.548965" elapsed="0.001638"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.550782" elapsed="0.000369"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:16.548005" elapsed="0.003191"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:16.544712" elapsed="0.006520"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:16.551276" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:16.551432" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:16.543407" elapsed="0.008051"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.543043" elapsed="0.008447"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.551689" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.551517" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.543017" elapsed="0.008751"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.552514" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:16.551917" elapsed="0.000671"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.552656" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:16.538958" elapsed="0.013827"/>
</kw>
<msg time="2026-06-06T03:31:16.552843" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:16.526041" elapsed="0.026853"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.565388" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.577806" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.590172" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.590410" elapsed="0.000037"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.590613" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.591048" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.590892" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:16.590874" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.591282" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.591455" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.591626" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:16.590833" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.590712" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.591875" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.591953" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:16.592109" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:16.521677" elapsed="0.070460"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.593680" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.593374" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.593851" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.592976" elapsed="0.000901"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.594221" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.593949" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.594852" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.594530" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.594304" elapsed="0.000610"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.593930" elapsed="0.001005"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.597458" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:16.595091" elapsed="0.002394"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:16.597538" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:16.597715" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:16.592594" elapsed="0.005148"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.599005" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.598768" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.599162" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.598393" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:16.599394" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:16.599258" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.599240" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.599627" elapsed="0.000036"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.599819" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.599884" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:16.601797" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:16.598058" elapsed="0.003766"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.603242" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.602985" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.603702" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.603445" elapsed="0.000301"/>
</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-06-06T03:31:16.613209" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:16.613363" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '361'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:31:16.613537" 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-06-06T03:31:16.605881" elapsed="0.007684"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.603812" elapsed="0.009801"/>
</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-06-06T03:31:16.613851" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.613664" elapsed="0.000253"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.603794" elapsed="0.010144"/>
</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-06-06T03:31:16.622609" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.616417" elapsed="0.006357"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.615782" elapsed="0.007086"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.615705" elapsed="0.007224"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.627893" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.623587" elapsed="0.004353"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.623058" elapsed="0.004917"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.623019" elapsed="0.004981"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.628667" 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-06-06T03:31:16.628225" elapsed="0.000471"/>
</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-06-06T03:31:16.629022" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.628769" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.629604" 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-06-06T03:31:16.629274" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.629103" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.628750" elapsed="0.000954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.630233" 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-06-06T03:31:16.629868" elapsed="0.000391"/>
</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-06-06T03:31:16.630580" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.630328" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.631192" 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-06-06T03:31:16.630896" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.630676" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.630310" elapsed="0.000964"/>
</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-06-06T03:31:16.631433" elapsed="0.000374"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:16.632276" 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-06-06T03:31:16.631977" elapsed="0.000325"/>
</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-06-06T03:31:16.632460" elapsed="0.002332"/>
</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-06-06T03:31:16.614327" elapsed="0.020532"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.635041" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:16.634931" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.634913" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:16.638049" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:16.635262" elapsed="0.002816"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:16.638131" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:16.638299" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:16.602135" elapsed="0.036191"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.638490" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:16.638666" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:16.499187" elapsed="0.139507"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.668694" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.668198" elapsed="0.000525"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.669537" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.669237" elapsed="0.000446">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.669863" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.668893" elapsed="0.000996"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.670531" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:16.670062" elapsed="0.000497"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.670905" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:16.671070" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:16.670742" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.671530" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-extended-community": {
                    "global-administrator": 64496,
                    "local-administrator": "AAAAZQ=="
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.671262" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:16.672076" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.671668" elapsed="0.000470"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.672845" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.672315" elapsed="0.000557"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.672163" elapsed="0.000744"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.671628" elapsed="0.001301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.673568" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:16.673080" elapsed="0.000517"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.673669" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:16.667557" elapsed="0.006242"/>
</kw>
<msg time="2026-06-06T03:31:16.673895" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:16.653124" elapsed="0.020821"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.686463" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.699075" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.711587" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.711803" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.711985" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.712376" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.712224" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:16.712209" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.712600" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.712789" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.712960" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:16.712178" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.712068" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.713192" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.713266" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:16.713404" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:16.650483" elapsed="0.062948"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:16.713612" elapsed="0.002230"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:16.717000" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.716577" elapsed="0.000484"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:16.717610" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.717223" elapsed="0.000428"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:16.717814" elapsed="0.000328"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:16.716163" elapsed="0.002039"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.715922" elapsed="0.002314"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.718415" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.718262" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.715903" elapsed="0.002617"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:16.639877" elapsed="0.078690"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:16.639043" elapsed="0.079613"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.638780" elapsed="0.079923"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.638762" elapsed="0.079965"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.718760" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:16.494121" elapsed="0.224764"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:14.355472" elapsed="2.363472"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.818461" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.818046" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.819453" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.819158" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.819659" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.818775" elapsed="0.000913"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.820253" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:16.819864" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.820598" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:16.820788" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:16.820447" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.821238" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.820980" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.822428" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.822079" elapsed="0.000436"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.823060" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.822778" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.823902" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.823470" elapsed="0.000459"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:16.825427" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.824875" elapsed="0.000653"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:16.825608" elapsed="0.000053"/>
</return>
<msg time="2026-06-06T03:31:16.825929" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:16.824121" elapsed="0.001836"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.826119" elapsed="0.000403"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:16.823327" elapsed="0.003243"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.827281" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.826842" elapsed="0.000467"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:16.828511" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.827974" elapsed="0.000637"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:16.828709" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:16.829000" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:16.827499" elapsed="0.001527"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:16.829183" elapsed="0.000363"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:16.826702" elapsed="0.002886"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:16.823146" elapsed="0.006476"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:16.829683" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:16.829842" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:16.821715" elapsed="0.008153"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.821367" elapsed="0.008533"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.830082" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.829927" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.821341" elapsed="0.008818"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.830917" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:16.830307" elapsed="0.000640"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.830998" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:16.817344" elapsed="0.013778"/>
</kw>
<msg time="2026-06-06T03:31:16.831178" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:16.804205" elapsed="0.027023"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.843762" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.856095" elapsed="0.000061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.868661" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.868862" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.869047" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.869427" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.869275" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:16.869260" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.869667" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.869844" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.870015" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:16.869231" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.869126" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.870246" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.870322" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:16.870443" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:16.799720" elapsed="0.070750"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.871766" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.871514" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.871927" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.871167" elapsed="0.000784"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.872272" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.872022" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.872848" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.872536" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.872356" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.872003" elapsed="0.000929"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.875481" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:16.873087" elapsed="0.002422"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:16.875562" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:16.875771" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:16.870837" elapsed="0.004960"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.877039" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.876802" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.877197" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.876443" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:16.877431" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:16.877294" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.877274" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.877684" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.877866" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.877934" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:16.879895" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:16.876108" elapsed="0.003815"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.881327" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.881071" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.881797" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.881536" elapsed="0.000306"/>
</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-06-06T03:31:16.890705" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:16.890848" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '361'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:31:16.890962" 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-06-06T03:31:16.883999" elapsed="0.006990"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.881910" elapsed="0.009123"/>
</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-06-06T03:31:16.891225" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.891060" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.881892" elapsed="0.009420"/>
</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-06-06T03:31:16.894907" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.892338" elapsed="0.002620"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.892106" elapsed="0.002887"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.892087" elapsed="0.002932"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.897616" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.895310" elapsed="0.002367"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.895075" elapsed="0.002671"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.895058" elapsed="0.002714"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.898335" 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-06-06T03:31:16.897948" elapsed="0.000414"/>
</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-06-06T03:31:16.898723" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.898434" elapsed="0.000348"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.899347" 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-06-06T03:31:16.898976" elapsed="0.000408"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.898807" elapsed="0.000628"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.898415" elapsed="0.001050"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.900226" 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-06-06T03:31:16.899719" elapsed="0.000545"/>
</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-06-06T03:31:16.900722" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.900363" elapsed="0.000442"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.901492" 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-06-06T03:31:16.901072" elapsed="0.000458"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.900839" elapsed="0.000741"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.900338" elapsed="0.001271"/>
</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-06-06T03:31:16.901847" elapsed="0.000493"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:16.903013" 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-06-06T03:31:16.902599" elapsed="0.000451"/>
</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-06-06T03:31:16.903279" elapsed="0.003272"/>
</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-06-06T03:31:16.891683" elapsed="0.014976"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.906912" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:16.906761" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.906734" elapsed="0.000273"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:16.909966" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:16.907196" elapsed="0.002799"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:16.910048" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:16.910209" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:16.880234" elapsed="0.030002"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.910299" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:16.910447" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:16.776184" elapsed="0.134289"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.938909" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.938377" elapsed="0.000562"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.939811" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:16.939508" elapsed="0.000426">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:16.940111" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:16.939159" elapsed="0.000978"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.940772" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:16.940310" elapsed="0.000490"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:16.941129" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:16.941443" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:16.940968" elapsed="0.000503"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.941920" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-extended-community": {
                    "global-administrator": 64496,
                    "local-administrator": "AAAAZQ=="
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:16.941634" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:16.942459" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.942042" elapsed="0.000506"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.943246" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:16.942744" elapsed="0.000530"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.942575" elapsed="0.000735"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.942021" elapsed="0.001311"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:16.943993" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:16.943484" elapsed="0.000539"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.944074" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:16.937739" elapsed="0.006462"/>
</kw>
<msg time="2026-06-06T03:31:16.944261" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:16.924899" elapsed="0.019411"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.956932" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.969446" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.982251" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.982458" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.982677" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.983075" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.982920" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:16.982904" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.983302" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.983478" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.983664" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:16.982872" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.982762" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.983900" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:16.983978" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:16.984126" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:16.922223" elapsed="0.061931"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:16.984336" elapsed="0.002435"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:16.987969" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.987527" elapsed="0.000471"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:16.988538" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:16.988157" elapsed="0.000409"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:16.988743" elapsed="0.000330"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:16.987099" elapsed="0.002036"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.986852" elapsed="0.002320"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:16.989349" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:16.989197" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.986833" elapsed="0.002593"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:16.911617" elapsed="0.077858"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:16.910822" elapsed="0.078732"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:16.910566" elapsed="0.079070"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:16.910549" elapsed="0.079129"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:16.989716" elapsed="0.000030"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:16.771320" elapsed="0.218531"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:16.719122" elapsed="0.270793"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.039189" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.038813" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.039967" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.039740" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.040135" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.039387" elapsed="0.000775"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.040732" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:17.040329" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.041062" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:17.041209" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:17.040926" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.041657" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.041396" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.042906" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.042398" elapsed="0.000555"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.043399" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.043125" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.044223" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.043811" elapsed="0.000439"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:17.045624" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.044923" elapsed="0.000818"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:17.045821" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:17.046113" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:17.044446" elapsed="0.001693"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.046298" elapsed="0.000411"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:17.043668" elapsed="0.003085"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.047414" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.047005" elapsed="0.000435"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:17.048695" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.048101" elapsed="0.000696"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:17.048875" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:17.049172" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:17.047630" elapsed="0.001568"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.049478" elapsed="0.000384"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:17.046867" elapsed="0.003039"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:17.043474" elapsed="0.006467"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:17.049985" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:17.050141" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:17.042071" elapsed="0.008096"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.041773" elapsed="0.008427"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.050378" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.050225" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.041754" elapsed="0.008702"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.051224" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:17.050632" elapsed="0.000622"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.051304" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:17.038171" elapsed="0.013258"/>
</kw>
<msg time="2026-06-06T03:31:17.051484" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:17.025575" elapsed="0.025956"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.064068" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.076395" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.089021" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.089239" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.089426" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.089829" elapsed="0.000070"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.089677" elapsed="0.000260"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:17.089659" elapsed="0.000303"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.090112" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.090288" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.090468" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:17.089613" elapsed="0.000910"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.089505" elapsed="0.001071"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.090745" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.090826" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:17.090964" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:17.021306" elapsed="0.069686"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.092331" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.092066" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.092496" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.091693" elapsed="0.000828"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.092869" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.092593" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.093663" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.093134" elapsed="0.000558"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.092952" elapsed="0.000777"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.092573" elapsed="0.001178"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.096132" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:17.093910" elapsed="0.002254"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:17.096218" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:17.096375" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:17.091329" elapsed="0.005071"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.097633" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.097400" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.097807" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.097054" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:17.098040" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:17.097903" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.097884" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.098274" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.098451" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.098568" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:17.100496" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:17.096724" elapsed="0.003799"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.101944" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.101689" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.102392" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.102148" elapsed="0.000288"/>
</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-06-06T03:31:17.111139" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:17.111282" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '361'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:31:17.111378" 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-06-06T03:31:17.104603" elapsed="0.006802"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.102502" elapsed="0.008947"/>
</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-06-06T03:31:17.111632" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.111475" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.102484" elapsed="0.009258"/>
</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-06-06T03:31:17.115468" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.112772" elapsed="0.002766"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.112530" elapsed="0.003058"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.112512" elapsed="0.003112"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.119361" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.116046" elapsed="0.003380"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.115725" elapsed="0.003752"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.115700" elapsed="0.003812"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.120309" 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-06-06T03:31:17.119772" elapsed="0.000575"/>
</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-06-06T03:31:17.120807" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.120446" elapsed="0.000443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.121576" 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-06-06T03:31:17.121158" elapsed="0.000455"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.120923" elapsed="0.000760"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.120420" elapsed="0.001293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.122450" 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-06-06T03:31:17.121942" elapsed="0.000545"/>
</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-06-06T03:31:17.123074" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.122713" elapsed="0.000441"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.123657" 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-06-06T03:31:17.123345" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.123178" elapsed="0.000608"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.122676" elapsed="0.001133"/>
</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-06-06T03:31:17.123966" elapsed="0.000352"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:17.124798" 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-06-06T03:31:17.124490" elapsed="0.000335"/>
</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-06-06T03:31:17.124985" elapsed="0.002309"/>
</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-06-06T03:31:17.112107" elapsed="0.015250"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.127532" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:17.127427" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.127409" elapsed="0.000190"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:17.130504" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:17.127763" elapsed="0.002771"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:17.130619" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:31:17.130795" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:17.100852" elapsed="0.029970"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.130885" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:31:17.131035" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:16.998820" elapsed="0.132241"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.160400" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.159773" elapsed="0.000665"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.161319" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.160990" elapsed="0.000464">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.161631" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.160616" elapsed="0.001057"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.162300" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:17.161848" elapsed="0.000480"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.162694" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:17.162866" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:17.162498" elapsed="0.000395"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.163324" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-extended-community": {
                    "global-administrator": 64496,
                    "local-administrator": "AAAAZQ=="
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.163051" elapsed="0.000382"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:17.163941" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.163505" elapsed="0.000498"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.164704" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.164178" elapsed="0.000554"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.164028" elapsed="0.000740"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.163484" elapsed="0.001358"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.165528" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:17.165004" elapsed="0.000553"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.165611" elapsed="0.000055"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:17.158343" elapsed="0.007429"/>
</kw>
<msg time="2026-06-06T03:31:17.165834" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:17.145489" elapsed="0.020397"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.178460" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.191069" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.203510" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.203722" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.203905" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.204299" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.204148" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:17.204130" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.204521" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.204706" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.204877" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:17.204099" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.203988" elapsed="0.001008"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.205153" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.205230" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:17.205369" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:17.142818" elapsed="0.062578"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:17.205578" elapsed="0.002398"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:17.209184" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.208759" elapsed="0.000453"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:17.209775" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.209372" elapsed="0.000433"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:17.209967" elapsed="0.000335"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:17.208316" elapsed="0.002048"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.208057" elapsed="0.002341"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.210595" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.210424" elapsed="0.000251"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.208038" elapsed="0.002659"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:17.132196" elapsed="0.078551"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:17.131383" elapsed="0.079442"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.131145" elapsed="0.079727"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.131127" elapsed="0.079769"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.210929" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:16.994412" elapsed="0.216646"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:16.990098" elapsed="0.221022"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:17.211293" elapsed="0.003034"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.267417" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.267017" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.268242" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.267990" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.268486" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.267625" elapsed="0.000886"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.269094" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:17.268700" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.269582" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:17.269753" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:17.269440" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.270193" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.269944" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.271526" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.271220" elapsed="0.000352"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.272047" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.271768" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.272879" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.272451" elapsed="0.000454"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:17.274123" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.273559" elapsed="0.000677"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:17.274318" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:17.274660" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:17.273100" elapsed="0.001588"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.274851" elapsed="0.000386"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:17.272310" elapsed="0.002969"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.275948" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.275532" elapsed="0.000443"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:17.277183" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.276620" elapsed="0.000663"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:17.277361" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:17.277667" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:17.276164" elapsed="0.001531"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:17.277854" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:17.275394" elapsed="0.002870"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:17.272127" elapsed="0.006172"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:17.278342" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:17.278500" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:17.270685" elapsed="0.007842"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.270317" elapsed="0.008242"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.278769" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.278599" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.270294" elapsed="0.008554"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.279571" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:17.278997" elapsed="0.000603"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.279666" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:17.266295" elapsed="0.013536"/>
</kw>
<msg time="2026-06-06T03:31:17.279888" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:17.253651" elapsed="0.026286"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.292607" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.305020" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.317403" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.317614" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.317814" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.318208" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.318052" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:17.318035" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.318435" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.318652" elapsed="0.000034"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.318840" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:17.318001" elapsed="0.000892"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.317896" elapsed="0.001023"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.319069" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.319145" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:17.319278" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:17.249335" elapsed="0.069970"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.320721" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.320434" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.320900" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.320051" elapsed="0.000875"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.321262" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.320997" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.323160" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.321531" elapsed="0.001656"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.321345" elapsed="0.001880"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.320978" elapsed="0.002269"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.325609" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:17.323410" elapsed="0.002226"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:17.325704" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:17.325861" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:17.319700" elapsed="0.006186"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.327100" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:17.326910" elapsed="0.000248"/>
</kw>
<msg time="2026-06-06T03:31:17.327242" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.326523" elapsed="0.000742"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.327471" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:17.327337" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.327317" elapsed="0.000221"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.327873" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:17.328023" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:17.327706" elapsed="0.000342"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:17.328444" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.328209" elapsed="0.000263"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:17.328519" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:17.328689" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:17.326194" elapsed="0.002521"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.330098" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.329849" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.330543" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.330301" elapsed="0.000285"/>
</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-06-06T03:31:17.340480" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:17.340971" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '537'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}]} 
 </msg>
<msg time="2026-06-06T03:31:17.341122" 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-06-06T03:31:17.332801" elapsed="0.008351"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.330707" elapsed="0.010492"/>
</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-06-06T03:31:17.341387" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.341226" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.330686" elapsed="0.010788"/>
</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-06-06T03:31:17.347342" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.342500" elapsed="0.004957"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.342273" elapsed="0.005263"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.342254" elapsed="0.005340"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.352231" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.348284" elapsed="0.003994"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.347760" elapsed="0.004554"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.347719" elapsed="0.004621"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.352936" 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-06-06T03:31:17.352524" elapsed="0.000440"/>
</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-06-06T03:31:17.353284" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.353037" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.353860" 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-06-06T03:31:17.353538" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.353368" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.353018" elapsed="0.000929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.354478" 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-06-06T03:31:17.354114" 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-06-06T03:31:17.354852" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.354578" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.355404" 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-06-06T03:31:17.355103" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.354935" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.354560" elapsed="0.000929"/>
</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-06-06T03:31:17.355665" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:17.356476" 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-06-06T03:31:17.356189" elapsed="0.000314"/>
</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-06-06T03:31:17.356683" elapsed="0.002529"/>
</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-06-06T03:31:17.341850" elapsed="0.017429"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.359457" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:17.359350" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.359331" elapsed="0.000194"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:17.362512" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<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="PASS" start="2026-06-06T03:31:17.359692" elapsed="0.002850"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:17.362597" elapsed="0.000089"/>
</return>
<msg time="2026-06-06T03:31:17.362825" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:17.329019" elapsed="0.033882"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.362970" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:17.363125" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:17.226560" elapsed="0.136592"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.391555" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.391072" elapsed="0.000513"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.392492" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.392126" elapsed="0.000496">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:17.392820" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:17.391783" elapsed="0.001063"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.393612" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:17.393020" elapsed="0.000636"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:17.393991" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:17.394160" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:17.393828" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.394693" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:17.394353" elapsed="0.000393"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:17.395229" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.394819" elapsed="0.000472"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.395997" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:17.395472" elapsed="0.000552"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:17.395318" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:17.394798" elapsed="0.001283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.396748" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:17.396233" elapsed="0.000544"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:17.396829" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:17.390411" elapsed="0.006545"/>
</kw>
<msg time="2026-06-06T03:31:17.397012" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:17.377723" elapsed="0.019337"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.409950" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.422465" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.434967" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.435170" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.435354" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.435758" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.435593" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:17.435577" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.435987" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.436160" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.436331" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:17.435547" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.435437" elapsed="0.000974"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.436562" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.436651" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:17.436770" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:17.375020" elapsed="0.061777"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:17.436978" elapsed="0.002258"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:17.440293" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.439993" elapsed="0.000328"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:17.441066" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:17.440482" elapsed="0.000646"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:31:17.441617" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-constrain-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "origin-as": 64511,
      "path-id": 0,
      "route-key": "AAL78AAAAGU=",
      "route-target-extended-community": {
       "global-administrator": 64496,
       "local-administrator": "AAAAZQ=="
      }
     }
    ]
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:31:17.441828" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.441299" elapsed="0.000600">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.439562" elapsed="0.002482">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:17.439319" elapsed="0.002803">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:17.442313" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:17.442157" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:17.439300" elapsed="0.003092">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.364308" elapsed="0.078206">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.363484" elapsed="0.079276">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:17.363238" elapsed="0.079656">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:17.363220" elapsed="0.079711">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:17.442983" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:17.220445" elapsed="0.222662">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AAL78AAAAGU=",
+      "route-target-extended-community": {
+       "global-administrator": 64496,
+       "local-administrator": "AAAAZQ=="
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.502972" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.502331" elapsed="0.000678"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.503906" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:19.503611" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:19.504083" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.503230" elapsed="0.000881"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.504800" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:19.504329" elapsed="0.000499"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.505155" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.505352" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.505003" elapsed="0.000387"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.505906" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.505572" elapsed="0.000397"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.507349" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.506967" elapsed="0.000431"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.507997" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.507708" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.509012" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.508471" elapsed="0.000576"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:19.510451" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.509834" elapsed="0.000723"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:19.510658" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:31:19.510975" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:19.509316" elapsed="0.001686"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.511192" elapsed="0.000413"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:19.508321" elapsed="0.003344"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.512346" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.511925" elapsed="0.000449"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:19.513902" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.513254" elapsed="0.000755"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:19.514091" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:19.514431" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:19.512780" elapsed="0.001686"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.514705" elapsed="0.000437"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:19.511785" elapsed="0.003402"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:19.508089" elapsed="0.007133"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:19.515267" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:19.515437" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:19.506538" elapsed="0.008925"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.506082" elapsed="0.009415"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.515704" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.515524" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.506047" elapsed="0.009736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.516673" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:19.515934" elapsed="0.000771"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.516758" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:19.501540" elapsed="0.015348"/>
</kw>
<msg time="2026-06-06T03:31:19.516943" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:19.487442" elapsed="0.029553"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.530660" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.543362" elapsed="0.000047"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.556210" elapsed="0.000042"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.556488" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.556700" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.557163" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.556999" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:19.556978" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.557427" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.557609" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.557803" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:19.556934" elapsed="0.000924"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.556791" elapsed="0.001095"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.558039" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.558121" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:19.558288" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:19.482982" elapsed="0.075335"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.559816" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:19.559499" elapsed="0.000394">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:19.559991" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.559066" elapsed="0.000950"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.560371" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.560092" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.561046" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.560659" elapsed="0.000421"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.560456" elapsed="0.000669"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.560072" elapsed="0.001080"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.563905" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:19.561351" elapsed="0.002582"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:19.563985" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:19.564143" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:19.558694" elapsed="0.005474"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.565365" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.565171" elapsed="0.000308"/>
</kw>
<msg time="2026-06-06T03:31:19.565566" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.564827" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.565816" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:19.565677" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.565657" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.566196" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.566349" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.566029" elapsed="0.000345"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:19.566790" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.566533" elapsed="0.000284"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:19.566866" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:19.567022" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:19.564478" elapsed="0.002570"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.568502" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.568243" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.568969" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.568723" elapsed="0.000289"/>
</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-06-06T03:31:19.576847" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:19.576995" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '177'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:31:19.577092" 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-06-06T03:31:19.571193" elapsed="0.005925"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.569079" elapsed="0.008083"/>
</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-06-06T03:31:19.577354" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.577190" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.569060" elapsed="0.008379"/>
</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-06-06T03:31:19.580965" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.578484" elapsed="0.002529"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.578254" elapsed="0.002792"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.578234" elapsed="0.002837"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.583832" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.581354" elapsed="0.002523"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.581128" elapsed="0.002785"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.581111" elapsed="0.002827"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.584523" 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-06-06T03:31:19.584123" elapsed="0.000427"/>
</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-06-06T03:31:19.584887" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.584621" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.585442" 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-06-06T03:31:19.585139" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.584969" elapsed="0.000592"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.584602" elapsed="0.000982"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.586139" 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-06-06T03:31:19.585768" elapsed="0.000399"/>
</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-06-06T03:31:19.586484" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.586241" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.587047" 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-06-06T03:31:19.586748" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.586566" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.586219" elapsed="0.000925"/>
</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-06-06T03:31:19.587303" elapsed="0.000376"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:19.588145" 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-06-06T03:31:19.587853" elapsed="0.000319"/>
</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-06-06T03:31:19.588330" elapsed="0.002302"/>
</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-06-06T03:31:19.577833" elapsed="0.012878"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.590888" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:19.590782" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.590763" elapsed="0.000191"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:19.593749" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<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="PASS" start="2026-06-06T03:31:19.591103" elapsed="0.002675"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:19.593829" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:19.593987" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:19.567399" elapsed="0.026614"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.594074" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:19.594226" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:19.459189" elapsed="0.135063"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.623112" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.622576" elapsed="0.000596"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.624042" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:19.623732" elapsed="0.000439">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:19.624349" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.623352" elapsed="0.001023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.625014" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:19.624548" elapsed="0.000555"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.625442" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.625597" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.625276" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.626079" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.625805" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:19.626673" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.626205" elapsed="0.000531"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.627456" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.626914" elapsed="0.000569"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.626762" elapsed="0.000759"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.626181" elapsed="0.001362"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.628210" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:19.627713" elapsed="0.000527"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.628293" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:19.621858" elapsed="0.006571"/>
</kw>
<msg time="2026-06-06T03:31:19.628487" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:19.608952" elapsed="0.019588"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.641206" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.653673" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.666089" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.666311" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.666500" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.667052" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.666892" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:19.666874" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.667317" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.667493" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.667684" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:19.666834" elapsed="0.000905"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.666706" elapsed="0.001062"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.667921" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.668000" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:19.668136" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:19.606101" elapsed="0.062063"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:19.668348" elapsed="0.002467"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:19.671931" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.671601" elapsed="0.000359"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:19.672396" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.672118" elapsed="0.000307"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:19.672585" elapsed="0.000353"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:19.671157" elapsed="0.001842"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.670897" elapsed="0.002136"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.673213" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.673059" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.670878" elapsed="0.002412"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:19.595429" elapsed="0.077909"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:19.594579" elapsed="0.078836"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.594336" elapsed="0.079124"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.594318" elapsed="0.079166"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.673519" elapsed="0.000030"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:19.452154" elapsed="0.221512"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:17.214527" elapsed="2.459203"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:19.673969" elapsed="0.003654"/>
</kw>
<arg>rt_constrain_type_0</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:14.345458" elapsed="5.332279"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:14.244492" elapsed="5.433369"/>
</test>
<test id="s1-s18-t8" name="Odl_To_Play_rt_constrain_type_1" line="85">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:19.681205" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:19.680938" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.682486" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:19.682373" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.682353" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.687517" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:19.687410" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.687392" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.688602" 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-06-06T03:31:19.688211" elapsed="0.000418"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.689111" 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-06-06T03:31:19.688812" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:19.689183" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:19.689338" 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-06-06T03:31:19.687831" elapsed="0.001531"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:19.695039" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:19.694928" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.694909" elapsed="0.000201"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:19.696372" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:19.696237" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.696214" elapsed="0.000233"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:19.696921" 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-06-06T03:31:19.696597" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:19.697347" level="INFO">${current_connection_index} = 7</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-06-06T03:31:19.697126" elapsed="0.000248"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:19.728329" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:19.697904" elapsed="0.030534"/>
</kw>
<msg time="2026-06-06T03:31:19.728619" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:19.728690" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:19.697541" elapsed="0.031187"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:19.764258" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "1 "[K"
[?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-06-06T03:31:19.729260" elapsed="0.035229"/>
</kw>
<msg time="2026-06-06T03:31:19.764735" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:19.764782" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</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-06-06T03:31:19.728908" elapsed="0.035911"/>
</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-06-06T03:31:19.765257" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.764932" elapsed="0.000384"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.764898" elapsed="0.000443"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.765886" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "1 "[K"
[?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-06-06T03:31:19.765492" elapsed="0.000545"/>
</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-06-06T03:31:19.766338" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.766107" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.766088" elapsed="0.000329"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:19.766455" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:19.769209" elapsed="0.000155"/>
</kw>
<msg time="2026-06-06T03:31:19.769427" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:19.768075" elapsed="0.001486"/>
</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="NOT RUN" start="2026-06-06T03:31:19.769866" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.770205" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:19.767406" elapsed="0.002985"/>
</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-06-06T03:31:19.766797" elapsed="0.003659"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:19.695924" elapsed="0.074633"/>
</kw>
<msg time="2026-06-06T03:31:19.770672" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:19.770719" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:19.695304" elapsed="0.075453"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:19.770951" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:31:19.770839" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.770818" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.771489" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.771857" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.771930" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:19.694573" elapsed="0.077469"/>
</kw>
<msg time="2026-06-06T03:31:19.772140" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:19.772185" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:19.689745" elapsed="0.082478"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.772561" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.772300" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.772282" elapsed="0.000371"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:19.689584" elapsed="0.083097"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:19.689415" elapsed="0.083300"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:19.687018" elapsed="0.085755"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:19.682084" elapsed="0.090747"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:19.681627" elapsed="0.091251"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:19.678736" elapsed="0.094197"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.773861" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/announce_rt_constrain_type_1.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/announce_rt_constrain_type_1.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.774043" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.773625" elapsed="0.000485"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:19.774492" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.774275" elapsed="0.000244"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.774888" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/withdraw_rt_constrain_type_1.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/withdraw_rt_constrain_type_1.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.775019" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.774699" elapsed="0.000347"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:19.775703" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.775250" elapsed="0.000481"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:19.776039" elapsed="0.002337"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.775805" elapsed="0.002609"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.775787" elapsed="0.002653"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.812497" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.812110" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.813365" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:19.813065" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:19.813540" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.812718" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.814150" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:19.813757" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.814492" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.814630" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.814353" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.815091" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.814842" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.816173" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.815908" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.816685" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.816389" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.817407" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.817097" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:19.818669" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.818000" elapsed="0.000699"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:19.818758" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:19.818922" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:19.817657" elapsed="0.001291"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.819172" elapsed="0.000286"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:19.816952" elapsed="0.002550"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.820086" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.819779" elapsed="0.000334"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:19.822120" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.821173" elapsed="0.001007"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:19.822299" elapsed="0.000066"/>
</return>
<msg time="2026-06-06T03:31:19.822665" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:19.820412" elapsed="0.002312"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:19.823076" elapsed="0.000647"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:19.819618" elapsed="0.004205"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:19.816772" elapsed="0.007130"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:19.823999" elapsed="0.000062"/>
</return>
<msg time="2026-06-06T03:31:19.824283" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:19.815561" elapsed="0.008747"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.815253" elapsed="0.009088"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.824528" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.824369" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.815228" elapsed="0.009376"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.825392" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:19.824772" elapsed="0.000649"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.825470" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:19.811456" elapsed="0.014137"/>
</kw>
<msg time="2026-06-06T03:31:19.825666" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:19.798652" elapsed="0.027066"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.838323" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.850828" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.863247" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.863627" elapsed="0.000045"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.863847" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.864270" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.864110" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:19.864090" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.864501" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.864690" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.864864" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:19.864050" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.863931" elapsed="0.001014"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.865099" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.865177" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:19.865334" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:19.794351" elapsed="0.071011"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.892211" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.891803" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.893059" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:19.892804" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:19.893231" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.892426" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.893848" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:19.893431" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.894193" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:19.894372" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:19.894047" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.894839" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;route-target-ipv4&gt;
        &lt;global-administrator&gt;192.0.2.2&lt;/global-administrator&gt;
        &lt;local-administrator&gt;123&lt;/local-administrator&gt;
    &lt;/route-target-ipv4&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.894567" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:19.895378" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.895020" elapsed="0.000420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.895946" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.895621" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.895466" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.894997" elapsed="0.001036"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.896679" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:19.896188" elapsed="0.000525"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.896767" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:19.891052" elapsed="0.005852"/>
</kw>
<msg time="2026-06-06T03:31:19.896964" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:19.876631" elapsed="0.020382"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.909633" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.924520" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.936893" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.937106" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.937291" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.937707" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.937537" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:19.937521" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.937939" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.938109" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.938278" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:19.937486" elapsed="0.000844"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.937374" elapsed="0.001038"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.938568" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.938659" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:19.938803" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:19.875733" elapsed="0.063101"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:19.940228" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:19.939940" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:19.940404" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:19.939544" elapsed="0.000884"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.940777" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.940498" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.941340" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:19.941047" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.940860" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.940479" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.944128" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:19.941576" elapsed="0.002586"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:19.944229" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:19.944410" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:19.939172" elapsed="0.005264"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.946141" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.945857" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.946587" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;route-target-ipv4&gt;
        &lt;global-administrator&gt;192.0.2.2&lt;/global-administrator&gt;
        &lt;local-administrator&gt;123&lt;/local-administrator&gt;
    &lt;/route-target-ipv4&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.946348" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.947060" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.946816" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.947511" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.947270" elapsed="0.000284"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:19.948388" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:19.948187" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:19.948782" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:19.948587" elapsed="0.000221"/>
</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-06-06T03:31:19.948964" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.949676" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.949409" elapsed="0.000313"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:19.949764" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:19.949921" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:19.947774" elapsed="0.002171"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:19.964681" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '697', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;route-target-ipv4&gt;
        &lt;global-administrator&gt;192.0.2.2&lt;/global-administrator&gt;
        &lt;local-administrator&gt;123&lt;/local-administrator&gt;
    &lt;/route-target-ipv4&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt; 
 </msg>
<msg time="2026-06-06T03:31:19.964772" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes/route-target-constrain-route=flow1,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:19.964923" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:19.952201" elapsed="0.012757"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.950024" elapsed="0.014999"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.965282" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.965061" elapsed="0.000314"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.950003" elapsed="0.015402"/>
</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-06-06T03:31:19.970264" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.966888" elapsed="0.003436"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.966552" elapsed="0.003822"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.966525" elapsed="0.003884"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.974255" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:19.970820" elapsed="0.003499"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.970486" elapsed="0.003882"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.970464" elapsed="0.003938"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.975252" 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-06-06T03:31:19.974679" elapsed="0.000611"/>
</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-06-06T03:31:19.975753" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.975390" elapsed="0.000444"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.976527" 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-06-06T03:31:19.976103" elapsed="0.000461"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.975868" elapsed="0.000745"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.975364" elapsed="0.001298"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.977407" 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-06-06T03:31:19.976897" elapsed="0.000547"/>
</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-06-06T03:31:19.977900" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.977541" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.978673" 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-06-06T03:31:19.978242" elapsed="0.000469"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.978014" elapsed="0.000795"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.977516" elapsed="0.001327"/>
</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-06-06T03:31:19.979065" elapsed="0.000532"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:19.980251" 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-06-06T03:31:19.979856" elapsed="0.000421"/>
</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-06-06T03:31:19.980438" elapsed="0.002320"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:31:19.965942" elapsed="0.016880"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:19.983003" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:19.982896" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.982877" elapsed="0.000213"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:19.983266" elapsed="0.000026"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:19.983341" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:19.985626" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:31:19.944849" elapsed="0.040818"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.985740" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:19.985894" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:19.783305" elapsed="0.202614"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:19.986264" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:19.986024" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:19.986007" elapsed="0.000351"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:19.986391" elapsed="0.000026"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:19.778742" elapsed="0.207773"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:19.989940" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:19.987484" elapsed="0.002486"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:19.990148" elapsed="0.002145"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:19.992345" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:19.987178" elapsed="0.005291"/>
</kw>
<msg time="2026-06-06T03:31:19.992545" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:19.986707" elapsed="0.005862"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.993439" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:31:19.993514" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:19.993170" elapsed="0.000367"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:19.993963" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:31:19.994037" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:19.993709" elapsed="0.000351"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:19.994218" elapsed="0.000304"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:19.994876" level="INFO">${sum_1} = 2059</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:19.994698" elapsed="0.000203"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:19.995326" level="INFO">${sum_2} = 2059</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:19.995101" elapsed="0.000252"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:19.995514" elapsed="0.000332"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:19.992802" elapsed="0.003105"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:19.996062" elapsed="0.001949"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.044021" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:20.043619" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.044859" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.044578" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:20.045033" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:20.044229" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.045618" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:20.045231" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.045974" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:20.046140" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:20.045830" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.046578" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.046329" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.047760" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.047424" elapsed="0.000381"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.048244" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.047972" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.049089" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.048669" elapsed="0.000446"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:20.050241" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.049761" elapsed="0.000560"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:20.050462" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:31:20.050710" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:20.049317" elapsed="0.001420"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.050897" elapsed="0.000506"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:20.048504" elapsed="0.002944"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.052148" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.051727" elapsed="0.000448"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:20.053469" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.052809" elapsed="0.000742"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:20.053770" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:20.053995" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:20.052367" elapsed="0.001654"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.054180" elapsed="0.000398"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:20.051566" elapsed="0.003054"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:20.048325" elapsed="0.006347"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:20.054718" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:20.054876" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:20.047048" elapsed="0.007853"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.046720" elapsed="0.008214"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.055114" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.054960" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.046695" elapsed="0.008495"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.055981" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:20.055372" elapsed="0.000639"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:20.056060" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:20.042975" elapsed="0.013211"/>
</kw>
<msg time="2026-06-06T03:31:20.056242" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:20.030298" elapsed="0.025995"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.069082" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.081542" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.093922" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.094124" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.094305" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.094691" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.094528" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:20.094513" elapsed="0.000291"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.094956" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.095132" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.095351" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:20.094483" elapsed="0.000927"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.094381" elapsed="0.001055"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.095589" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.095681" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:20.095806" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:20.025981" elapsed="0.069851"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.096949" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.096696" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:20.109553" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:20.109621" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:20.109776" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:20.099121" elapsed="0.010691"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.097062" elapsed="0.012806"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.110125" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.109906" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.097043" elapsed="0.013198"/>
</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-06-06T03:31:20.117097" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.111728" elapsed="0.005467"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.111389" elapsed="0.005888"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.111361" elapsed="0.005973"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.121566" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.117999" elapsed="0.003614"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.117460" elapsed="0.004201"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.117422" elapsed="0.004265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.122251" 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-06-06T03:31:20.121872" elapsed="0.000406"/>
</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-06-06T03:31:20.122741" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.122479" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.123315" 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-06-06T03:31:20.122994" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.122824" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.122330" elapsed="0.001071"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.124018" 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-06-06T03:31:20.123604" elapsed="0.000442"/>
</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-06-06T03:31:20.124359" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.124117" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.124922" 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-06-06T03:31:20.124608" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.124441" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.124098" elapsed="0.000907"/>
</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-06-06T03:31:20.125160" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:20.125980" 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-06-06T03:31:20.125696" elapsed="0.000310"/>
</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-06-06T03:31:20.126167" elapsed="0.002359"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:20.110760" elapsed="0.017831"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:20.128637" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:31:20.130963" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:20.096100" elapsed="0.034890"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:20.131045" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:19.999514" elapsed="0.131657"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:19.998872" elapsed="0.132356"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:19.998296" elapsed="0.133024"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:20.134490" level="INFO">${update} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.132264" elapsed="0.002256"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:20.134728" elapsed="0.002129"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:20.136909" elapsed="0.000029"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:20.131989" elapsed="0.005045"/>
</kw>
<msg time="2026-06-06T03:31:20.137111" level="INFO">${update} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:20.131495" elapsed="0.005641"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.138004" level="INFO">Length is 112.</msg>
<msg time="2026-06-06T03:31:20.138080" level="INFO">${len_1} = 112</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:20.137738" elapsed="0.000367"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.138523" level="INFO">Length is 112.</msg>
<msg time="2026-06-06T03:31:20.138600" level="INFO">${len_2} = 112</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:20.138268" elapsed="0.000357"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:20.138800" elapsed="0.000309"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:20.139485" level="INFO">${sum_1} = 1612</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:20.139302" elapsed="0.000209"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:20.139859" level="INFO">${sum_2} = 1612</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:20.139687" elapsed="0.000198"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:20.140041" elapsed="0.000365"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:20.137353" elapsed="0.003137"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.188388" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:20.187995" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.189233" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.188955" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:20.189408" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:20.188594" elapsed="0.000838"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.190007" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:20.189604" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.190341" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:20.190507" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:20.190199" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.190962" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.190716" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.192059" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.191802" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.192540" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.192267" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.193509" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.192958" elapsed="0.000578"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:20.194719" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.194250" elapsed="0.000511"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:20.194882" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:20.195111" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:20.193753" elapsed="0.001384"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.195317" elapsed="0.000525"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:20.192817" elapsed="0.003067"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.196668" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.196136" elapsed="0.000559"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:20.198000" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.197360" elapsed="0.000682"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:20.198158" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:20.198378" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:20.196886" elapsed="0.001518"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.198563" elapsed="0.000502"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:20.196000" elapsed="0.003107"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:20.192622" elapsed="0.006521"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:20.199186" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:20.199412" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:20.191425" elapsed="0.008013"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.191085" elapsed="0.008386"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.199668" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.199497" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.191061" elapsed="0.008686"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.200481" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:20.199897" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:20.200560" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:20.187323" elapsed="0.013377"/>
</kw>
<msg time="2026-06-06T03:31:20.200757" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:20.174529" elapsed="0.026290"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.213406" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.225859" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.238416" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.238620" elapsed="0.000034"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.238818" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.239189" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.239039" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:20.239024" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.239444" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.239616" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.239803" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:20.238995" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.238893" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.240034" elapsed="0.000053"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.240146" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:20.240269" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:20.169992" elapsed="0.070304"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.241436" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.241185" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:20.248378" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:20.248519" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '430'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-route-target-constrain:route-target-constrain-subsequent-address-family']/bgp-route-target-constrain:route-target-constrain-routes",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:20.248678" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:31:20.248731" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.243669" elapsed="0.005456">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:20.241549" elapsed="0.007657">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.249405" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.249243" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:20.241530" elapsed="0.007962">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:20.253170" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.250546" elapsed="0.002661">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:20.250321" elapsed="0.002951">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:20.250303" elapsed="0.003002">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.255951" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.253608" elapsed="0.002375">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:20.253378" elapsed="0.002667">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:20.253360" elapsed="0.002717">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.256715" 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-06-06T03:31:20.256305" elapsed="0.000437"/>
</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-06-06T03:31:20.257066" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.256815" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.257657" 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-06-06T03:31:20.257328" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.257150" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.256796" elapsed="0.000949"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.258293" 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-06-06T03:31:20.257913" elapsed="0.000407"/>
</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-06-06T03:31:20.258653" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.258397" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.259207" 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-06-06T03:31:20.258907" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.258739" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.258378" elapsed="0.000949"/>
</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-06-06T03:31:20.259494" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:20.260327" 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-06-06T03:31:20.260037" elapsed="0.000316"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:31:20.262799" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.260513" elapsed="0.002319">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:31:20.249882" elapsed="0.013091">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:20.263036" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:20.265412" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:31:20.265443" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:31:20.240562" elapsed="0.024910">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:20.265538" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.142057" elapsed="0.123669">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:20.141444" elapsed="0.124349"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:20.140827" elapsed="0.125029"/>
</kw>
<arg>rt_constrain_type_1</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:19.773229" elapsed="0.492680"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:19.678249" elapsed="0.587775"/>
</test>
<test id="s1-s18-t9" name="Play_To_Odl_rt_constrain_type_1" line="89">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:20.269543" elapsed="0.000230"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:20.269168" elapsed="0.000662"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.270842" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:20.270731" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.270711" elapsed="0.000198"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.275931" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:20.275825" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.275807" elapsed="0.000192"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.277010" 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-06-06T03:31:20.276608" elapsed="0.000430"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.277507" 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-06-06T03:31:20.277205" elapsed="0.000328"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:20.277578" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:20.277749" 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-06-06T03:31:20.276226" elapsed="0.001549"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:20.283560" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:20.283275" elapsed="0.000331"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.283254" elapsed="0.000375"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:20.284834" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:20.284725" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.284706" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:20.285363" 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-06-06T03:31:20.285054" elapsed="0.000336"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:20.285794" level="INFO">${current_connection_index} = 7</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-06-06T03:31:20.285554" elapsed="0.000266"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:20.319385" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:20.286329" elapsed="0.033163"/>
</kw>
<msg time="2026-06-06T03:31:20.319684" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:20.319732" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:20.285987" elapsed="0.033780"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:20.355711" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "1 "[K"
[?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-06-06T03:31:20.320449" elapsed="0.035608"/>
</kw>
<msg time="2026-06-06T03:31:20.356472" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:20.356581" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</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-06-06T03:31:20.319947" elapsed="0.036773"/>
</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-06-06T03:31:20.357562" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.356937" elapsed="0.000798"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.356877" elapsed="0.000917"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.358960" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "1 "[K"
[?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-06-06T03:31:20.358137" elapsed="0.000986"/>
</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-06-06T03:31:20.359881" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.359278" elapsed="0.000729"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.359236" elapsed="0.000824"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:20.360138" elapsed="0.000069"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:20.362941" elapsed="0.000194"/>
</kw>
<msg time="2026-06-06T03:31:20.363274" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:20.361781" elapsed="0.001667"/>
</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="NOT RUN" start="2026-06-06T03:31:20.363795" elapsed="0.000079"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.364147" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:20.361106" elapsed="0.003231"/>
</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-06-06T03:31:20.360506" elapsed="0.003901"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:20.284400" elapsed="0.080127"/>
</kw>
<msg time="2026-06-06T03:31:20.364625" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:20.364691" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:20.283803" elapsed="0.080926"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:20.364921" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:20.364810" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.364789" elapsed="0.000220"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.365425" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.365820" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.365897" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:20.282929" elapsed="0.083083"/>
</kw>
<msg time="2026-06-06T03:31:20.366109" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:20.366155" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:20.278156" elapsed="0.088035"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.366535" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.366274" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.366255" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:20.278008" elapsed="0.088664"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:20.277833" elapsed="0.088877"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:20.275451" elapsed="0.091319"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:20.270425" elapsed="0.096406"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:20.269986" elapsed="0.096891"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:20.266855" elapsed="0.100079"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.368114" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.367614" elapsed="0.000530"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.368790" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.368316" elapsed="0.000503"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.369380" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.368990" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.369798" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/announce_rt_constrain_type_1.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/announce_rt_constrain_type_1.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:20.370006" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:20.369573" elapsed="0.000461"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.370390" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/withdraw_rt_constrain_type_1.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/withdraw_rt_constrain_type_1.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:20.370516" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:20.370196" elapsed="0.000346"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:20.370716" elapsed="0.002817"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:20.373721" elapsed="0.002030"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.428423" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:20.428035" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.429239" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.428986" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:20.429414" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:20.428625" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.430022" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:20.429613" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.430360" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:20.430514" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:20.430216" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.430966" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.430720" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.432051" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.431750" elapsed="0.000347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.432528" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.432260" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.433345" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.432944" elapsed="0.000428"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:20.434617" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.434037" elapsed="0.000704"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:20.434822" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:20.435116" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:20.433564" elapsed="0.001579"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.435367" elapsed="0.000403"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:20.432804" elapsed="0.003010"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.438165" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:20.436150" elapsed="0.002043"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:20.439450" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.438886" elapsed="0.000666"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:20.439631" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:31:20.439942" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:20.438401" elapsed="0.001567"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:20.440130" elapsed="0.000371"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:20.436007" elapsed="0.004538"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:20.432605" elapsed="0.007977"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:20.440627" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:31:20.440803" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:20.431406" elapsed="0.009424"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.431086" elapsed="0.009776"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.441044" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.440888" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.431064" elapsed="0.010058"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.441928" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:20.441270" elapsed="0.000688"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:20.442008" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:20.427397" elapsed="0.014734"/>
</kw>
<msg time="2026-06-06T03:31:20.442187" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:20.414625" elapsed="0.027612"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.454882" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.467506" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.480003" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.480207" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.480439" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.480837" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.480686" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:20.480669" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.481059" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.481232" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.481400" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:20.480623" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.480518" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.481630" elapsed="0.000035"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.481721" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:20.481847" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:20.410339" elapsed="0.071535"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.483191" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.482913" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:20.483372" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:20.482535" elapsed="0.000862"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.483742" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.483470" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.484304" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:20.484009" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.483826" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.483451" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.486952" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:20.484545" elapsed="0.002435"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:20.487032" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:20.487186" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:20.482200" elapsed="0.005011"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:20.488483" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.488244" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:20.488654" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:20.487900" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:20.488889" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:20.488752" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:20.488733" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.489125" elapsed="0.000055"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.489345" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.489412" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:20.491545" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:20.487551" elapsed="0.004021"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.492999" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.492744" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:20.493446" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:20.493204" elapsed="0.000285"/>
</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-06-06T03:31:20.502265" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:20.502401" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:20.502513" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</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="FAIL" start="2026-06-06T03:31:20.495680" elapsed="0.007227">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:20.493556" elapsed="0.009437">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:20.503190" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.503028" elapsed="0.000234"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:20.493536" elapsed="0.009749">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:20.503705" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.503840" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:20.503803" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:20.503785" elapsed="0.000120"/>
</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-06-06T03:31:20.504055" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.504124" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:20.491901" elapsed="0.012329">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.504343" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.387486" elapsed="0.116957">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:20.504743" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:20.504540" elapsed="0.000277"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:20.504522" elapsed="0.000319"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:20.504874" elapsed="0.000015"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:20.380812" elapsed="0.124160">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.563872" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.563417" elapsed="0.000494"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.564722" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.564442" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.564895" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.564092" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.565485" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:22.565095" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.565847" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:22.566115" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:22.565702" elapsed="0.000441"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.566560" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.566309" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.567687" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.567347" elapsed="0.000389"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.568205" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.567932" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.569028" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.568604" elapsed="0.000450"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:22.570282" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.569723" elapsed="0.000667"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:22.570471" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:22.570846" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:22.569247" elapsed="0.001626"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.571037" elapsed="0.000392"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:22.568463" elapsed="0.003009"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.572338" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.571739" elapsed="0.000626"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:22.573591" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.573042" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:22.573794" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:22.574092" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:22.572560" elapsed="0.001559"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.574280" elapsed="0.000390"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:22.571586" elapsed="0.003128"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:22.568287" elapsed="0.006463"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:22.574795" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:22.574955" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:22.567015" elapsed="0.007966"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.566705" elapsed="0.008308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.575195" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.575039" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.566681" elapsed="0.008593"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.576041" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:22.575424" elapsed="0.000646"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.576122" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:22.562794" elapsed="0.013452"/>
</kw>
<msg time="2026-06-06T03:31:22.576302" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.550042" elapsed="0.026308"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.588906" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.601350" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.613699" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.613982" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.614170" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.614561" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.614410" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:22.614393" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.614808" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.614981" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.615152" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:22.614361" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.614249" elapsed="0.000983"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.615390" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.615467" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:22.615604" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:22.545567" elapsed="0.070066"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.617017" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.616750" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.617183" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.616365" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.617541" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.617281" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.618122" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.617826" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.617625" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.617262" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.620790" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:22.618369" elapsed="0.002450"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:22.620872" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:22.621028" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:22.616019" elapsed="0.005035"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.622300" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.622068" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.622458" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.621720" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:22.622735" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:22.622557" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.622538" elapsed="0.000325"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.623017" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.623196" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.623263" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:22.625239" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:22.621371" elapsed="0.003895"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.626696" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.626425" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.627148" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.626903" elapsed="0.000289"/>
</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-06-06T03:31:22.636545" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:22.637056" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '346'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:31:22.637197" 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-06-06T03:31:22.629369" elapsed="0.007864"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.627260" elapsed="0.010034"/>
</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-06-06T03:31:22.637555" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.637332" elapsed="0.000334"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.627241" elapsed="0.010458"/>
</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-06-06T03:31:22.642734" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.639116" elapsed="0.003689"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.638804" elapsed="0.004050"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.638778" elapsed="0.004114"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.646552" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.643291" elapsed="0.003326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.642972" elapsed="0.003713"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.642948" elapsed="0.003774"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.647493" 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-06-06T03:31:22.646958" elapsed="0.000573"/>
</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-06-06T03:31:22.648063" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.647631" elapsed="0.000519"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.648711" 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-06-06T03:31:22.648390" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.648185" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.647605" elapsed="0.001191"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.649326" 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-06-06T03:31:22.648963" elapsed="0.000391"/>
</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-06-06T03:31:22.649755" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.649490" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.650307" 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-06-06T03:31:22.650008" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.649840" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.649470" elapsed="0.000922"/>
</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-06-06T03:31:22.650548" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:22.651375" 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-06-06T03:31:22.651089" elapsed="0.000312"/>
</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-06-06T03:31:22.651564" elapsed="0.002348"/>
</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-06-06T03:31:22.638197" elapsed="0.015780"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.654156" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:22.654049" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.654030" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:22.657163" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:22.654374" elapsed="0.002820"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:22.657247" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:22.657404" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:22.625580" elapsed="0.031851"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.657495" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:31:22.657665" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:22.522905" elapsed="0.134788"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.686323" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.685856" elapsed="0.000496"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.687156" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.686891" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.687450" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.686522" elapsed="0.000954"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.688131" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:22.687662" elapsed="0.000496"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.688486" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:22.688692" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:22.688326" elapsed="0.000394"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.689154" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-ipv4": {
                    "global-administrator": "192.0.2.2",
                    "local-administrator": 123
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.688884" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:22.689690" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.689273" elapsed="0.000479"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.690559" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.689928" elapsed="0.000659"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.689777" elapsed="0.000846"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.689253" elapsed="0.001407"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.691299" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:22.690814" elapsed="0.000518"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.691381" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:22.685218" elapsed="0.006290"/>
</kw>
<msg time="2026-06-06T03:31:22.691566" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.672407" elapsed="0.019208"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.704211" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.716595" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.728994" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.729194" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.729374" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.729799" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.729631" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:22.729616" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.730026" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.730200" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.730372" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:22.729586" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.729451" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.730603" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.730695" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:22.730831" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:22.669564" elapsed="0.061294"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.731039" elapsed="0.002351"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:22.734542" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.734147" elapsed="0.000424"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:22.735132" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.734750" elapsed="0.000410"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:22.735321" elapsed="0.000337"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:22.733731" elapsed="0.001988"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.733472" elapsed="0.002282"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.735961" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.735779" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.733453" elapsed="0.002586"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:22.658842" elapsed="0.077245"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:22.658019" elapsed="0.078145"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.657778" elapsed="0.078432"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.657760" elapsed="0.078474"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.736267" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:22.515663" elapsed="0.220731"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:20.375934" elapsed="2.360521"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.786074" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.785694" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.786832" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.786609" elapsed="0.000287">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.786989" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.786270" elapsed="0.000743"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.787563" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:22.787180" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.787927" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:22.788053" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:22.787770" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.788483" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.788240" elapsed="0.000288"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.789720" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.789229" elapsed="0.000538"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.790212" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.789936" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.791017" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.790600" elapsed="0.000444"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:22.792288" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.791704" elapsed="0.000690"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:22.792472" elapsed="0.000194"/>
</return>
<msg time="2026-06-06T03:31:22.792929" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:22.791236" elapsed="0.001728"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.793124" elapsed="0.000537"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:22.790461" elapsed="0.003242"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.794352" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.793955" elapsed="0.000423"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:22.795576" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.795040" elapsed="0.000653"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:22.795771" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:22.796080" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:22.794566" elapsed="0.001539"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:22.796263" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:22.793818" elapsed="0.002871"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:22.790286" elapsed="0.006439"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:22.796768" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:22.796962" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:22.788902" elapsed="0.008086"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.788595" elapsed="0.008427"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.797202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.797047" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.788575" elapsed="0.008704"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.798029" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:22.797424" elapsed="0.000634"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.798111" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:22.785064" elapsed="0.013180"/>
</kw>
<msg time="2026-06-06T03:31:22.798302" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.772295" elapsed="0.026060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.810917" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.823292" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.835628" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.835841" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.836042" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.836407" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.836258" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:22.836244" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.836631" elapsed="0.000035"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.836818" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.836986" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:22.836216" elapsed="0.000823"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.836116" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.837246" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.837322" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:22.837442" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:22.768027" elapsed="0.069441"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.838737" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.838482" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.838897" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.838137" elapsed="0.000784"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.839241" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.838993" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.839808" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.839502" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.839326" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.838974" elapsed="0.000962"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.842480" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:22.840100" elapsed="0.002408"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:22.842560" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:22.842730" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:22.837811" elapsed="0.004944"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.844000" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.843745" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.844157" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.843389" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:22.844386" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:22.844251" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.844233" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.844619" elapsed="0.000036"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.844811" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.844877" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:22.846790" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:22.843059" elapsed="0.003757"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.848227" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.847978" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.848694" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.848437" elapsed="0.000300"/>
</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-06-06T03:31:22.856399" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:22.856529" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '346'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:31:22.856626" 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-06-06T03:31:22.850948" elapsed="0.005726"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.848839" elapsed="0.007879"/>
</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-06-06T03:31:22.856903" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.856745" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.848819" elapsed="0.008170"/>
</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-06-06T03:31:22.860792" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.858009" elapsed="0.002854"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.857784" elapsed="0.003129"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.857765" elapsed="0.003184"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.864592" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.861355" elapsed="0.003322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.861028" elapsed="0.003699"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.861004" elapsed="0.003759"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.865526" 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-06-06T03:31:22.865000" elapsed="0.000565"/>
</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-06-06T03:31:22.866035" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.865688" elapsed="0.000428"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.866836" 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-06-06T03:31:22.866386" elapsed="0.000488"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.866151" elapsed="0.000774"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.865659" elapsed="0.001296"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.867722" 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-06-06T03:31:22.867190" elapsed="0.000571"/>
</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-06-06T03:31:22.868221" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.867860" elapsed="0.000441"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.868999" 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-06-06T03:31:22.868566" elapsed="0.000469"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.868334" elapsed="0.000750"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.867834" elapsed="0.001280"/>
</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-06-06T03:31:22.869333" elapsed="0.000512"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:22.870464" 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-06-06T03:31:22.870081" elapsed="0.000419"/>
</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-06-06T03:31:22.870742" elapsed="0.002760"/>
</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-06-06T03:31:22.857347" elapsed="0.016253"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.873796" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:22.873687" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.873666" elapsed="0.000197"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:22.876776" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:22.874013" elapsed="0.002793"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:22.876859" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:22.877013" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:22.847124" elapsed="0.029915"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.877102" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:31:22.877249" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:22.745312" elapsed="0.131963"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.905719" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.905247" elapsed="0.000501"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.906516" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:22.906257" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:22.906829" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:22.905916" elapsed="0.000939"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.907468" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:22.907026" elapsed="0.000469"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:22.907837" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:22.908002" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:22.907677" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.908458" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-ipv4": {
                    "global-administrator": "192.0.2.2",
                    "local-administrator": 123
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:22.908192" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:22.908992" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.908574" elapsed="0.000480"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.909865" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:22.909268" elapsed="0.000625"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.909111" elapsed="0.000819"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.908555" elapsed="0.001397"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:22.910588" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:22.910105" elapsed="0.000512"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.910691" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:22.904614" elapsed="0.006203"/>
</kw>
<msg time="2026-06-06T03:31:22.910876" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.891751" elapsed="0.019173"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.923341" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.935721" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.948122" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.948323" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.948502" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.948891" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.948742" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:22.948727" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.949116" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.949288" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.949463" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:22.948697" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.948579" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.949707" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:22.949817" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:22.949956" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:22.889103" elapsed="0.060880"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.950164" elapsed="0.003325"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:22.954674" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.954247" elapsed="0.000457"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:22.955271" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:22.954879" elapsed="0.000421"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:22.955467" elapsed="0.000351"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:22.953831" elapsed="0.002049"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.953571" elapsed="0.002380"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:22.956138" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:22.955984" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.953551" elapsed="0.002665"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:22.878409" elapsed="0.077856"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:22.877601" elapsed="0.078745"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:22.877363" elapsed="0.079030"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:22.877346" elapsed="0.079071"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:22.956450" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:22.740923" elapsed="0.215652"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:22.736633" elapsed="0.220002"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.006165" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.005785" elapsed="0.000409"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.006973" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.006740" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.007136" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.006363" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.007776" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:23.007370" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.008146" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:23.008289" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:23.008000" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.008739" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.008476" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.009964" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.009477" elapsed="0.000534"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.010458" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.010179" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.011275" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.010871" elapsed="0.000431"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:23.012543" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.011994" elapsed="0.000664"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:23.012740" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:23.013034" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:23.011495" elapsed="0.001565"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.013219" elapsed="0.000380"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:23.010731" elapsed="0.002924"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.014319" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.013913" elapsed="0.000432"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:23.015546" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.015009" elapsed="0.000656"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:23.015745" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:23.016065" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:23.014538" elapsed="0.001554"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.016251" elapsed="0.000368"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:23.013775" elapsed="0.002902"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:23.010534" elapsed="0.006180"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:23.016758" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:23.016918" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:23.009151" elapsed="0.007793"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.008854" elapsed="0.008123"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.017156" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.017002" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.008834" elapsed="0.008400"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.017965" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:23.017381" elapsed="0.000613"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.018045" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:23.005145" elapsed="0.013024"/>
</kw>
<msg time="2026-06-06T03:31:23.018263" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:22.992493" elapsed="0.025819"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.030893" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.043345" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.055806" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.056027" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.056210" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.056580" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.056431" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:23.056415" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.056825" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.056998" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.057170" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:23.056387" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.056285" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.057399" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.057476" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:23.057596" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:22.988225" elapsed="0.069398"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.058891" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.058637" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.059082" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.058291" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.059432" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.059180" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.060038" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.059713" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.059514" elapsed="0.000587"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.059161" elapsed="0.000962"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.062676" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:23.060281" elapsed="0.002423"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:23.062757" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:23.062912" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:23.057963" elapsed="0.004974"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.064190" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.063945" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.064346" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.063567" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:23.064579" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:23.064442" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.064424" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.064834" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.065009" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.065075" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:23.066994" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:23.063239" elapsed="0.003782"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.068441" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.068190" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.068904" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.068660" elapsed="0.000288"/>
</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-06-06T03:31:23.077701" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:23.077840" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '346'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:31:23.077950" 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-06-06T03:31:23.071265" elapsed="0.006712"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.069020" elapsed="0.009000"/>
</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-06-06T03:31:23.078203" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.078047" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.068997" elapsed="0.009334"/>
</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-06-06T03:31:23.083195" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.079792" elapsed="0.003471"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.079457" elapsed="0.003855"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.079430" elapsed="0.003917"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.087216" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.083764" elapsed="0.003517"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.083425" elapsed="0.003904"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.083402" elapsed="0.003964"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.088192" 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-06-06T03:31:23.087603" elapsed="0.000627"/>
</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-06-06T03:31:23.088580" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.088332" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.089148" 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-06-06T03:31:23.088848" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.088679" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.088305" elapsed="0.000926"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.089773" 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-06-06T03:31:23.089395" elapsed="0.000405"/>
</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-06-06T03:31:23.090110" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.089871" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.090675" 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-06-06T03:31:23.090356" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.090190" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.089852" elapsed="0.000908"/>
</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-06-06T03:31:23.090916" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:23.091923" 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-06-06T03:31:23.091437" elapsed="0.000536"/>
</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-06-06T03:31:23.092136" elapsed="0.002571"/>
</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-06-06T03:31:23.078861" elapsed="0.015910"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.094949" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:23.094842" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.094823" elapsed="0.000192"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:23.097971" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:23.095166" elapsed="0.002834"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:23.098052" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:23.098207" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:23.067332" elapsed="0.030901"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.098296" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:31:23.098481" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:22.965553" elapsed="0.132955"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.126937" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.126476" elapsed="0.000490"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.127772" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.127476" elapsed="0.000413">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.128103" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.127135" elapsed="0.000994"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.128762" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:23.128301" elapsed="0.000489"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.129116" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:23.129253" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:23.128957" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.129726" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-ipv4": {
                    "global-administrator": "192.0.2.2",
                    "local-administrator": 123
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.129442" elapsed="0.000335"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:23.130250" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.129846" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.131015" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.130494" elapsed="0.000549"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.130341" elapsed="0.000738"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.129827" elapsed="0.001274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.131753" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:23.131253" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.131833" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:23.125857" elapsed="0.006119"/>
</kw>
<msg time="2026-06-06T03:31:23.132035" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:23.113003" elapsed="0.019082"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.144636" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.157075" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.169561" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.169776" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.169959" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.170328" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.170181" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:23.170165" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.170552" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.170740" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.170914" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:23.170136" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.170036" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.171141" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.171216" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:23.171350" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:23.110322" elapsed="0.061055"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:23.171570" elapsed="0.002390"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:23.175180" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.174772" elapsed="0.000437"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:23.175779" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.175367" elapsed="0.000474"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:23.176036" elapsed="0.000337"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:23.174283" elapsed="0.002151"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.174042" elapsed="0.002426"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.176663" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.176494" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.174023" elapsed="0.002720"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:23.099656" elapsed="0.077136"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:23.098847" elapsed="0.078020"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.098591" elapsed="0.078321"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.098573" elapsed="0.078363"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.176970" elapsed="0.000027"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:22.961177" elapsed="0.215917"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:22.956831" elapsed="0.220322"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:23.177320" elapsed="0.002986"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.229924" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.229528" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.230681" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.230455" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.230840" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.230119" elapsed="0.000745"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.231411" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:23.231030" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.231751" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:23.231882" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:23.231601" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.232342" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.232098" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.233613" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.233324" elapsed="0.000358"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.234124" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.233852" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.234929" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.234507" elapsed="0.000483"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:23.236216" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.235656" elapsed="0.000659"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:23.236397" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:23.236698" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:23.235186" elapsed="0.001539"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.236884" elapsed="0.000368"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:23.234369" elapsed="0.002926"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.237962" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.237545" elapsed="0.000443"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:23.239187" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.238630" elapsed="0.000656"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:23.239364" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:23.239670" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:23.238179" elapsed="0.001518"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:23.239855" elapsed="0.000399"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:23.237408" elapsed="0.002888"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:23.234198" elapsed="0.006136"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:23.240378" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:23.240535" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:23.232823" elapsed="0.007737"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.232455" elapsed="0.008137"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.240787" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.240617" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.232436" elapsed="0.008428"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.241575" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:23.241012" elapsed="0.000591"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.241667" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:23.228909" elapsed="0.012885"/>
</kw>
<msg time="2026-06-06T03:31:23.241849" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:23.216266" elapsed="0.025630"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.254407" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.266740" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.279199" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.279398" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.279578" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.279961" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.279813" elapsed="0.000275"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:23.279797" elapsed="0.000319"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.280265" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.280436" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.280605" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:23.279768" elapsed="0.000911"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.279665" elapsed="0.001041"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.280857" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.280932" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:23.281052" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:23.211950" elapsed="0.069129"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.282337" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.282095" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.282495" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.281748" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.282855" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.282590" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.283608" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.283109" elapsed="0.000525"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.282937" elapsed="0.000751"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.282571" elapsed="0.001139"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.286086" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:23.283868" elapsed="0.002245"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:23.286166" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:23.286320" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:23.281404" elapsed="0.004941"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.287529" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:23.287343" elapsed="0.000274"/>
</kw>
<msg time="2026-06-06T03:31:23.287722" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.286998" elapsed="0.000749"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.287953" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:23.287818" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.287799" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.288349" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:23.288474" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:23.288183" elapsed="0.000316"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:23.288905" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.288673" elapsed="0.000258"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:23.288978" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:23.289131" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:23.286666" elapsed="0.002489"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.290543" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.290293" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.291002" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.290760" elapsed="0.000285"/>
</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-06-06T03:31:23.298471" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:23.299298" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '522'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}}]} 
 </msg>
<msg time="2026-06-06T03:31:23.299420" 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-06-06T03:31:23.293232" elapsed="0.006213"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.291111" elapsed="0.008377"/>
</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-06-06T03:31:23.299686" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.299514" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.291092" elapsed="0.008679"/>
</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-06-06T03:31:23.304619" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.301038" elapsed="0.003681"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.300723" elapsed="0.004045"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.300695" elapsed="0.004108"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.308628" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.305196" elapsed="0.003517"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.304881" elapsed="0.003881"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.304857" elapsed="0.003938"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.309550" 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-06-06T03:31:23.309029" elapsed="0.000558"/>
</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-06-06T03:31:23.310098" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.309751" elapsed="0.000428"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.310890" 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-06-06T03:31:23.310446" elapsed="0.000480"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.310213" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.309722" elapsed="0.001283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.311763" 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-06-06T03:31:23.311235" elapsed="0.000565"/>
</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-06-06T03:31:23.312278" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.311899" elapsed="0.000459"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.312870" 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-06-06T03:31:23.312549" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.312382" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.311873" elapsed="0.001080"/>
</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-06-06T03:31:23.313107" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:23.313918" 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-06-06T03:31:23.313626" elapsed="0.000318"/>
</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-06-06T03:31:23.314102" elapsed="0.002311"/>
</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-06-06T03:31:23.300168" elapsed="0.016308"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.316667" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:23.316547" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.316528" elapsed="0.000209"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:23.319686" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<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="PASS" start="2026-06-06T03:31:23.316885" elapsed="0.002831"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:23.319769" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:23.319924" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:23.289465" elapsed="0.030485"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.320039" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:23.320191" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:23.189152" elapsed="0.131065"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.348418" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.347931" elapsed="0.000515"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.349237" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.348979" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:23.349558" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:23.348613" elapsed="0.000971"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.350215" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:23.349771" elapsed="0.000472"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:23.350571" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:23.350718" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:23.350414" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.351175" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:23.350908" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:23.351700" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.351289" elapsed="0.000472"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.352453" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:23.351936" elapsed="0.000544"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:23.351786" elapsed="0.000729"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:23.351270" elapsed="0.001266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.353175" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:23.352704" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:23.353253" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:23.347295" elapsed="0.006082"/>
</kw>
<msg time="2026-06-06T03:31:23.353431" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:23.334547" elapsed="0.018932"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.365943" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.378289" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.390779" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.391012" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.391195" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.391569" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.391421" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:23.391406" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.391813" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.391987" elapsed="0.000042"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.392187" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:23.391378" elapsed="0.000863"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.391270" elapsed="0.000996"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.392416" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.392493" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:23.392610" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:23.331910" elapsed="0.060728"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:23.392837" elapsed="0.002332"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:23.396221" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.395921" elapsed="0.000328"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:23.396984" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:23.396409" elapsed="0.000603"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:31:23.397490" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-constrain-route": [
     {
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "origin-as": 64511,
      "path-id": 0,
      "route-key": "AQLAAAICAHs=",
      "route-target-ipv4": {
       "global-administrator": "192.0.2.2",
       "local-administrator": 123
      }
     }
    ]
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:31:23.397697" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.397173" elapsed="0.000594">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.395492" elapsed="0.002453">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:23.395251" elapsed="0.002776">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:23.398219" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:23.398063" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:23.395231" elapsed="0.003067">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.321411" elapsed="0.077008">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.320598" elapsed="0.077965">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:23.320301" elapsed="0.078368">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:23.320283" elapsed="0.078425">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:23.398757" elapsed="0.000017"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:23.184815" elapsed="0.214060">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,30 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AQLAAAICAHs=",
+      "route-target-ipv4": {
+       "global-administrator": "192.0.2.2",
+       "local-administrator": 123
+      }
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.455209" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.454704" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.456141" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:25.455870" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:25.456323" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.455447" elapsed="0.000918"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.457135" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:25.456659" elapsed="0.000514"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.457589" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.457798" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.457409" elapsed="0.000418"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.458290" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.457999" elapsed="0.000344"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.459559" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.459220" elapsed="0.000389"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.460104" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.459816" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.460991" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.460542" elapsed="0.000476"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:25.462288" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.461716" elapsed="0.000680"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:25.462485" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:25.462827" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:25.461221" elapsed="0.001635"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.463068" elapsed="0.000460"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:25.460375" elapsed="0.003198"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.464282" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.463857" elapsed="0.000452"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:25.465634" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.465070" elapsed="0.000688"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:25.465843" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:25.466142" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:25.464570" elapsed="0.001600"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.466388" elapsed="0.000410"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:25.463712" elapsed="0.003130"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:25.460189" elapsed="0.006689"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:25.466923" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:25.467089" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:25.458850" elapsed="0.008332"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.458432" elapsed="0.008788"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.467429" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.467250" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.458404" elapsed="0.009110"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.470140" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:25.467686" elapsed="0.002486"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.470226" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:25.453939" elapsed="0.016419"/>
</kw>
<msg time="2026-06-06T03:31:25.470418" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.440760" elapsed="0.029712"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.483832" elapsed="0.000052"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.496847" elapsed="0.000061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.509745" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.509988" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.510186" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.510614" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.510457" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:25.510437" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.510866" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.511041" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.511213" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:25.510396" elapsed="0.000871"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.510270" elapsed="0.001025"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.511448" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.511604" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:31:25.511776" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:25.435758" elapsed="0.076047"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.513273" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:25.512977" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:25.513451" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.512548" elapsed="0.000929"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.513842" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.513549" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.514414" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.514114" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.513925" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.513530" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.516930" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:25.514672" elapsed="0.002285"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:25.517010" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:25.517170" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:25.512154" elapsed="0.005042"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.518497" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.518208" elapsed="0.000347"/>
</kw>
<msg time="2026-06-06T03:31:25.518665" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.517862" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.518904" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:25.518765" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.518744" elapsed="0.000228"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.519294" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.519458" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.519124" elapsed="0.000360"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:25.519909" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.519663" elapsed="0.000272"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:25.519984" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:25.520140" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:25.517508" elapsed="0.002657"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.521607" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.521354" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.522072" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.521829" elapsed="0.000330"/>
</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-06-06T03:31:25.531485" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:25.531727" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '177'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:31:25.531918" 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-06-06T03:31:25.524570" elapsed="0.007389"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.522228" elapsed="0.009803"/>
</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-06-06T03:31:25.532345" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.532075" elapsed="0.000371"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.522209" elapsed="0.010323"/>
</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-06-06T03:31:25.537604" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.534119" elapsed="0.003581"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.533778" elapsed="0.003972"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.533750" elapsed="0.004037"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.541515" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.538191" elapsed="0.003389"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.537868" elapsed="0.003761"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.537844" elapsed="0.003842"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.542495" 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-06-06T03:31:25.541945" elapsed="0.000589"/>
</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-06-06T03:31:25.543003" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.542634" elapsed="0.000452"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.543803" 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-06-06T03:31:25.543358" elapsed="0.000483"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.543120" elapsed="0.000772"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.542608" elapsed="0.001313"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.544703" 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-06-06T03:31:25.544153" elapsed="0.000589"/>
</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-06-06T03:31:25.545179" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.544840" elapsed="0.000418"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.545961" 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-06-06T03:31:25.545521" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.545292" elapsed="0.000755"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.544814" elapsed="0.001262"/>
</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-06-06T03:31:25.546298" elapsed="0.000509"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:25.547453" 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-06-06T03:31:25.547046" elapsed="0.000446"/>
</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-06-06T03:31:25.547739" elapsed="0.002822"/>
</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-06-06T03:31:25.533116" elapsed="0.017511"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.550894" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:25.550715" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.550695" elapsed="0.000274"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:25.553802" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<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="PASS" start="2026-06-06T03:31:25.551123" elapsed="0.002708"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:25.553884" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:25.554052" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:25.520511" elapsed="0.033568"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.554143" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:25.554296" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:25.411997" elapsed="0.142325"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.583300" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.582798" elapsed="0.000535"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.584384" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:25.584076" elapsed="0.000480">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:25.584759" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.583727" elapsed="0.001058"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.585475" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:25.584964" elapsed="0.000540"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.585893" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.586061" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.585716" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.586525" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.586254" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:25.587089" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.586667" elapsed="0.000482"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.587854" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.587328" elapsed="0.000553"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.587176" elapsed="0.000742"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.586624" elapsed="0.001315"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.588629" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:25.588093" elapsed="0.000597"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.588797" elapsed="0.000037"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:25.582132" elapsed="0.006807"/>
</kw>
<msg time="2026-06-06T03:31:25.588994" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.569282" elapsed="0.019762"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.601921" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.614905" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.628316" elapsed="0.000042"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.628589" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.628796" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.629219" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.629065" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:25.629047" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.629454" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.629624" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.629812" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:25.629011" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.628884" elapsed="0.001009"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.630044" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.630123" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:25.630266" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:25.566503" elapsed="0.063791"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.630551" elapsed="0.002437"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:25.634125" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.633803" elapsed="0.000351"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:25.634584" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.634311" elapsed="0.000301"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:25.634790" elapsed="0.000337"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:25.633346" elapsed="0.001841"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.633074" elapsed="0.002147"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.635399" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.635247" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.633053" elapsed="0.002422"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:25.555481" elapsed="0.080043"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:25.554672" elapsed="0.080930"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.554411" elapsed="0.081253"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.554390" elapsed="0.081300"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.635727" elapsed="0.000033"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:25.407229" elapsed="0.228635"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:23.180490" elapsed="2.455438"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:25.636151" elapsed="0.003089"/>
</kw>
<arg>rt_constrain_type_1</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:20.367196" elapsed="5.272104"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:20.266356" elapsed="5.373064"/>
</test>
<test id="s1-s18-t10" name="Odl_To_Play_rt_constrain_type_2" line="93">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:25.642827" elapsed="0.000218"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:25.642537" elapsed="0.000564"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.644137" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:25.644019" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.643998" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.649372" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:25.649265" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.649247" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.650457" 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-06-06T03:31:25.650073" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.650961" 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-06-06T03:31:25.650664" elapsed="0.000323"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:25.651034" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:25.651190" 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-06-06T03:31:25.649688" elapsed="0.001526"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:25.656766" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:25.656653" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.656620" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:25.658022" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:25.657913" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.657894" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:25.658544" 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-06-06T03:31:25.658240" elapsed="0.000330"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:25.658972" level="INFO">${current_connection_index} = 7</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-06-06T03:31:25.658753" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:25.691080" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:25.659502" elapsed="0.031779"/>
</kw>
<msg time="2026-06-06T03:31:25.691505" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:25.691554" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:25.659162" elapsed="0.032429"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:25.728816" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "2 "[K"
[?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-06-06T03:31:25.692307" elapsed="0.036674"/>
</kw>
<msg time="2026-06-06T03:31:25.729180" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:25.729226" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</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-06-06T03:31:25.691867" elapsed="0.037397"/>
</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-06-06T03:31:25.729693" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.729370" elapsed="0.000382"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.729338" elapsed="0.000442"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.730276" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "d "l "_ "T "o "_ "P "l "a "y "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "2 "[K"
[?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-06-06T03:31:25.729930" elapsed="0.000424"/>
</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-06-06T03:31:25.730675" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.730427" elapsed="0.000306"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.730406" elapsed="0.000350"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:25.730794" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:25.733596" elapsed="0.000410"/>
</kw>
<msg time="2026-06-06T03:31:25.734078" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.732362" elapsed="0.001860"/>
</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="NOT RUN" start="2026-06-06T03:31:25.734511" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.734877" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:25.731707" elapsed="0.003359"/>
</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-06-06T03:31:25.731118" elapsed="0.004013"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:25.657585" elapsed="0.077645"/>
</kw>
<msg time="2026-06-06T03:31:25.735327" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:25.735373" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:25.656992" elapsed="0.078420"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:25.735693" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:31:25.735542" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.735518" elapsed="0.000268"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.736225" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.736590" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.736681" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:25.656286" elapsed="0.080507"/>
</kw>
<msg time="2026-06-06T03:31:25.736888" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:25.736932" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "O "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:25.651663" elapsed="0.085307"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.737303" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.737046" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.737028" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:25.651496" elapsed="0.085909"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:25.651318" elapsed="0.086120"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:25.648902" elapsed="0.088590"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:25.643723" elapsed="0.093829"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:25.643260" elapsed="0.094340"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:25.640307" elapsed="0.097364"/>
</kw>
<kw name="Odl_To_Play_Template" owner="BgpOperations">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.738567" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/announce_rt_constrain_type_2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/announce_rt_constrain_type_2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.738755" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.738361" elapsed="0.000421"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:25.739159" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b</msg>
<var>${announce_hex}</var>
<arg>${announce_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.738944" elapsed="0.000242"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.739541" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/withdraw_rt_constrain_type_2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/withdraw_rt_constrain_type_2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.739731" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.739350" elapsed="0.000409"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:25.740126" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b</msg>
<var>${withdraw_hex}</var>
<arg>${withdraw_hex}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.739921" elapsed="0.000232"/>
</kw>
<if>
<branch type="IF" condition="'${remove}' == 'True'">
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:25.740444" elapsed="0.002319"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.740225" elapsed="0.002574"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.740207" elapsed="0.002617"/>
</if>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.777183" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.776764" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.778109" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:25.777843" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:25.778281" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.777475" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.778894" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:25.778484" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.779234" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.779391" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.779091" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.779850" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.779581" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.780943" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.780680" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.781430" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.781156" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.782146" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.781846" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:25.783150" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.782707" elapsed="0.000471"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:25.783232" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:25.783391" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:25.782363" elapsed="0.001053"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.783578" elapsed="0.000268"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:25.781703" elapsed="0.002186"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.784439" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.784140" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:25.785426" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.785016" elapsed="0.000438"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:25.785505" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:25.785672" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:25.784691" elapsed="0.001007"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:25.785856" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:25.784002" elapsed="0.002122"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:25.781511" elapsed="0.004649"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:25.786203" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:25.786360" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:25.780309" elapsed="0.006077"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.779974" elapsed="0.006445"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.786727" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.786446" elapsed="0.000375"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.779951" elapsed="0.006894"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.787786" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:25.786998" elapsed="0.000819"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.787868" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:25.776035" elapsed="0.011960"/>
</kw>
<msg time="2026-06-06T03:31:25.788051" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.763291" elapsed="0.024809"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.800664" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.813221" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.825630" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.825848" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.826034" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.826409" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.826258" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:25.826242" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.826637" elapsed="0.000035"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.826826" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.826996" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:25.826213" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.826111" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.827226" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.827302" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:25.827425" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:25.758806" elapsed="0.068683"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.852340" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.851961" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.853131" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:25.852904" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:25.853297" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.852535" elapsed="0.000787"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.853893" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:25.853491" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.854222" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:25.854370" level="INFO">${template} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:25.854086" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.854824" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;as-4-route-target-extended-community&gt;
        &lt;as-4-specific-common&gt;
            &lt;as-number&gt;65000&lt;/as-number&gt;
            &lt;local-administrator&gt;123&lt;/local-administrator&gt;
        &lt;/as-4-specific-common&gt;
    &lt;/as-4-route-target-extended-community&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.854561" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:25.855243" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.854948" elapsed="0.000353"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.855790" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.855477" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.855327" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.854929" elapsed="0.000945"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.856467" level="INFO">${final_text} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:25.856023" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.856578" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:25.851327" elapsed="0.005398"/>
</kw>
<msg time="2026-06-06T03:31:25.856782" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.838696" elapsed="0.018133"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.869586" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.882065" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.894525" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.894753" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.894945" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.895339" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.895190" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:25.895173" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.895564" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.895752" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.895923" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:25.895139" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.895027" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.896179" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.896255" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:25.896402" level="INFO">${data} = &lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;645...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:25.837813" elapsed="0.058623"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:25.897890" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:25.897578" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:25.898060" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:25.897199" elapsed="0.000937"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.898485" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.898213" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.899082" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:25.898775" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.898569" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.898193" elapsed="0.000976"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.901629" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:25.899332" elapsed="0.002339"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:25.901726" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:25.901887" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:25.896821" elapsed="0.005092"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.903461" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.903203" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.903925" level="INFO">&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;as-4-route-target-extended-community&gt;
        &lt;as-4-specific-common&gt;
            &lt;as-number&gt;65000&lt;/as-number&gt;
            &lt;local-administrator&gt;123&lt;/local-administrator&gt;
        &lt;/as-4-specific-common&gt;
    &lt;/as-4-route-target-extended-community&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.903681" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.904414" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.904135" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.904915" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.904665" elapsed="0.000295"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:25.905794" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:25.905573" elapsed="0.000247"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:25.906158" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:25.905978" elapsed="0.000206"/>
</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-06-06T03:31:25.906366" elapsed="0.000223"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.907028" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.906775" elapsed="0.000297"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:25.907114" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:25.907270" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:25.905162" elapsed="0.002134"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:25.919959" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '780', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;?xml version="1.0"?&gt;
&lt;route-target-constrain-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp:route:target:constrain"&gt;
    &lt;route-key&gt;flow1&lt;/route-key&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;origin-as&gt;64511&lt;/origin-as&gt;
    &lt;as-4-route-target-extended-community&gt;
        &lt;as-4-specific-common&gt;
            &lt;as-number&gt;65000&lt;/as-number&gt;
            &lt;local-administrator&gt;123&lt;/local-administrator&gt;
        &lt;/as-4-specific-common&gt;
    &lt;/as-4-route-target-extended-community&gt;
    &lt;attributes&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;199.20.166.41&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
    &lt;/attributes&gt;
&lt;/route-target-constrain-route&gt; 
 </msg>
<msg time="2026-06-06T03:31:25.920063" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes/route-target-constrain-route=flow1,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:25.920160" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:25.909697" elapsed="0.010490"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.907367" elapsed="0.012867"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.920426" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.920261" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.907349" elapsed="0.013167"/>
</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-06-06T03:31:25.927346" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.921918" elapsed="0.005525"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.921390" elapsed="0.006131"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.921367" elapsed="0.006212"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.932134" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:25.928247" elapsed="0.003955"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.927742" elapsed="0.004513"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.927702" elapsed="0.004589"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.933178" 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-06-06T03:31:25.932579" elapsed="0.000640"/>
</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-06-06T03:31:25.933703" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.933322" elapsed="0.000468"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.934511" 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-06-06T03:31:25.934073" elapsed="0.000477"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.933825" elapsed="0.000776"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.933295" elapsed="0.001337"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.935432" 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-06-06T03:31:25.934898" elapsed="0.000573"/>
</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-06-06T03:31:25.935956" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.935575" elapsed="0.000466"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.936826" 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-06-06T03:31:25.936322" elapsed="0.000543"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.936078" elapsed="0.000840"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.935548" elapsed="0.001401"/>
</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-06-06T03:31:25.937178" elapsed="0.000424"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:25.938085" 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-06-06T03:31:25.937792" elapsed="0.000320"/>
</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-06-06T03:31:25.938378" elapsed="0.002483"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:31:25.920944" elapsed="0.019987"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:25.941116" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:31:25.941006" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.940986" elapsed="0.000222"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:25.941360" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:25.941427" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:25.943711" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:31:25.902241" elapsed="0.041497"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.943873" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:25.944031" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:25.747680" elapsed="0.196376"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:25.944415" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:25.944162" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:25.944144" elapsed="0.000364"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:25.944541" elapsed="0.000041"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:25.743098" elapsed="0.201598"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:25.948090" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:25.945630" elapsed="0.002490"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:25.948300" elapsed="0.002288"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:25.950667" elapsed="0.000033"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:25.945348" elapsed="0.005453"/>
</kw>
<msg time="2026-06-06T03:31:25.950878" level="INFO">${update} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:25.944875" elapsed="0.006029"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.951777" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:31:25.951854" level="INFO">${len_1} = 124</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:25.951496" elapsed="0.000383"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:25.952294" level="INFO">Length is 124.</msg>
<msg time="2026-06-06T03:31:25.952370" level="INFO">${len_2} = 124</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:25.952039" elapsed="0.000356"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:25.952555" elapsed="0.000343"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:25.953238" level="INFO">${sum_1} = 2349</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:25.953060" elapsed="0.000204"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:25.953593" level="INFO">${sum_2} = 2349</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:25.953421" elapsed="0.000198"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:25.953796" elapsed="0.000308"/>
</kw>
<arg>${update}</arg>
<arg>${announce_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:25.951121" elapsed="0.003043"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:25.954320" elapsed="0.002192"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.002697" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:26.002293" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.003509" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.003249" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:26.003773" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:26.002905" elapsed="0.000893"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.004367" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:26.003973" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.004750" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:26.004903" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:26.004562" elapsed="0.000368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.005341" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.005094" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.006608" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.006295" elapsed="0.000383"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.007123" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.006847" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.007966" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.007526" elapsed="0.000467"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:26.009136" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.008652" elapsed="0.000566"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:26.009357" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:26.009586" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:26.008185" elapsed="0.001428"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.009790" elapsed="0.000407"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:26.007385" elapsed="0.002854"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.010928" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.010493" elapsed="0.000462"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:26.012070" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.011572" elapsed="0.000580"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:26.012292" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:26.012514" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:26.011147" elapsed="0.001393"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.012733" elapsed="0.000404"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:26.010354" elapsed="0.002826"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:26.007206" elapsed="0.006009"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:26.013259" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:26.013417" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:26.005790" elapsed="0.007653"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.005461" elapsed="0.008015"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.013671" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.013502" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.005438" elapsed="0.008312"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.014479" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:26.013901" elapsed="0.000607"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:26.014558" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:26.001674" elapsed="0.013101"/>
</kw>
<msg time="2026-06-06T03:31:26.014833" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:25.989014" elapsed="0.025869"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.027596" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.040168" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.054243" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.054456" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.054656" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.055046" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.054896" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:26.054880" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.055271" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.055443" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.055612" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:26.054847" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.054739" elapsed="0.000968"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.055858" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.055933" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:26.056065" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:25.984625" elapsed="0.071467"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.057307" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.057036" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:26.069828" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:26.069876" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:26.069977" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:26.059476" elapsed="0.010528"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.057421" elapsed="0.012622"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.070228" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.070070" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.057403" elapsed="0.012908"/>
</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-06-06T03:31:26.074114" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.071322" elapsed="0.002888"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.071095" elapsed="0.003194"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.071076" elapsed="0.003269"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.080247" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.075002" elapsed="0.005345"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.074472" elapsed="0.005953"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.074433" elapsed="0.006047"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.081606" 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-06-06T03:31:26.080944" elapsed="0.000690"/>
</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-06-06T03:31:26.081979" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.081726" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.082539" 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-06-06T03:31:26.082235" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.082063" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.081705" elapsed="0.000919"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.083175" 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-06-06T03:31:26.082809" elapsed="0.000393"/>
</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-06-06T03:31:26.083514" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.083272" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.084077" 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-06-06T03:31:26.083780" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.083596" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.083253" elapsed="0.000908"/>
</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-06-06T03:31:26.084321" elapsed="0.000404"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:26.085195" 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-06-06T03:31:26.084899" elapsed="0.000323"/>
</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-06-06T03:31:26.085383" elapsed="0.002813"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:26.070688" elapsed="0.017581"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:26.088385" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:26.090983" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:26.056405" elapsed="0.034608"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:26.091082" elapsed="0.000035"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:25.958092" elapsed="0.133155"/>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:25.957438" elapsed="0.133882"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:25.956891" elapsed="0.134501"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_Update_Message" owner="BgpOperations">
<kw name="Play Get" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:26.095479" level="INFO">${update} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.092560" elapsed="0.002952"/>
</kw>
<kw name="Should Not Be Equal" owner="BuiltIn">
<arg>${update}</arg>
<arg>${Empty}</arg>
<doc>Fails if the given objects are equal.</doc>
<status status="PASS" start="2026-06-06T03:31:26.095725" elapsed="0.002222"/>
</kw>
<return>
<value>${update}</value>
<status status="PASS" start="2026-06-06T03:31:26.098005" elapsed="0.000043"/>
</return>
<doc>Returns hex update message.</doc>
<status status="PASS" start="2026-06-06T03:31:26.092225" elapsed="0.005931"/>
</kw>
<msg time="2026-06-06T03:31:26.098236" level="INFO">${update} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b</msg>
<var>${update}</var>
<arg>3x</arg>
<arg>2s</arg>
<arg>Get_Update_Message</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:26.091599" elapsed="0.006662"/>
</kw>
<kw name="Verify_Two_Hex_Messages_Are_Equal" owner="BgpOperations">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.099229" level="INFO">Length is 112.</msg>
<msg time="2026-06-06T03:31:26.099308" level="INFO">${len_1} = 112</msg>
<var>${len_1}</var>
<arg>${hex_1}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:26.098917" elapsed="0.000416"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.099812" level="INFO">Length is 112.</msg>
<msg time="2026-06-06T03:31:26.099889" level="INFO">${len_2} = 112</msg>
<var>${len_2}</var>
<arg>${hex_2}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:26.099519" elapsed="0.000393"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${len_1}</arg>
<arg>${len_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:26.100096" elapsed="0.000326"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:26.100877" level="INFO">${sum_1} = 1902</msg>
<var>${sum_1}</var>
<arg>${hex_1}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:26.100683" elapsed="0.000221"/>
</kw>
<kw name="Sum Hex Message" owner="BgpRpcClient">
<msg time="2026-06-06T03:31:26.101266" level="INFO">${sum_2} = 1902</msg>
<var>${sum_2}</var>
<arg>${hex_2}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Converts hex message arguments to integers and sums them up and returns the sum.</doc>
<status status="PASS" start="2026-06-06T03:31:26.101077" elapsed="0.000216"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${sum_1}</arg>
<arg>${sum_2}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:26.101523" elapsed="0.000504"/>
</kw>
<arg>${update}</arg>
<arg>${withdraw_hex}</arg>
<doc>Verifies two hex messages are equal even in case, their arguments are misplaced.
Compares length of the hex messages and sums hex messages arguments as integers and compares results.</doc>
<status status="PASS" start="2026-06-06T03:31:26.098514" elapsed="0.003635"/>
</kw>
<kw name="Remove_Configured_Routes" owner="BgpOperations" type="TEARDOWN">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.154952" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:26.154516" elapsed="0.000472"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.155833" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.155531" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:26.156011" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:26.155178" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.156719" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:26.156210" elapsed="0.000539"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.157073" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:26.157316" level="INFO">${template} = /rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-con...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:26.156923" elapsed="0.000422"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.157790" level="INFO">/rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.157511" elapsed="0.000329"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.158906" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.158617" elapsed="0.000337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.159408" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.159126" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.160406" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.159839" elapsed="0.000595"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:26.161682" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.161184" elapsed="0.000544"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:26.161858" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:31:26.162100" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:26.160670" elapsed="0.001458"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.162293" elapsed="0.000545"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:26.159691" elapsed="0.003190"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.163688" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.163140" elapsed="0.000578"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:26.164943" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.164424" elapsed="0.000564"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:26.165109" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:26.165337" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:26.163909" elapsed="0.001456"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.165526" elapsed="0.000528"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:26.162998" elapsed="0.003100"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:26.159493" elapsed="0.006641"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:26.166177" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:26.166339" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:26.158246" elapsed="0.008120"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.157922" elapsed="0.008476"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.166580" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.166425" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.157896" elapsed="0.008780"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.167425" level="INFO">${final_text} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:26.166828" elapsed="0.000628"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:26.167506" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:26.153810" elapsed="0.013823"/>
</kw>
<msg time="2026-06-06T03:31:26.167708" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:26.140123" elapsed="0.027651"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.181091" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.194978" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/app/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.207666" elapsed="0.000043"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.207939" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.208134" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.208609" elapsed="0.000067"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.208421" elapsed="0.000294"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:26.208400" elapsed="0.000343"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.208897" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.209071" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.209240" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:26.208355" elapsed="0.000938"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.208224" elapsed="0.001098"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.209475" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.209557" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:26.209741" level="INFO">${uri} = /rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-t...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:26.134879" elapsed="0.074893"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.211117" level="INFO">/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.210798" elapsed="0.000374"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:26.219448" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:26.219768" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '430'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Data does not exist",
        "error-path": "/bgp-rib:application-rib[id='10.30.170.38']/tables[afi='bgp-types:ipv4-address-family'][safi='bgp-route-target-constrain:route-target-constrain-subsequent-address-family']/bgp-route-target-constrain:route-target-constrain-routes",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:26.219985" level="INFO">${response} = None</msg>
<msg time="2026-06-06T03:31:26.220048" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.213428" elapsed="0.007261">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:26.211241" elapsed="0.009575">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.221105" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.220867" elapsed="0.000327"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:26.211222" elapsed="0.010007">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:26.226625" level="FAIL">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.222811" elapsed="0.003887">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:26.222464" elapsed="0.004328">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:26.222436" elapsed="0.004403">Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.230326" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.227267" elapsed="0.003093">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:26.226943" elapsed="0.003482">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:26.226917" elapsed="0.003542">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.231224" 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-06-06T03:31:26.230774" elapsed="0.000479"/>
</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-06-06T03:31:26.231580" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.231327" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.232176" 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-06-06T03:31:26.231859" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.231683" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.231308" elapsed="0.000954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.232987" 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-06-06T03:31:26.232449" elapsed="0.000568"/>
</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-06-06T03:31:26.233347" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.233094" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.233977" 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-06-06T03:31:26.233599" elapsed="0.000405"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.233433" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.233074" elapsed="0.000990"/>
</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-06-06T03:31:26.234257" elapsed="0.000369"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:26.235187" 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-06-06T03:31:26.234883" elapsed="0.000332"/>
</kw>
<kw name="List Should Contain Value" owner="Collections">
<msg time="2026-06-06T03:31:26.237794" level="FAIL">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</msg>
<arg>${final_allowd_list}</arg>
<arg>${response.status_code}</arg>
<doc>Fails if the ``value`` is not found from ``list``.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.235378" elapsed="0.002452">Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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="FAIL" start="2026-06-06T03:31:26.221817" elapsed="0.016196">Several failures occurred:

1) Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'

2) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'

3) Resolving variable '${response.status_code}' failed: AttributeError: 'NoneType' object has no attribute 'status_code'</status>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:26.238086" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:26.240517" level="INFO">${response_text} = None</msg>
<msg time="2026-06-06T03:31:26.240548" level="FAIL">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="FAIL" start="2026-06-06T03:31:26.210071" elapsed="0.030508">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:26.240700" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.103943" elapsed="0.136941">Replacing variables from keyword return value failed: Resolving variable '${response.text}' failed: AttributeError: 'NoneType' object has no attribute 'text'</status>
</kw>
<arg>TemplatedRequests.Delete_Templated</arg>
<arg>${dir}/${totest}/app</arg>
<arg>mapping=${APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:26.103215" elapsed="0.137737"/>
</kw>
<arg>${totest}</arg>
<arg>${dir}</arg>
<doc>Removes the route if present.</doc>
<status status="PASS" start="2026-06-06T03:31:26.102584" elapsed="0.138431"/>
</kw>
<arg>rt_constrain_type_2</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:25.737971" elapsed="0.503099"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:25.639829" elapsed="0.601364"/>
</test>
<test id="s1-s18-t11" name="Play_To_Odl_rt_constrain_type_2" line="97">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:26.244858" elapsed="0.000226"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:26.244528" elapsed="0.000612"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.246199" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:26.246083" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.246062" elapsed="0.000205"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.251342" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:26.251231" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.251211" elapsed="0.000203"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.252451" 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-06-06T03:31:26.252059" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.253002" 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-06-06T03:31:26.252694" elapsed="0.000335"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:26.253075" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:26.253233" 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-06-06T03:31:26.251668" elapsed="0.001590"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:26.258878" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:26.258766" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.258745" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:26.260216" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:26.260105" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.260083" elapsed="0.000204"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:26.260816" 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-06-06T03:31:26.260444" elapsed="0.000401"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:26.261298" level="INFO">${current_connection_index} = 7</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-06-06T03:31:26.261070" elapsed="0.000255"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:26.292509" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:26.261860" elapsed="0.030860"/>
</kw>
<msg time="2026-06-06T03:31:26.292943" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:26.292992" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:26.261493" elapsed="0.031538"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:26.329387" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "2 "[K"
[?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-06-06T03:31:26.294111" elapsed="0.035637"/>
</kw>
<msg time="2026-06-06T03:31:26.330094" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:26.330191" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</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-06-06T03:31:26.293262" elapsed="0.037000"/>
</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-06-06T03:31:26.331003" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.330439" elapsed="0.000659"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.330396" elapsed="0.000743"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.331936" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "2 "[K"
[?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-06-06T03:31:26.331370" elapsed="0.000683"/>
</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-06-06T03:31:26.332505" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.332159" elapsed="0.000431"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.332129" elapsed="0.000498"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:26.332749" elapsed="0.000064"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:26.335825" elapsed="0.000158"/>
</kw>
<msg time="2026-06-06T03:31:26.336050" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:26.334675" elapsed="0.001514"/>
</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="NOT RUN" start="2026-06-06T03:31:26.336484" elapsed="0.000087"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.336912" elapsed="0.000090"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:26.333964" elapsed="0.003183"/>
</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-06-06T03:31:26.333249" elapsed="0.003983"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:26.259787" elapsed="0.077575"/>
</kw>
<msg time="2026-06-06T03:31:26.337478" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:26.337536" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:26.259108" elapsed="0.078469"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:26.337793" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:26.337678" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.337655" elapsed="0.000225"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.338313" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.338682" elapsed="0.000144"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.338882" elapsed="0.000019"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:26.258397" elapsed="0.080603"/>
</kw>
<msg time="2026-06-06T03:31:26.339099" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:26.339144" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "P "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:26.253667" elapsed="0.085514"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.339566" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.339262" elapsed="0.000368"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.339242" elapsed="0.000433"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:26.253499" elapsed="0.086203"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:26.253319" elapsed="0.086417"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:26.250826" elapsed="0.088972"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:26.245783" elapsed="0.094074"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:26.245300" elapsed="0.094603"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:26.242035" elapsed="0.097925"/>
</kw>
<kw name="Play_To_Odl_Template" owner="BgpOperations">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.341219" level="INFO">&amp;{adj_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/adj-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{adj_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/adj-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.340632" elapsed="0.000616"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.342029" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F10.30.171.194/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${TOOLS_SYSTEM_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.341476" elapsed="0.000590"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.342670" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.342252" elapsed="0.000448"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.343084" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/announce_rt_constrain_type_2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/announce_rt_constrain_type_2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:26.343321" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:26.342872" elapsed="0.000486"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.343882" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/withdraw_rt_constrain_type_2.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/withdraw_rt_constrain_type_2.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:26.344065" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:26.343588" elapsed="0.000515"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:26.344344" elapsed="0.002888"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:26.347401" elapsed="0.001838"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.401590" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:26.401088" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.402481" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.402197" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:26.402758" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:26.401841" elapsed="0.000945"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.403371" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:26.402964" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.403746" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:26.403913" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:26.403580" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.404371" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.404110" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.405569" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.405252" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.406091" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.405814" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.406929" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.406496" elapsed="0.000459"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:26.408232" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.407662" elapsed="0.000672"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:26.408418" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:26.408765" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:26.407151" elapsed="0.001641"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.408960" elapsed="0.000405"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:26.406352" elapsed="0.003056"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.410276" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:26.409684" elapsed="0.000619"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:26.411538" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.410995" elapsed="0.000660"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:26.411739" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:26.412037" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:26.410500" elapsed="0.001564"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:26.412225" elapsed="0.000387"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:26.409524" elapsed="0.003163"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:26.406173" elapsed="0.006551"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:26.412770" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:26.412934" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:26.404915" elapsed="0.008045"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.404500" elapsed="0.008493"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.413178" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.413021" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.404475" elapsed="0.008781"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.414023" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:26.413406" elapsed="0.000646"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:26.414140" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:26.400362" elapsed="0.013944"/>
</kw>
<msg time="2026-06-06T03:31:26.414365" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:26.387689" elapsed="0.026728"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.427278" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.439949" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.452758" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.452980" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.453170" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.453576" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.453421" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:26.453403" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.453826" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.453998" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.454168" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:26.453367" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.453254" elapsed="0.000993"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.454399" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.454475" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:26.454620" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:26.383409" elapsed="0.071252"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.456134" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.455816" elapsed="0.000393">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:26.456305" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:26.455410" elapsed="0.000920"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.456713" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.456402" elapsed="0.000373"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.457301" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:26.456993" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.456802" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.456382" elapsed="0.001004"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.460021" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:26.457568" elapsed="0.002481"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:26.460102" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:26.460258" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:26.455055" elapsed="0.005227"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:26.461557" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.461308" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:26.461732" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:26.460965" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:26.461964" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:26.461827" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:26.461808" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.462199" elapsed="0.000038"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.462432" elapsed="0.000027"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.462509" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:26.464423" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:26.460599" elapsed="0.003851"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.465908" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.465652" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:26.466354" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:26.466112" elapsed="0.000293"/>
</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-06-06T03:31:26.474186" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:26.474330" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:26.474506" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</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="FAIL" start="2026-06-06T03:31:26.468658" elapsed="0.006428">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:26.466484" elapsed="0.008720">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:26.475476" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.475252" elapsed="0.000315"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:26.466464" elapsed="0.009136">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:26.476158" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.476345" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:26.476293" elapsed="0.000118"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:26.476268" elapsed="0.000187"/>
</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-06-06T03:31:26.476730" elapsed="0.000035"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.476837" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:26.464817" elapsed="0.012171">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.477096" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.359146" elapsed="0.118086">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:26.477627" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:26.477365" elapsed="0.000387"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:26.477341" elapsed="0.000445"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:26.477832" elapsed="0.000021"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:26.354214" elapsed="0.123758">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.535466" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.535037" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.536382" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.536104" elapsed="0.000432">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.536637" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.535709" elapsed="0.000970"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.537294" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.536857" elapsed="0.000466"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.537667" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:28.537841" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:28.537499" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.538307" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.538038" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.539449" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.539114" elapsed="0.000385"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.539983" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.539698" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.540875" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.540415" elapsed="0.000489"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:28.542170" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.541592" elapsed="0.000681"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:28.542356" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:28.542675" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:28.541101" elapsed="0.001602"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.542869" elapsed="0.000510"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/adj-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:28.540255" elapsed="0.003168"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.544330" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.543712" elapsed="0.000645"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:28.545691" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.545075" elapsed="0.000721"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:28.545878" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:28.546183" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:28.544561" elapsed="0.001649"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.546373" elapsed="0.000435"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:28.543547" elapsed="0.003307"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:28.540068" elapsed="0.006824"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:28.546939" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:28.547102" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:28.538773" elapsed="0.008354"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.538436" elapsed="0.008724"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.547346" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.547187" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.538412" elapsed="0.009012"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.548204" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:28.547575" elapsed="0.000770"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.548403" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:28.534360" elapsed="0.014174"/>
</kw>
<msg time="2026-06-06T03:31:28.548598" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.521248" elapsed="0.027439"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.561364" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.573804" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.586284" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.586501" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.586703" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.587107" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.586953" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:28.586935" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.587336" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.587510" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.587695" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:28.586898" elapsed="0.000852"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.586787" elapsed="0.000990"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.587928" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.588005" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:28.588147" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-f...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:28.516801" elapsed="0.071374"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.589700" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.589388" elapsed="0.000390">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.589879" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.588960" elapsed="0.000945"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.590258" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.589982" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.590853" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.590535" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.590341" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.589961" elapsed="0.000975"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.595070" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.591092" elapsed="0.004006"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:28.595153" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:28.595314" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:28.588587" elapsed="0.006752"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.596598" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.596362" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.596777" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.596015" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:28.597013" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:31:28.596874" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.596855" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.597274" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.597452" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.597523" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:28.599472" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:28.595671" elapsed="0.003828"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.600931" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.600668" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.601415" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.601166" elapsed="0.000293"/>
</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-06-06T03:31:28.609380" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:28.609909" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/adj-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}} 
 </msg>
<msg time="2026-06-06T03:31:28.610131" 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-06-06T03:31:28.603600" elapsed="0.006569"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.601525" elapsed="0.008705"/>
</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-06-06T03:31:28.610489" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.610267" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.601507" elapsed="0.009102"/>
</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-06-06T03:31:28.615611" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.612054" elapsed="0.003673"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.611738" elapsed="0.004054"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.611711" elapsed="0.004117"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.619734" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.616240" elapsed="0.003572"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.615912" elapsed="0.003951"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.615886" elapsed="0.004012"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.620741" 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-06-06T03:31:28.620145" elapsed="0.000637"/>
</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-06-06T03:31:28.621297" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.620895" elapsed="0.000487"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.621949" 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-06-06T03:31:28.621619" elapsed="0.000356"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.621416" elapsed="0.000596"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.620867" elapsed="0.001166"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.622575" 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-06-06T03:31:28.622199" elapsed="0.000403"/>
</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-06-06T03:31:28.622950" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.622695" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.623501" 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-06-06T03:31:28.623201" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.623033" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.622674" elapsed="0.000911"/>
</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-06-06T03:31:28.623757" elapsed="0.000378"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:28.624615" 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-06-06T03:31:28.624311" elapsed="0.000345"/>
</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-06-06T03:31:28.624823" elapsed="0.002358"/>
</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-06-06T03:31:28.611129" elapsed="0.016118"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.627425" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:28.627318" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.627298" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:28.630539" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<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="PASS" start="2026-06-06T03:31:28.627659" elapsed="0.002916"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:28.630629" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:31:28.630811" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:28.599833" elapsed="0.031005"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.630945" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:28.631128" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:28.493865" elapsed="0.137289"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.660065" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.659573" elapsed="0.000522"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.660902" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.660606" elapsed="0.000417">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.661232" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.660265" elapsed="0.000993"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.661892" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.661430" elapsed="0.000490"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.662246" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:28.662406" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:28.662086" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.662881" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                    "as-4-specific-common": {
                        "as-number": 65000,
                        "local-administrator": 123
                    }
                },
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "origin": {
                        "value": "igp"
                    }
                },
                "origin-as": 64511,
                "path-id": 0,
                "route-key": "AgIAAP3oAHs="
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.662596" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:28.663408" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.663000" elapsed="0.000469"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.664172" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/adj-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.663665" elapsed="0.000535"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.663494" elapsed="0.000741"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.662980" elapsed="0.001277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.664916" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:28.664409" elapsed="0.000536"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.664995" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:28.658946" elapsed="0.006175"/>
</kw>
<msg time="2026-06-06T03:31:28.665226" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.645923" elapsed="0.019355"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.677840" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.690397" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.703034" elapsed="0.000066"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.703360" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.703556" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.704032" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.703872" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:28.703852" elapsed="0.000279"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.704283" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.704457" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.704633" elapsed="0.000045"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:28.703810" elapsed="0.000902"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.703666" elapsed="0.001074"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.704894" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.704972" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:28.705152" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:28.643249" elapsed="0.061966"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.705405" elapsed="0.002571"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:28.709289" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.708799" elapsed="0.000586"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:28.709976" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.709550" elapsed="0.000454"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:28.710168" elapsed="0.000347"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:28.708338" elapsed="0.002238"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.708060" elapsed="0.002550"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.710822" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.710637" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.708040" elapsed="0.002861"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:28.632361" elapsed="0.078591"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:28.631485" elapsed="0.079548"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.631239" elapsed="0.079842"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.631221" elapsed="0.079885"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.711141" elapsed="0.000034"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:28.488774" elapsed="0.222501"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${adj_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:26.349442" elapsed="2.361894"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.761977" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.761545" elapsed="0.000466"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.762834" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.762550" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.763011" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.762200" elapsed="0.000839"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.763615" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.763226" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.763977" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:28.764157" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:28.763831" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.764599" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.764348" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.766061" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.765450" elapsed="0.000663"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.766704" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.766373" elapsed="0.000360"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.767562" level="INFO">${value} = peer=bgp:%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.767145" elapsed="0.000444"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:28.768858" level="INFO">${encoded} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.768275" elapsed="0.000684"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:28.769040" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:28.769427" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:28.767808" elapsed="0.001648"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.769630" elapsed="0.000412"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F10.30.171.194/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:28.766974" elapsed="0.003110"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.770767" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.770337" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:28.772029" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.771450" elapsed="0.000681"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:28.772209" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:28.772502" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:28.770988" elapsed="0.001540"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.772703" elapsed="0.000370"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:28.770199" elapsed="0.002917"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:28.766791" elapsed="0.006359"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:28.773210" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:28.773370" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:28.765090" elapsed="0.008306"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.764744" elapsed="0.008684"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.773611" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.773454" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.764719" elapsed="0.008985"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.774458" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:28.773856" elapsed="0.000631"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.774537" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:28.760825" elapsed="0.013853"/>
</kw>
<msg time="2026-06-06T03:31:28.774734" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.747361" elapsed="0.027422"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.787313" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.799637" elapsed="0.000082"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.812099" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.812302" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.812485" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.812882" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.812730" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:28.812714" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.813111" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.813298" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.813470" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:28.812682" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.812565" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.813715" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.813793" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:28.813919" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-add...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:28.743074" elapsed="0.070873"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.815234" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.814978" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.815398" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.814609" elapsed="0.000813"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.815763" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.815493" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.816328" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.816032" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.815847" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.815474" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.819029" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.816568" elapsed="0.002488"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:28.819109" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:28.819302" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:28.814278" elapsed="0.005050"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.820570" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.820338" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.820744" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.819996" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:28.820976" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:28.820840" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.820821" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.821229" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.821407" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.821472" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:28.823416" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:28.819660" elapsed="0.003782"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.824857" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.824590" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.825325" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.825064" elapsed="0.000305"/>
</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-06-06T03:31:28.832210" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:28.832354" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F10.30.171.194/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}} 
 </msg>
<msg time="2026-06-06T03:31:28.832452" 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-06-06T03:31:28.827524" elapsed="0.004955"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.825436" elapsed="0.007087"/>
</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-06-06T03:31:28.832730" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.832549" elapsed="0.000249"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.825417" elapsed="0.007402"/>
</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-06-06T03:31:28.836431" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.833878" elapsed="0.002604"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.833632" elapsed="0.002885"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.833614" elapsed="0.002929"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.839175" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.836848" elapsed="0.002373"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.836599" elapsed="0.002693"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.836582" elapsed="0.002736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.839894" 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-06-06T03:31:28.839493" elapsed="0.000429"/>
</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-06-06T03:31:28.840242" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.839994" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.840968" 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-06-06T03:31:28.840493" elapsed="0.000503"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.840325" elapsed="0.000707"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.839975" elapsed="0.001078"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.841601" 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-06-06T03:31:28.841231" elapsed="0.000397"/>
</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-06-06T03:31:28.841960" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.841715" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.842506" 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-06-06T03:31:28.842210" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.842042" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.841696" elapsed="0.000893"/>
</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-06-06T03:31:28.842760" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:28.843566" 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-06-06T03:31:28.843283" elapsed="0.000309"/>
</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-06-06T03:31:28.843770" elapsed="0.002325"/>
</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-06-06T03:31:28.833179" elapsed="0.012980"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.846337" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:28.846229" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.846210" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:28.849375" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<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="PASS" start="2026-06-06T03:31:28.846561" elapsed="0.002844"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:28.849459" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:28.849621" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:28.823774" elapsed="0.025889"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.849728" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:28.849878" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:28.720203" elapsed="0.129701"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.878486" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.878027" elapsed="0.000488"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.879372" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.879101" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.879693" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.878750" elapsed="0.000969"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.880334" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.879892" elapsed="0.000469"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.880707" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:28.880857" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:28.880530" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.881345" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                    "as-4-specific-common": {
                        "as-number": 65000,
                        "local-administrator": 123
                    }
                },
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "origin": {
                        "value": "igp"
                    }
                },
                "origin-as": 64511,
                "path-id": 0,
                "route-key": "AgIAAP3oAHs="
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.881046" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:28.881891" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.881464" elapsed="0.000489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.882635" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F10.30.171.194/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.882128" elapsed="0.000549"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.881977" elapsed="0.000736"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.881445" elapsed="0.001290"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.883373" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:28.882887" elapsed="0.000515"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.883452" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:28.877389" elapsed="0.006192"/>
</kw>
<msg time="2026-06-06T03:31:28.883661" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.864512" elapsed="0.019201"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.896128" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.908499" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.920952" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.921153" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.921352" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.921744" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.921580" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:28.921564" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.921970" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.922141" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.922310" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:28.921535" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.921431" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.922538" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:28.922613" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:28.922769" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:28.861888" elapsed="0.060908"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.922976" elapsed="0.002385"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:28.926536" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.926123" elapsed="0.000441"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:28.927142" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.926741" elapsed="0.000429"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:28.927329" elapsed="0.000341"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:28.925706" elapsed="0.002026"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.925445" elapsed="0.002320"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.927944" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.927790" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.925425" elapsed="0.002596"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:28.851046" elapsed="0.077022"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:28.850233" elapsed="0.077911"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.849989" elapsed="0.078235"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.849971" elapsed="0.078278"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.928282" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:28.715825" elapsed="0.212583"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:28.711515" elapsed="0.216953"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.977886" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:28.977493" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.978627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:28.978418" elapsed="0.000291">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:28.978803" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:28.978082" elapsed="0.000745"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.979375" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:28.978995" elapsed="0.000407"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:28.979722" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:28.979851" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:28.979569" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.980282" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.980040" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.981501" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:28.981032" elapsed="0.000516"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.982014" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.981739" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.982828" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.982399" elapsed="0.000456"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:28.984068" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.983505" elapsed="0.000665"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:28.984248" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:28.984539" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:28.983049" elapsed="0.001516"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.984739" elapsed="0.000376"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:28.982259" elapsed="0.002899"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.985859" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:28.985439" elapsed="0.000447"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:28.987142" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.986531" elapsed="0.000711"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:28.987321" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:28.987619" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:28.986077" elapsed="0.001584"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:28.987822" elapsed="0.000367"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:28.985300" elapsed="0.002931"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:28.982089" elapsed="0.006178"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:28.988308" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:28.988464" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:28.980703" elapsed="0.007785"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:28.980394" elapsed="0.008126"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:28.988712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:28.988545" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:28.980375" elapsed="0.008415"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:28.989508" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:28.988936" elapsed="0.000601"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:28.989587" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:28.976850" elapsed="0.012878"/>
</kw>
<msg time="2026-06-06T03:31:28.989783" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:28.964057" elapsed="0.025772"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.002334" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.014878" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.027331" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.027533" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.027731" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.028100" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.027951" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:29.027936" elapsed="0.000279"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.028364" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.028546" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.028731" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:29.027908" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.027806" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.028962" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.029037" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:29.029157" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:28.959806" elapsed="0.069378"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.030467" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.030232" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:29.030625" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.029887" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.030989" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.030737" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.031533" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.031243" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.031070" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.030718" elapsed="0.000897"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.034189" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:29.031785" elapsed="0.002431"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:29.034269" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:29.034427" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:29.029541" elapsed="0.004911"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.035715" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.035460" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:29.035872" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.035114" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:29.036102" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:29.035967" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.035948" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.036333" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.036508" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.036612" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:29.038561" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:29.034781" elapsed="0.003807"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.040002" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.039753" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.040445" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.040205" 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-06-06T03:31:29.048157" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:29.048284" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '373'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}} 
 </msg>
<msg time="2026-06-06T03:31:29.048380" 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-06-06T03:31:29.042656" elapsed="0.005750"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.040553" elapsed="0.007896"/>
</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-06-06T03:31:29.048743" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.048476" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.040535" elapsed="0.008330"/>
</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-06-06T03:31:29.053969" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.050360" elapsed="0.003677"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.050044" elapsed="0.004043"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.050017" elapsed="0.004105"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.057715" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.054514" elapsed="0.003247"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.054199" elapsed="0.003596"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.054176" elapsed="0.003643"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.058360" 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-06-06T03:31:29.057988" elapsed="0.000399"/>
</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-06-06T03:31:29.058717" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.058458" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.059266" 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-06-06T03:31:29.058968" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.058799" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.058439" elapsed="0.000910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.059889" 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-06-06T03:31:29.059513" elapsed="0.000403"/>
</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-06-06T03:31:29.060228" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.059987" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.060786" 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-06-06T03:31:29.060474" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.060308" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.059968" elapsed="0.000936"/>
</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-06-06T03:31:29.061061" elapsed="0.000365"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:29.061895" 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-06-06T03:31:29.061602" elapsed="0.000320"/>
</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-06-06T03:31:29.062083" elapsed="0.002307"/>
</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-06-06T03:31:29.049388" elapsed="0.015066"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.064635" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:29.064529" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.064507" elapsed="0.000211"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:29.067661" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<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="PASS" start="2026-06-06T03:31:29.064867" elapsed="0.002825"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:29.067745" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:29.067902" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:29.038917" elapsed="0.029011"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:29.067990" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:29.068147" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:28.937290" elapsed="0.130883"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.097699" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.097192" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.098505" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.098244" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:29.098818" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.097900" elapsed="0.000943"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.099456" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:29.099016" elapsed="0.000467"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.099846" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:29.099985" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:29.099686" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.100441" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                    "as-4-specific-common": {
                        "as-number": 65000,
                        "local-administrator": 123
                    }
                },
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "local-pref": {
                        "pref": 100
                    },
                    "origin": {
                        "value": "igp"
                    }
                },
                "origin-as": 64511,
                "path-id": 0,
                "route-key": "AgIAAP3oAHs="
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.100174" elapsed="0.000350"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:29.101013" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.100592" elapsed="0.000481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.101820" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.101296" elapsed="0.000552"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.101099" elapsed="0.000784"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.100573" elapsed="0.001332"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.102538" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:29.102057" elapsed="0.000514"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:29.102623" elapsed="0.000051"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:29.096395" elapsed="0.006379"/>
</kw>
<msg time="2026-06-06T03:31:29.102831" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:29.082738" elapsed="0.020142"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.115381" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.127878" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_2/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.140344" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.140543" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.140735" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.141107" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.140958" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:29.140943" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.141361" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.141536" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.141722" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:29.140914" elapsed="0.000863"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.140811" elapsed="0.001031"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.141996" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.142072" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:29.142208" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "as-4-route-target-extended-community": {
                  ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:29.080047" elapsed="0.062187"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:29.142414" elapsed="0.002368"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:29.145973" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.145534" elapsed="0.000468"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:29.146563" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "as-4-route-target-extended-community": {
     "as-4-specific-common": {
      "as-number"...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.146160" elapsed="0.000431"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:29.146765" elapsed="0.000324"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:29.145105" elapsed="0.002044"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.144863" elapsed="0.002319"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.147359" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.147207" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.144844" elapsed="0.002590"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:29.069319" elapsed="0.078161"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:29.068494" elapsed="0.079060"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.068255" elapsed="0.079345"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.068238" elapsed="0.079386"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:29.147672" elapsed="0.000028"/>
</return>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:28.932921" elapsed="0.214876"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/${totest}/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:28.928663" elapsed="0.219191"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:29.148024" elapsed="0.002707"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.200436" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.200052" elapsed="0.000413"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.201199" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.200989" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:29.201428" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.200634" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.202187" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:29.201789" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.202518" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:29.202660" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:29.202382" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.203100" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.202854" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.204315" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.204024" elapsed="0.000337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.204828" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:29.204530" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.205626" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.205212" elapsed="0.000457"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:29.206871" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:29.206316" elapsed="0.000654"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:29.207048" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:29.207336" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:29.205863" elapsed="0.001499"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:29.207520" elapsed="0.000383"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:29.205073" elapsed="0.002871"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.208593" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.208194" elapsed="0.000425"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:29.209873" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:29.209310" elapsed="0.000663"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:29.210050" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:29.210337" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:29.208828" elapsed="0.001535"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:29.210521" elapsed="0.000387"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:29.208056" elapsed="0.002894"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:29.204903" elapsed="0.006081"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:29.211027" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:29.211185" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:29.203507" elapsed="0.007703"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.203213" elapsed="0.008030"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.211421" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.211267" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.203194" elapsed="0.008304"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.212338" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:29.211771" elapsed="0.000596"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:29.212417" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:29.199413" elapsed="0.013172"/>
</kw>
<msg time="2026-06-06T03:31:29.212661" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:29.186701" elapsed="0.026012"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.225175" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.237737" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.250118" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.250318" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.250499" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.250889" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.250740" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:29.250720" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.251115" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.251286" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.251457" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:29.250688" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.250573" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.251701" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.251778" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:29.251897" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:29.182282" elapsed="0.069641"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.253212" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.252977" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:29.253393" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.252614" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.253761" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.253490" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.254514" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.254019" elapsed="0.000522"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.253845" elapsed="0.000733"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.253471" elapsed="0.001128"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.256975" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:29.254780" elapsed="0.002222"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:29.257055" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:29.257208" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:29.252284" elapsed="0.004949"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.258439" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:29.258253" elapsed="0.000239"/>
</kw>
<msg time="2026-06-06T03:31:29.258578" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.257907" elapsed="0.000695"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.258828" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:29.258689" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.258669" elapsed="0.000226"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.259211" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:29.259335" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:29.259045" elapsed="0.000315"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:29.259774" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.259525" elapsed="0.000276"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:29.259849" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:29.260008" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:29.257557" elapsed="0.002476"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.261444" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.261167" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.261908" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.261663" elapsed="0.000288"/>
</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-06-06T03:31:29.269112" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:29.269627" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '549'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}}]} 
 </msg>
<msg time="2026-06-06T03:31:29.269856" 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-06-06T03:31:29.264153" elapsed="0.005742"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.262018" elapsed="0.007938"/>
</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-06-06T03:31:29.270217" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.269994" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.261999" elapsed="0.008339"/>
</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-06-06T03:31:29.275221" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false},"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AgIAAP3oAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"as-4-route-target-extended-community":{"as-4-specific-common":{"as-number":65000,"local-administrator":123}}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.271807" elapsed="0.003485"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.271469" elapsed="0.003873"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.271442" elapsed="0.003936"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.279053" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.275800" elapsed="0.003318"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.275458" elapsed="0.003708"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.275434" elapsed="0.003768"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.279991" 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-06-06T03:31:29.279438" elapsed="0.000592"/>
</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-06-06T03:31:29.280582" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.280131" elapsed="0.000563"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.281416" 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-06-06T03:31:29.280967" elapsed="0.000487"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.280730" elapsed="0.000776"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.280105" elapsed="0.001430"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.282084" 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-06-06T03:31:29.281718" elapsed="0.000394"/>
</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-06-06T03:31:29.282425" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.282183" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.282987" 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-06-06T03:31:29.282689" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.282506" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.282164" elapsed="0.000907"/>
</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-06-06T03:31:29.283225" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:29.284034" 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-06-06T03:31:29.283758" elapsed="0.000302"/>
</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-06-06T03:31:29.284220" elapsed="0.002517"/>
</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-06-06T03:31:29.270868" elapsed="0.015934"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.286980" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:29.286873" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.286854" elapsed="0.000193"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:29.290058" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<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="PASS" start="2026-06-06T03:31:29.287197" elapsed="0.002890"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:29.290141" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:29.290298" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:29.260338" elapsed="0.030050"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:29.290457" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:29.290618" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:29.159551" elapsed="0.131109"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.319011" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.318544" elapsed="0.000496"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.319839" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.319553" elapsed="0.000405">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:29.320136" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:29.319209" elapsed="0.000952"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.320797" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:29.320338" elapsed="0.000487"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:29.321149" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:29.321280" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:29.320991" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.321779" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:29.321495" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:29.322297" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.321893" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.323060" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:29.322538" elapsed="0.000548"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:29.322383" elapsed="0.000740"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:29.321874" elapsed="0.001269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.323782" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:29.323294" elapsed="0.000518"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:29.323861" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:29.317918" elapsed="0.006067"/>
</kw>
<msg time="2026-06-06T03:31:29.324039" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:29.305248" elapsed="0.018839"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.336840" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.349597" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.362065" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.362266" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.362448" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.362839" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.362691" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:29.362674" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.363065" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.363239" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.363410" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:29.362630" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.362525" elapsed="0.000965"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.363661" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.363739" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:29.363856" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:29.302581" elapsed="0.061303"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:29.364064" elapsed="0.002231"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:29.367335" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.367054" elapsed="0.000309"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:29.368112" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-co...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:29.367522" elapsed="0.000654"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<msg time="2026-06-06T03:31:29.368680" level="INFO">{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}

!=

{
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "bgp-route-target-constrain:route-target-constrain-routes": {
    "route-target-constrain-route": [
     {
      "as-4-route-target-extended-community": {
       "as-4-specific-common": {
        "as-number": 65000,
        "local-administrator": 123
       }
      },
      "attributes": {
       "ipv4-next-hop": {
        "global": "199.20.166.41"
       },
       "local-pref": {
        "pref": 100
       },
       "origin": {
        "value": "igp"
       }
      },
      "origin-as": 64511,
      "path-id": 0,
      "route-key": "AgIAAP3oAHs="
     }
    ]
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
  }
 ]
}</msg>
<msg time="2026-06-06T03:31:29.368869" level="FAIL">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</msg>
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.368342" elapsed="0.000597">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.366622" elapsed="0.002463">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:29.366377" elapsed="0.002787">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:29.369378" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:29.369198" elapsed="0.000239"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:29.366357" elapsed="0.003103">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.291816" elapsed="0.077767">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.290990" elapsed="0.078758">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:29.290747" elapsed="0.079121">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:29.290730" elapsed="0.079175">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:29.369955" elapsed="0.000016"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:29.155203" elapsed="0.214872">Multiline strings are different:
--- first
+++ second
@@ -5,6 +5,32 @@
    "attributes": {
     "uptodate": "*"
    },
+   "bgp-route-target-constrain:route-target-constrain-routes": {
+    "route-target-constrain-route": [
+     {
+      "as-4-route-target-extended-community": {
+       "as-4-specific-common": {
+        "as-number": 65000,
+        "local-administrator": 123
+       }
+      },
+      "attributes": {
+       "ipv4-next-hop": {
+        "global": "199.20.166.41"
+       },
+       "local-pref": {
+        "pref": 100
+       },
+       "origin": {
+        "value": "igp"
+       }
+      },
+      "origin-as": 64511,
+      "path-id": 0,
+      "route-key": "AgIAAP3oAHs="
+     }
+    ]
+   },
    "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
   }
  ]</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.427851" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:31.427423" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.428703" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:31.428425" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:31.428878" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:31.428073" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.429470" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:31.429076" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.429844" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:31.430011" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:31.429681" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.430454" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.430203" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.431663" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.431321" elapsed="0.000392"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.432158" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.431884" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.432992" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.432557" elapsed="0.000462"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.434286" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.433696" elapsed="0.000688"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.434466" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:31:31.434784" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.433214" elapsed="0.001596"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.434973" elapsed="0.000386"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:31.432415" elapsed="0.002986"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.436072" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.435672" elapsed="0.000426"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.437493" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.436949" elapsed="0.000645"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.437693" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:31.438004" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.436468" elapsed="0.001562"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.438189" elapsed="0.000363"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:31.435515" elapsed="0.003080"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:31.432238" elapsed="0.006392"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:31.438692" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:31.438851" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:31.430922" elapsed="0.007955"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.430580" elapsed="0.008329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.439090" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.438935" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.430556" elapsed="0.008610"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.439928" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:31.439314" elapsed="0.000643"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:31.440007" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:31.426770" elapsed="0.013362"/>
</kw>
<msg time="2026-06-06T03:31:31.440188" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:31.413000" elapsed="0.027238"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.453046" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.466132" elapsed="0.000089"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.478708" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.478921" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.479108" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.479529" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.479349" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:31.479332" elapsed="0.000286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.479784" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.479957" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.480126" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:31.479297" elapsed="0.000882"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.479188" elapsed="0.001017"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.480354" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.480432" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:31:31.480582" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:31.406984" elapsed="0.073626"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.482041" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:31.481716" elapsed="0.000403">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:31.482217" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:31.481316" elapsed="0.000926"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.482578" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.482314" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.483170" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:31.482871" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.482681" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.482294" elapsed="0.000960"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.485883" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:31.483412" elapsed="0.002499"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:31.485965" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:31.486192" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:31.480963" elapsed="0.005258"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.487460" level="INFO" html="true">File '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;' exists.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="PASS" start="2026-06-06T03:31:31.487256" elapsed="0.000263"/>
</kw>
<msg time="2026-06-06T03:31:31.487614" level="INFO">${read_volatiles_file} = True</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:31.486905" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.487875" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.487733" elapsed="0.000188"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.487713" elapsed="0.000231"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.488266" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:31.488421" level="INFO">${volatiles} = uptodate
</msg>
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:31.488093" elapsed="0.000354"/>
</kw>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:31:31.488883" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.488616" elapsed="0.000294"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="PASS" start="2026-06-06T03:31:31.488960" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:31.489121" level="INFO">${volatiles_list} = ['uptodate', '']</msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:31.486544" elapsed="0.002603"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.490659" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.490382" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.491119" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.490872" elapsed="0.000291"/>
</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-06-06T03:31:31.499133" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:31.499360" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '177'} 
 body={"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]} 
 </msg>
<msg time="2026-06-06T03:31:31.499529" 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-06-06T03:31:31.493447" elapsed="0.006122"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.491231" elapsed="0.008438"/>
</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-06-06T03:31:31.500032" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.499729" elapsed="0.000413"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.491212" elapsed="0.008961"/>
</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-06-06T03:31:31.505157" level="INFO">{"bgp-rib:tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.501696" elapsed="0.003529"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.501350" elapsed="0.003924"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.501323" elapsed="0.003986"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.509484" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.505735" elapsed="0.003814"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.505390" elapsed="0.004208"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.505365" elapsed="0.004270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.510631" 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-06-06T03:31:31.510071" elapsed="0.000605"/>
</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-06-06T03:31:31.511075" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.510752" elapsed="0.000388"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.511700" 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-06-06T03:31:31.511344" elapsed="0.000385"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.511166" elapsed="0.000599"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.510731" elapsed="0.001055"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.512496" 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-06-06T03:31:31.511998" elapsed="0.000532"/>
</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-06-06T03:31:31.512987" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.512627" elapsed="0.000442"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.513755" 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-06-06T03:31:31.513317" elapsed="0.000499"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.513102" elapsed="0.000759"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.512600" elapsed="0.001283"/>
</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-06-06T03:31:31.514058" elapsed="0.000372"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:31.514939" 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-06-06T03:31:31.514606" elapsed="0.000368"/>
</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-06-06T03:31:31.515167" elapsed="0.002515"/>
</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-06-06T03:31:31.500716" elapsed="0.017101"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.518068" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.517919" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.517892" elapsed="0.000273"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:31.521486" level="INFO">${text_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<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="PASS" start="2026-06-06T03:31:31.518376" elapsed="0.003147"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:31.521588" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:31:31.521859" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:31.489477" elapsed="0.032424"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:31.521986" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:31.522151" level="INFO">${response_text} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:31.384125" elapsed="0.138054"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.553878" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:31.553287" elapsed="0.000634"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.554814" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:31.554470" elapsed="0.000599">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:31.555272" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:31.554109" elapsed="0.001189"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.555952" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:31.555475" elapsed="0.000506"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.556369" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/empty_routes/ipv4/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:31.556534" level="INFO">${template} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:31.556190" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.557025" level="INFO">{
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "uptodate": "*"
      }
    }
  ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.556749" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:31.557673" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.557153" elapsed="0.000597"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.558542" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:31.557992" elapsed="0.000577"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.557832" elapsed="0.000774"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.557128" elapsed="0.001501"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.559349" level="INFO">${final_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:31.558809" elapsed="0.000571"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:31.559433" elapsed="0.000035"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:31.552572" elapsed="0.006998"/>
</kw>
<msg time="2026-06-06T03:31:31.559626" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:31.538701" elapsed="0.020999"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.573349" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.586494" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/empty_routes/ipv4/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.599194" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.599559" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.599768" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.600188" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.600030" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:31.600012" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.600417" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.600593" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.600781" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:31.599973" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.599855" elapsed="0.001007"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.601013" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.601090" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:31.601234" level="INFO">${expected_text} = {
  "bgp-rib:tables": [
    {
      "afi": "bgp-types:ipv4-address-family",
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family",
      "attributes": {
        "...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:31.535105" elapsed="0.066157"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:31.601445" elapsed="0.002720"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:31.605347" level="INFO">${expected_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.605022" elapsed="0.000354"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:31.605839" level="INFO">${actual_normalized} = {
 "bgp-rib:tables": [
  {
   "afi": "bgp-types:ipv4-address-family",
   "attributes": {
    "uptodate": "*"
   },
   "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-fami...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.605536" elapsed="0.000332"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:31.606028" elapsed="0.000342"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:31.604519" elapsed="0.001913"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.604249" elapsed="0.002218"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.606663" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.606493" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.604228" elapsed="0.002512"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:31.523394" elapsed="0.083396"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:31.522531" elapsed="0.084337"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.522264" elapsed="0.084649"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.522247" elapsed="0.084691"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:31.606974" elapsed="0.000033"/>
</return>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:31.379297" elapsed="0.227811"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${dir}/empty_routes/${ipv}</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:29.150907" elapsed="2.456314"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient" type="TEARDOWN">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:31.607447" elapsed="0.002748"/>
</kw>
<arg>rt_constrain_type_2</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<status status="PASS" start="2026-06-06T03:31:26.340233" elapsed="5.270027"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:26.241427" elapsed="5.368958"/>
</test>
<test id="s1-s18-t12" name="Kill_Talking_BGP_Speaker" line="101">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:31.615331" elapsed="0.000371"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:31.614911" elapsed="0.000879"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.617440" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.617251" elapsed="0.000260"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.617219" elapsed="0.000326"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.624413" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.624297" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.624278" elapsed="0.000207"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.625547" 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-06-06T03:31:31.625138" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.626088" 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-06-06T03:31:31.625762" elapsed="0.000353"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:31.626161" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:31.626324" 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-06-06T03:31:31.624745" elapsed="0.001604"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:31.633353" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.633240" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.633219" elapsed="0.000205"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:31.634906" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.634581" elapsed="0.000380"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.634561" elapsed="0.000424"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:31.635482" 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-06-06T03:31:31.635140" elapsed="0.000371"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.635934" level="INFO">${current_connection_index} = 7</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-06-06T03:31:31.635704" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.666849" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:31.636485" elapsed="0.030473"/>
</kw>
<msg time="2026-06-06T03:31:31.667147" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:31.667195" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:31.636128" elapsed="0.031105"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.696846" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:31:31.667803" elapsed="0.029228"/>
</kw>
<msg time="2026-06-06T03:31:31.697217" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:31.697264" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "K "...</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-06-06T03:31:31.667414" elapsed="0.029888"/>
</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-06-06T03:31:31.697708" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.697400" elapsed="0.000481"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.697372" elapsed="0.000538"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.698411" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "[K"
[?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-06-06T03:31:31.698069" elapsed="0.000417"/>
</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-06-06T03:31:31.698806" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.698556" elapsed="0.000307"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.698537" elapsed="0.000351"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:31.698925" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:31.701657" elapsed="0.000185"/>
</kw>
<msg time="2026-06-06T03:31:31.701917" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:31.700526" elapsed="0.001541"/>
</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="NOT RUN" start="2026-06-06T03:31:31.702355" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.702788" elapsed="0.000081"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:31.699863" elapsed="0.003121"/>
</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-06-06T03:31:31.699257" elapsed="0.003794"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:31.634264" elapsed="0.068888"/>
</kw>
<msg time="2026-06-06T03:31:31.703253" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:31.703300" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "K "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:31.633587" elapsed="0.069753"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:31.703536" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:31.703421" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.703401" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.704081" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.704441" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.704513" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:31.632884" elapsed="0.071743"/>
</kw>
<msg time="2026-06-06T03:31:31.704759" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:31.704805" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "K "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:31.626747" elapsed="0.078098"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.705226" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.704924" elapsed="0.000359"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.704905" elapsed="0.000402"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:31.626582" elapsed="0.078750"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:31.626407" elapsed="0.078959"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:31.623913" elapsed="0.081512"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:31.616739" elapsed="0.088743"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:31.616031" elapsed="0.089497"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:31.611414" elapsed="0.094166"/>
</kw>
<kw name="Kill_BGP_Speaker" owner="BGPSpeaker">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.706908" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:31.706565" elapsed="0.000372"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:31.707096" elapsed="0.000246"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:31:31.706291" elapsed="0.001125"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.724088" level="INFO">^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:31:31.707955" elapsed="0.016206"/>
</kw>
<msg time="2026-06-06T03:31:31.724266" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:31.724310" level="INFO">${message} = ^C
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${status}</var>
<var>${message}</var>
<arg>SSHLibrary.Read_Until_Prompt</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:31.707584" elapsed="0.016750"/>
</kw>
<kw name="Dump_BGP_Speaker_Logs" owner="BGPSpeaker">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.725020" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:31:31.737107" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:31.737206" level="INFO">${output_log} = 2026-06-06 03:31:01,761 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:31:01,762 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${BGPSpeaker__OUTPUT_LOG}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:31:31.724873" elapsed="0.012360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.737906" level="INFO">2026-06-06 03:31:01,761 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:31:01,763 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Length=53 (0x0035)
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=24 (0x18)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400010084020641040000fbf0
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400010084020641040000fbf0'
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400010084020641040000fbf0
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:01,771 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:01,771 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:01,771 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:01,779 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:31:01,779 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:01,779 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): ... idle for 0.000s
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:31:01,780 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:01,781 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:01,781 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:01,781 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.009s
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:03,785 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.010s
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:04,787 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:04,787 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.011s
2026-06-06 03:31:04,787 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:04,788 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:04,788 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.013s
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:06,790 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.014s
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.015s
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:07] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:07,989 INFO BGP-Thread-1 (job): ... idle for 0.197s
2026-06-06 03:31:07,990 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.212s
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0032' (50)
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:07,991 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:07,991 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:07,991 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:08,129 INFO BGP-Thread-1 (job): ... idle for 0.138s
2026-06-06 03:31:08,129 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.350s
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'002c' (44)
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:08,130 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:08,130 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:08,130 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:09,131 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:09,133 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.351s
2026-06-06 03:31:09,133 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000
2026-06-06 03:31:09,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:09,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:09,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:10,135 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:10,135 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.352s
2026-06-06 03:31:10,136 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:10,136 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:10,136 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.353s
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:11] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.354s
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.356s
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:13,956 INFO BGP-Thread-1 (job): ... idle for 0.815s
2026-06-06 03:31:13,956 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.170s
2026-06-06 03:31:13,956 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
2026-06-06 03:31:13,956 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:31:13,956 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:13,956 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:13,957 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:13,957 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:13,957 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:14,101 INFO BGP-Thread-1 (job): ... idle for 0.144s
2026-06-06 03:31:14,102 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.314s
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0038' (56)
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:14,103 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:14,103 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:14,103 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:15,104 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:15,104 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.316s
2026-06-06 03:31:15,104 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:31:15,105 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:15,105 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:15,105 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:16,106 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.317s
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:17,108 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.318s
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:17] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:18,110 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:18,110 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.320s
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:19,112 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.321s
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:19,989 INFO BGP-Thread-1 (job): ... idle for 0.876s
2026-06-06 03:31:19,989 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.197s
2026-06-06 03:31:19,989 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:19,991 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:19,991 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:19,991 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:20,127 INFO BGP-Thread-1 (job): ... idle for 0.137s
2026-06-06 03:31:20,127 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.334s
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0038' (56)
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:20,128 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:20,129 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:20,129 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 19.335s
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:21,131 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:21,131 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.336s
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:23,133 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.337s
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:24,135 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 22.338s
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:25,138 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 23.340s
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:25,950 INFO BGP-Thread-1 (job): ... idle for 0.809s
2026-06-06 03:31:25,950 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.149s
2026-06-06 03:31:25,950 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:25,951 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:25,951 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:25,951 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:26,088 INFO BGP-Thread-1 (job): ... idle for 0.136s
2026-06-06 03:31:26,088 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.285s
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0038' (56)
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:26,089 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:26,089 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:26,089 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:27,090 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:27,090 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 25.286s
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:28,092 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:28,092 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.288s
2026-06-06 03:31:28,092 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:28,093 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:28,093 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 27.289s
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:29] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 28.290s
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:30,097 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:30,097 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.291s
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:31] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.737402" elapsed="0.001391"/>
</kw>
<doc>Send all output produced by the play.py utility to Robot logs.
This needs to be called if your suite detects play.py crashing and bypasses
Kill_BGP_Speaker in that case otherwise the output of play.py (which most
likely contains clues about why it crashed) will be lost.</doc>
<status status="PASS" start="2026-06-06T03:31:31.724551" elapsed="0.014372"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<status status="PASS" start="2026-06-06T03:31:31.739339" elapsed="0.000066"/>
</return>
<status status="PASS" start="2026-06-06T03:31:31.739074" elapsed="0.000399"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.739028" elapsed="0.000501"/>
</if>
<kw name="Log" owner="BuiltIn">
<arg>${message}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.739914" elapsed="0.000050"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>The prompt was not seen within timeout period.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.740303" elapsed="0.000045"/>
</kw>
<doc>Interrupt play.py, fail if no prompt is seen within SSHLibrary timeout.
Also dump the logs with the output the program produced.
This keyword is also suitable for stopping BGP manager.</doc>
<status status="PASS" start="2026-06-06T03:31:31.705958" elapsed="0.034517"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.752818" level="INFO">Executing command 'cat play.py.out'.</msg>
<msg time="2026-06-06T03:31:31.783231" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:31.783404" level="INFO">${output_log} = 2026-06-06 03:31:01,761 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:31:01,762 DEBUG BGP-Thr...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:31:31.752677" elapsed="0.030768"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.784226" level="INFO">2026-06-06 03:31:01,761 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Local IP address: 10.30.171.194
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:31:01,762 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:31:01,763 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:31:01,766 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   My BGP Identifier: 169782210
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:31:01,767 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Length=53 (0x0035)
2026-06-06 03:31:01,767 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   BGP Identifier=169782210 (0x0a1eabc2)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=24 (0x18)
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400010084020641040000fbf0
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400010084020641040000fbf0'
2026-06-06 03:31:01,768 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff00350104fbf000b40a1eabc21802060104000100010206010400010084020641040000fbf0
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:01,770 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:01,771 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:01,771 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:01,771 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:01,771 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:01,779 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:31:01,779 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:01,779 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:01,779 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): ... idle for 0.000s
2026-06-06 03:31:01,780 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:31:01,780 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:01,781 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:01,781 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:01,781 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:01,781 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.009s
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:02,783 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:03,785 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.010s
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:03,786 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:04,787 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:04,787 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.011s
2026-06-06 03:31:04,787 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:04,788 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:04,788 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.013s
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:05,789 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:06,790 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.014s
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:06,791 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.015s
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:07,792 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:07] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:07,989 INFO BGP-Thread-1 (job): ... idle for 0.197s
2026-06-06 03:31:07,990 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.212s
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0032' (50)
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:07,990 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:07,991 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:07,991 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:07,991 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:08,129 INFO BGP-Thread-1 (job): ... idle for 0.138s
2026-06-06 03:31:08,129 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.350s
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'002c' (44)
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:08,129 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:08,130 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:08,130 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:08,130 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:08,130 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:08] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:09,131 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:09,133 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.351s
2026-06-06 03:31:09,133 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0032020000001b4001010040020040050400000064800e0a00018404c714a6290000
2026-06-06 03:31:09,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:09,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:09,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:10,135 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:10,135 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.352s
2026-06-06 03:31:10,136 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:10,136 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:10,136 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.353s
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:11,137 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:11] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.354s
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:12,139 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.356s
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:13,141 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:13,956 INFO BGP-Thread-1 (job): ... idle for 0.815s
2026-06-06 03:31:13,956 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.170s
2026-06-06 03:31:13,956 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff002c02000000154001010040020040050400000064800f0400018400
2026-06-06 03:31:13,956 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:31:13,956 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:13,956 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:13,957 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:13,957 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:13,957 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:13,957 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:13] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:14,101 INFO BGP-Thread-1 (job): ... idle for 0.144s
2026-06-06 03:31:14,102 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.314s
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0038' (56)
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:14,102 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:14,103 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:14,103 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:14,103 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:14] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:14] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:15,104 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:15,104 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.316s
2026-06-06 03:31:15,104 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:31:15,105 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:15,105 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:15,105 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:16,106 INFO BGP-Thread-1 (job): ... idle for 1.002s
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.317s
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:16,107 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:17,108 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 15.318s
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:17,109 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:17] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:18,110 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:18,110 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 16.320s
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:18,111 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:19,112 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 17.321s
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:19,113 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:19] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:19] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:19,989 INFO BGP-Thread-1 (job): ... idle for 0.876s
2026-06-06 03:31:19,989 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.197s
2026-06-06 03:31:19,989 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:19,990 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:19,991 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:19,991 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:19,991 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:20,127 INFO BGP-Thread-1 (job): ... idle for 0.137s
2026-06-06 03:31:20,127 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 18.334s
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0038' (56)
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:20,128 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:20,128 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:20,129 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:20,129 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:20] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 19.335s
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
2026-06-06 03:31:21,130 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:21,131 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:21,131 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 20.336s
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:22,132 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:23,133 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 21.337s
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:23,134 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:23] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:24,135 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 22.338s
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:24,136 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:25,138 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 23.340s
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:25,140 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:25,950 INFO BGP-Thread-1 (job): ... idle for 0.809s
2026-06-06 03:31:25,950 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.149s
2026-06-06 03:31:25,950 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:25,950 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'003e' (62)
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:25,951 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:25,951 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:25,951 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:25,951 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:25] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:26,088 INFO BGP-Thread-1 (job): ... idle for 0.136s
2026-06-06 03:31:26,088 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 24.285s
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0038' (56)
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:26,088 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): Route-Target-Constrain True
2026-06-06 03:31:26,089 DEBUG BGP-Thread-1 (job): Skipping update decoding due to Route-Target-Constrain data expected
2026-06-06 03:31:26,089 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:26,089 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:26,089 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:26] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:26] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:27,090 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:27,090 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 25.286s
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff02020000fde8007b
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:27,091 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:28,092 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:28,092 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 26.288s
2026-06-06 03:31:28,092 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:28,093 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:28,093 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 27.289s
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:29,094 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:29] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 28.290s
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff02020000fde8007b
2026-06-06 03:31:30,096 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:30,097 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:30,097 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 29.291s
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:31,098 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:31] "POST /RPC2 HTTP/1.1" 200 -
Traceback (most recent call last):
  File "/home/jenkins/play.py", line 2543, in &lt;module&gt;
    threaded_job(arguments)
  File "/home/jenkins/play.py", line 2537, in threaded_job
    rpcserver.serve_forever()
  File "/usr/lib/python3.10/socketserver.py", line 232, in serve_forever
    ready = selector.select(poll_interval)
  File "/usr/lib/python3.10/selectors.py", line 416, in select
    fd_event_list = self._selector.poll(timeout)
KeyboardInterrupt</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.783766" elapsed="0.001085"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.785748" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/rt_constrain_play.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/rt_constrain_play.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:31:31.785154" elapsed="0.000708"/>
</kw>
<arg>play.py.out</arg>
<arg>rt_constrain_play.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:31.752320" elapsed="0.033637"/>
</kw>
<doc>Abort the Python speaker</doc>
<status status="PASS" start="2026-06-06T03:31:31.610711" elapsed="0.175414"/>
</test>
<test id="s1-s18-t13" name="Delete_Bgp_Peer_Configuration" line="107">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:31.790793" elapsed="0.000307"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:31.790384" elapsed="0.000795"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.792688" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.792490" elapsed="0.000268"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.792459" elapsed="0.000333"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.799515" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.799402" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.799383" elapsed="0.000206"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.800659" 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-06-06T03:31:31.800245" elapsed="0.000444"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.801234" 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-06-06T03:31:31.800861" elapsed="0.000400"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:31.801308" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:31.801473" 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-06-06T03:31:31.799849" elapsed="0.001650"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:31.807416" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.807295" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.807273" elapsed="0.000220"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:31.808788" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:31.808674" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.808632" elapsed="0.000226"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:31.809324" 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-06-06T03:31:31.809010" elapsed="0.000342"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.809759" level="INFO">${current_connection_index} = 7</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-06-06T03:31:31.809519" elapsed="0.000266"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.839237" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:31.810333" elapsed="0.029192"/>
</kw>
<msg time="2026-06-06T03:31:31.840014" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:31.840119" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:31.809985" elapsed="0.030216"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:31.869508" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:31:31.841530" elapsed="0.028141"/>
</kw>
<msg time="2026-06-06T03:31:31.869888" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:31.869937" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "...</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-06-06T03:31:31.840690" elapsed="0.029285"/>
</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-06-06T03:31:31.870454" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.870159" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.870048" elapsed="0.000493"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.871053" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:31:31.870709" elapsed="0.000418"/>
</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-06-06T03:31:31.871436" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.871196" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.871176" elapsed="0.000340"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:31.871554" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:31.874236" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:31:31.874447" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:31.873179" elapsed="0.001432"/>
</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="NOT RUN" start="2026-06-06T03:31:31.874966" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.875314" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:31.872501" elapsed="0.003002"/>
</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-06-06T03:31:31.871912" elapsed="0.003660"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:31.808344" elapsed="0.067349"/>
</kw>
<msg time="2026-06-06T03:31:31.875793" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:31.875837" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:31.807684" elapsed="0.068193"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:31.876072" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:31.875957" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.875937" elapsed="0.000225"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.876612" elapsed="0.000044"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.876995" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.877070" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:31.806928" elapsed="0.070255"/>
</kw>
<msg time="2026-06-06T03:31:31.877281" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:31.877330" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:31.801939" elapsed="0.075444"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.877805" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.877465" elapsed="0.000429"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.877447" elapsed="0.000479"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:31.801759" elapsed="0.076200"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:31.801557" elapsed="0.076444"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:31.799029" elapsed="0.079047"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:31.792070" elapsed="0.086082"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:31.791406" elapsed="0.086805"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:31.787229" elapsed="0.091073"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.922076" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:31.921672" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.922901" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:31.922631" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:31.923074" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:31.922284" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.923675" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:31.923270" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:31.924013" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/bgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:31.924177" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:31.923871" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.924613" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.924365" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.925675" level="INFO">mapping: {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.925388" elapsed="0.000336"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.926196" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.925920" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.926924" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.926603" elapsed="0.000347"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.927723" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.927477" elapsed="0.000274"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.927805" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:31.927966" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.927144" elapsed="0.000848"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.928154" elapsed="0.000243"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:31:31.926461" elapsed="0.001977"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.929012" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.928709" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.929975" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.929552" elapsed="0.000450"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.930054" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:31.930207" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.929229" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.930389" elapsed="0.000228"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:31.928555" elapsed="0.002120"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.931227" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.930925" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.932063" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.931848" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.932141" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:31.932293" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.931504" elapsed="0.000814"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.932474" elapsed="0.000241"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:31.930789" elapsed="0.001968"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.933309" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.933008" elapsed="0.000327"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.934110" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.933894" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.934188" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:31.934339" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.933523" elapsed="0.000841"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.934520" elapsed="0.000243"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:31.932870" elapsed="0.001935"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.935360" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.935056" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.936127" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.935916" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.936203" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:31.936351" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.935576" elapsed="0.000800"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.936529" elapsed="0.000238"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:31.934919" elapsed="0.001889"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.937413" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:31.937056" elapsed="0.000383"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:31.938209" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.937993" elapsed="0.000243"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:31.938287" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:31.938438" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:31.937629" elapsed="0.000833"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:31.938618" elapsed="0.000244"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:31.936920" elapsed="0.001984"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:31.926276" elapsed="0.012664"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:31.938984" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:31.939145" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:31.925056" elapsed="0.014115"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.924749" elapsed="0.014455"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.939386" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.939231" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.924729" elapsed="0.014736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.940308" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:31.939616" elapsed="0.000721"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:31.940388" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:31.921027" elapsed="0.019486"/>
</kw>
<msg time="2026-06-06T03:31:31.940619" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:31.908220" elapsed="0.032466"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.953408" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.965913" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/bgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.978442" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.978678" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.978870" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.979276" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.979122" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:31.979104" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.979505" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.979697" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.979870" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:31.979066" elapsed="0.000857"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.978952" elapsed="0.000998"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.980100" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:31.980177" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:31:31.980324" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:31.903524" elapsed="0.076829"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:31.981544" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.981257" elapsed="0.000408"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:31.992203" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:31.992270" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:31.992417" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:31.983828" elapsed="0.008626"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.981737" elapsed="0.010775"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:31.992802" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:31.992548" elapsed="0.000343"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.981718" elapsed="0.011202"/>
</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-06-06T03:31:31.997668" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.994353" elapsed="0.003379"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.994034" elapsed="0.003748"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.994008" elapsed="0.003810"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.001477" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:31.998258" elapsed="0.003283"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:31.997937" elapsed="0.003655"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:31.997910" elapsed="0.003719"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.002467" 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-06-06T03:31:32.001922" elapsed="0.000583"/>
</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-06-06T03:31:32.002987" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.002610" elapsed="0.000459"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.003786" 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-06-06T03:31:32.003339" elapsed="0.000485"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.003104" elapsed="0.000769"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.002582" elapsed="0.001320"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.004636" 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-06-06T03:31:32.004132" elapsed="0.000563"/>
</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-06-06T03:31:32.005131" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.004795" elapsed="0.000416"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.006013" 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-06-06T03:31:32.005474" elapsed="0.000577"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.005244" elapsed="0.000858"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.004769" elapsed="0.001362"/>
</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-06-06T03:31:32.006355" elapsed="0.000438"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:32.007262" 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-06-06T03:31:32.006965" elapsed="0.000323"/>
</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-06-06T03:31:32.007449" elapsed="0.002548"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:31.993414" elapsed="0.016650"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:32.010114" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:32.012392" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:31.980624" elapsed="0.031795"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:32.012534" elapsed="0.000029"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/bgp_peer</arg>
<arg>mapping=${RT_CONSTRAIN_ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:31.878586" elapsed="0.134092"/>
</kw>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:31:31.786419" elapsed="0.226387"/>
</test>
<test id="s1-s18-t14" name="Deconfigure_App_Peer" line="115">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:32.016043" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:32.015772" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.017332" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.017220" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.017200" elapsed="0.000251"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.022439" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.022331" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.022313" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.023519" 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-06-06T03:31:32.023136" elapsed="0.000409"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.024025" 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-06-06T03:31:32.023726" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:32.024095" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:32.024248" 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-06-06T03:31:32.022755" elapsed="0.001517"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:32.029914" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.029786" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.029766" elapsed="0.000217"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:32.031207" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.031099" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.031080" elapsed="0.000195"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:32.031744" 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-06-06T03:31:32.031426" elapsed="0.000345"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.032157" level="INFO">${current_connection_index} = 7</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-06-06T03:31:32.031938" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.063121" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:32.032710" elapsed="0.030613"/>
</kw>
<msg time="2026-06-06T03:31:32.063598" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:32.063699" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:32.032349" elapsed="0.031408"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.092968" level="INFO">". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:31:32.064672" elapsed="0.028406"/>
</kw>
<msg time="2026-06-06T03:31:32.093241" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:32.093287" level="INFO">${message_wait} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "...</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-06-06T03:31:32.064073" elapsed="0.029251"/>
</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-06-06T03:31:32.093703" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.093417" elapsed="0.000415"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.093391" elapsed="0.000469"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.094355" level="INFO"> ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:31:32.094042" elapsed="0.000387"/>
</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-06-06T03:31:32.094747" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.094500" elapsed="0.000305"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.094480" elapsed="0.000349"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:32.094866" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:32.097451" elapsed="0.000214"/>
</kw>
<msg time="2026-06-06T03:31:32.097730" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:32.096409" elapsed="0.001456"/>
</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="NOT RUN" start="2026-06-06T03:31:32.098191" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.098534" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:32.095762" elapsed="0.002982"/>
</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-06-06T03:31:32.095179" elapsed="0.003631"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:32.030793" elapsed="0.068118"/>
</kw>
<msg time="2026-06-06T03:31:32.099007" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:32.099052" level="INFO">${message} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:32.030139" elapsed="0.068951"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:32.099279" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:32.099168" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.099149" elapsed="0.000215"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.099800" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.100145" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.100218" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:32.029429" elapsed="0.070900"/>
</kw>
<msg time="2026-06-06T03:31:32.100426" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:32.100471" level="INFO">${output} =  ". "t "x "t ". "0 "8 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n ". "D "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:32.024663" elapsed="0.075847"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.100871" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.100587" elapsed="0.000340"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.100569" elapsed="0.000381"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:32.024502" elapsed="0.076472"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:32.024329" elapsed="0.076678"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:32.021970" elapsed="0.079093"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:32.016927" elapsed="0.084194"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:32.016468" elapsed="0.084701"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:32.013549" elapsed="0.087674"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.146881" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:32.146436" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:32.147727" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:32.147457" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:32.147899" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:32.147102" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.148488" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:32.148095" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:32.148844" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:32.149008" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:32.148698" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.149463" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.149199" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.150610" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.150347" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.151121" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.150846" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.151917" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:32.151579" elapsed="0.000365"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:32.152756" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.152513" elapsed="0.000269"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:32.152838" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:32.152997" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:32.152160" elapsed="0.000862"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.153183" elapsed="0.000244"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:31:32.151418" elapsed="0.002050"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.154060" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:32.153743" elapsed="0.000343"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:32.155258" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.154600" elapsed="0.000715"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:32.155367" elapsed="0.000057"/>
</return>
<msg time="2026-06-06T03:31:32.155666" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:32.154276" elapsed="0.001460"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.155906" elapsed="0.000256"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:32.153584" elapsed="0.002619"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:32.151221" elapsed="0.005017"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:32.156281" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:32.156440" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:32.150014" elapsed="0.006451"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.149590" elapsed="0.006991"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.156788" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.156613" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.149566" elapsed="0.007300"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.157625" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:32.157016" elapsed="0.000654"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:32.157721" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:32.145682" elapsed="0.012165"/>
</kw>
<msg time="2026-06-06T03:31:32.157931" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:32.132134" elapsed="0.025847"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.171657" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.184731" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.198172" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.198379" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.198567" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.198993" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.198842" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:32.198827" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.199218" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.199389" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.199556" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:32.198797" elapsed="0.000811"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.198677" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.199801" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.199877" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:32.200042" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:32.127364" elapsed="0.072706"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.201200" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.200942" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:32.210218" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node07jhh7w8qu65dglrs342pugbl27.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:32.210277" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:32.210383" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:32.203387" elapsed="0.007024"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.201316" elapsed="0.009143"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:32.210740" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.210489" elapsed="0.000341"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.201298" elapsed="0.009562"/>
</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-06-06T03:31:32.216001" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.212331" elapsed="0.003734"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.212005" elapsed="0.004110"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.211978" elapsed="0.004173"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.219829" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.216555" elapsed="0.003340"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.216231" elapsed="0.003713"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.216207" elapsed="0.003773"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.220796" 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-06-06T03:31:32.220232" elapsed="0.000603"/>
</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-06-06T03:31:32.221282" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.220936" elapsed="0.000429"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.222121" 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-06-06T03:31:32.221656" elapsed="0.000503"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.221401" elapsed="0.000810"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.220909" elapsed="0.001333"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.222901" 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-06-06T03:31:32.222477" elapsed="0.000452"/>
</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-06-06T03:31:32.223246" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.223001" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.223812" 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-06-06T03:31:32.223497" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:32.223329" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.222982" elapsed="0.000914"/>
</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-06-06T03:31:32.224054" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:32.224939" 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-06-06T03:31:32.224628" elapsed="0.000339"/>
</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-06-06T03:31:32.225149" elapsed="0.002329"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:32.211385" elapsed="0.016158"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:32.227591" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:32.229861" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:32.200340" elapsed="0.029549"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:32.229973" elapsed="0.000029"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/app_peer</arg>
<arg>mapping=${RT_CONSTRAIN_APP_PEER}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:32.101457" elapsed="0.128647"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:31:32.013024" elapsed="0.217200"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:31:32.230924" elapsed="0.000430"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:32.231595" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:31:32.231520" elapsed="0.000174"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:31:32.230698" elapsed="0.001051"/>
</kw>
<doc>Functional test for bgp - route-target-constrain safi

Copyright (c) 2018 AT&amp;T Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distbmution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests advertising rt-constrain routes to odl. For advertising from peer,
play.py is used, sending hex messages to odl.
For advertising to app-peer, we are sending post requests with routes in xml.</doc>
<status status="PASS" start="2026-06-06T03:30:59.696303" elapsed="32.535476"/>
</suite>
<suite id="s1-s19" name="090 Bgp Functional Rt Constrain Validation" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/090_bgp_functional_rt_constrain_validation.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.333504" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:31:32.329075" elapsed="0.004484"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:31:32.328830" elapsed="0.004804"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.338706" 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-06-06T03:31:32.334819" elapsed="0.003917"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:31:32.338957" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.338825" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.338798" elapsed="0.000229"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.339549" 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-06-06T03:31:32.339193" elapsed="0.000399"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.340095" 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-06-06T03:31:32.339783" elapsed="0.000339"/>
</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-06-06T03:31:32.340660" elapsed="0.000290"/>
</kw>
<msg time="2026-06-06T03:31:32.341049" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:32.341095" 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-06-06T03:31:32.340296" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.341685" 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-06-06T03:31:32.341297" elapsed="0.000416"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.342776" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:31:32.342457" elapsed="0.000347"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.343220" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:31:32.342962" elapsed="0.000284"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.343724" 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-06-06T03:31:32.343414" elapsed="0.000338"/>
</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-06-06T03:31:32.347211" elapsed="0.000212"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.347934" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:31:32.347592" elapsed="0.000369"/>
</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-06-06T03:31:32.348124" elapsed="0.000229"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.349173" 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-06-06T03:31:32.348877" elapsed="0.000323"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:31:32.349245" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:32.349403" 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-06-06T03:31:32.348552" elapsed="0.000877"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:32.350070" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e472fb10&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-06-06T03:31:32.349594" elapsed="0.000619"/>
</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-06-06T03:31:32.350386" elapsed="0.000193"/>
</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-06-06T03:31:32.346621" elapsed="0.004032"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:32.346426" elapsed="0.004273"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:31:32.343885" elapsed="0.006846"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.351304" 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-06-06T03:31:32.350904" elapsed="0.000443"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.351941" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:31:32.351518" elapsed="0.000466"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.352545" 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-06-06T03:31:32.352157" elapsed="0.000431"/>
</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-06-06T03:31:32.341994" elapsed="0.010672"/>
</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-06-06T03:31:32.334449" elapsed="0.018275"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.352904" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.352790" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.352771" elapsed="0.000200"/>
</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-06-06T03:31:32.356187" 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-06-06T03:31:32.355804" elapsed="0.000410"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.356703" 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-06-06T03:31:32.356384" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:32.356776" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:32.356931" 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-06-06T03:31:32.355445" elapsed="0.001511"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:32.357978" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:31:32.357692" elapsed="0.000313"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.358792" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:31:32.358937" 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-06-06T03:31:32.358605" elapsed="0.000359"/>
</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-06-06T03:31:32.362715" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.361995" elapsed="0.000809"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.361973" elapsed="0.000870"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.363490" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:31:32.363052" elapsed="0.000740"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.364749" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.364070" elapsed="0.000785"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.366079" 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-06-06T03:31:32.365135" elapsed="0.000996"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.368069" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:31:32.368250" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:32.367667" elapsed="0.000626"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:32.368668" elapsed="0.000480"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.370382" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:31:32.700301" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:30:38 UTC 2026

  System load:  0.16               Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:31:00 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:31:32.370048" elapsed="0.330413"/>
</kw>
<msg time="2026-06-06T03:31:32.700548" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:32.369522" elapsed="0.331219"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:31:32.366720" elapsed="0.334169"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.701773" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:31:32.714781" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:31:32.714983" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:31:32.715096" 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-06-06T03:31:32.701268" elapsed="0.013879"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:32.715496" elapsed="0.000551"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.717351" 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-06-06T03:31:32.716735" elapsed="0.000723"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.717932" elapsed="0.000053"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.717662" elapsed="0.000418"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.717617" elapsed="0.000503"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:31:32.718427" elapsed="0.000064"/>
</return>
<status status="PASS" start="2026-06-06T03:31:32.718203" elapsed="0.000367"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.718185" elapsed="0.000507"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.718760" elapsed="0.000017"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:32.722343" elapsed="0.000479"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.723111" elapsed="0.000292"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:32.723698" elapsed="0.000225"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:32.719256" elapsed="0.004738"/>
</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-06-06T03:31:32.361005" elapsed="0.363168"/>
</kw>
<msg time="2026-06-06T03:31:32.724230" 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-06-06T03:31:32.360171" elapsed="0.364116"/>
</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-06-06T03:31:32.359677" elapsed="0.364693"/>
</kw>
<msg time="2026-06-06T03:31:32.724413" 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-06-06T03:31:32.359133" elapsed="0.365327"/>
</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-06-06T03:31:32.727280" elapsed="0.000314"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.727789" elapsed="0.000148"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:32.728096" elapsed="0.000097"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:32.724858" elapsed="0.003387"/>
</kw>
<msg time="2026-06-06T03:31:32.728337" 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-06-06T03:31:32.358234" elapsed="0.370128"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.728885" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.728562" elapsed="0.000364"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:31:32.728969" elapsed="0.000029"/>
</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-06-06T03:31:32.357311" elapsed="0.371784"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:32.357133" elapsed="0.371999"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:32.357007" elapsed="0.372160"/>
</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-06-06T03:31:32.353198" elapsed="0.376025"/>
</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-06-06T03:31:32.729390" elapsed="0.000212"/>
</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-06-06T03:31:32.743953" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.743825" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.743801" elapsed="0.000228"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.744369" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:31:32.744477" 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-06-06T03:31:32.744210" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.744962" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.744687" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.745413" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:32.745167" elapsed="0.000291"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:32.746295" 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-06-06T03:31:32.746061" elapsed="0.000345">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:31:32.746594" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:31:32.746662" 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-06-06T03:31:32.745628" elapsed="0.001060"/>
</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-06-06T03:31:32.747006" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:32.746767" elapsed="0.000316"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.746747" elapsed="0.000361"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:32.747900" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:31:32.747613" elapsed="0.000313"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:31:32.747976" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:32.748130" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:31:32.747328" elapsed="0.000826"/>
</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-06-06T03:31:32.748318" elapsed="0.000427"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.749033" level="INFO">index=4
host=10.30.170.38
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-06-06T03:31:32.749133" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:31:32.748926" elapsed="0.000234"/>
</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-06-06T03:31:32.749320" elapsed="0.002507"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.752265" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:31:32.910863" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.752003" elapsed="0.159049"/>
</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-06-06T03:31:32.914634" elapsed="0.000385"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:32.915197" elapsed="0.000166"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:32.915522" elapsed="0.000102"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:32.912244" elapsed="0.003457"/>
</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-06-06T03:31:32.911523" elapsed="0.004228"/>
</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-06-06T03:31:32.743475" elapsed="0.172330"/>
</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-06-06T03:31:32.730384" elapsed="0.185471"/>
</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-06-06T03:31:32.729972" elapsed="0.185938"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:32.729825" elapsed="0.186128"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:31:32.729673" elapsed="0.186316"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:31:32.333990" elapsed="0.582060"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.918931" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.918808" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.918786" elapsed="0.000222"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:32.923943" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.923835" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.923817" elapsed="0.000194"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.925007" 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-06-06T03:31:32.924596" elapsed="0.000438"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:32.925502" 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-06-06T03:31:32.925206" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:32.925572" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:32.925752" 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-06-06T03:31:32.924248" elapsed="0.001529"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:32.931514" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.931404" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.931384" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:32.932816" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:32.932685" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:32.932664" elapsed="0.000222"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:32.933363" 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-06-06T03:31:32.933041" elapsed="0.000349"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.933801" 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-06-06T03:31:32.933558" elapsed="0.000269"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:32.968470" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:32.934534" elapsed="0.034395"/>
</kw>
<msg time="2026-06-06T03:31:32.969297" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:32.969405" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:31:32.933997" elapsed="0.035507"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.047402" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "9 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "v "a "l "i "d "a "t "i "o "n ". "r "o "b "o "t "[K"
[?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-06-06T03:31:32.971219" elapsed="0.076377"/>
</kw>
<msg time="2026-06-06T03:31:33.047761" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:33.047808" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:31:32.970142" elapsed="0.077703"/>
</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-06-06T03:31:33.048284" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.047954" elapsed="0.000487"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.047919" elapsed="0.000557"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.049050" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "0 "9 "0 "_ "b "g "[78Cp "[A[78C_
 "f "u "n "c "t "i "o "n "a "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "v "a "l "i "d "a "t "i "o "n ". "r "o "b "o "t "[K"
[?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-06-06T03:31:33.048655" elapsed="0.000493"/>
</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-06-06T03:31:33.049485" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.049220" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.049198" elapsed="0.000571"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:33.049812" elapsed="0.000045"/>
</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-06-06T03:31:33.052186" elapsed="0.000493"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.053046" elapsed="0.000323"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:33.053741" elapsed="0.000249"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:33.051185" elapsed="0.002977"/>
</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-06-06T03:31:33.050208" elapsed="0.004099"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:32.932375" elapsed="0.122040"/>
</kw>
<msg time="2026-06-06T03:31:33.054516" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:33.054562" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:32.931759" elapsed="0.122842"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:33.054824" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:33.054708" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.054684" elapsed="0.000227"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.055341" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.055785" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.055861" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:32.931112" elapsed="0.124863"/>
</kw>
<msg time="2026-06-06T03:31:33.056075" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:33.056120" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:32.926188" elapsed="0.129969"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.056502" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.056236" elapsed="0.000321"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.056218" elapsed="0.000362"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:32.926008" elapsed="0.130597"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:32.925833" elapsed="0.130822"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:32.923530" elapsed="0.133190"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:31:32.916766" elapsed="0.140016"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:32.916219" elapsed="0.140615"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:31:32.328480" elapsed="0.728423"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.057442" level="INFO">${conn_id} = 7</msg>
<var>${conn_id}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=6s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.057073" elapsed="0.000397"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.058015" level="INFO">${conn_id} = 7</msg>
<arg>${conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:31:33.057672" elapsed="0.000392"/>
</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-06-06T03:31:33.060339" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:31:33.060418" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:33.059636" elapsed="0.000806"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.060613" elapsed="0.000588"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.062202" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:31:33.400790" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:30:38 UTC 2026

  System load:  0.16               Processes:             122
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:31:32 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:31:33.061844" elapsed="0.339099"/>
</kw>
<msg time="2026-06-06T03:31:33.401031" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.061447" elapsed="0.339674"/>
</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-06-06T03:31:33.059158" elapsed="0.342081"/>
</kw>
<msg time="2026-06-06T03:31:33.401295" 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-06-06T03:31:33.058748" elapsed="0.342595"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:31:33.058352" elapsed="0.343069"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:33.402043" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e59bb9d0&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:31:33.401682" elapsed="0.000579"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.413473" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:31:33.428287" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../../tools/fastbgp/play.py' -&gt; '/home/jenkins//play.py'</msg>
<arg>${PLAY_SCRIPT}</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:31:33.402443" elapsed="0.025930"/>
</kw>
<kw name="Assure_Library_Ipaddr" owner="SSHKeywords">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.430408" level="INFO">Executing command 'bash -c 'cd "." &amp;&amp; python -c "import ipaddr"''.</msg>
<msg time="2026-06-06T03:31:33.463077" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:33.463355" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:31:33.463462" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:31:33.463564" 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-06-06T03:31:33.430097" elapsed="0.033523"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.465815" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:31:33.465116" elapsed="0.000810"/>
</kw>
<msg time="2026-06-06T03:31:33.466213" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:31:33.466328" 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-06-06T03:31:33.464155" elapsed="0.002229"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.467964" 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-06-06T03:31:33.466853" elapsed="0.001175"/>
</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">
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.469137" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.468243" elapsed="0.001065"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.468183" elapsed="0.001189"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="PASS" start="2026-06-06T03:31:33.469792" elapsed="0.000076"/>
</return>
<status status="PASS" start="2026-06-06T03:31:33.469508" elapsed="0.000443"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.469470" elapsed="0.000540"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.470269" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:33.470141" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:33.470104" elapsed="0.000327"/>
</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-06-06T03:31:33.470837" elapsed="0.000054"/>
</kw>
<msg time="2026-06-06T03:31:33.471202" level="INFO">${passed} = True</msg>
<var>${passed}</var>
<arg>bash -c 'cd "${target_dir}" &amp;&amp; python -c "import ipaddr"'</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-06-06T03:31:33.429519" elapsed="0.041746"/>
</kw>
<if>
<branch type="IF" condition="${passed}">
<return>
<status status="PASS" start="2026-06-06T03:31:33.471833" elapsed="0.000064"/>
</return>
<status status="PASS" start="2026-06-06T03:31:33.471567" elapsed="0.000403"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.471520" elapsed="0.000512"/>
</if>
<kw name="Put File" owner="SSHLibrary">
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPCEP/ipaddr.py</arg>
<arg>${target_dir}/</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.472441" elapsed="0.000054"/>
</kw>
<arg>target_dir=.</arg>
<doc>Tests whether ipaddr module is present on ssh-connected machine, Puts ipaddr.py to target_dir if not.</doc>
<status status="PASS" start="2026-06-06T03:31:33.428854" elapsed="0.043825"/>
</kw>
<doc>Initialize SetupUtils. Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:32.328102" elapsed="1.144718"/>
</kw>
<test id="s1-s19-t1" name="Reconfigure_ODL_To_Accept_Connection" line="57">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:33.477796" elapsed="0.000217"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:33.477494" elapsed="0.000578"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.479145" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:33.479031" elapsed="0.000161"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.479011" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.484356" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:33.484248" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.484230" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.485481" 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-06-06T03:31:33.485094" elapsed="0.000414"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.486005" 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-06-06T03:31:33.485705" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:33.486076" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:33.486252" 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-06-06T03:31:33.484703" elapsed="0.001575"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:33.491949" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:33.491839" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.491819" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:33.493245" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:33.493137" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.493118" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:33.493812" 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-06-06T03:31:33.493470" elapsed="0.000369"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.494252" level="INFO">${current_connection_index} = 7</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-06-06T03:31:33.494008" elapsed="0.000270"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.528177" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:33.494822" elapsed="0.033590"/>
</kw>
<msg time="2026-06-06T03:31:33.528838" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:33.528945" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:33.494447" elapsed="0.034579"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:33.575083" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "[78Ce "[A[78Cc
 "t "i "o "n "[K"
[?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-06-06T03:31:33.530669" elapsed="0.044536"/>
</kw>
<msg time="2026-06-06T03:31:33.575369" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:33.575415" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:33.529436" elapsed="0.046016"/>
</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-06-06T03:31:33.575881" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.575592" elapsed="0.000347"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.575568" elapsed="0.000396"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.576427" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "[78Ce "[A[78Cc
 "t "i "o "n "[K"
[?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-06-06T03:31:33.576117" elapsed="0.000390"/>
</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-06-06T03:31:33.576822" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.576575" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.576557" elapsed="0.000345"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:33.576937" elapsed="0.000031"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:33.579672" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:31:33.579885" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.578480" elapsed="0.001540"/>
</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="NOT RUN" start="2026-06-06T03:31:33.580310" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.580678" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:33.577819" elapsed="0.003049"/>
</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-06-06T03:31:33.577245" elapsed="0.003689"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:33.492831" elapsed="0.088203"/>
</kw>
<msg time="2026-06-06T03:31:33.581267" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:33.581320" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:33.492181" elapsed="0.089177"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:33.581547" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:33.581438" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.581418" elapsed="0.000213"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.582060" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.582420" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.582491" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:33.491471" elapsed="0.091127"/>
</kw>
<msg time="2026-06-06T03:31:33.582707" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:33.582752" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:33.486696" elapsed="0.096093"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.583123" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.582865" elapsed="0.000311"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.582847" elapsed="0.000353"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:33.486519" elapsed="0.096705"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:33.486337" elapsed="0.096918"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:33.483884" elapsed="0.099424"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:33.478731" elapsed="0.104632"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:33.478254" elapsed="0.105154"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:33.474406" elapsed="0.109094"/>
</kw>
<for flavor="IN ZIP">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.584716" level="INFO">&amp;{ODL_CONFIG} = { IP=127.0.0.2 | TYPE=external | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{ODL_CONFIG}</var>
<arg>IP=${ODL_${i}_IP}</arg>
<arg>TYPE=${type}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.583963" elapsed="0.000786"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.619548" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.619166" elapsed="0.000412"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.620406" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:33.620113" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:33.620595" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:33.619767" elapsed="0.000853"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.621194" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:33.620809" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.621529" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:33.621756" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:33.621392" elapsed="0.000392"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.622215" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.621954" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.623250" level="INFO">mapping: {'IP': '127.0.0.2', 'TYPE': 'external', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.622993" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.623745" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.623464" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.624437" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.624142" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.625450" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.625001" elapsed="0.000476"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.625527" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:33.625709" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.624671" elapsed="0.001063"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.625898" elapsed="0.000238"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:31:33.623999" elapsed="0.002178"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.626772" level="INFO">${value} = external</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.626458" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.627757" level="INFO">${encoded} = external</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.627308" elapsed="0.000476"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.627833" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.627982" level="INFO">${encoded_value} = external</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.626986" elapsed="0.001020"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.628205" elapsed="0.000223"/>
</kw>
<var name="${key}">TYPE</var>
<var name="${value}">external</var>
<status status="PASS" start="2026-06-06T03:31:33.626315" elapsed="0.002154"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.630460" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.628742" elapsed="0.001746"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.631495" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.631062" elapsed="0.000462"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.631576" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.631748" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.630731" elapsed="0.001042"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.631935" elapsed="0.000224"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:33.628580" elapsed="0.003620"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.632771" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.632454" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.633785" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.633316" elapsed="0.000496"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.633863" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.634015" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.632989" elapsed="0.001050"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.634225" elapsed="0.000227"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:33.632313" elapsed="0.002182"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.635077" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.634779" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.636057" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.635614" elapsed="0.000469"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.636133" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.636283" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.635291" elapsed="0.001017"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.636469" elapsed="0.000237"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:33.634607" elapsed="0.002140"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.637298" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.637000" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.638334" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.637875" elapsed="0.000486"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.638411" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.638563" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.637511" elapsed="0.001076"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.638798" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:33.636859" elapsed="0.002204"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.639608" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.639313" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.640594" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.640163" elapsed="0.000459"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.640688" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:33.640842" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.639838" elapsed="0.001028"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.641067" elapsed="0.000224"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:33.639174" elapsed="0.002158"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:33.623820" elapsed="0.017547"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:33.641410" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:33.641569" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'TYPE': 'external', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:33.622655" elapsed="0.018940"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.622334" elapsed="0.019293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.641846" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.641686" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.622313" elapsed="0.019610"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.642815" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:33.642077" elapsed="0.000767"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:33.642894" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:33.618520" elapsed="0.024498"/>
</kw>
<msg time="2026-06-06T03:31:33.643073" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.605442" elapsed="0.037679"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.705875" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.718742" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.731444" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.731682" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.731877" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.732291" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.732132" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:33.732113" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.732523" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.732712" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.732962" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:33.732073" elapsed="0.000944"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.731958" elapsed="0.001087"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.733200" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.733278" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:33.733433" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:33.601014" elapsed="0.132448"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.760916" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.760501" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.761815" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:33.761536" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:33.761989" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:33.761131" elapsed="0.000882"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.762613" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:33.762197" elapsed="0.000459"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.762976" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:33.763141" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:33.762831" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.763582" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="$TYPE-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.763335" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:33.764028" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.763724" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.764564" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'TYPE': 'external', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.764265" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.764113" elapsed="0.000514"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.763703" elapsed="0.000961"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.765501" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-gr...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:33.764825" elapsed="0.000707"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:33.765583" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:33.759872" elapsed="0.005860"/>
</kw>
<msg time="2026-06-06T03:31:33.765827" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.746586" elapsed="0.019290"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.778898" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.791872" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.804785" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.804987" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.805170" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.805542" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.805392" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:33.805377" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.805784" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.805961" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.806133" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:33.805348" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.805245" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.806389" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.806467" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:33.806588" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-gr...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:33.743824" elapsed="0.062793"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.807921" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:33.807668" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:33.808080" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:33.807303" elapsed="0.000801"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.808467" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.808212" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.809049" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.808757" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.808549" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.808192" elapsed="0.000939"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.811550" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:33.809291" elapsed="0.002286"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:33.811629" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:31:33.811805" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:33.806967" elapsed="0.004864"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.813220" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.812971" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.813681" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="external-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.813428" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.814134" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.813891" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.814617" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.814376" elapsed="0.000303"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:33.815501" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:33.815304" elapsed="0.000222"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:33.815881" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:33.815704" elapsed="0.000202"/>
</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-06-06T03:31:33.816064" elapsed="0.000210"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.816696" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.816436" elapsed="0.000305"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:33.816783" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.816937" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:33.814892" elapsed="0.002070"/>
</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-06-06T03:31:33.845868" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '291', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="external-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:31:33.845926" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:31:33 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:33.846136" 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-06-06T03:31:33.819366" elapsed="0.026798"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.817031" elapsed="0.029181"/>
</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-06-06T03:31:33.846425" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.846239" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.817013" elapsed="0.029538"/>
</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-06-06T03:31:33.849999" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.847579" elapsed="0.002462"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.847351" elapsed="0.002726"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.847332" elapsed="0.002770"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.852784" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.850409" elapsed="0.002422"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.850158" elapsed="0.002709"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.850141" elapsed="0.002752"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.853460" 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-06-06T03:31:33.853074" elapsed="0.000414"/>
</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-06-06T03:31:33.853830" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.853560" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.854440" 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-06-06T03:31:33.854090" elapsed="0.000379"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.853914" elapsed="0.000592"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.853541" elapsed="0.000986"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.855088" 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-06-06T03:31:33.854719" elapsed="0.000397"/>
</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-06-06T03:31:33.855439" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.855188" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.856010" 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-06-06T03:31:33.855709" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.855520" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.855169" elapsed="0.000923"/>
</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-06-06T03:31:33.856254" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:33.857079" 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-06-06T03:31:33.856793" elapsed="0.000313"/>
</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-06-06T03:31:33.857270" elapsed="0.002405"/>
</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-06-06T03:31:33.846992" elapsed="0.012747"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:33.859914" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:31:33.859806" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.859787" elapsed="0.000214"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:33.860157" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.860225" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:31:33.862917" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:31:33.812159" elapsed="0.050786"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:33.863013" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.863171" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:33.589510" elapsed="0.273687"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.863540" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.863297" elapsed="0.000370"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.863279" elapsed="0.000415"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:33.863728" elapsed="0.000027"/>
</return>
<arg>${EBGP_DIR}</arg>
<arg>mapping=${ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:33.585030" elapsed="0.278827"/>
</kw>
<var name="${i}">2</var>
<var name="${type}">external</var>
<status status="PASS" start="2026-06-06T03:31:33.583806" elapsed="0.280093"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.864864" level="INFO">&amp;{ODL_CONFIG} = { IP=127.0.0.3 | TYPE=internal | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{ODL_CONFIG}</var>
<arg>IP=${ODL_${i}_IP}</arg>
<arg>TYPE=${type}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.864170" elapsed="0.000723"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.899612" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.899235" elapsed="0.000422"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.900419" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:33.900176" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:33.900585" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:33.899835" elapsed="0.000775"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.901189" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:33.900805" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.901522" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:33.901691" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:33.901386" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.902151" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.901909" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.903214" level="INFO">mapping: {'IP': '127.0.0.3', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.902953" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.903707" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.903425" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.904402" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.904107" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.905433" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.904958" elapsed="0.000503"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.905512" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.905693" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.904615" elapsed="0.001104"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.905881" elapsed="0.000227"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:31:33.903964" elapsed="0.002184"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.906869" level="INFO">${value} = internal</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.906412" elapsed="0.000484"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.907945" level="INFO">${encoded} = internal</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.907486" elapsed="0.000486"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.908023" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.908175" level="INFO">${encoded_value} = internal</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.907158" elapsed="0.001041"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.908360" elapsed="0.000223"/>
</kw>
<var name="${key}">TYPE</var>
<var name="${value}">internal</var>
<status status="PASS" start="2026-06-06T03:31:33.906271" elapsed="0.002353"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.909191" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.908894" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.910201" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.909757" elapsed="0.000471"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.910305" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:33.910458" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.909403" elapsed="0.001080"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.910670" elapsed="0.000225"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:33.908753" elapsed="0.002183"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.911485" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.911189" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.912468" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.912038" elapsed="0.000456"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.912544" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:33.912716" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.911716" elapsed="0.001024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.912902" elapsed="0.000219"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:33.911048" elapsed="0.002114"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.913739" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.913412" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.914761" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.914297" elapsed="0.000491"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.914838" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.914988" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.913951" elapsed="0.001061"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.915170" elapsed="0.000222"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:33.913272" elapsed="0.002161"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.915996" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.915700" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.916987" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.916537" elapsed="0.000477"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.917066" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:33.917219" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.916210" elapsed="0.001034"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.917404" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:33.915543" elapsed="0.002155"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.918253" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:33.917957" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:33.919524" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.919093" elapsed="0.000458"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:33.919602" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:33.919771" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:33.918534" elapsed="0.001262"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:33.919958" elapsed="0.000222"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:33.917814" elapsed="0.002408"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:33.903787" elapsed="0.016469"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:33.920299" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:33.920457" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:33.902586" elapsed="0.017897"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.902287" elapsed="0.018228"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.920712" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.920539" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.902244" elapsed="0.018545"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.921597" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:33.920940" elapsed="0.000685"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:33.921709" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:33.898595" elapsed="0.023240"/>
</kw>
<msg time="2026-06-06T03:31:33.921890" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.885374" elapsed="0.036563"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.934859" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.947633" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.960510" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.960738" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.960927" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.961313" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.961157" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:33.961142" elapsed="0.000292"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.961589" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.961794" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.961972" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:33.961111" elapsed="0.000915"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.961002" elapsed="0.001050"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:33.962217" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:33.962384" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:31:33.962539" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:33.880972" elapsed="0.081596"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.990093" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.989709" elapsed="0.000412"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.990926" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:33.990701" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:33.991091" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:33.990326" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.991945" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:33.991386" elapsed="0.000598"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:33.992410" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:33.992592" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:33.992223" elapsed="0.000409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.993222" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="$TYPE-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:33.992885" elapsed="0.000406"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:33.993810" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:33.993384" elapsed="0.000507"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.994581" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:33.994144" elapsed="0.000476"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:33.993926" elapsed="0.000761"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:33.993358" elapsed="0.001366"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:33.996095" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-gr...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:33.994946" elapsed="0.001193"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:33.996269" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:33.989055" elapsed="0.007396"/>
</kw>
<msg time="2026-06-06T03:31:33.996528" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:33.975928" elapsed="0.020668"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.009989" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.022997" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.035917" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.036124" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.036320" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.036718" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.036548" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:34.036533" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.036950" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.037126" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.037310" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:34.036504" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.036399" elapsed="0.000992"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.037546" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.037622" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.037761" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-gr...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:33.972991" elapsed="0.064800"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.039179" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.038940" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.039350" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.038561" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.039726" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.039447" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.040346" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.040013" elapsed="0.000361"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.039811" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.039428" elapsed="0.001006"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.042990" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:34.040603" elapsed="0.002414"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:34.043073" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:34.043239" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:34.038171" elapsed="0.005093"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.044751" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.044470" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.045207" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.044965" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.045704" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.045437" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.046154" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.045913" elapsed="0.000286"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:34.047074" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:34.046874" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:34.047455" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:34.047265" elapsed="0.000216"/>
</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-06-06T03:31:34.047658" elapsed="0.000219"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.048295" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.048045" elapsed="0.000294"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:34.048382" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:34.048551" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:34.046435" elapsed="0.002141"/>
</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-06-06T03:31:34.061324" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Content-Length': '291', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:31:34.061380" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:34.061527" 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-06-06T03:31:34.051082" elapsed="0.010472"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.048663" elapsed="0.012943"/>
</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-06-06T03:31:34.062181" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.061683" elapsed="0.000714"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.048629" elapsed="0.013824"/>
</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-06-06T03:31:34.070477" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.064849" elapsed="0.005727"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.064257" elapsed="0.006444"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.064213" elapsed="0.006560"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.073465" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.071115" elapsed="0.002396"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.070876" elapsed="0.002671"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.070851" elapsed="0.002721"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.074338" 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-06-06T03:31:34.073781" elapsed="0.000585"/>
</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-06-06T03:31:34.074716" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.074440" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.075290" 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-06-06T03:31:34.074978" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.074800" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.074421" elapsed="0.000953"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.075934" 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-06-06T03:31:34.075551" elapsed="0.000409"/>
</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-06-06T03:31:34.076291" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.076032" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.076868" 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-06-06T03:31:34.076548" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.076374" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.076014" elapsed="0.000936"/>
</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-06-06T03:31:34.077117" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:34.077962" 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-06-06T03:31:34.077672" elapsed="0.000316"/>
</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-06-06T03:31:34.078166" elapsed="0.002423"/>
</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-06-06T03:31:34.063370" elapsed="0.017300"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:34.080853" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:34.080741" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.080721" elapsed="0.000220"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:34.081102" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.081177" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:31:34.083545" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:31:34.043627" elapsed="0.039946"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.083653" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:34.083814" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:33.869808" elapsed="0.214031"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.084241" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.083987" elapsed="0.000326"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.083968" elapsed="0.000370"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.084372" elapsed="0.000027"/>
</return>
<arg>${EBGP_DIR}</arg>
<arg>mapping=${ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:33.865175" elapsed="0.219325"/>
</kw>
<var name="${i}">3</var>
<var name="${type}">internal</var>
<status status="PASS" start="2026-06-06T03:31:33.864017" elapsed="0.220526"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.085518" level="INFO">&amp;{ODL_CONFIG} = { IP=127.0.0.4 | TYPE=internal | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{ODL_CONFIG}</var>
<arg>IP=${ODL_${i}_IP}</arg>
<arg>TYPE=${type}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.084837" elapsed="0.000710"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.120692" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.120299" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.121480" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.121241" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.121666" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.120896" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.122256" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:34.121868" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.122606" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:34.122777" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:34.122468" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.123214" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.122971" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.124237" level="INFO">mapping: {'IP': '127.0.0.4', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.123978" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.124730" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.124450" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.125429" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.125133" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.126488" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.125992" elapsed="0.000523"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.126566" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.126756" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.125660" elapsed="0.001121"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.126943" elapsed="0.000224"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:31:34.124991" elapsed="0.002257"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.127823" level="INFO">${value} = internal</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.127504" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.128960" level="INFO">${encoded} = internal</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.128506" elapsed="0.000481"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.129039" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.129191" level="INFO">${encoded_value} = internal</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.128177" elapsed="0.001038"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.129376" elapsed="0.000221"/>
</kw>
<var name="${key}">TYPE</var>
<var name="${value}">internal</var>
<status status="PASS" start="2026-06-06T03:31:34.127363" elapsed="0.002288"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.130205" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.129911" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.131220" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.130786" elapsed="0.000461"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.131298" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.131446" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.130432" elapsed="0.001038"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.131629" elapsed="0.000252"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:34.129771" elapsed="0.002151"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.132463" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.132171" elapsed="0.000318"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.133441" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.133015" elapsed="0.000453"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.133518" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:34.133689" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.132691" elapsed="0.001024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.133875" elapsed="0.000220"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:34.132031" elapsed="0.002103"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.134740" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.134413" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.135738" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.135276" elapsed="0.000489"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.135815" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:34.135964" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.134952" elapsed="0.001037"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.136147" elapsed="0.000218"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:34.134244" elapsed="0.002161"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.136966" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.136670" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.137943" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.137500" elapsed="0.000470"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.138020" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.138170" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.137177" elapsed="0.001017"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.138371" elapsed="0.000222"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:34.136515" elapsed="0.002184"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.139257" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.138960" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.140452" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.139854" elapsed="0.000625"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.140531" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.140697" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.139471" elapsed="0.001252"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.140882" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:34.138818" elapsed="0.002328"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:34.124812" elapsed="0.016368"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:34.141223" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:34.141380" level="INFO">${mapping_to_use} = {'IP': '127.0.0.4', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:34.123630" elapsed="0.017775"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.123327" elapsed="0.018111"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.141617" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.141462" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.123308" elapsed="0.018404"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.142547" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:34.141861" elapsed="0.000716"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.142628" elapsed="0.000056"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:34.119676" elapsed="0.023112"/>
</kw>
<msg time="2026-06-06T03:31:34.142843" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:34.106347" elapsed="0.036543"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.155651" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.168377" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.181053" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.181257" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.181480" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.181869" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.181715" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:34.181700" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.182099" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.182325" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.182510" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:34.181670" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.181556" elapsed="0.001033"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.182754" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.182831" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:34.182952" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:34.101816" elapsed="0.081163"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.209983" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.209591" elapsed="0.000420"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.210826" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.210549" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.210993" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.210180" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.211569" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:34.211188" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.211916" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:34.212060" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/p...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:34.211781" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.212496" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="$TYPE-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.212254" elapsed="0.000290"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:34.212923" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.212610" elapsed="0.000371"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.213451" level="INFO">${mapping_to_use} = {'IP': '127.0.0.4', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.213158" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.213006" elapsed="0.000506"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.212591" elapsed="0.000982"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.214411" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-gr...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:34.213748" elapsed="0.000693"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.214490" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:34.208973" elapsed="0.005641"/>
</kw>
<msg time="2026-06-06T03:31:34.214701" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:34.195916" elapsed="0.018844"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.229791" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.242898" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.255676" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.256032" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.256216" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.256597" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.256442" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:34.256425" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.256843" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.257018" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.257190" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:34.256395" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.256290" elapsed="0.000977"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.257420" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.257494" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:34.257618" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-gr...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:34.193217" elapsed="0.064443"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.259036" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.258793" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.259195" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.258412" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.259544" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.259289" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.260125" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.259833" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.259625" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.259270" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.262950" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:34.260366" elapsed="0.002618"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:34.263050" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:34.263209" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:34.258036" elapsed="0.005197"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.264631" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.264383" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.265094" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.264856" elapsed="0.000287"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.265544" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.265302" elapsed="0.000284"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.265997" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.265760" elapsed="0.000280"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:34.266919" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:31:34.266723" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:31:34.267310" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:31:34.267117" elapsed="0.000219"/>
</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-06-06T03:31:34.267495" elapsed="0.000222"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.268133" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.267886" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:31:34.268228" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:34.268409" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:31:34.266245" elapsed="0.002194"/>
</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-06-06T03:31:34.281750" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Content-Length': '291', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;/bgp/neighbors/neighbor/bgp/peer-groups/peer-group[peer-group-name="internal-neighbor"]&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:31:34.281878" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:34.282021" 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-06-06T03:31:34.271930" elapsed="0.010128"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.268523" elapsed="0.013598"/>
</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-06-06T03:31:34.282432" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.282159" elapsed="0.000372"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.268501" elapsed="0.014060"/>
</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-06-06T03:31:34.287370" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.283933" elapsed="0.003498"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.283587" elapsed="0.003893"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.283561" elapsed="0.003955"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.291238" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.287937" elapsed="0.003365"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.287594" elapsed="0.003757"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.287571" elapsed="0.003814"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.292196" 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-06-06T03:31:34.291660" elapsed="0.000576"/>
</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-06-06T03:31:34.292709" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.292336" elapsed="0.000457"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.293496" 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-06-06T03:31:34.293073" elapsed="0.000461"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.292827" elapsed="0.000758"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.292309" elapsed="0.001305"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.294411" 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-06-06T03:31:34.293885" elapsed="0.000563"/>
</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-06-06T03:31:34.294926" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.294550" elapsed="0.000458"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.295730" 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-06-06T03:31:34.295289" elapsed="0.000479"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.295042" elapsed="0.000776"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.294523" elapsed="0.001325"/>
</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-06-06T03:31:34.296071" elapsed="0.000489"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:34.297223" 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-06-06T03:31:34.296832" elapsed="0.000429"/>
</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-06-06T03:31:34.297492" elapsed="0.002755"/>
</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-06-06T03:31:34.283091" elapsed="0.017221"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:34.300489" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:34.300380" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.300360" elapsed="0.000215"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:31:34.300751" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.300820" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:34.303180" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:31:34.263570" elapsed="0.039637"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.303308" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:34.303466" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:34.090516" elapsed="0.212975"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.303853" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.303590" elapsed="0.000332"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.303573" elapsed="0.000373"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.303979" elapsed="0.000026"/>
</return>
<arg>${EBGP_DIR}</arg>
<arg>mapping=${ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:31:34.085846" elapsed="0.218256"/>
</kw>
<var name="${i}">4</var>
<var name="${type}">internal</var>
<status status="PASS" start="2026-06-06T03:31:34.084681" elapsed="0.219462"/>
</iter>
<var>${i}</var>
<var>${type}</var>
<value>${ODL_IP_INDICES_ALL}</value>
<value>${BGP_PEER_TYPES}</value>
<status status="PASS" start="2026-06-06T03:31:33.583567" elapsed="0.720612"/>
</for>
<doc>Configures BGP peer module with initiate-connection set to false.</doc>
<status status="PASS" start="2026-06-06T03:31:33.472952" elapsed="0.831349"/>
</test>
<test id="s1-s19-t2" name="Start_Bgp_Peers" line="72">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:34.308534" elapsed="0.000231"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:34.308256" elapsed="0.000567"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.309845" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.309733" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.309714" elapsed="0.000200"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.315217" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.315107" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.315089" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.316323" 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-06-06T03:31:34.315933" elapsed="0.000417"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.316839" 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-06-06T03:31:34.316521" elapsed="0.000345"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:34.316912" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:34.317069" 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-06-06T03:31:34.315523" elapsed="0.001590"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:34.322813" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.322703" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.322682" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:34.324128" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.324019" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.324000" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:34.324665" 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-06-06T03:31:34.324349" elapsed="0.000344"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.325082" level="INFO">${current_connection_index} = 7</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-06-06T03:31:34.324861" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.356839" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:34.325619" elapsed="0.031322"/>
</kw>
<msg time="2026-06-06T03:31:34.357123" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:34.357169" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:34.325275" elapsed="0.031929"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.391982" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "s "[K"
[?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-06-06T03:31:34.357860" elapsed="0.034245"/>
</kw>
<msg time="2026-06-06T03:31:34.392272" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:34.392318" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:34.357450" elapsed="0.034904"/>
</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-06-06T03:31:34.392746" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.392447" elapsed="0.000357"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.392419" elapsed="0.000412"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.393310" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "S "t "a "r "t "_ "B "g "p "_ "P "e "e "r "s "[K"
[?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-06-06T03:31:34.392987" elapsed="0.000394"/>
</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-06-06T03:31:34.393694" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.393449" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.393430" elapsed="0.000344"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:34.393812" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:34.396695" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:31:34.396915" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:34.395423" elapsed="0.001630"/>
</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="NOT RUN" start="2026-06-06T03:31:34.397610" elapsed="0.000120"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.398136" elapsed="0.000099"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:34.394780" elapsed="0.003638"/>
</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-06-06T03:31:34.394143" elapsed="0.004365"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:34.323635" elapsed="0.074996"/>
</kw>
<msg time="2026-06-06T03:31:34.398797" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:34.398859" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:34.323040" elapsed="0.075866"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:34.399140" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:31:34.399000" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.398977" elapsed="0.000280"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.399937" elapsed="0.000034"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.400313" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.400387" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:34.322330" elapsed="0.078170"/>
</kw>
<msg time="2026-06-06T03:31:34.400595" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:34.400657" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:34.317517" elapsed="0.083181"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.401043" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.400776" elapsed="0.000369"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.400759" elapsed="0.000413"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:34.317362" elapsed="0.083836"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:34.317181" elapsed="0.084051"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:34.314741" elapsed="0.086549"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:34.309422" elapsed="0.091928"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:34.308984" elapsed="0.092413"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:34.305593" elapsed="0.095861"/>
</kw>
<for flavor="IN ZIP">
<iter>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.402200" level="INFO">IP: 127.0.0.2</msg>
<msg time="2026-06-06T03:31:34.402272" level="INFO">as_number: 65000</msg>
<arg>IP: ${ODL_${i}_IP}</arg>
<arg>as_number: ${as_number}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.401908" elapsed="0.000403"/>
</kw>
<kw name="Start_Bgp_Peer">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.403488" level="INFO">${command} = python3 play.py --amount 0 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --asnumber=65000 --peerport=1790 --port=8002 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.2 &amp;</msg>
<var>${command}</var>
<arg>python3 play.py --amount 0 --myip=${ip} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --asnumber=${as_number} --peerport=${ODL_BGP_PORT} --port=${port} --usepeerip --debug --allf --wfr 1 &amp;&gt; ${filename} &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.403009" elapsed="0.000509"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.403987" level="INFO">python3 play.py --amount 0 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --asnumber=65000 --peerport=1790 --port=8002 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.2 &amp;</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.403740" elapsed="0.000295"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.408123" level="INFO">python3 play.py --amount 0 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --asnumber=65000 --peerport=1790 --port=8002 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.2 &amp;</msg>
<msg time="2026-06-06T03:31:34.408220" level="INFO">${output} =  python3 play.py --amount 0 --myip=127.0.0.2 --myport=17900 --peerip=10.30.170.38 --asnumber=65000 --peerport=1790 --port=8002 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.2 &amp;
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:34.404199" elapsed="0.004049"/>
</kw>
<arg>${ODL_${i}_IP}</arg>
<arg>${as_number}</arg>
<arg>800${i}</arg>
<arg>play.py.090.${i}</arg>
<doc>Starts bgp peer.</doc>
<status status="PASS" start="2026-06-06T03:31:34.402482" elapsed="0.005830"/>
</kw>
<var name="${i}">2</var>
<var name="${as_number}">65000</var>
<status status="PASS" start="2026-06-06T03:31:34.401758" elapsed="0.006596"/>
</iter>
<iter>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.408915" level="INFO">IP: 127.0.0.3</msg>
<msg time="2026-06-06T03:31:34.408985" level="INFO">as_number: 64496</msg>
<arg>IP: ${ODL_${i}_IP}</arg>
<arg>as_number: ${as_number}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.408615" elapsed="0.000408"/>
</kw>
<kw name="Start_Bgp_Peer">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.410131" level="INFO">${command} = python3 play.py --amount 0 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --asnumber=64496 --peerport=1790 --port=8003 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.3 &amp;</msg>
<var>${command}</var>
<arg>python3 play.py --amount 0 --myip=${ip} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --asnumber=${as_number} --peerport=${ODL_BGP_PORT} --port=${port} --usepeerip --debug --allf --wfr 1 &amp;&gt; ${filename} &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.409660" elapsed="0.000501"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.410600" level="INFO">python3 play.py --amount 0 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --asnumber=64496 --peerport=1790 --port=8003 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.3 &amp;</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.410330" elapsed="0.000334"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.411495" level="INFO">[?2004l[1] 6603</msg>
<msg time="2026-06-06T03:31:34.411585" level="INFO">${output} = [?2004l[1] 6603
</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:34.410832" elapsed="0.000779"/>
</kw>
<arg>${ODL_${i}_IP}</arg>
<arg>${as_number}</arg>
<arg>800${i}</arg>
<arg>play.py.090.${i}</arg>
<doc>Starts bgp peer.</doc>
<status status="PASS" start="2026-06-06T03:31:34.409160" elapsed="0.002536"/>
</kw>
<var name="${i}">3</var>
<var name="${as_number}">64496</var>
<status status="PASS" start="2026-06-06T03:31:34.408465" elapsed="0.003270"/>
</iter>
<iter>
<kw name="Log Many" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.412304" level="INFO">IP: 127.0.0.4</msg>
<msg time="2026-06-06T03:31:34.412375" level="INFO">as_number: 64496</msg>
<arg>IP: ${ODL_${i}_IP}</arg>
<arg>as_number: ${as_number}</arg>
<doc>Logs the given messages as separate entries using the INFO level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.411993" elapsed="0.000421"/>
</kw>
<kw name="Start_Bgp_Peer">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.413551" level="INFO">${command} = python3 play.py --amount 0 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --asnumber=64496 --peerport=1790 --port=8004 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.4 &amp;</msg>
<var>${command}</var>
<arg>python3 play.py --amount 0 --myip=${ip} --myport=${BGP_TOOL_PORT} --peerip=${ODL_SYSTEM_IP} --asnumber=${as_number} --peerport=${ODL_BGP_PORT} --port=${port} --usepeerip --debug --allf --wfr 1 &amp;&gt; ${filename} &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.413082" elapsed="0.000497"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.414006" level="INFO">python3 play.py --amount 0 --myip=127.0.0.4 --myport=17900 --peerip=10.30.170.38 --asnumber=64496 --peerport=1790 --port=8004 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.4 &amp;</msg>
<arg>${command}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.413765" elapsed="0.000287"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.416834" level="INFO">[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; python3 play.py --amount 0 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --asnumber=64496 --peerport=1790 --port=8003 --usepeerip --debug --allf --wfr 1 &amp;&gt; play.py.090.3 &amp;</msg>
<msg time="2026-06-06T03:31:34.416930" level="INFO">${output} = [?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt; python3 play.py --amount 0 --myip=127.0.0.3 --myport=17900 --peerip=10.30.170.38 --asnumber=64496 --peerport=1790 --port=8003 --usepeerip --debug --al...</msg>
<var>${output}</var>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:34.414263" elapsed="0.002695"/>
</kw>
<arg>${ODL_${i}_IP}</arg>
<arg>${as_number}</arg>
<arg>800${i}</arg>
<arg>play.py.090.${i}</arg>
<doc>Starts bgp peer.</doc>
<status status="PASS" start="2026-06-06T03:31:34.412551" elapsed="0.004468"/>
</kw>
<var name="${i}">4</var>
<var name="${as_number}">64496</var>
<status status="PASS" start="2026-06-06T03:31:34.411844" elapsed="0.005214"/>
</iter>
<var>${i}</var>
<var>${as_number}</var>
<value>${ODL_IP_INDICES_ALL}</value>
<value>${BGP_PEER_AS_NUMBERS}</value>
<status status="PASS" start="2026-06-06T03:31:34.401525" elapsed="0.015567"/>
</for>
<doc>Start Python speaker to connect to ODL. We give each speaker time until odl really starts to accept incoming
bgp connection. The failure happens if the incoming connection comes too quickly after configuring the peer.</doc>
<tag>local_run</tag>
<status status="PASS" start="2026-06-06T03:31:34.304757" elapsed="0.112449"/>
</test>
<test id="s1-s19-t3" name="Play_To_Odl_ext_l3vpn_rt_arg" line="82">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:34.421192" elapsed="0.000210"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:34.420921" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.422571" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.422444" elapsed="0.000174"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.422347" elapsed="0.000307"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.428111" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.428000" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.427980" elapsed="0.000202"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.429380" 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-06-06T03:31:34.428989" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.429916" 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-06-06T03:31:34.429582" elapsed="0.000368"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:34.429999" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:34.430161" 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-06-06T03:31:34.428419" elapsed="0.001773"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:34.435847" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.435737" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.435717" elapsed="0.000197"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:34.437121" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.437013" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.436994" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:34.437694" 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-06-06T03:31:34.437344" elapsed="0.000379"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.438110" level="INFO">${current_connection_index} = 7</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-06-06T03:31:34.437893" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.467328" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:34.438732" elapsed="0.028771"/>
</kw>
<msg time="2026-06-06T03:31:34.467749" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:34.467798" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:34.438328" elapsed="0.029505"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:34.520832" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "e "x "t "_ "l "3 "v "p "n "_ "r "t "_ "a "r "g "[K"
[?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-06-06T03:31:34.468478" elapsed="0.052706"/>
</kw>
<msg time="2026-06-06T03:31:34.521432" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:34.521483" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:34.468068" elapsed="0.053456"/>
</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-06-06T03:31:34.522035" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.521674" elapsed="0.000424"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.521609" elapsed="0.000517"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.522793" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "e "x "t "_ "l "3 "v "p "n "_ "r "t "_ "a "r "g "[K"
[?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-06-06T03:31:34.522288" elapsed="0.000596"/>
</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-06-06T03:31:34.523197" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.522957" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.522937" elapsed="0.000341"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:34.523319" elapsed="0.000045"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:34.526301" elapsed="0.000228"/>
</kw>
<msg time="2026-06-06T03:31:34.526598" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:34.525108" elapsed="0.001670"/>
</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="NOT RUN" start="2026-06-06T03:31:34.527108" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.527481" elapsed="0.000080"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:34.524379" elapsed="0.003430"/>
</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-06-06T03:31:34.523708" elapsed="0.004178"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:34.436708" elapsed="0.091297"/>
</kw>
<msg time="2026-06-06T03:31:34.528109" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:34.528156" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:34.436088" elapsed="0.092105"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:34.528391" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:34.528276" elapsed="0.000177"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.528255" elapsed="0.000224"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.528992" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.529562" elapsed="0.000029"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.529657" elapsed="0.000019"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:34.435370" elapsed="0.094407"/>
</kw>
<msg time="2026-06-06T03:31:34.529880" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:34.529928" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:34.430609" elapsed="0.099380"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.530360" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.530083" elapsed="0.000369"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.530063" elapsed="0.000425"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:34.430457" elapsed="0.100061"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:34.430250" elapsed="0.100305"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:34.427616" elapsed="0.103003"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:34.422074" elapsed="0.108726"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:34.421618" elapsed="0.109232"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:34.418418" elapsed="0.112492"/>
</kw>
<kw name="Play_To_Odl_Non_Removal_BgpRpcClient2">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.543076" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/announce_ext_l3vpn_rt_arg.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/announce_ext_l3vpn_rt_arg.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:34.543292" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:34.542858" elapsed="0.000462"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient2">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:34.543485" elapsed="0.003151"/>
</kw>
<arg>ext_l3vpn_rt_arg</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<doc>Read contents of file ${dir}/${totest}/announce_${totest}.hex and send it to odl.</doc>
<status status="PASS" start="2026-06-06T03:31:34.542431" elapsed="0.004322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.547754" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F127.0.0.2/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${ODL_2_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.547034" elapsed="0.000762"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.604291" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.603876" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.605197" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.604901" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.605379" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.604525" elapsed="0.000879"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.605998" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:34.605584" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.606372" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:34.606576" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:34.606199" elapsed="0.000404"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.607235" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.606791" elapsed="0.000491"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.608366" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.2/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.608100" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.608885" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.608586" elapsed="0.000326"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.609696" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.609304" elapsed="0.000420"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.611032" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.610361" elapsed="0.000701"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.611123" elapsed="0.000115"/>
</return>
<msg time="2026-06-06T03:31:34.611377" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.609920" elapsed="0.001483"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.611576" elapsed="0.000322"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.2/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:34.609155" elapsed="0.002785"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.612551" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:34.612209" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:34.613809" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.613417" elapsed="0.000420"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:34.613889" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:34.614043" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:34.612802" elapsed="0.001272"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:34.614243" elapsed="0.000307"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:34.612064" elapsed="0.002529"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:34.608969" elapsed="0.005659"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:34.614697" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:34.614860" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:34.607759" elapsed="0.007127"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.607366" elapsed="0.007552"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.615135" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.614947" elapsed="0.000248"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.607337" elapsed="0.007878"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.616040" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vp...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:34.615376" elapsed="0.000699"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:34.616134" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:34.603198" elapsed="0.013065"/>
</kw>
<msg time="2026-06-06T03:31:34.616321" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:34.589704" elapsed="0.026681"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.629628" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.643075" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.655907" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.656221" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.656426" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.656933" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.656734" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:34.656713" elapsed="0.000310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.657180" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.657356" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.657530" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:34.656635" elapsed="0.000947"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.656512" elapsed="0.001098"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.657787" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.657867" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:34.658015" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vp...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:34.585091" elapsed="0.072952"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.659587" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.659280" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.659789" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.658860" elapsed="0.000961"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.660200" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.659902" elapsed="0.000358"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.660820" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:34.660487" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:34.660285" elapsed="0.000599"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.659883" elapsed="0.001022"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.663580" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:34.661073" elapsed="0.002536"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:34.663690" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:31:34.663865" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:34.658399" elapsed="0.005492"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:34.665333" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.665030" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:34.665507" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:34.664657" elapsed="0.000875"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:34.665772" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:34.665607" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:34.665588" elapsed="0.000338"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.666090" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.666274" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.666341" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:34.668416" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:34.664268" elapsed="0.004175"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.669974" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.669706" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:34.670468" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:34.670188" elapsed="0.000326"/>
</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-06-06T03:31:34.679864" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:34.680016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:34.680116" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</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="FAIL" start="2026-06-06T03:31:34.672964" elapsed="0.007541">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:34.670585" elapsed="0.010006">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:31:34.680812" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.680624" elapsed="0.000254"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:34.670566" elapsed="0.010336">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:34.681285" elapsed="0.000024"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.681440" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:34.681399" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:34.681377" elapsed="0.000128"/>
</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-06-06T03:31:34.681678" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.681751" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:34.668831" elapsed="0.013025">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.681932" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.560285" elapsed="0.121782">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:34.682353" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:34.682165" elapsed="0.000308"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:34.682147" elapsed="0.000353"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:34.682536" elapsed="0.000016"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.554108" elapsed="0.128545">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.740017" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:36.739576" elapsed="0.000475"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:36.740912" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:36.740595" elapsed="0.000396">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:36.741089" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:36.740240" elapsed="0.000873"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.741704" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:36.741293" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:36.742050" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:36.742220" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:36.741905" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.742680" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:36.742414" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.743800" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.2/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:36.743464" elapsed="0.000383"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.744295" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:36.744020" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.745066" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:36.744715" elapsed="0.000377"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:36.746010" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:36.745636" elapsed="0.000401"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:36.746091" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:36.746249" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:36.745283" elapsed="0.000991"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:36.746491" elapsed="0.000317"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.2/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:36.744553" elapsed="0.002323"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.747630" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:36.747139" elapsed="0.000535"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:36.748559" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:36.748220" elapsed="0.000366"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:36.748651" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:36.748807" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:36.747869" elapsed="0.000963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:36.748995" elapsed="0.000271"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:36.746994" elapsed="0.002315"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:36.744378" elapsed="0.004967"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:36.749388" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:36.749545" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:36.743129" elapsed="0.006442"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:36.742805" elapsed="0.006798"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.749810" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:36.749629" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:36.742781" elapsed="0.007105"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.750620" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vp...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:36.750038" elapsed="0.000631"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:36.750720" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:36.738936" elapsed="0.011923"/>
</kw>
<msg time="2026-06-06T03:31:36.750915" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:36.725728" elapsed="0.025243"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.770160" elapsed="0.000051"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.783437" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.796183" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.796464" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.796673" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.797078" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:36.796918" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:36.796901" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.797311" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.797488" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.797676" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:36.796866" elapsed="0.000866"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.796757" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.797916" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.797993" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:36.798135" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vp...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:36.721288" elapsed="0.076875"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:36.799566" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:36.799291" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:36.799754" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:36.798899" elapsed="0.000880"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.800123" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:36.799851" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.800724" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:36.800402" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:36.800206" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:36.799832" elapsed="0.000982"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.803436" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:36.800978" elapsed="0.002486"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:36.803518" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:36.803691" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:36.798492" elapsed="0.005225"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:36.804981" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:36.804744" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:36.805141" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:36.804374" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:36.805377" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:36.805238" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:36.805219" elapsed="0.000280"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.805676" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.805861" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.805927" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:36.807935" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:36.804033" elapsed="0.003929"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.809423" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:36.809166" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:36.809899" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:36.809634" elapsed="0.000310"/>
</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-06-06T03:31:36.817654" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:36.817810" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:36.817947" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</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="FAIL" start="2026-06-06T03:31:36.812163" elapsed="0.006305">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:36.810012" elapsed="0.008577">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:31:36.818936" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:36.818661" elapsed="0.000375"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:36.809994" elapsed="0.009077">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:36.819624" elapsed="0.000059"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.819847" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:36.819791" elapsed="0.000118"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:36.819764" elapsed="0.000179"/>
</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-06-06T03:31:36.820168" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.820271" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:36.808313" elapsed="0.012110">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.820533" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:36.697382" elapsed="0.123359">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:36.821163" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:36.820892" elapsed="0.000380"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:36.820867" elapsed="0.000441"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:36.821357" elapsed="0.000021"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:36.690946" elapsed="0.130551">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.881366" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:38.880941" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:38.882279" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:38.882008" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:38.882481" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:38.881588" elapsed="0.000919"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.883140" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:38.882723" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:38.883525" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:38.883714" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:38.883376" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.884173" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:38.883912" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.885261" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.2/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:38.885002" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.885761" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:38.885474" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.886524" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:38.886172" elapsed="0.000379"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:38.887494" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:38.887120" elapsed="0.000401"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:38.887575" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:31:38.887766" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:38.886770" elapsed="0.001022"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:38.888016" elapsed="0.000293"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.2/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:38.886025" elapsed="0.002328"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.890617" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:38.888615" elapsed="0.002045"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:38.891615" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:38.891270" elapsed="0.000394"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:38.891719" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:38.891879" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:38.890874" elapsed="0.001030"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:38.892069" elapsed="0.000273"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:38.888471" elapsed="0.003915"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:38.885848" elapsed="0.006574"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:38.892466" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:38.892623" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:38.884656" elapsed="0.008010"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:38.884300" elapsed="0.008400"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.892888" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:38.892728" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.884275" elapsed="0.008691"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.893737" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vp...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:38.893118" elapsed="0.000649"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:38.893817" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:38.880245" elapsed="0.013697"/>
</kw>
<msg time="2026-06-06T03:31:38.893999" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:38.867049" elapsed="0.027001"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.906984" elapsed="0.000189"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.920223" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.932985" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.933274" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.933468" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.933891" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:38.933731" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:38.933714" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.934126" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.934303" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.934477" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:38.933677" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.933551" elapsed="0.001006"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.934728" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.934806" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:38.934947" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vp...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:38.862578" elapsed="0.072396"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:38.936388" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:38.936102" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:38.936563" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:38.935708" elapsed="0.000880"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.936954" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:38.936676" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.937534" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:38.937239" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:38.937036" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.936656" elapsed="0.000961"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.940250" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:38.937797" elapsed="0.002480"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:38.940330" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:38.940485" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:38.935335" elapsed="0.005175"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:38.941776" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:38.941528" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:38.941936" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:38.941181" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:38.942171" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:31:38.942034" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.942015" elapsed="0.000278"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.942453" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.942635" elapsed="0.000036"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.942719" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:38.944751" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:38.940846" elapsed="0.003932"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.946200" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:38.945944" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.946670" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:38.946410" elapsed="0.000305"/>
</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-06-06T03:31:38.954337" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:38.954473" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:38.954584" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</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="FAIL" start="2026-06-06T03:31:38.948949" elapsed="0.006026">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:38.946783" elapsed="0.008276">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:31:38.955276" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:38.955093" elapsed="0.000251"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:38.946764" elapsed="0.008603">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:38.955770" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.955905" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:38.955867" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:38.955849" elapsed="0.000120"/>
</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-06-06T03:31:38.956122" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.956192" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:38.945095" elapsed="0.011202">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.956371" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:38.838982" elapsed="0.117523">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:38.956814" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:38.956602" elapsed="0.000286"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:38.956585" elapsed="0.000327"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.956945" elapsed="0.000014"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:38.832514" elapsed="0.124528">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<msg time="2026-06-06T03:31:38.957146" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 3 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.548051" elapsed="4.409196">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 3 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<doc>This TC sends route-target route containing route-target argument from node 1 to odl
so odl can identify this peer as appropriate for advertizement when it recieves such route.</doc>
<status status="FAIL" start="2026-06-06T03:31:34.417685" elapsed="4.539738">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 3 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.2/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</test>
<test id="s1-s19-t4" name="Play_To_Odl_rt_constrain_type_0" line="98">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:38.961082" elapsed="0.000236"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:38.960804" elapsed="0.000572"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.962427" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:38.962307" elapsed="0.000166"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.962287" elapsed="0.000209"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:38.967635" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:38.967527" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.967508" elapsed="0.000210"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.968749" 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-06-06T03:31:38.968343" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:38.969242" 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-06-06T03:31:38.968944" elapsed="0.000324"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:38.969312" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:38.969467" 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-06-06T03:31:38.967954" elapsed="0.001537"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:38.975110" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:38.975002" elapsed="0.000153"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.974982" elapsed="0.000195"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:38.976397" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:38.976289" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:38.976270" elapsed="0.000234"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:38.976991" 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-06-06T03:31:38.976687" elapsed="0.000331"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:38.977408" level="INFO">${current_connection_index} = 7</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-06-06T03:31:38.977187" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:39.006313" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:38.977970" elapsed="0.028456"/>
</kw>
<msg time="2026-06-06T03:31:39.006589" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:39.006638" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:38.977602" elapsed="0.029098"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:39.052349" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "[78C0 "[A[78C"[K
[K
[?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-06-06T03:31:39.007404" elapsed="0.045230"/>
</kw>
<msg time="2026-06-06T03:31:39.052930" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:39.052982" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:39.006884" elapsed="0.046136"/>
</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-06-06T03:31:39.053546" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.053156" elapsed="0.000456"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.053114" elapsed="0.000545"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.054254" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "[78C0 "[A[78C"[K
[K
[?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-06-06T03:31:39.053826" elapsed="0.000515"/>
</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-06-06T03:31:39.054666" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.054412" elapsed="0.000313"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.054392" elapsed="0.000357"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:39.054790" elapsed="0.000047"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:39.057677" elapsed="0.000163"/>
</kw>
<msg time="2026-06-06T03:31:39.057904" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:39.056560" elapsed="0.001484"/>
</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="NOT RUN" start="2026-06-06T03:31:39.058336" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.058707" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:39.055842" elapsed="0.003057"/>
</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-06-06T03:31:39.055173" elapsed="0.003794"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:38.975987" elapsed="0.083081"/>
</kw>
<msg time="2026-06-06T03:31:39.059169" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:39.059215" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:38.975353" elapsed="0.083928"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:39.059478" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:39.059364" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.059344" elapsed="0.000223"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.060017" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.060462" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.060535" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:38.974664" elapsed="0.086000"/>
</kw>
<msg time="2026-06-06T03:31:39.060767" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:39.060816" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:38.969892" elapsed="0.090964"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.061225" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.060935" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.060917" elapsed="0.000391"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:38.969740" elapsed="0.091593"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:38.969550" elapsed="0.091820"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:38.967151" elapsed="0.094283"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:38.962011" elapsed="0.099486"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:38.961541" elapsed="0.100006"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:38.958273" elapsed="0.103334"/>
</kw>
<kw name="Play_To_Odl_Non_Removal_BgpRpcClient3">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:39.073728" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/announce_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:39.073913" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:39.073501" elapsed="0.000439"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient3">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:39.074105" elapsed="0.003137"/>
</kw>
<arg>rt_constrain_type_0</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<doc>Read contents of file ${dir}/${totest}/announce_${totest}.hex and send it to odl.</doc>
<status status="PASS" start="2026-06-06T03:31:39.073100" elapsed="0.004212"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.078021" level="INFO">&amp;{loc_rib} = { PATH=loc-rib | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{loc_rib}</var>
<arg>PATH=loc-rib</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:39.077532" elapsed="0.000518"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.133119" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:39.132703" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:39.134005" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:39.133726" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:39.134185" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:39.133351" elapsed="0.000859"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.134803" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:39.134388" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:39.135149" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:39.135337" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:39.135005" elapsed="0.000452"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.135923" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:39.135663" elapsed="0.000308"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.137072" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:39.136808" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.137563" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:39.137290" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.138340" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:39.137988" elapsed="0.000378"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:39.139302" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:39.138936" elapsed="0.000393"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:39.139385" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:39.139551" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:39.138559" elapsed="0.001017"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:39.139761" elapsed="0.000299"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:39.137843" elapsed="0.002259"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.140699" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:39.140357" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:39.141799" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:39.141443" elapsed="0.000384"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:39.141878" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:39.142031" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:39.140917" elapsed="0.001139"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:39.142220" elapsed="0.000286"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:39.140216" elapsed="0.002332"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:39.137660" elapsed="0.004926"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:39.142632" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:31:39.142818" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:39.136411" elapsed="0.006433"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:39.136057" elapsed="0.006820"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.143072" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.142905" elapsed="0.000245"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.136029" elapsed="0.007149"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.144154" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:39.143408" elapsed="0.000776"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:39.144234" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:39.132034" elapsed="0.012328"/>
</kw>
<msg time="2026-06-06T03:31:39.144420" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:39.118504" elapsed="0.025970"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.158163" elapsed="0.000062"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.171178" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.183980" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.184232" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.184432" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.184893" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.184728" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:39.184708" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.185133" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.185308" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.185482" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:39.184661" elapsed="0.000873"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.184520" elapsed="0.001042"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.185733" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.185815" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:39.185982" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:39.113776" elapsed="0.072237"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:39.187577" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:39.187193" elapsed="0.000483">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:39.187777" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:39.186749" elapsed="0.001054"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.188162" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.187879" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.188843" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:39.188521" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:39.188312" elapsed="0.000595"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.187859" elapsed="0.001069"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.191590" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:39.189092" elapsed="0.002525"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:39.191685" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:39.191846" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:39.186354" elapsed="0.005517"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:39.193125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:39.192888" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:39.193283" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:39.192521" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:39.193515" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:31:39.193379" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:39.193360" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.193768" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.193950" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.194016" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:39.196009" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:39.192182" elapsed="0.003853"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.197500" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:39.197205" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:39.197986" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:39.197737" elapsed="0.000293"/>
</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-06-06T03:31:39.206747" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:39.206924" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:39.207030" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</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="FAIL" start="2026-06-06T03:31:39.200367" elapsed="0.007092">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:39.198100" elapsed="0.009445">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:39.208001" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.207820" elapsed="0.000249"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:39.198081" elapsed="0.010013">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:39.208560" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.208721" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:39.208678" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:39.208658" elapsed="0.000131"/>
</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-06-06T03:31:39.208947" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.209019" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:39.196354" elapsed="0.012777">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.209210" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:39.089857" elapsed="0.119450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:39.209590" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:39.209402" elapsed="0.000277"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:39.209385" elapsed="0.000319"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:39.209737" elapsed="0.000014"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/rt_constrain_type_0/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:39.083860" elapsed="0.125974">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.268394" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:41.267936" elapsed="0.000495"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.269306" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.269019" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.269488" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.268627" elapsed="0.000887"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.270127" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:41.269712" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.270481" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:41.270746" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:41.270331" elapsed="0.000443"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.271220" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.270950" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.272400" level="INFO">mapping: {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.272131" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.272922" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.272622" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.273741" level="INFO">${value} = loc-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:41.273351" elapsed="0.000417"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:41.274702" level="INFO">${encoded} = loc-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.274328" elapsed="0.000402"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:41.274786" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:41.274951" level="INFO">${encoded_value} = loc-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:41.273970" elapsed="0.001006"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.275144" elapsed="0.000297"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">loc-rib</var>
<status status="PASS" start="2026-06-06T03:31:41.273187" elapsed="0.002297"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.276404" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:41.275811" elapsed="0.000624"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:41.277427" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.277067" elapsed="0.000387"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:41.277506" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:41.277679" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:41.276636" elapsed="0.001069"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.277871" elapsed="0.000276"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:41.275601" elapsed="0.002590"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:41.273007" elapsed="0.005219"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:41.278270" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:41.278430" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:41.271778" elapsed="0.006679"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.271357" elapsed="0.007132"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.278698" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.278514" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.271331" elapsed="0.007446"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.279550" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:41.278931" elapsed="0.000648"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:41.279678" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:41.267195" elapsed="0.012614"/>
</kw>
<msg time="2026-06-06T03:31:41.279866" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:41.253918" elapsed="0.026055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.293682" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.306621" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.319949" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.320188" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.320416" elapsed="0.000034"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.320892" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.320726" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:41.320706" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.321134" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.321312" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.321488" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:41.320664" elapsed="0.000877"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.320526" elapsed="0.001042"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.321744" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.321824" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:41.321979" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:r...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:41.249404" elapsed="0.072604"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.323466" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.323165" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.323697" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.322743" elapsed="0.000982"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.324141" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.323859" elapsed="0.000341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.324739" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:41.324424" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.324225" elapsed="0.000576"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.323838" elapsed="0.000984"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.327478" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:41.324990" elapsed="0.002515"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:41.327561" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:31:41.327773" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:41.322350" elapsed="0.005450"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.329066" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.328829" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.329225" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.328462" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:41.329457" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:31:41.329320" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.329301" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.329710" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.329892" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.329958" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:41.332020" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:41.328119" elapsed="0.003928"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.333488" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.333224" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.333967" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.333716" elapsed="0.000295"/>
</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-06-06T03:31:41.342294" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:41.342442" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/loc-rib/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '361'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}} 
 </msg>
<msg time="2026-06-06T03:31:41.342541" 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-06-06T03:31:41.336245" elapsed="0.006322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.334078" elapsed="0.008532"/>
</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-06-06T03:31:41.342838" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.342636" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.334060" elapsed="0.008919"/>
</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-06-06T03:31:41.347987" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AAL78AAAAGU=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-extended-community":{"local-administrator":"AAAAZQ==","global-administrator":64496}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.344149" elapsed="0.003909"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.343835" elapsed="0.004274"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.343816" elapsed="0.004328"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.352001" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.348558" elapsed="0.003491"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.348226" elapsed="0.003859"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.348201" elapsed="0.003910"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.352720" 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-06-06T03:31:41.352301" elapsed="0.000448"/>
</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-06-06T03:31:41.353086" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.352822" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.353673" 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-06-06T03:31:41.353350" elapsed="0.000352"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.353172" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.352803" elapsed="0.000957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.354303" 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-06-06T03:31:41.353934" elapsed="0.000397"/>
</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-06-06T03:31:41.354677" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.354402" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.355244" 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-06-06T03:31:41.354944" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.354762" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.354383" elapsed="0.000944"/>
</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-06-06T03:31:41.355490" elapsed="0.000420"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:41.356395" 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-06-06T03:31:41.356094" elapsed="0.000328"/>
</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-06-06T03:31:41.356587" elapsed="0.002361"/>
</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-06-06T03:31:41.343347" elapsed="0.015668"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.359199" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:41.359089" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.359069" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:41.362265" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:41.359425" elapsed="0.002870"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:41.362346" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:41.362503" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:41.332367" elapsed="0.030162"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:41.362591" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:31:41.362760" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:41.224979" elapsed="0.137846"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.392336" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:41.391948" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.393228" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.392908" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.393410" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.392540" elapsed="0.000895"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.394076" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:41.393612" elapsed="0.000492"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.394426" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:41.394587" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:41.394282" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.395068" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-extended-community": {
                    "global-administrator": 64496,
                    "local-administrator": "AAAAZQ=="
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.394810" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:41.395515" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.395191" elapsed="0.000388"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.396162" level="INFO">${mapping_to_use} = {'PATH': 'loc-rib', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:41.395802" elapsed="0.000387"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.395606" elapsed="0.000620"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.395170" elapsed="0.001078"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.396885" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:41.396406" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:41.396967" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:41.391247" elapsed="0.005851"/>
</kw>
<msg time="2026-06-06T03:31:41.397156" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:41.378003" elapsed="0.019201"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.410089" elapsed="0.000046"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.423257" elapsed="0.000052"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_0/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.437847" elapsed="0.000047"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.438126" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.438327" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.438785" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.438607" elapsed="0.000238"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:41.438588" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.439027" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.439210" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.439391" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:41.438548" elapsed="0.000899"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.438417" elapsed="0.001058"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.439711" elapsed="0.000032"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.439810" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:41.440029" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AAL78AAAAGU=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:41.375098" elapsed="0.064973"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:41.440350" elapsed="0.003590"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:41.445814" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:41.445149" elapsed="0.000708"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:41.446707" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:41.446107" elapsed="0.000643"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:41.447080" elapsed="0.000502"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:41.444468" elapsed="0.003271"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.444067" elapsed="0.003728"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.448073" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.447833" elapsed="0.000324"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.444037" elapsed="0.004151"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:41.364080" elapsed="0.084177"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:41.363163" elapsed="0.085207"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.362913" elapsed="0.085526"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.362895" elapsed="0.085580"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:41.448525" elapsed="0.000047"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/rt_constrain_type_0/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:41.218530" elapsed="0.230214"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${RT_CONSTRAIN_DIR}/rt_constrain_type_0/rib</arg>
<arg>mapping=${loc_rib}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:39.078232" elapsed="2.370603"/>
</kw>
<doc>Sends RT route from node 2 to odl and then checks that odl advertizes l3vpn route from previous TC.</doc>
<status status="PASS" start="2026-06-06T03:31:38.957685" elapsed="2.491338"/>
</test>
<test id="s1-s19-t5" name="Check_Presence_Of_l3vpn_Route_In_Node_2_Effective_Rib_In_Table" line="111">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:41.454032" elapsed="0.000326"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:41.453601" elapsed="0.000840"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.456067" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:41.455934" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.455910" elapsed="0.000229"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.461473" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:41.461353" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.461334" elapsed="0.000211"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.462636" 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-06-06T03:31:41.462221" elapsed="0.000459"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.463155" 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-06-06T03:31:41.462855" elapsed="0.000326"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:41.463225" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:41.463389" 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-06-06T03:31:41.461818" elapsed="0.001597"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:41.469123" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:41.469002" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.468980" elapsed="0.000215"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:41.470467" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:41.470356" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.470337" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:41.471038" 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-06-06T03:31:41.470722" elapsed="0.000343"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:41.471460" level="INFO">${current_connection_index} = 7</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-06-06T03:31:41.471239" elapsed="0.000247"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:41.502032" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:41.472157" elapsed="0.030086"/>
</kw>
<msg time="2026-06-06T03:31:41.502468" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:41.502517" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:41.471792" elapsed="0.030761"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:41.551830" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "C "h "e "c "k "_ "P "r "e "s "e "n "c "e "_ "O "f "_ "l "3 "v "p "n "_ "R "o "u "t "e "_ "[78CI "[A[78Cn
 "_ "N "o "d "e "_ "2 "_ "E "f "f "e "c "t "i "v "e "_ "R "i "b "_ "I "n "_ "T "a "b "l "e "[K"
[?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-06-06T03:31:41.503288" elapsed="0.048785"/>
</kw>
<msg time="2026-06-06T03:31:41.552298" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:41.552349" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:41.502839" elapsed="0.049548"/>
</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-06-06T03:31:41.552871" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.552498" elapsed="0.000434"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.552465" elapsed="0.000495"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.553489" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "C "h "e "c "k "_ "P "r "e "s "e "n "c "e "_ "O "f "_ "l "3 "v "p "n "_ "R "o "u "t "e "_ "[78CI "[A[78Cn
 "_ "N "o "d "e "_ "2 "_ "E "f "f "e "c "t "i "v "e "_ "R "i "b "_ "I "n "_ "T "a "b "l "e "[K"
[?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-06-06T03:31:41.553118" elapsed="0.000457"/>
</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-06-06T03:31:41.553907" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.553663" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.553627" elapsed="0.000363"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:41.554030" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:41.556904" elapsed="0.000157"/>
</kw>
<msg time="2026-06-06T03:31:41.557128" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:41.555751" elapsed="0.001521"/>
</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="NOT RUN" start="2026-06-06T03:31:41.557665" elapsed="0.000104"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.558071" elapsed="0.000296"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:41.554985" elapsed="0.003506"/>
</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-06-06T03:31:41.554373" elapsed="0.004188"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:41.470047" elapsed="0.088638"/>
</kw>
<msg time="2026-06-06T03:31:41.558787" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:41.558834" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:41.469367" elapsed="0.089504"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:41.559078" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:31:41.558956" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.558934" elapsed="0.000235"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.559613" elapsed="0.000066"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.560012" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.560139" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:41.468620" elapsed="0.091632"/>
</kw>
<msg time="2026-06-06T03:31:41.560347" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:41.560392" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:41.463839" elapsed="0.096589"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.560807" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.560505" elapsed="0.000358"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.560487" elapsed="0.000400"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:41.463684" elapsed="0.097228"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:41.463473" elapsed="0.097472"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:41.460955" elapsed="0.100046"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:41.455384" elapsed="0.105676"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:41.454709" elapsed="0.106398"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:41.450238" elapsed="0.110924"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.621858" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:41.621393" elapsed="0.000500"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.622733" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.622454" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.622910" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.622088" elapsed="0.000847"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.623508" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:41.623113" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.623917" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:41.624089" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:41.623769" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.624536" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.624285" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.625950" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.3/adj-rib-out', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.625401" elapsed="0.000598"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.626458" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.626174" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.627243" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:41.626888" elapsed="0.000382"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:41.628410" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.627899" elapsed="0.000550"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:41.628600" elapsed="0.000076"/>
</return>
<msg time="2026-06-06T03:31:41.628870" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:41.627467" elapsed="0.001440"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.629296" elapsed="0.000452"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.3/adj-rib-out</var>
<status status="PASS" start="2026-06-06T03:31:41.626740" elapsed="0.003071"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.630717" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:41.630194" elapsed="0.000565"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:41.632117" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.631628" elapsed="0.000517"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:41.632198" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:41.632354" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:41.631048" elapsed="0.001331"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:41.632543" elapsed="0.000323"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:41.629981" elapsed="0.002929"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:41.626541" elapsed="0.006405"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:41.632992" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:41.633154" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:41.625054" elapsed="0.008127"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.624682" elapsed="0.008533"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.633437" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.633245" elapsed="0.000262"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.624656" elapsed="0.008873"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.634383" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:41.633706" elapsed="0.000710"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:41.634478" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:41.620558" elapsed="0.014067"/>
</kw>
<msg time="2026-06-06T03:31:41.634713" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:41.605712" elapsed="0.029059"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.647777" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.660712" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.673457" elapsed="0.000045"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.673843" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.674049" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.674487" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.674323" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:41.674304" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.674742" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.674924" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.675103" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:41.674265" elapsed="0.000892"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.674135" elapsed="0.001050"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.675343" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.675424" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:41.675580" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:41.596017" elapsed="0.079592"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.677092" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.676795" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.677265" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.676370" elapsed="0.000920"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.677659" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.677362" elapsed="0.000357"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.678506" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:41.677945" elapsed="0.000589"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:41.677744" elapsed="0.000828"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.677343" elapsed="0.001251"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.681137" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:41.678774" elapsed="0.002391"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:41.681220" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:41.681382" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:41.676002" elapsed="0.005405"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:41.682704" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.682444" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:41.682970" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:41.682091" elapsed="0.000905"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:41.683209" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:41.683070" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:41.683050" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.683449" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.683634" elapsed="0.000064"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.683750" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:41.685745" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:41.681744" elapsed="0.004028"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.687216" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.686952" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:41.687700" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:41.687430" elapsed="0.000315"/>
</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-06-06T03:31:41.696299" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:41.696449" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:41.696571" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</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="FAIL" start="2026-06-06T03:31:41.689945" elapsed="0.007035">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:41.687814" elapsed="0.009254">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:31:41.697269" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.697102" elapsed="0.000233"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:41.687795" elapsed="0.009564">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:41.697764" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.697901" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:41.697860" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:41.697843" elapsed="0.000123"/>
</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-06-06T03:31:41.698120" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.698189" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:41.686094" elapsed="0.012200">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.698421" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.570935" elapsed="0.127586">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:41.698821" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:41.698618" elapsed="0.000279"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:41.698599" elapsed="0.000323"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:41.698956" elapsed="0.000016"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${ADJ_RIB_OUT}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.566020" elapsed="0.133035">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.759382" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:43.758894" elapsed="0.000524"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:43.760283" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:43.759990" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:43.760462" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:43.759612" elapsed="0.000875"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.761175" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:43.760699" elapsed="0.000506"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:43.761529" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:43.761788" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:43.761382" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.762234" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:43.761985" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.763375" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.3/adj-rib-out', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:43.763106" elapsed="0.000315"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.763884" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:43.763592" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.764691" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:43.764312" elapsed="0.000407"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:43.765703" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:43.765330" elapsed="0.000459"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:43.765848" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:31:43.766017" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:43.764925" elapsed="0.001117"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:43.766209" elapsed="0.000295"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.3/adj-rib-out</var>
<status status="PASS" start="2026-06-06T03:31:43.764166" elapsed="0.002381"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.767389" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:43.766853" elapsed="0.000564"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:43.768352" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:43.767983" elapsed="0.000396"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:43.768430" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:43.768584" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:43.767612" elapsed="0.001002"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:43.768840" elapsed="0.000287"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:43.766678" elapsed="0.002492"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:43.763969" elapsed="0.005236"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:43.769248" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:43.769404" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:43.762711" elapsed="0.006718"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:43.762362" elapsed="0.007099"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.769665" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:43.769487" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:43.762337" elapsed="0.007406"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.770507" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:43.769896" elapsed="0.000655"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:43.770618" elapsed="0.000052"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:43.758230" elapsed="0.012544"/>
</kw>
<msg time="2026-06-06T03:31:43.770831" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:43.744481" elapsed="0.026399"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.784185" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.797516" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.811078" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.811327" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.811524" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.812051" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:43.811808" elapsed="0.000315"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:43.811789" elapsed="0.000362"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.812309" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.812489" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.812679" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:43.811748" elapsed="0.000987"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.811612" elapsed="0.001150"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.812919" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.812998" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:43.813158" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:43.739929" elapsed="0.073259"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:43.814739" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:43.814393" elapsed="0.000428">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:43.814918" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:43.813976" elapsed="0.000967"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.815296" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:43.815016" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.815896" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:43.815578" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:43.815378" elapsed="0.000580"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:43.814997" elapsed="0.000988"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.818958" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:43.816223" elapsed="0.002769"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:43.819047" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:43.819213" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:43.813581" elapsed="0.005657"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:43.820673" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:43.820402" elapsed="0.000397">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:43.820898" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:43.819914" elapsed="0.001010"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:43.821160" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:31:43.820999" elapsed="0.000240"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:43.820979" elapsed="0.000296"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.821477" elapsed="0.000027"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.821711" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.821782" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:43.823846" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:43.819554" elapsed="0.004321"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.825430" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:43.825130" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:43.826007" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:43.825716" elapsed="0.000339"/>
</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-06-06T03:31:43.834897" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:43.835041" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:43.835145" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</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="FAIL" start="2026-06-06T03:31:43.828404" elapsed="0.007199">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:43.826123" elapsed="0.009595">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:31:43.835927" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:43.835755" elapsed="0.000244"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:43.826104" elapsed="0.009966">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:43.836485" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.836623" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:43.836585" elapsed="0.000098"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:43.836567" elapsed="0.000139"/>
</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-06-06T03:31:43.836892" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.837013" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:43.824239" elapsed="0.012927">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.837338" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:43.716309" elapsed="0.121165">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:43.837895" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:43.837607" elapsed="0.000391"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:43.837582" elapsed="0.000451"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:43.838080" elapsed="0.000020"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${ADJ_RIB_OUT}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:43.709673" elapsed="0.128560">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.898505" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:45.898094" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:45.899374" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:45.899102" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:45.899555" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:45.898744" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.900167" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:45.899774" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:45.900544" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:45.900738" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:45.900394" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.901189" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:45.900933" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.902271" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.3/adj-rib-out', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:45.902008" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.902779" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:45.902488" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.903544" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:45.903186" elapsed="0.000384"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:45.904585" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:45.904216" elapsed="0.000397"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:45.904686" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:45.904851" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:45.903793" elapsed="0.001084"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:45.905048" elapsed="0.000295"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.3/adj-rib-out</var>
<status status="PASS" start="2026-06-06T03:31:45.903040" elapsed="0.002345"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.906160" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:45.905654" elapsed="0.000533"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:45.907093" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:45.906749" elapsed="0.000370"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:45.907171" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:45.907324" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:45.906381" elapsed="0.000968"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:45.907511" elapsed="0.000293"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:45.905499" elapsed="0.002348"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:45.902862" elapsed="0.005020"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:45.907925" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:45.908084" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:45.901669" elapsed="0.006441"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:45.901318" elapsed="0.006823"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.908325" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:45.908167" elapsed="0.000249"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.901292" elapsed="0.007146"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.909213" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:45.908591" elapsed="0.000651"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:45.909291" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:45.897411" elapsed="0.012004"/>
</kw>
<msg time="2026-06-06T03:31:45.909469" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:45.884153" elapsed="0.025364"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.922302" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.935316" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.948535" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.948773" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.948965" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.949381" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:45.949210" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:45.949191" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.949619" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.949815" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.949990" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:45.949157" elapsed="0.000886"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.949047" elapsed="0.001022"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.950224" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.950302" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:31:45.950440" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:45.879190" elapsed="0.071279"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:45.951854" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:45.951563" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:45.952023" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:45.951178" elapsed="0.000872"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.952410" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:45.952125" elapsed="0.000343"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.953004" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:45.952707" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:45.952493" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.952106" elapsed="0.000981"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.955827" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:45.953248" elapsed="0.002607"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:45.955908" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:45.956064" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:45.950817" elapsed="0.005272"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:45.957381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:45.957130" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:45.957594" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:45.956780" elapsed="0.000839"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:45.957881" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:31:45.957709" elapsed="0.000249"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.957689" elapsed="0.000300"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.958198" elapsed="0.000028"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.958434" elapsed="0.000026"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.958518" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:45.960596" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:45.956426" elapsed="0.004197"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.962231" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:45.961958" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.962726" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:45.962443" elapsed="0.000331"/>
</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-06-06T03:31:45.971761" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:45.971905" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:45.972005" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</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="FAIL" start="2026-06-06T03:31:45.965022" elapsed="0.007415">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:45.962844" elapsed="0.009682">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</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-06-06T03:31:45.972748" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:45.972561" elapsed="0.000254"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:45.962825" elapsed="0.010014">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:45.973236" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.973373" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:45.973334" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:45.973316" elapsed="0.000153"/>
</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-06-06T03:31:45.973629" elapsed="0.000039"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.973719" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:45.960961" elapsed="0.012864">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.973955" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:45.853854" elapsed="0.120202">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:45.974371" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:45.974151" elapsed="0.000299"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:45.974134" elapsed="0.000340"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.974508" elapsed="0.000014"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${ADJ_RIB_OUT}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:45.847330" elapsed="0.127278">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<msg time="2026-06-06T03:31:45.974734" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 3 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</msg>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/rib</arg>
<arg>mapping=${ADJ_RIB_OUT}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.561348" elapsed="4.413483">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 3 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</kw>
<doc>Checks l3vpn route is present in node 2 effective-rib-in table.</doc>
<status status="FAIL" start="2026-06-06T03:31:41.449338" elapsed="4.525672">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 3 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.3/adj-rib-out/tables=bgp-types%3Aipv4-address-family,bgp-types%3Ampls-labeled-vpn-subsequent-address-family/bgp-vpn-ipv4:vpn-ipv4-routes</status>
</test>
<test id="s1-s19-t6" name="Check_l3vpn_Route_Advertisement_On_Each_Node" line="122">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:45.979541" elapsed="0.000363"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:45.979121" elapsed="0.000867"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.981729" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:45.981538" elapsed="0.000256"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.981510" elapsed="0.000316"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:45.988062" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:45.987952" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.987932" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.989194" 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-06-06T03:31:45.988799" elapsed="0.000422"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:45.989705" 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-06-06T03:31:45.989391" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:45.989777" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:45.989932" 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-06-06T03:31:45.988366" elapsed="0.001591"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:45.995724" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:45.995547" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.995527" elapsed="0.000272"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:45.997098" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:45.996988" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:45.996968" elapsed="0.000200"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:45.997626" 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-06-06T03:31:45.997324" elapsed="0.000346"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:45.998064" level="INFO">${current_connection_index} = 7</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-06-06T03:31:45.997841" elapsed="0.000250"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:46.033978" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:45.998607" elapsed="0.035561"/>
</kw>
<msg time="2026-06-06T03:31:46.034385" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:46.034433" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:45.998260" elapsed="0.036209"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:46.082248" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "C "h "e "c "k "_ "l "3 "v "p "n "_ "R "o "u "t "e "_ "A "d "v "e "r "t "i "s "e "m "e "n "[78Ct "[A[78C_
 "O "n "_ "E "a "c "h "_ "N "o "d "e "[K"
[?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-06-06T03:31:46.037305" elapsed="0.045070"/>
</kw>
<msg time="2026-06-06T03:31:46.082542" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:46.082588" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:46.034743" elapsed="0.047881"/>
</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-06-06T03:31:46.083014" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.082742" elapsed="0.000327"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.082713" elapsed="0.000383"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.083567" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "C "h "e "c "k "_ "l "3 "v "p "n "_ "R "o "u "t "e "_ "A "d "v "e "r "t "i "s "e "m "e "n "[78Ct "[A[78C_
 "O "n "_ "E "a "c "h "_ "N "o "d "e "[K"
[?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-06-06T03:31:46.083246" elapsed="0.000416"/>
</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-06-06T03:31:46.083961" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.083732" elapsed="0.000285"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.083713" elapsed="0.000328"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:46.084077" elapsed="0.000038"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:46.086740" elapsed="0.000149"/>
</kw>
<msg time="2026-06-06T03:31:46.086953" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:46.085691" elapsed="0.001397"/>
</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="NOT RUN" start="2026-06-06T03:31:46.087375" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.087744" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:46.085024" elapsed="0.002905"/>
</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-06-06T03:31:46.084434" elapsed="0.003559"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:45.996675" elapsed="0.091415"/>
</kw>
<msg time="2026-06-06T03:31:46.088183" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:46.088228" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:45.995964" elapsed="0.092300"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:46.088522" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:46.088411" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.088374" elapsed="0.000234"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.089038" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.089382" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.089454" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:45.995204" elapsed="0.094359"/>
</kw>
<msg time="2026-06-06T03:31:46.089683" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:46.089729" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:45.990344" elapsed="0.099421"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.090106" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.089842" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.089824" elapsed="0.000360"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:45.990190" elapsed="0.100018"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:45.990015" elapsed="0.100224"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:45.987559" elapsed="0.102734"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:45.981112" elapsed="0.109242"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:45.980242" elapsed="0.110157"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:45.975966" elapsed="0.114485"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:46.090804" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/announce_ext_l3vpn_rt_arg.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/announce_ext_l3vpn_rt_arg.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:46.090972" level="INFO">${announce} = ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065
</msg>
<var>${announce}</var>
<arg>${RT_CONSTRAIN_DIR}/ext_l3vpn_rt_arg/announce_ext_l3vpn_rt_arg.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:46.090624" elapsed="0.000374"/>
</kw>
<kw name="Remove String" owner="String">
<msg time="2026-06-06T03:31:46.091373" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</msg>
<var>${announce_hex}</var>
<arg>${announce}</arg>
<arg>\n</arg>
<doc>Removes all ``removables`` from the given ``string``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.091163" elapsed="0.000236"/>
</kw>
<kw name="Check_For_L3VPN_Odl_Avertisement">
<for flavor="IN ZIP">
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.092504" level="INFO">${keyword_name} = Get_Update_Message_And_Compare_With_Hex_BgpRpcClient2</msg>
<var>${keyword_name}</var>
<arg>Get_Update_Message_And_Compare_With_Hex_BgpRpcClient${i}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:46.092155" elapsed="0.000378"/>
</kw>
<kw name="Run Keyword" owner="BuiltIn">
<kw name="Get_Update_Message_And_Compare_With_Hex_BgpRpcClient2">
<kw name="Play Get" owner="BgpRpcClient2">
<msg time="2026-06-06T03:31:46.096494" level="INFO">${update} = ffffffffffffffffffffffffffffffff001d0200000006800f03000181</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:46.093526" elapsed="0.002996"/>
</kw>
<if>
<branch type="IF" condition="&quot;${option}&quot; == &quot;true&quot;">
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<arg>${update}</arg>
<arg>${hex}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.096866" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.096592" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.096573" elapsed="0.000377"/>
</if>
<if>
<branch type="IF" condition="&quot;${option}&quot; == &quot;false&quot;">
<kw name="Should Not Be Equal As Strings" owner="BuiltIn">
<arg>${update}</arg>
<arg>${hex}</arg>
<doc>Fails if objects are equal after converting them to strings.</doc>
<status status="PASS" start="2026-06-06T03:31:46.097223" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:46.097004" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.096988" elapsed="0.000620"/>
</if>
<arg>${announce_hex}</arg>
<arg>${option}</arg>
<doc>Returns hex update message and compares it to hex.</doc>
<status status="PASS" start="2026-06-06T03:31:46.093160" elapsed="0.004515"/>
</kw>
<arg>${keyword_name}</arg>
<arg>${announce_hex}</arg>
<arg>${option}</arg>
<doc>Executes the given keyword with the given arguments.</doc>
<status status="PASS" start="2026-06-06T03:31:46.092719" elapsed="0.005007"/>
</kw>
<var name="${i}">2</var>
<var name="${option}">false</var>
<status status="PASS" start="2026-06-06T03:31:46.092009" elapsed="0.005752"/>
</iter>
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.098356" level="INFO">${keyword_name} = Get_Update_Message_And_Compare_With_Hex_BgpRpcClient3</msg>
<var>${keyword_name}</var>
<arg>Get_Update_Message_And_Compare_With_Hex_BgpRpcClient${i}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:46.098061" elapsed="0.000321"/>
</kw>
<kw name="Run Keyword" owner="BuiltIn">
<kw name="Get_Update_Message_And_Compare_With_Hex_BgpRpcClient3">
<kw name="Play Get" owner="BgpRpcClient3">
<msg time="2026-06-06T03:31:46.102167" level="INFO">${update} = ffffffffffffffffffffffffffffffff001d0200000006800f03400447</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:46.099379" elapsed="0.002852"/>
</kw>
<if>
<branch type="IF" condition="&quot;${option}&quot; == &quot;true&quot;">
<kw name="Should Be Equal As Strings" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.103179" level="FAIL">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</msg>
<arg>${update}</arg>
<arg>${hex}</arg>
<doc>Fails if objects are unequal after converting them to strings.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.102679" elapsed="0.000600">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:46.102332" elapsed="0.001044">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</branch>
<status status="FAIL" start="2026-06-06T03:31:46.102305" elapsed="0.001117">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</if>
<if>
<branch type="IF" condition="&quot;${option}&quot; == &quot;false&quot;">
<kw name="Should Not Be Equal As Strings" owner="BuiltIn">
<arg>${update}</arg>
<arg>${hex}</arg>
<doc>Fails if objects are equal after converting them to strings.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.103763" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.103518" elapsed="0.000326"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:46.103494" elapsed="0.000383"/>
</if>
<arg>${announce_hex}</arg>
<arg>${option}</arg>
<doc>Returns hex update message and compares it to hex.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.099007" elapsed="0.004986">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</kw>
<arg>${keyword_name}</arg>
<arg>${announce_hex}</arg>
<arg>${option}</arg>
<doc>Executes the given keyword with the given arguments.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.098549" elapsed="0.005515">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</kw>
<var name="${i}">3</var>
<var name="${option}">true</var>
<status status="FAIL" start="2026-06-06T03:31:46.097910" elapsed="0.006235">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</iter>
<var>${i}</var>
<var>${option}</var>
<value>${ODL_IP_INDICES_ALL}</value>
<value>${L3VPN_RT_CHECK}</value>
<status status="FAIL" start="2026-06-06T03:31:46.091806" elapsed="0.012424">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</for>
<arg>${announce_hex}</arg>
<doc>Checks that each node received or did not receive update message containing given hex message.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.091563" elapsed="0.012796">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</kw>
<doc>Checks that each node received or did not receive update message containing given hex message.</doc>
<status status="FAIL" start="2026-06-06T03:31:45.975322" elapsed="0.129250">ffffffffffffffffffffffffffffffff001d0200000006800f03400447 != ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065</status>
</test>
<test id="s1-s19-t7" name="Play_To_Odl_rt_constrain_type_1" line="128">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:46.109599" elapsed="0.000320"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:46.109220" elapsed="0.000778"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.111412" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:46.111256" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.111229" elapsed="0.000279"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.117077" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:46.116967" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.116948" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.118180" 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-06-06T03:31:46.117789" elapsed="0.000419"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.118688" 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-06-06T03:31:46.118377" elapsed="0.000337"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:46.118760" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:31:46.118917" 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-06-06T03:31:46.117383" elapsed="0.001559"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:46.124799" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:46.124688" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.124666" elapsed="0.000202"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:46.126070" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:46.125961" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.125942" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:46.126595" 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-06-06T03:31:46.126295" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:46.127028" level="INFO">${current_connection_index} = 7</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-06-06T03:31:46.126811" elapsed="0.000243"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:46.157589" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:46.127575" elapsed="0.030157"/>
</kw>
<msg time="2026-06-06T03:31:46.157919" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:46.157972" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:46.127225" elapsed="0.030783"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:46.199010" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "[78C1 "[A[78C"[K
[K
[?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-06-06T03:31:46.158731" elapsed="0.040435"/>
</kw>
<msg time="2026-06-06T03:31:46.199352" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:46.199400" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:46.158222" elapsed="0.041214"/>
</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-06-06T03:31:46.199906" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.199551" elapsed="0.000414"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.199510" elapsed="0.000482"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.200528" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "t "_ "c "o "n "s "t "r "a "i "n "_ "t "y "p "e "_ "[78C1 "[A[78C"[K
[K
[?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-06-06T03:31:46.200150" elapsed="0.000458"/>
</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-06-06T03:31:46.200925" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.200694" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.200674" elapsed="0.000329"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:46.201046" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:46.203783" elapsed="0.000150"/>
</kw>
<msg time="2026-06-06T03:31:46.203996" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:46.202654" elapsed="0.001482"/>
</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="NOT RUN" start="2026-06-06T03:31:46.204446" elapsed="0.000083"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.204819" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:46.201988" elapsed="0.003021"/>
</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-06-06T03:31:46.201391" elapsed="0.003682"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:46.125632" elapsed="0.079539"/>
</kw>
<msg time="2026-06-06T03:31:46.205266" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:46.205311" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:46.125034" elapsed="0.080367"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:46.205593" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:46.205483" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.205463" elapsed="0.000233"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.206112" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.206459" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.206532" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:46.124296" elapsed="0.082364"/>
</kw>
<msg time="2026-06-06T03:31:46.206762" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:46.206806" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:46.119371" elapsed="0.087471"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.207181" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.206919" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.206901" elapsed="0.000359"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:46.119219" elapsed="0.088066"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:46.119046" elapsed="0.088273"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:46.116587" elapsed="0.090789"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:46.110854" elapsed="0.096580"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:46.110228" elapsed="0.097251"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:46.106009" elapsed="0.101525"/>
</kw>
<kw name="Play_To_Odl_Non_Removal_BgpRpcClient4">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:46.219860" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/announce_rt_constrain_type_1.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/announce_rt_constrain_type_1.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:46.220030" level="INFO">${announce_hex} = ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
</msg>
<var>${announce_hex}</var>
<arg>${dir}/${totest}/announce_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:46.219637" elapsed="0.000419"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient4">
<arg>${announce_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:46.220219" elapsed="0.003749"/>
</kw>
<arg>rt_constrain_type_1</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<doc>Read contents of file ${dir}/${totest}/announce_${totest}.hex and send it to odl.</doc>
<status status="PASS" start="2026-06-06T03:31:46.219100" elapsed="0.004934"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.224773" level="INFO">&amp;{effective_rib_in} = { PATH=peer=bgp:%2F%2F127.0.0.4/effective-rib-in | BGP_RIB=example-bgp-rib }</msg>
<var>&amp;{effective_rib_in}</var>
<arg>PATH=peer\=bgp:%2F%2F${ODL_4_IP}/effective-rib-in</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.224239" elapsed="0.000563"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.279686" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:46.279237" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:46.280604" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.280264" elapsed="0.000445">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:46.280810" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:46.279907" elapsed="0.000997"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.281483" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:46.281088" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:46.281846" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:46.282000" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:46.281700" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.282440" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:46.282193" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.283483" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.4/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:46.283224" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.283990" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.283719" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.284966" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.4/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:46.284394" elapsed="0.000599"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:46.285927" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.285546" elapsed="0.000408"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:46.286009" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:31:46.286174" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:46.285190" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.286364" elapsed="0.000307"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.4/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:46.284251" elapsed="0.002464"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.287290" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:46.286970" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:46.288207" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.287873" elapsed="0.000360"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:46.288283" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:46.288448" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:46.287503" elapsed="0.000971"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:46.288634" elapsed="0.000287"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:46.286828" elapsed="0.002136"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:46.284072" elapsed="0.004925"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:46.289039" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:46.289194" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:46.282890" elapsed="0.006329"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:46.282565" elapsed="0.006686"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.289440" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.289276" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.282541" elapsed="0.006975"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.290271" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:46.289686" elapsed="0.000615"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:46.290350" elapsed="0.000064"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:46.278559" elapsed="0.011954"/>
</kw>
<msg time="2026-06-06T03:31:46.290569" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:46.265187" elapsed="0.025431"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.303631" elapsed="0.000049"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.316485" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.329326" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.329536" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.329739" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.330131" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.329971" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:46.329954" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.330361" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.330536" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.330724" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:46.329923" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.329820" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.330958" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.331034" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:46.331160" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:46.260595" elapsed="0.070592"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:46.332571" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.332282" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:46.332754" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:46.331917" elapsed="0.000862"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.333320" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.332850" elapsed="0.000543"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.333954" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:46.333630" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:46.333420" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.332831" elapsed="0.001209"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.336700" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:46.334208" elapsed="0.002519"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:46.336780" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:46.336936" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:46.331556" elapsed="0.005405"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:46.338217" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.337974" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:46.338375" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:46.337608" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:46.338606" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:31:46.338470" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:46.338452" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.338868" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.339048" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.339113" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:46.341110" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:46.337268" elapsed="0.003869"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.342541" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:46.342291" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:46.343011" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:46.342767" elapsed="0.000293"/>
</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-06-06T03:31:46.350554" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:46.350715" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:31:46.350881" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</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="FAIL" start="2026-06-06T03:31:46.345386" elapsed="0.005876">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:31:46.343125" elapsed="0.008222">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</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-06-06T03:31:46.351555" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.351383" elapsed="0.000238"/>
</branch>
<status status="FAIL" start="2026-06-06T03:31:46.343107" elapsed="0.008554">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:31:46.352065" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.352200" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:46.352161" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:46.352143" elapsed="0.000122"/>
</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-06-06T03:31:46.352420" elapsed="0.000062"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.352532" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:31:46.341447" elapsed="0.011204">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.352732" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.234452" elapsed="0.118376">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:46.353105" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:46.352921" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:46.352905" elapsed="0.000295"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:46.353233" elapsed="0.000014"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/rt_constrain_type_1/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:31:46.229415" elapsed="0.123913">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.412713" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:48.412293" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.413713" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:48.413428" elapsed="0.000447">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:48.413994" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:48.413068" elapsed="0.000954"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.414610" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:48.414203" elapsed="0.000452"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.414993" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:48.415174" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-targ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:48.414833" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.415637" level="INFO">rests/data/bgp-rib:bgp-rib/rib=$BGP_RIB/$PATH/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.415377" elapsed="0.000329"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.416749" level="INFO">mapping: {'PATH': 'peer=bgp:%2F%2F127.0.0.4/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.416456" elapsed="0.000388"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.417316" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:48.417031" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.418153" level="INFO">${value} = peer=bgp:%2F%2F127.0.0.4/effective-rib-in</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:48.417781" elapsed="0.000399"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:48.419130" level="INFO">${encoded} = peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:48.418765" elapsed="0.000394"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:48.419215" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:48.419379" level="INFO">${encoded_value} = peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:48.418376" elapsed="0.001028"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:48.419572" elapsed="0.000318"/>
</kw>
<var name="${key}">PATH</var>
<var name="${value}">peer=bgp:%2F%2F127.0.0.4/effective-rib-in</var>
<status status="PASS" start="2026-06-06T03:31:48.417584" elapsed="0.002349"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.420521" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:48.420193" elapsed="0.000355"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:48.421732" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:48.421356" elapsed="0.000406"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:48.421815" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:48.421974" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:48.420983" elapsed="0.001018"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:48.422170" elapsed="0.000285"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:48.420049" elapsed="0.002449"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:48.417403" elapsed="0.005131"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:48.422579" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:48.422759" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:48.416108" elapsed="0.006678"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.415786" elapsed="0.007033"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.423006" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.422844" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.415762" elapsed="0.007324"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.423907" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:48.423279" elapsed="0.000659"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:48.423990" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:48.411637" elapsed="0.012482"/>
</kw>
<msg time="2026-06-06T03:31:48.424176" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:48.398327" elapsed="0.025898"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.437440" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.450979" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.463831" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.464066" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.464264" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.464708" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.464529" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:48.464510" elapsed="0.000314"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.464982" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.465159" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.465333" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:48.464470" elapsed="0.000915"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.464350" elapsed="0.001063"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.465569" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.465666" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:48.465829" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:48.393748" elapsed="0.072111"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.467373" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:48.467076" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:48.467546" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:48.466659" elapsed="0.000912"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.467938" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.467657" elapsed="0.000341"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.468528" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:48.468223" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.468023" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.467624" elapsed="0.000990"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.471270" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:48.468817" elapsed="0.002480"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:31:48.471351" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:48.471508" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:48.466273" elapsed="0.005260"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.472826" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:48.472539" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:48.472988" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:48.472192" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:31:48.473221" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:31:48.473084" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.473065" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.473459" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.473658" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.473727" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:31:48.475704" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:31:48.471856" elapsed="0.003874"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.477165" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.476906" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.477624" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.477378" elapsed="0.000308"/>
</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-06-06T03:31:48.486274" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:48.486464" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.4/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-route-target-constrain%3Aroute-target-constrain-subsequent-address-family/bgp-route-target-constrain:route-target-constrain-routes 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '346'} 
 body={"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}} 
 </msg>
<msg time="2026-06-06T03:31:48.486566" 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-06-06T03:31:48.479904" elapsed="0.006689"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.477754" elapsed="0.008904"/>
</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-06-06T03:31:48.486855" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.486687" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.477735" elapsed="0.009208"/>
</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-06-06T03:31:48.490701" level="INFO">{"bgp-route-target-constrain:route-target-constrain-routes":{"route-target-constrain-route":[{"path-id":0,"route-key":"AQLAAAICAHs=","attributes":{"ipv4-next-hop":{"global":"199.20.166.41"},"origin":{"value":"igp"},"local-pref":{"pref":100}},"origin-as":64511,"route-target-ipv4":{"local-administrator":123,"global-administrator":"192.0.2.2"}}]}}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.487999" elapsed="0.002754"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.487764" elapsed="0.003025"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.487744" elapsed="0.003071"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.493639" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.491107" elapsed="0.002618"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.490873" elapsed="0.002902"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.490855" elapsed="0.002955"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.494615" 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-06-06T03:31:48.494072" elapsed="0.000602"/>
</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-06-06T03:31:48.495135" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.494778" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.495938" 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-06-06T03:31:48.495496" elapsed="0.000480"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.495250" elapsed="0.000777"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.494751" elapsed="0.001305"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.496843" 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-06-06T03:31:48.496301" elapsed="0.000580"/>
</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-06-06T03:31:48.497334" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.496982" elapsed="0.000433"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.498130" 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-06-06T03:31:48.497716" elapsed="0.000449"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.497449" elapsed="0.000765"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.496956" elapsed="0.001288"/>
</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-06-06T03:31:48.498464" elapsed="0.000510"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:48.499621" 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-06-06T03:31:48.499220" elapsed="0.000459"/>
</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-06-06T03:31:48.499959" elapsed="0.002738"/>
</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-06-06T03:31:48.487316" elapsed="0.015454"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.502960" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.502847" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.502825" elapsed="0.000205"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:48.506064" level="INFO">${text_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<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="PASS" start="2026-06-06T03:31:48.503197" elapsed="0.002954"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:31:48.506207" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:48.506374" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:31:48.476044" elapsed="0.030356"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:48.506466" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:31:48.506622" level="INFO">${response_text} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:31:48.369229" elapsed="0.137434"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.535872" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:48.535477" elapsed="0.000423"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.536769" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:48.536421" elapsed="0.000446">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:48.536963" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:48.536074" elapsed="0.000915"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.537555" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:48.537165" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.537913" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:48.538074" level="INFO">${template} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:48.537771" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.538512" level="INFO">{
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
                "attributes": {
                    "ipv4-next-hop": {
                        "global": "199.20.166.41"
                    },
                    "origin": {
                        "value": "igp"
                    },
                    "local-pref": {
                        "pref": 100
                    }
                },
                "route-target-ipv4": {
                    "global-administrator": "192.0.2.2",
                    "local-administrator": 123
                },
                "origin-as": 64511
            }
        ]
    }
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.538266" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:31:48.538954" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.538630" elapsed="0.000384"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.539492" level="INFO">${mapping_to_use} = {'PATH': 'peer=bgp:%2F%2F127.0.0.4/effective-rib-in', 'BGP_RIB': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:48.539197" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.539039" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.538611" elapsed="0.000964"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.540198" level="INFO">${final_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:48.539745" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:48.540276" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:48.534845" elapsed="0.005599"/>
</kw>
<msg time="2026-06-06T03:31:48.540504" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:48.521567" elapsed="0.018986"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.553439" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.566250" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/rt_constrain/rt_constrain_type_1/rib/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.579001" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.579224" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.579416" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.579843" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.579684" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:48.579666" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.580091" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.580273" elapsed="0.000027"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.580468" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:48.579615" elapsed="0.000909"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.579503" elapsed="0.001048"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.580726" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.580826" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:48.580992" level="INFO">${expected_text} = {
    "bgp-route-target-constrain:route-target-constrain-routes": {
        "route-target-constrain-route": [
            {
                "route-key": "AQLAAAICAHs=",
                "path-id": 0,
 ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:48.518839" elapsed="0.062183"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:48.581261" elapsed="0.002513"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:48.585116" level="INFO">${expected_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:48.584589" elapsed="0.000557"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:31:48.585731" level="INFO">${actual_normalized} = {
 "bgp-route-target-constrain:route-target-constrain-routes": {
  "route-target-constrain-route": [
   {
    "attributes": {
     "ipv4-next-hop": {
      "global": "199.20.166.41"
     },
     "loca...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:31:48.585316" elapsed="0.000445"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:31:48.585944" elapsed="0.000371"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:31:48.584121" elapsed="0.002259"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.583858" elapsed="0.002558"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.586603" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.586441" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.583838" elapsed="0.002862"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:31:48.507846" elapsed="0.078906"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:31:48.507010" elapsed="0.079822"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:48.506750" elapsed="0.080129"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.506733" elapsed="0.080178"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:48.586954" elapsed="0.000031"/>
</return>
<arg>${RT_CONSTRAIN_DIR}/rt_constrain_type_1/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:31:48.363540" elapsed="0.223548"/>
</kw>
<arg>3x</arg>
<arg>2s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${RT_CONSTRAIN_DIR}/rt_constrain_type_1/rib</arg>
<arg>mapping=${effective_rib_in}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:31:46.224986" elapsed="2.362166"/>
</kw>
<kw name="Play Get" owner="BgpRpcClient4">
<msg time="2026-06-06T03:31:48.590266" level="INFO">${update} = ffffffffffffffffffffffffffffffff001d0200000006800f03000181</msg>
<var>${update}</var>
<doc>Gets the last received (update) mesage as hex string.</doc>
<status status="PASS" start="2026-06-06T03:31:48.587332" elapsed="0.002963"/>
</kw>
<doc>Sends RT route from node 3 to odl and then checks that odl does not advertize l3vpn route from previous TC,
that is that update message is empty.</doc>
<status status="PASS" start="2026-06-06T03:31:46.105082" elapsed="2.485355"/>
</test>
<test id="s1-s19-t8" name="Play_To_Odl_remove_rt" line="145">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:48.594021" elapsed="0.000222"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:48.593730" elapsed="0.000570"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.595349" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.595231" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.595212" elapsed="0.000206"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.602042" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.601877" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.601852" elapsed="0.000288"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.603581" 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-06-06T03:31:48.603044" elapsed="0.000575"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.604292" 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-06-06T03:31:48.603879" elapsed="0.000448"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:48.604390" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:31:48.604639" 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-06-06T03:31:48.602464" elapsed="0.002251"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:48.612630" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.612511" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.612490" elapsed="0.000248"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:48.614089" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.613977" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.613957" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:48.614625" 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-06-06T03:31:48.614314" elapsed="0.000357"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.615067" level="INFO">${current_connection_index} = 7</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-06-06T03:31:48.614843" elapsed="0.000251"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.642985" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:48.615616" elapsed="0.027574"/>
</kw>
<msg time="2026-06-06T03:31:48.643476" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:48.643548" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:48.615264" elapsed="0.028338"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.677268" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "e "m "o "v "e "_ "r "t "[K"
[?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-06-06T03:31:48.644555" elapsed="0.032850"/>
</kw>
<msg time="2026-06-06T03:31:48.677580" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:48.677626" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:48.643959" elapsed="0.033734"/>
</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-06-06T03:31:48.678075" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.677795" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.677765" elapsed="0.000395"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.678663" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "e "m "o "v "e "_ "r "t "[K"
[?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-06-06T03:31:48.678316" elapsed="0.000425"/>
</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-06-06T03:31:48.679036" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.678809" elapsed="0.000282"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.678790" elapsed="0.000325"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:48.679152" elapsed="0.000040"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:48.682119" elapsed="0.000299"/>
</kw>
<msg time="2026-06-06T03:31:48.682482" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:48.680888" elapsed="0.001734"/>
</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="NOT RUN" start="2026-06-06T03:31:48.682968" elapsed="0.000084"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.683331" elapsed="0.000078"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:48.680129" elapsed="0.003415"/>
</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-06-06T03:31:48.679494" elapsed="0.004119"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:48.613664" elapsed="0.070072"/>
</kw>
<msg time="2026-06-06T03:31:48.683836" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:48.683883" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:48.613003" elapsed="0.070978"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:48.684181" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:48.684067" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.684046" elapsed="0.000221"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.684774" elapsed="0.000029"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.685171" elapsed="0.000032"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.685259" elapsed="0.000018"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:48.612130" elapsed="0.073254"/>
</kw>
<msg time="2026-06-06T03:31:48.685528" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:48.685577" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:48.605323" elapsed="0.080290"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.686097" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.685747" elapsed="0.000415"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.685714" elapsed="0.000472"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:48.605172" elapsed="0.081041"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:48.604923" elapsed="0.081352"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:48.601344" elapsed="0.085046"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:48.594931" elapsed="0.091556"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:48.594464" elapsed="0.092075"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:48.591317" elapsed="0.095280"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient3">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:48.686931" elapsed="0.002802"/>
</kw>
<kw name="Play_To_Odl_Routes_Removal_Template_BgpRpcClient3">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.701987" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/withdraw_rt_constrain_type_0.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_0/withdraw_rt_constrain_type_0.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:48.702151" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0002fbf000000065
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:48.701771" elapsed="0.000407"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient3">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:48.702344" elapsed="0.001903"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient3">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:48.704433" elapsed="0.001925"/>
</kw>
<arg>rt_constrain_type_0</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<doc>Read contents of file ${dir}/${totest}/withdraw_${totest}.hex and send it to odl to remove rt argument from odl.</doc>
<status status="PASS" start="2026-06-06T03:31:48.701342" elapsed="0.005107"/>
</kw>
<doc>Removes RT from odl and then checks that second node withdrew l3vpn route and third node did not receive any message.</doc>
<status status="PASS" start="2026-06-06T03:31:48.590689" elapsed="0.115944"/>
</test>
<test id="s1-s19-t9" name="Play_To_Odl_remove_routes" line="150">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:48.711333" elapsed="0.000331"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:48.710943" elapsed="0.000804"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.713237" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.713069" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.713040" elapsed="0.000295"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.719540" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.719431" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.719412" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.720663" 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-06-06T03:31:48.720257" elapsed="0.000436"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.721262" 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-06-06T03:31:48.720946" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:48.721336" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:48.721494" 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-06-06T03:31:48.719863" elapsed="0.001657"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:48.727306" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.727194" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.727173" elapsed="0.000204"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:48.728567" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.728457" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.728438" elapsed="0.000197"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:48.729151" 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-06-06T03:31:48.728841" elapsed="0.000337"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.729567" level="INFO">${current_connection_index} = 7</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-06-06T03:31:48.729348" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.756172" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:48.730141" elapsed="0.026139"/>
</kw>
<msg time="2026-06-06T03:31:48.756448" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:48.756495" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:48.729782" elapsed="0.026749"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.803076" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "e "m "o "v "e "_ "r "o "u "t "e "s "[K"
[?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-06-06T03:31:48.757134" elapsed="0.046058"/>
</kw>
<msg time="2026-06-06T03:31:48.803355" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:48.803401" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:48.756738" elapsed="0.046698"/>
</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-06-06T03:31:48.803791" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.803519" elapsed="0.000330"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.803496" elapsed="0.000378"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.804333" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "P "l "a "y "_ "T "o "_ "O "d "l "_ "r "e "m "o "v "e "_ "r "o "u "t "e "s "[K"
[?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-06-06T03:31:48.804028" elapsed="0.000380"/>
</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-06-06T03:31:48.804722" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.804476" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.804458" elapsed="0.000345"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:48.804853" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:48.807503" elapsed="0.000167"/>
</kw>
<msg time="2026-06-06T03:31:48.807733" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:48.806385" elapsed="0.001484"/>
</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="NOT RUN" start="2026-06-06T03:31:48.808156" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.808558" elapsed="0.000077"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:48.805740" elapsed="0.003041"/>
</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-06-06T03:31:48.805165" elapsed="0.003701"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:48.728153" elapsed="0.080815"/>
</kw>
<msg time="2026-06-06T03:31:48.809065" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:48.809110" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:48.727541" elapsed="0.081609"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:48.809341" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:48.809230" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.809210" elapsed="0.000217"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.809856" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.810205" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.810278" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:48.726847" elapsed="0.083542"/>
</kw>
<msg time="2026-06-06T03:31:48.810487" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:48.810532" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:48.721924" elapsed="0.088644"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.810923" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.810661" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.810628" elapsed="0.000374"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:48.721770" elapsed="0.089256"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:48.721576" elapsed="0.089482"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:48.719065" elapsed="0.092051"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:48.712610" elapsed="0.098565"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:48.711978" elapsed="0.099244"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:48.707778" elapsed="0.103500"/>
</kw>
<kw name="Play_To_Odl_Routes_Removal_Template_BgpRpcClient2">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.823439" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/withdraw_ext_l3vpn_rt_arg.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/ext_l3vpn_rt_arg/withdraw_ext_l3vpn_rt_arg.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:48.823611" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff0045020000002e4001010040020040050400000064800f12000180708000000001010203040001010101c010080002fbf000000065
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:48.823232" elapsed="0.000419"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient2">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:48.823817" elapsed="0.003515"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient2">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:48.827506" elapsed="0.001686"/>
</kw>
<arg>ext_l3vpn_rt_arg</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<doc>Read contents of file ${dir}/${totest}/withdraw_${totest}.hex and send it to odl to remove rt argument from odl.</doc>
<status status="PASS" start="2026-06-06T03:31:48.822838" elapsed="0.006444"/>
</kw>
<kw name="Play_To_Odl_Routes_Removal_Template_BgpRpcClient4">
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.843210" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/withdraw_rt_constrain_type_1.hex"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/rt_constrain/rt_constrain_type_1/withdraw_rt_constrain_type_1.hex&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:48.843345" level="INFO">${withdraw_hex} = ffffffffffffffffffffffffffffffff003802000000214001010040020040050400000064800f10000184600000fbff0102c0000202007b
</msg>
<var>${withdraw_hex}</var>
<arg>${dir}/${totest}/withdraw_${totest}.hex</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:48.843012" elapsed="0.000359"/>
</kw>
<kw name="Play Clean" owner="BgpRpcClient4">
<doc>Cleans the message (update) on the server.</doc>
<status status="PASS" start="2026-06-06T03:31:48.843576" elapsed="0.002215"/>
</kw>
<kw name="Play Send" owner="BgpRpcClient4">
<arg>${withdraw_hex}</arg>
<doc>Sends given hex data, already encoded bgp update message is expected.</doc>
<status status="PASS" start="2026-06-06T03:31:48.845977" elapsed="0.001636"/>
</kw>
<arg>rt_constrain_type_1</arg>
<arg>${RT_CONSTRAIN_DIR}</arg>
<doc>Read contents of file ${dir}/${totest}/withdraw_${totest}.hex and send it to odl to remove rt argument from odl.</doc>
<status status="PASS" start="2026-06-06T03:31:48.842610" elapsed="0.005083"/>
</kw>
<doc>Removes rt arguments from odl.</doc>
<status status="PASS" start="2026-06-06T03:31:48.707058" elapsed="0.140769"/>
</test>
<test id="s1-s19-t10" name="Kill_Talking_BGP_Speakers" line="155">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:48.851188" elapsed="0.000222"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:48.850915" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.852507" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.852390" elapsed="0.000164"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.852370" elapsed="0.000208"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.857738" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.857613" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.857594" elapsed="0.000215"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.858843" 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-06-06T03:31:48.858437" elapsed="0.000433"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.859339" 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-06-06T03:31:48.859040" elapsed="0.000325"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:48.859411" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:48.859568" 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-06-06T03:31:48.858047" elapsed="0.001546"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:48.865545" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.865433" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.865413" elapsed="0.000203"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:48.866816" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:48.866706" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.866686" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:48.867340" 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-06-06T03:31:48.867038" elapsed="0.000329"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.867763" level="INFO">${current_connection_index} = 7</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-06-06T03:31:48.867533" elapsed="0.000256"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.894921" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:48.868301" elapsed="0.026735"/>
</kw>
<msg time="2026-06-06T03:31:48.895205" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:48.895252" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:48.867958" elapsed="0.027329"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.930680" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "s "[K"
[?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-06-06T03:31:48.895852" elapsed="0.034984"/>
</kw>
<msg time="2026-06-06T03:31:48.931034" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:48.931081" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:48.895470" elapsed="0.035647"/>
</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-06-06T03:31:48.931686" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.931212" elapsed="0.000615"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.931185" elapsed="0.000684"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.932381" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "K "i "l "l "_ "T "a "l "k "i "n "g "_ "B "G "P "_ "S "p "e "a "k "e "r "s "[K"
[?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-06-06T03:31:48.932042" elapsed="0.000415"/>
</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-06-06T03:31:48.932783" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.932527" elapsed="0.000312"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.932506" elapsed="0.000393"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:48.932943" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:48.935712" elapsed="0.000182"/>
</kw>
<msg time="2026-06-06T03:31:48.935975" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:48.934530" elapsed="0.001589"/>
</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="NOT RUN" start="2026-06-06T03:31:48.936412" elapsed="0.000078"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.936779" elapsed="0.000111"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:48.933874" elapsed="0.003135"/>
</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-06-06T03:31:48.933279" elapsed="0.003798"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:48.866379" elapsed="0.070815"/>
</kw>
<msg time="2026-06-06T03:31:48.937295" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:48.937340" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:48.865795" elapsed="0.071584"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:48.937573" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:31:48.937461" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.937440" elapsed="0.000251"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.938104" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.938455" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:48.938528" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:48.865089" elapsed="0.073565"/>
</kw>
<msg time="2026-06-06T03:31:48.938756" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:48.938801" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:48.859989" elapsed="0.078850"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:48.939186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:48.938917" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:48.938899" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:48.859838" elapsed="0.079453"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:48.859665" elapsed="0.079658"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:48.857246" elapsed="0.082133"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:48.852094" elapsed="0.087344"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:48.851627" elapsed="0.087859"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:48.848636" elapsed="0.090906"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.950070" level="INFO">Executing command 'cat play.py.090.2'.</msg>
<msg time="2026-06-06T03:31:48.964090" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:48.964390" level="INFO">${output_log} = 2026-06-06 03:31:34,492 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:34,492 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:31:34,492 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:31:48.949915" elapsed="0.014537"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:48.965735" level="INFO">2026-06-06 03:31:34,492 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:34,492 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.2
2026-06-06 03:31:34,492 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:31:34,492 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:31:34,492 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:31:34,493 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:31:34,497 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf0005ac0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job):   My Autonomous System number: 65000
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706434
2026-06-06 03:31:34,515 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Length=125 (0x007d)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   My Autonomous System=65000 (0xfde8)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706434 (0x7f000002)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=96 (0x60)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fde8
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff007d0104fde800b47f0000026002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fde8'
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff007d0104fde800b47f0000026002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fde8
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000180
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000280
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,529 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,530 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000201
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,531 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,532 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,532 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:34,532 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:34,532 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:34] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:35,534 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:35,534 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.001s
2026-06-06 03:31:35,534 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff0052020000003b4001010040020602010000fbf0800e200001800c00000000000000000a00fffe007005dc510001010203040001010101c010080002fbf000000065
2026-06-06 03:31:35,535 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:35,536 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:35,536 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:36,537 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:36,537 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.002s
2026-06-06 03:31:36,538 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:36,538 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:36,538 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:37,538 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:31:37,539 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.002s
2026-06-06 03:31:37,539 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:37,539 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:37,539 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:38,540 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:38,540 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.004s
2026-06-06 03:31:38,540 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:38,540 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:38,541 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:39,542 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:39,542 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.004s
2026-06-06 03:31:39,542 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:39,542 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:39,542 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:40,543 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:40,544 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.006s
2026-06-06 03:31:40,544 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:40,544 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:40,544 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:41,545 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:41,545 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.007s
2026-06-06 03:31:41,546 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:41,546 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:41,546 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:42,547 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:42,547 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.008s
2026-06-06 03:31:42,547 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:42,547 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:42,547 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:43,549 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:43,549 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.009s
2026-06-06 03:31:43,549 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:43,549 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:43,549 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:44,551 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:44,551 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.010s
2026-06-06 03:31:44,551 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:44,551 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:44,551 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:45,553 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:45,553 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.011s
2026-06-06 03:31:45,553 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:45,553 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:45,553 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:46,555 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:46,555 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.012s
2026-06-06 03:31:46,555 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:46,555 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:46,555 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:47,556 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:47,557 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.013s
2026-06-06 03:31:47,557 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:47,557 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:47,557 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:48,558 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:48,559 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.014s
2026-06-06 03:31:48,559 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:48,559 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:48,559 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:48.965003" elapsed="0.001339"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:48.967721" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/090_rt_constrain_play_1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/090_rt_constrain_play_1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:31:48.966841" elapsed="0.001023"/>
</kw>
<arg>play.py.090.2</arg>
<arg>090_rt_constrain_play_1.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:48.949519" elapsed="0.018495"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:48.982621" level="INFO">Executing command 'cat play.py.090.3'.</msg>
<msg time="2026-06-06T03:31:49.015854" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:49.016080" level="INFO">${output_log} = 2026-06-06 03:31:34,497 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:34,497 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:31:34,497 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:31:48.982470" elapsed="0.033671"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.017262" level="INFO">2026-06-06 03:31:34,497 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:34,497 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.3
2026-06-06 03:31:34,497 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:31:34,498 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:31:34,498 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:31:34,498 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:31:34,499 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:31:34,499 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706435
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:31:34,500 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:31:34,501 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:31:34,501 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   Length=125 (0x007d)
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:31:34,501 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706435 (0x7f000003)
2026-06-06 03:31:34,502 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=96 (0x60)
2026-06-06 03:31:34,502 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:31:34,502 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff007d0104fbf000b47f0000036002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0'
2026-06-06 03:31:34,502 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff007d0104fbf000b47f0000036002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:34,503 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:34,504 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,504 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,504 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:34,504 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:34,504 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:34,512 INFO BGP-Thread-1 (job): ... idle for 0.008s
2026-06-06 03:31:34,513 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.008s
2026-06-06 03:31:34,513 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:31:34,513 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,514 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,514 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,514 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,515 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000280
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,517 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000201
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,520 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,521 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,522 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,522 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,522 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,522 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:31:34,522 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,522 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,523 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,523 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,523 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000180
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,525 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,526 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,527 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,528 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,528 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:34,528 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:34,528 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:35,530 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:35,530 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.009s
2026-06-06 03:31:35,530 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:35,530 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:35,530 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:36,531 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:36,532 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.011s
2026-06-06 03:31:36,532 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:36,532 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:36,532 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:37,533 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:37,533 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.012s
2026-06-06 03:31:37,534 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:37,534 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:37,534 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:38,535 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:38,535 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.013s
2026-06-06 03:31:38,535 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:38,535 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:38,536 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:39] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:39,537 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:39,537 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.014s
2026-06-06 03:31:39,537 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0002fbf000000065
2026-06-06 03:31:39,538 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:39,538 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:39,538 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:40,539 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:40,539 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.015s
2026-06-06 03:31:40,539 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:40,540 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:40,540 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:41,541 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:41,541 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.016s
2026-06-06 03:31:41,541 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:41,542 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:41,542 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:42,543 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:42,543 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.017s
2026-06-06 03:31:42,543 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:42,544 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:42,544 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:43,545 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:43,545 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.018s
2026-06-06 03:31:43,545 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:43,545 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:43,545 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:44,547 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:44,547 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.019s
2026-06-06 03:31:44,547 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:44,547 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:44,547 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:45,549 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:45,549 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.020s
2026-06-06 03:31:45,549 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:45,549 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:45,549 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:46,551 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:46,551 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.022s
2026-06-06 03:31:46,551 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:46,551 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:46,551 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:47,553 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:47,553 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.023s
2026-06-06 03:31:47,553 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:47,553 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:47,553 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:48,555 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:48,555 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.024s
2026-06-06 03:31:48,555 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:48,555 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:48,555 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.016534" elapsed="0.001419"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.019141" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/090_rt_constrain_play_2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/090_rt_constrain_play_2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:31:49.018400" elapsed="0.000868"/>
</kw>
<arg>play.py.090.3</arg>
<arg>090_rt_constrain_play_2.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:48.982096" elapsed="0.037307"/>
</kw>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.034025" level="INFO">Executing command 'cat play.py.090.4'.</msg>
<msg time="2026-06-06T03:31:49.063699" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:49.063925" level="INFO">${output_log} = 2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.4
2026-06-06 03:31:34,516 DEBUG BGP-Thread-...</msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:31:49.033884" elapsed="0.030102"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.065025" level="INFO">2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job): Connecting in the talking mode.
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Local IP address: 127.0.0.4
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Local port: 17900
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Remote IP address: 10.30.170.38
2026-06-06 03:31:34,516 DEBUG BGP-Thread-1 (job): Remote port: 1790
2026-06-06 03:31:34,516 INFO BGP-Thread-1 (job): Connected to ODL.
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job): Open message received.
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job): ffffffffffffffffffffffffffffffff00d90104fbf000b4c0000202bc02ba41040000fbf0060002000104000100010104000100040104000100850104000200040104000100810104000100840104000200810104000200800104000100860104000200860104000200850104000200050104000100800104000100050104400400470104001900460104000200014046003c00028500000205000001800040044700000281000001040000010100000186000002800000018500001946000002040000020100000105000001840000028600000181004700
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job): Generator initialisation
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Target total number of prefixes to be introduced: 0
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Prefix base: 8.0.1.0/28
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   My Autonomous System number: 64496
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   My Hold Time: 180
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   My BGP Identifier: 2130706436
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Next Hop: 192.0.2.1
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Originator ID: None
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Cluster list: None
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Prefix count to be inserted at once: 1
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Prefix count to be withdrawn at once: 0
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Fast pre-fill up to 0 prefixes
2026-06-06 03:31:34,518 INFO BGP-Thread-1 (job):   Remaining number of prefixes to be processed in parallel with withdrawals: 0
2026-06-06 03:31:34,518 DEBUG BGP-Thread-1 (job):   Prefix index range used after pre-fill procedure [0, -1]
2026-06-06 03:31:34,519 INFO BGP-Thread-1 (job):   Two separate UPDATEs will be generated for each NLRI &amp; WITHDRAWN lists
2026-06-06 03:31:34,519 INFO BGP-Thread-1 (job):   Let's go ...

2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): OPEN message encoding
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Length=125 (0x007d)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Type=1 (0x01)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Version=4 (0x04)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   My Autonomous System=64496 (0xfbf0)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Hold Time=180 (0x00b4)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   BGP Identifier=2130706436 (0x7f000004)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Optional Parameters Length=96 (0x60)
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job):   Optional Parameters=0x02060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): OPEN message encoded: 0xb'ffffffffffffffffffffffffffffffff007d0104fbf000b47f0000046002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0'
2026-06-06 03:31:34,519 DEBUG BGP-Thread-1 (job): Sending the OPEN message: ffffffffffffffffffffffffffffffff007d0104fbf000b47f0000046002060104000100010206010400020001020601044004004702060104001900460206010400010005020601040002000502060104000100810206010400020081020601040001008002060104000200800206010400010084020641040000fbf0
2026-06-06 03:31:34,523 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoding
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job):   Marker=0xffffffffffffffffffffffffffffffff
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job):   Length=19 (0x0013)
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job):   Type=4 (0x04)
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): KEEP ALIVE message encoded: 0xffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,524 DEBUG BGP-Thread-1 (job): Sending a KEEP ALIVE message: ffffffffffffffffffffffffffffffff001304
2026-06-06 03:31:34,524 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:34,524 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:34,524 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:34,534 INFO BGP-Thread-1 (job): ... idle for 0.010s
2026-06-06 03:31:34,534 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.010s
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000205
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,534 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000180
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03400447
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,535 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,536 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:34,536 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:34,536 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:34,536 INFO BGP-Thread-1 (job): ... idle for 0.000s
2026-06-06 03:31:34,536 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 0.010s
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000281
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,536 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff00170200000000
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'0017' (23)
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,537 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000280
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03001946
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,538 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000201
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000105
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000184
2026-06-06 03:31:34,539 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): UPDATE message received: 0xffffffffffffffffffffffffffffffff001d0200000006800f03000181
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Decoding update message:
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Message header marker: 0xb'ffffffffffffffffffffffffffffffff'
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Message lenght: 0xb'001d' (29)
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Evpn False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Graceful-restart 8
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Mvpn False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): L3vpn-mcast False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): L3vpn-unicast False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Route-Target-Constrain False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Ipv6-Unicast False
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Allf True
2026-06-06 03:31:34,540 DEBUG BGP-Thread-1 (job): Skipping update decoding
2026-06-06 03:31:34,540 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:34,540 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:34,540 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:35,542 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:35,542 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 1.011s
2026-06-06 03:31:35,542 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:35,542 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:35,542 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:36,543 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:36,544 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 2.012s
2026-06-06 03:31:36,544 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:36,544 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:36,544 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:37,545 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:37,545 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 3.013s
2026-06-06 03:31:37,546 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:37,546 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:37,546 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:38,547 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:38,547 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 4.014s
2026-06-06 03:31:38,547 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:38,547 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:38,548 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:39,549 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:39,549 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 5.015s
2026-06-06 03:31:39,549 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:39,549 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:39,549 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:40,551 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:40,551 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 6.017s
2026-06-06 03:31:40,551 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:40,551 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:40,551 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:41,553 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:41,553 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 7.018s
2026-06-06 03:31:41,553 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:41,553 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:41,553 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:42,554 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:42,555 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 8.019s
2026-06-06 03:31:42,555 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:42,555 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:42,555 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:43,556 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:43,556 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 9.020s
2026-06-06 03:31:43,557 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:43,557 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:43,557 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:44,558 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:44,558 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 10.021s
2026-06-06 03:31:44,558 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:44,559 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:44,559 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:45,560 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:45,560 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 11.022s
2026-06-06 03:31:45,560 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:45,560 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:45,560 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:46] "POST /RPC2 HTTP/1.1" 200 -
2026-06-06 03:31:46,561 INFO BGP-Thread-1 (job): ... idle for 1.000s
2026-06-06 03:31:46,561 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 12.022s
2026-06-06 03:31:46,561 INFO BGP-Thread-1 (job): Received message: ffffffffffffffffffffffffffffffff003e02000000274001010040020040050400000064800e1600018404c714a62900600000fbff0102c0000202007b
2026-06-06 03:31:46,562 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:46,562 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:46,562 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:47,563 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:47,563 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 13.023s
2026-06-06 03:31:47,563 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:47,564 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:47,564 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
2026-06-06 03:31:48,565 INFO BGP-Thread-1 (job): ... idle for 1.001s
2026-06-06 03:31:48,565 INFO BGP-Thread-1 (job): total_rx_idle_time_counter: 14.024s
2026-06-06 03:31:48,565 INFO BGP-Thread-1 (job): total_received_update_message_counter: 0
2026-06-06 03:31:48,565 INFO BGP-Thread-1 (job): total_received_nlri_prefix_counter: 0
2026-06-06 03:31:48,565 INFO BGP-Thread-1 (job): total_received_withdrawn_prefix_counter: 0
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -
10.30.170.78 - - [06/Jun/2026 03:31:48] "POST /RPC2 HTTP/1.1" 200 -</msg>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.064374" elapsed="0.001242"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.066777" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/090_rt_constrain_play_3.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/090_rt_constrain_play_3.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:31:49.066082" elapsed="0.000821"/>
</kw>
<arg>play.py.090.4</arg>
<arg>090_rt_constrain_play_3.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:49.033515" elapsed="0.033524"/>
</kw>
<kw name="Kill_All_BGP_Speakers" owner="BGPSpeaker">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.068852" level="INFO">${command} = ps axf | grep play.py | grep -v grep | awk '{print "kill -9 " $1}' | sh</msg>
<var>${command}</var>
<arg>ps axf | grep play.py | grep -v grep | awk '{print \"kill -9 \" $1}' | sh</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:49.068211" elapsed="0.000729"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.070129" level="INFO">[?2004l[2] 6604</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:49.069303" elapsed="0.000941"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.071848" level="INFO">[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:31:49.072045" level="INFO">${output} = [?2004h[jenkins@releng-26932-288-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-06-06T03:31:49.070611" elapsed="0.001492"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.073120" level="INFO">[?2004h[jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.072470" elapsed="0.000717"/>
</kw>
<doc>Kill all play.py processes.</doc>
<status status="PASS" start="2026-06-06T03:31:49.067543" elapsed="0.005721"/>
</kw>
<doc>Abort all Python speakers.</doc>
<status status="PASS" start="2026-06-06T03:31:48.848134" elapsed="0.225276"/>
</test>
<test id="s1-s19-t11" name="Delete_Bgp_Peers_Configuration" line="163">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:31:49.078283" elapsed="0.000299"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:31:49.077883" elapsed="0.000803"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.080244" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:49.080052" elapsed="0.000261"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.080017" elapsed="0.000328"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.087092" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:49.086983" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.086964" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.088195" 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-06-06T03:31:49.087805" elapsed="0.000417"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.088708" 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-06-06T03:31:49.088393" elapsed="0.000341"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:49.088780" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:31:49.088957" 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-06-06T03:31:49.087399" elapsed="0.001584"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:49.094634" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:49.094525" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.094506" elapsed="0.000212"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:49.095917" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:49.095809" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.095789" elapsed="0.000198"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:49.096541" 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-06-06T03:31:49.096191" elapsed="0.000378"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.097022" level="INFO">${current_connection_index} = 7</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-06-06T03:31:49.096775" elapsed="0.000275"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.133027" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:49.097617" elapsed="0.035735"/>
</kw>
<msg time="2026-06-06T03:31:49.133724" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:49.133802" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:31:49.097261" elapsed="0.036809"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.169074" level="INFO">". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[78C[K"
[?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-06-06T03:31:49.135341" elapsed="0.033979"/>
</kw>
<msg time="2026-06-06T03:31:49.169559" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:49.169608" level="INFO">${message_wait} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</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-06-06T03:31:49.134666" elapsed="0.035010"/>
</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-06-06T03:31:49.170148" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.169799" elapsed="0.000411"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.169762" elapsed="0.000474"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.170808" level="INFO"> ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V "a "l "i "d "a "t "i "o "n ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "s "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[78C[K"
[?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-06-06T03:31:49.170393" elapsed="0.000499"/>
</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-06-06T03:31:49.171199" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.170963" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.170943" elapsed="0.000337"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:49.171319" elapsed="0.000041"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:31:49.174211" elapsed="0.000153"/>
</kw>
<msg time="2026-06-06T03:31:49.174427" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.173097" elapsed="0.001470"/>
</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="NOT RUN" start="2026-06-06T03:31:49.174878" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.175230" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:49.172311" elapsed="0.003120"/>
</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-06-06T03:31:49.171680" elapsed="0.003817"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:49.095478" elapsed="0.080119"/>
</kw>
<msg time="2026-06-06T03:31:49.175713" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:49.175760" level="INFO">${message} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:49.094878" elapsed="0.080919"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:49.175989" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:31:49.175877" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.175857" elapsed="0.000218"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.176778" elapsed="0.000027"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.177236" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.177312" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:49.094184" elapsed="0.083255"/>
</kw>
<msg time="2026-06-06T03:31:49.177545" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:49.177600" level="INFO">${output} =  ". "t "x "t ". "0 "9 "0 "[C "B "g "p "[C "F "u "n "c "t "i "o "n "a "l "[C "R "t "[C "C "o "n "s "t "r "a "i "n "[C "V ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:49.089370" elapsed="0.088267"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.178058" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.177732" elapsed="0.000387"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.177713" elapsed="0.000433"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:49.089218" elapsed="0.088953"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:49.089040" elapsed="0.089163"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:49.086603" elapsed="0.091657"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:31:49.079580" elapsed="0.098736"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:49.078931" elapsed="0.099431"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:31:49.074591" elapsed="0.103825"/>
</kw>
<for flavor="IN ZIP">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.179615" level="INFO">&amp;{ODL_CONFIG} = { IP=127.0.0.2 | TYPE=external | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{ODL_CONFIG}</var>
<arg>IP=${ODL_${i}_IP}</arg>
<arg>TYPE=${type}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.178879" elapsed="0.000809"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.227291" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:49.226761" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.228306" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:49.227973" elapsed="0.000418">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:49.228508" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:49.227537" elapsed="0.001002"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.229254" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:49.228753" elapsed="0.000536"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.229662" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:49.229861" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:49.229484" elapsed="0.000411"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.230368" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.230079" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.231618" level="INFO">mapping: {'IP': '127.0.0.2', 'TYPE': 'external', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.231330" elapsed="0.000377"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.232187" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.231899" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.233027" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.232617" elapsed="0.000438"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.233883" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.233619" elapsed="0.000292"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.233967" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:31:49.234139" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.233265" elapsed="0.000900"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.234357" elapsed="0.000612"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:31:49.232466" elapsed="0.002592"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.235724" level="INFO">${value} = external</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.235364" elapsed="0.000387"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.236592" level="INFO">${encoded} = external</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.236338" elapsed="0.000283"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.236691" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:31:49.236897" level="INFO">${encoded_value} = external</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.235973" elapsed="0.000974"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.237134" elapsed="0.000255"/>
</kw>
<var name="${key}">TYPE</var>
<var name="${value}">external</var>
<status status="PASS" start="2026-06-06T03:31:49.235202" elapsed="0.002244"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.238072" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.237751" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.238879" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.238658" elapsed="0.000249"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.238959" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:49.239116" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.238310" elapsed="0.000832"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.239305" elapsed="0.000232"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:49.237563" elapsed="0.002017"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.240200" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.239874" elapsed="0.000353"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.241027" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.240778" elapsed="0.000280"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.241120" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:49.241299" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.240421" elapsed="0.000908"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.241530" elapsed="0.000285"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:49.239714" elapsed="0.002151"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.242549" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.242186" elapsed="0.000395"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.243381" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.243171" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.243456" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:49.243605" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.242832" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.243833" elapsed="0.000233"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:49.242001" elapsed="0.002106"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.244720" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.244382" elapsed="0.000365"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.245656" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.245408" elapsed="0.000277"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.245738" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:49.245899" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.245010" elapsed="0.000914"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.246094" elapsed="0.000234"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:49.244229" elapsed="0.002233"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.247087" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.246760" elapsed="0.000354"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.248151" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.247923" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.248231" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:49.248395" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.247318" elapsed="0.001102"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.248592" elapsed="0.000262"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:49.246577" elapsed="0.002359"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:49.232272" elapsed="0.016709"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:49.249037" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:49.249242" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'TYPE': 'external', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:49.230957" elapsed="0.018313"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.230515" elapsed="0.018801"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.249536" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.249347" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.230486" elapsed="0.019129"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.250623" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:49.249795" elapsed="0.000883"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:49.250763" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:49.225821" elapsed="0.025087"/>
</kw>
<msg time="2026-06-06T03:31:49.250978" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.211179" elapsed="0.039853"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.264613" elapsed="0.000075"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.278532" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.292323" elapsed="0.000043"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.292607" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.292973" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.293521" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.293351" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:49.293296" elapsed="0.000310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.293775" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.293954" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.294130" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:49.293250" elapsed="0.000933"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.293084" elapsed="0.001128"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.294370" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.294452" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:31:49.294622" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:49.206413" elapsed="0.088252"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.295984" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.295619" elapsed="0.000428"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:49.307047" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:49.307104" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:49.307246" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:49.298409" elapsed="0.008866"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.296115" elapsed="0.011210"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.307558" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.307358" elapsed="0.000265"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.296096" elapsed="0.011575"/>
</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-06-06T03:31:49.313968" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.308838" elapsed="0.005245"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.308558" elapsed="0.005620"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.308539" elapsed="0.005700"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.320618" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.314979" elapsed="0.005771"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.314369" elapsed="0.006469"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.314331" elapsed="0.006562"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.322281" 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-06-06T03:31:49.321502" elapsed="0.000807"/>
</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-06-06T03:31:49.322661" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.322383" elapsed="0.000429"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.323353" 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-06-06T03:31:49.323024" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.322839" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.322363" elapsed="0.001076"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.324007" 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-06-06T03:31:49.323614" elapsed="0.000431"/>
</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-06-06T03:31:49.324396" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.324128" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.325064" 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-06-06T03:31:49.324669" elapsed="0.000426"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.324478" elapsed="0.000660"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.324108" elapsed="0.001057"/>
</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-06-06T03:31:49.325338" elapsed="0.000382"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:49.326222" 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-06-06T03:31:49.325907" elapsed="0.000342"/>
</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-06-06T03:31:49.326415" elapsed="0.002481"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:49.308097" elapsed="0.020895"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:49.329057" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:31:49.331545" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:49.294981" elapsed="0.036591"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:49.331629" elapsed="0.000042"/>
</return>
<arg>${EBGP_DIR}</arg>
<arg>mapping=${ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:49.179953" elapsed="0.151820"/>
</kw>
<var name="${i}">2</var>
<var name="${type}">external</var>
<status status="PASS" start="2026-06-06T03:31:49.178722" elapsed="0.153094"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.333021" level="INFO">&amp;{ODL_CONFIG} = { IP=127.0.0.3 | TYPE=internal | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{ODL_CONFIG}</var>
<arg>IP=${ODL_${i}_IP}</arg>
<arg>TYPE=${type}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.332131" elapsed="0.000933"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.379571" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:49.379142" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.380440" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:49.380186" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:49.380610" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:49.379823" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.381376" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:49.380831" elapsed="0.000573"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.381771" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:49.381950" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:49.381598" elapsed="0.000461"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.382525" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.382250" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.383750" level="INFO">mapping: {'IP': '127.0.0.3', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.383445" elapsed="0.000363"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.384299" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.383999" elapsed="0.000336"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.385409" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.385031" elapsed="0.000416"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.386292" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.386056" elapsed="0.000262"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.386373" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:31:49.386558" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.385675" elapsed="0.000910"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.386787" elapsed="0.000266"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:31:49.384600" elapsed="0.002507"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.387715" level="INFO">${value} = internal</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.387378" elapsed="0.000364"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.388531" level="INFO">${encoded} = internal</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.388305" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.388619" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:31:49.388799" level="INFO">${encoded_value} = internal</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.387954" elapsed="0.000871"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.389045" elapsed="0.000259"/>
</kw>
<var name="${key}">TYPE</var>
<var name="${value}">internal</var>
<status status="PASS" start="2026-06-06T03:31:49.387223" elapsed="0.002135"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.389951" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.389636" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.390800" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.390543" elapsed="0.000285"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.390879" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:49.391041" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.390192" elapsed="0.000884"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.391247" elapsed="0.000233"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:49.389482" elapsed="0.002038"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.392129" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.391818" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.393011" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.392728" elapsed="0.000315"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.393102" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:31:49.393299" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.392365" elapsed="0.000959"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.393498" elapsed="0.000258"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:49.391665" elapsed="0.002133"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.394470" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.394147" elapsed="0.000349"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.395294" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.395069" elapsed="0.000251"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.395371" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:49.395534" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.394714" elapsed="0.000856"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.395757" elapsed="0.000234"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:49.393993" elapsed="0.002040"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.396657" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.396311" elapsed="0.000375"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.402364" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.401821" elapsed="0.000594"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.402515" elapsed="0.000066"/>
</return>
<msg time="2026-06-06T03:31:49.402802" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.396876" elapsed="0.005963"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.403137" elapsed="0.000382"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:49.396161" elapsed="0.007421"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.404584" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.404052" elapsed="0.000571"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.405905" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.405552" elapsed="0.000395"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.406025" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:31:49.406278" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.405035" elapsed="0.001282"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.406561" elapsed="0.000375"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:49.403807" elapsed="0.003193"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:49.384391" elapsed="0.022665"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:49.407129" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:31:49.407377" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:49.383084" elapsed="0.024333"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.382682" elapsed="0.024785"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.407786" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.407514" elapsed="0.000362"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.382656" elapsed="0.025259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.409331" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:49.408155" elapsed="0.001232"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:49.409467" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:49.378064" elapsed="0.031623"/>
</kw>
<msg time="2026-06-06T03:31:49.409775" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.363973" elapsed="0.045884"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.426303" elapsed="0.000073"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.439681" elapsed="0.000063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.452696" elapsed="0.000049"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.453027" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.453236" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.453709" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.453528" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:49.453508" elapsed="0.000287"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.453956" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.454143" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.454320" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:49.453465" elapsed="0.000909"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.453327" elapsed="0.001074"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.454558" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.454653" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:31:49.454823" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:49.359265" elapsed="0.095587"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.456129" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.455820" elapsed="0.000363"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:49.466785" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:49.466895" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:49.467006" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:49.458711" elapsed="0.008322"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.456250" elapsed="0.010826"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.467267" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.467102" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.456232" elapsed="0.011120"/>
</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-06-06T03:31:49.471891" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.468395" elapsed="0.003595"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.468158" elapsed="0.003909"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.468139" elapsed="0.003985"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.478159" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.472802" elapsed="0.005460"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.472250" elapsed="0.006088"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.472212" elapsed="0.006182"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.479765" 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-06-06T03:31:49.478848" elapsed="0.000980"/>
</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-06-06T03:31:49.480554" elapsed="0.000046"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.479991" elapsed="0.000723"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.481928" 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-06-06T03:31:49.481227" elapsed="0.000759"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.480769" elapsed="0.001298"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.479949" elapsed="0.002166"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.482708" 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-06-06T03:31:49.482320" 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-06-06T03:31:49.483063" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.482809" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.483615" 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-06-06T03:31:49.483320" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.483144" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.482789" elapsed="0.000926"/>
</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-06-06T03:31:49.483884" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:49.484725" 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-06-06T03:31:49.484410" elapsed="0.000342"/>
</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-06-06T03:31:49.485070" elapsed="0.002397"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:49.467735" elapsed="0.019803"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:49.487591" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:31:49.489977" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:49.455166" elapsed="0.034839"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:49.490063" elapsed="0.000027"/>
</return>
<arg>${EBGP_DIR}</arg>
<arg>mapping=${ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:49.333392" elapsed="0.156797"/>
</kw>
<var name="${i}">3</var>
<var name="${type}">internal</var>
<status status="PASS" start="2026-06-06T03:31:49.331948" elapsed="0.158282"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.491205" level="INFO">&amp;{ODL_CONFIG} = { IP=127.0.0.4 | TYPE=internal | HOLDTIME=180 | PEER_PORT=17900 | INITIATE=false | BGP_RIB=example-bgp-rib | PASSIVE_MODE=true }</msg>
<var>&amp;{ODL_CONFIG}</var>
<arg>IP=${ODL_${i}_IP}</arg>
<arg>TYPE=${type}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PEER_PORT=${BGP_TOOL_PORT}</arg>
<arg>INITIATE=false</arg>
<arg>BGP_RIB=${RIB_NAME}</arg>
<arg>PASSIVE_MODE=true</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.490513" elapsed="0.000721"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.536071" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:31:49.535630" elapsed="0.000475"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.536988" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:31:49.536675" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:31:49.537163" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:31:49.536300" elapsed="0.000889"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.537775" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:31:49.537368" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:31:49.538121" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:31:49.538310" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:31:49.537976" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.538773" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.538506" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.539881" level="INFO">mapping: {'IP': '127.0.0.4', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.539602" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.540366" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.540095" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.541108" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.540794" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.541896" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.541669" elapsed="0.000253"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.541976" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:31:49.542144" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.541324" elapsed="0.000846"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.542334" elapsed="0.000240"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:31:49.540634" elapsed="0.001982"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.543184" level="INFO">${value} = internal</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.542887" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.544072" level="INFO">${encoded} = internal</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.543860" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.544149" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:49.544302" level="INFO">${encoded_value} = internal</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.543501" elapsed="0.000825"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.544485" elapsed="0.000240"/>
</kw>
<var name="${key}">TYPE</var>
<var name="${value}">internal</var>
<status status="PASS" start="2026-06-06T03:31:49.542745" elapsed="0.002021"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.545368" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.545058" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.546221" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.546009" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.546299" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:49.546450" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.545679" elapsed="0.000796"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.546637" elapsed="0.000240"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:31:49.544879" elapsed="0.002040"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.547697" level="INFO">${value} = 17900</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.547171" elapsed="0.000552"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.548455" level="INFO">${encoded} = 17900</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.548246" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.548531" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:49.548697" level="INFO">${encoded_value} = 17900</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.547916" elapsed="0.000806"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.548883" elapsed="0.000233"/>
</kw>
<var name="${key}">PEER_PORT</var>
<var name="${value}">17900</var>
<status status="PASS" start="2026-06-06T03:31:49.547031" elapsed="0.002127"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.549723" level="INFO">${value} = false</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.549410" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.550478" level="INFO">${encoded} = false</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.550263" elapsed="0.000242"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.550558" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:49.550741" level="INFO">${encoded_value} = false</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.549937" elapsed="0.000829"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.550939" elapsed="0.000241"/>
</kw>
<var name="${key}">INITIATE</var>
<var name="${value}">false</var>
<status status="PASS" start="2026-06-06T03:31:49.549271" elapsed="0.001952"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.551835" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.551492" elapsed="0.000370"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.552626" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.552414" elapsed="0.000254"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.552721" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:31:49.552874" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.552069" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.553103" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:31:49.551347" elapsed="0.002024"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.553945" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:31:49.553625" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:31:49.554726" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.554494" elapsed="0.000258"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:31:49.554804" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:31:49.554955" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:31:49.554161" elapsed="0.000818"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:31:49.555140" elapsed="0.000221"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:31:49.553484" elapsed="0.001919"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:31:49.540447" elapsed="0.014992"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:31:49.555486" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:49.555751" level="INFO">${mapping_to_use} = {'IP': '127.0.0.4', 'TYPE': 'internal', 'HOLDTIME': '180', 'PEER_PORT': '17900', 'INITIATE': 'false', 'BGP_RIB': 'example-bgp-rib', 'PASSIVE_MODE': 'true'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:31:49.539260" elapsed="0.016518"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.538903" elapsed="0.016910"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.556014" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.555845" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.538877" elapsed="0.017217"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.557024" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:31:49.556252" elapsed="0.000803"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:31:49.557106" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:31:49.534933" elapsed="0.022306"/>
</kw>
<msg time="2026-06-06T03:31:49.557301" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.521410" elapsed="0.035945"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.570776" elapsed="0.000064"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.583891" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.597135" elapsed="0.000049"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.597434" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.597635" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.598099" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.597935" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:31:49.597916" elapsed="0.000273"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.598346" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.598527" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.598719" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:31:49.597876" elapsed="0.000899"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.597741" elapsed="0.001062"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.598961" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.599126" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:31:49.599294" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:31:49.516789" elapsed="0.082535"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.600607" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.600297" elapsed="0.000390"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:49.610875" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node034lhxyxiznwq3ffmji070fx028.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:49.610968" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:31:49.611148" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:31:49.603007" elapsed="0.008186"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.600758" elapsed="0.010509"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:49.611587" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.611314" elapsed="0.000397"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.600739" elapsed="0.011010"/>
</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-06-06T03:31:49.617224" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.613463" elapsed="0.003828"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.613073" elapsed="0.004270"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.613038" elapsed="0.004345"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.621350" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.617830" elapsed="0.003595"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.617464" elapsed="0.004016"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.617440" elapsed="0.004083"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.622496" 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-06-06T03:31:49.621876" elapsed="0.000663"/>
</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-06-06T03:31:49.623070" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.622673" elapsed="0.000487"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.623960" 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-06-06T03:31:49.623468" elapsed="0.000535"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.623201" elapsed="0.000860"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.622621" elapsed="0.001476"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.624956" 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-06-06T03:31:49.624364" elapsed="0.000679"/>
</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-06-06T03:31:49.625542" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.625151" elapsed="0.000479"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.626609" 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-06-06T03:31:49.625965" elapsed="0.000707"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:49.625692" elapsed="0.001040"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.625120" elapsed="0.001649"/>
</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-06-06T03:31:49.627039" elapsed="0.000670"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:31:49.628443" 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-06-06T03:31:49.627977" elapsed="0.000506"/>
</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-06-06T03:31:49.628767" elapsed="0.004112"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:31:49.612333" elapsed="0.020777"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:31:49.633255" elapsed="0.000083"/>
</return>
<msg time="2026-06-06T03:31:49.638578" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:31:49.599629" elapsed="0.038991"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:31:49.638727" elapsed="0.000047"/>
</return>
<arg>${EBGP_DIR}</arg>
<arg>mapping=${ODL_CONFIG}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:31:49.491560" elapsed="0.147363"/>
</kw>
<var name="${i}">4</var>
<var name="${type}">internal</var>
<status status="PASS" start="2026-06-06T03:31:49.490356" elapsed="0.148628"/>
</iter>
<var>${i}</var>
<var>${type}</var>
<value>${ODL_IP_INDICES_ALL}</value>
<value>${BGP_PEER_TYPES}</value>
<status status="PASS" start="2026-06-06T03:31:49.178484" elapsed="0.460556"/>
</for>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:31:49.073826" elapsed="0.565411"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:31:49.640381" elapsed="0.000715"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:49.641464" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:31:49.641348" elapsed="0.000246"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:31:49.639976" elapsed="0.001719"/>
</kw>
<doc>Functional test for bgp - route-target-constrain safi

Copyright (c) 2018 AT&amp;T Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distbmution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite tests advertising rt-constrain routes to odl. For advertising from peer,
play.py is used, sending hex messages to odl.
There are 3 peers: ebgp and two ibgps. First peer sends l3vpn route with specific RT to odl, second peer
sends RT route and third peer only establishes connection. Then it is checked that odl advertizes l3vpn route
to second peer. Third peer sends wildcard RT route and it is checked that odl doesn't advertize l3vpn route
to it. Then second peer removes RT and it is checked that second peer withdrew RT route and that odl withdrew
l3vpn route from it.</doc>
<status status="FAIL" start="2026-06-06T03:31:32.232520" elapsed="17.409221"/>
</suite>
<suite id="s1-s20" name="Bgp Policies Default" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/bgp_policies_default.robot">
<kw name="Start_Suite" type="SETUP">
<kw name="Setup_Utils_For_Setup_And_Teardown" owner="SetupUtils">
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.733710" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:31:49.729431" elapsed="0.004337"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:31:49.729193" elapsed="0.004649"/>
</kw>
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.738677" 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-06-06T03:31:49.734967" elapsed="0.003740"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:31:49.738930" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:49.738798" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.738771" elapsed="0.000228"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.739515" 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-06-06T03:31:49.739158" elapsed="0.000400"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.740119" 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-06-06T03:31:49.739779" elapsed="0.000371"/>
</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-06-06T03:31:49.740698" elapsed="0.000310"/>
</kw>
<msg time="2026-06-06T03:31:49.741111" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:49.741158" 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-06-06T03:31:49.740333" elapsed="0.000847"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.741748" 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-06-06T03:31:49.741352" elapsed="0.000423"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.742850" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:31:49.742562" elapsed="0.000400"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.743379" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:31:49.743117" elapsed="0.000288"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.743879" 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-06-06T03:31:49.743565" elapsed="0.000340"/>
</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-06-06T03:31:49.746998" elapsed="0.000218"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.747719" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:31:49.747377" elapsed="0.000369"/>
</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-06-06T03:31:49.747901" elapsed="0.000227"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.748971" 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-06-06T03:31:49.748617" elapsed="0.000415"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:31:49.749083" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:31:49.749251" 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-06-06T03:31:49.748324" elapsed="0.000952"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:31:49.750074" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e4f939d0&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-06-06T03:31:49.749439" elapsed="0.000784"/>
</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-06-06T03:31:49.750539" elapsed="0.000213"/>
</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-06-06T03:31:49.746417" elapsed="0.004397"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:49.746224" elapsed="0.004636"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:31:49.743963" elapsed="0.006930"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.751467" 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-06-06T03:31:49.751059" elapsed="0.000452"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.752101" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:31:49.751693" elapsed="0.000473"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.752760" 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-06-06T03:31:49.752349" elapsed="0.000456"/>
</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-06-06T03:31:49.742092" elapsed="0.010770"/>
</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-06-06T03:31:49.734605" elapsed="0.018316"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:49.753208" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:49.753064" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.752970" elapsed="0.000308"/>
</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-06-06T03:31:49.756331" 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-06-06T03:31:49.755947" elapsed="0.000411"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.756828" 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-06-06T03:31:49.756516" elapsed="0.000338"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:49.756900" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:31:49.757092" 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-06-06T03:31:49.755603" elapsed="0.001514"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:49.758169" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:31:49.757899" elapsed="0.000299"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.759003" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:31:49.759105" 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-06-06T03:31:49.758826" elapsed="0.000306"/>
</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-06-06T03:31:49.763000" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:49.762098" elapsed="0.001033"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:49.762073" elapsed="0.001116"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.764196" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:31:49.763501" elapsed="0.001163"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.766148" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:49.765122" elapsed="0.001139"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.767501" 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-06-06T03:31:49.766543" elapsed="0.001011"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:31:49.769687" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:31:49.769876" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:49.768960" elapsed="0.000959"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.770271" elapsed="0.000546"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:31:49.772014" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:31:50.414482" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:31:49 UTC 2026

  System load:  0.13               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:31:33 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:31:49.771621" elapsed="0.643045"/>
</kw>
<msg time="2026-06-06T03:31:50.414760" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.771171" elapsed="0.643768"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:31:49.768021" elapsed="0.647077"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.416038" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:31:50.429057" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:31:50.429375" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:31:50.429609" 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-06-06T03:31:50.415499" elapsed="0.014271"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:50.430454" elapsed="0.001151"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.434241" 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-06-06T03:31:50.432933" elapsed="0.001544"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:31:50.435571" elapsed="0.000196"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:50.435020" elapsed="0.000917"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.434964" elapsed="0.001057"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:31:50.436731" elapsed="0.000136"/>
</return>
<status status="PASS" start="2026-06-06T03:31:50.436203" elapsed="0.000838"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.436163" elapsed="0.001014"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:31:50.437317" elapsed="0.000037"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:50.441019" elapsed="0.000480"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:50.441798" elapsed="0.000289"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:50.442346" elapsed="0.000225"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:50.438274" elapsed="0.004391"/>
</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-06-06T03:31:49.761033" elapsed="0.681814"/>
</kw>
<msg time="2026-06-06T03:31:50.442903" 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-06-06T03:31:49.760344" elapsed="0.682612"/>
</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-06-06T03:31:49.759851" elapsed="0.683186"/>
</kw>
<msg time="2026-06-06T03:31:50.443079" 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-06-06T03:31:49.759297" elapsed="0.683829"/>
</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-06-06T03:31:50.445804" elapsed="0.000312"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:50.446281" elapsed="0.000144"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:50.446572" elapsed="0.000125"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:50.443421" elapsed="0.003330"/>
</kw>
<msg time="2026-06-06T03:31:50.446844" 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-06-06T03:31:49.758423" elapsed="0.688447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.447305" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:50.447054" elapsed="0.000292"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:31:50.447389" elapsed="0.000029"/>
</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-06-06T03:31:49.757473" elapsed="0.690042"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:49.757296" elapsed="0.690257"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:49.757170" elapsed="0.690418"/>
</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-06-06T03:31:49.753505" elapsed="0.694216"/>
</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-06-06T03:31:50.447886" elapsed="0.000212"/>
</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-06-06T03:31:50.461758" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:50.461631" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.461611" elapsed="0.000217"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.462117" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:31:50.462220" 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-06-06T03:31:50.461983" elapsed="0.000264"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.462677" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:50.462402" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.463168" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:50.462921" elapsed="0.000291"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:50.463980" 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-06-06T03:31:50.463754" elapsed="0.000329">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:31:50.464194" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:31:50.464240" 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-06-06T03:31:50.463372" elapsed="0.000891"/>
</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-06-06T03:31:50.464565" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:50.464339" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.464321" elapsed="0.000361"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:50.465456" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:31:50.465189" elapsed="0.000293"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:31:50.465530" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:31:50.465698" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:31:50.464886" elapsed="0.000837"/>
</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-06-06T03:31:50.465878" elapsed="0.000401"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.466552" level="INFO">index=4
host=10.30.170.38
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-06-06T03:31:50.466669" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:31:50.466448" elapsed="0.000249"/>
</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-06-06T03:31:50.466847" elapsed="0.002107"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.469415" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:31:50.679325" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:31:50.469151" elapsed="0.210333"/>
</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-06-06T03:31:50.684515" elapsed="0.000395"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:50.685078" elapsed="0.000204"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:50.685433" elapsed="0.000101"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:50.680631" elapsed="0.004956"/>
</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-06-06T03:31:50.679933" elapsed="0.005700"/>
</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-06-06T03:31:50.461349" elapsed="0.224360"/>
</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-06-06T03:31:50.448832" elapsed="0.236924"/>
</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-06-06T03:31:50.448448" elapsed="0.237359"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:50.448308" elapsed="0.237598"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:31:50.448157" elapsed="0.237785"/>
</for>
<arg>http_timeout=${http_timeout}</arg>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:31:49.734155" elapsed="0.951848"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Test_Suite_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:50.688626" elapsed="0.000039"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:50.688508" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.688485" elapsed="0.000238"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:31:50.693432" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:50.693325" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.693307" elapsed="0.000195"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.694470" 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-06-06T03:31:50.694077" elapsed="0.000420"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.694977" 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-06-06T03:31:50.694676" elapsed="0.000327"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:31:50.695049" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:31:50.695209" 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-06-06T03:31:50.693742" elapsed="0.001493"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:31:50.700447" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:50.700340" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.700321" elapsed="0.000193"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:31:50.701816" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:50.701613" elapsed="0.000262"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.701592" elapsed="0.000311"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:31:50.702430" 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-06-06T03:31:50.702085" elapsed="0.000372"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.702875" 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-06-06T03:31:50.702619" elapsed="0.000282"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.740534" level="INFO">@root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "r "k "s "p "a "c "e "/ "b "g "p "[78Cc "[A[78Ce</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:31:50.703573" elapsed="0.037126"/>
</kw>
<msg time="2026-06-06T03:31:50.740841" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:31:50.740888" level="INFO">${message_write} = @root&gt;log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "s "u "i "t "e "[C "/ "w "/ "w "o "...</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-06-06T03:31:50.703062" elapsed="0.037861"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.814244" level="INFO">"p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "p "o "[78Cl "[A[78Ci
 "c "i "e "s "_ "d "e "f "a "u "l "t ". "r "o "b "o "t "[K"
[?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-06-06T03:31:50.741665" elapsed="0.072760"/>
</kw>
<msg time="2026-06-06T03:31:50.814564" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:31:50.814611" level="INFO">${message_wait} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</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-06-06T03:31:50.741107" elapsed="0.073615"/>
</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-06-06T03:31:50.815090" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:50.814818" elapsed="0.000423"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.814790" elapsed="0.000481"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.815815" level="INFO"> "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t "e "s "t "/ "c "s "i "t "/ "s "u "i "t "e "s "/ "b "g "p "c "e "p "/ "b "g "p "f "u "n "c "t "/ "b "g "p "_ "p "o "[78Cl "[A[78Ci
 "c "i "e "s "_ "d "e "f "a "u "l "t ". "r "o "b "o "t "[K"
[?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-06-06T03:31:50.815425" elapsed="0.000549"/>
</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-06-06T03:31:50.816297" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:50.816046" elapsed="0.000402"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.816026" elapsed="0.000450"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:31:50.816513" elapsed="0.000041"/>
</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-06-06T03:31:50.819139" elapsed="0.000486"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:50.819998" elapsed="0.000315"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:31:50.820696" elapsed="0.000248"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:31:50.818254" elapsed="0.002785"/>
</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-06-06T03:31:50.816852" elapsed="0.004351"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:31:50.701325" elapsed="0.119994"/>
</kw>
<msg time="2026-06-06T03:31:50.821429" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:50.821476" level="INFO">${message} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:50.700681" elapsed="0.120832"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:31:50.821888" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:31:50.821604" elapsed="0.000360"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.821578" elapsed="0.000417"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:50.822502" elapsed="0.000032"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:50.822949" elapsed="0.000027"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:31:50.823026" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:31:50.700049" elapsed="0.123089"/>
</kw>
<msg time="2026-06-06T03:31:50.823233" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:31:50.823279" level="INFO">${output} =  "p "- "c "s "i "t "- "1 "n "o "d "e "- "u "s "e "r "f "e "a "t "u "r "e "s "- "a "l "l "- "v "a "n "a "d "i "u "m "/ "t ...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:31:50.695601" elapsed="0.127714"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:31:50.823683" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:31:50.823403" elapsed="0.000337"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:50.823380" elapsed="0.000384"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:31:50.695459" elapsed="0.128332"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:31:50.695289" elapsed="0.128544"/>
</for>
<arg>Starting suite ${SUITE_SOURCE}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:31:50.692993" elapsed="0.130909"/>
</kw>
<doc>Log suite name to karaf log, useful in suite setup.</doc>
<status status="PASS" start="2026-06-06T03:31:50.686604" elapsed="0.137358"/>
</kw>
<arg>KarafKeywords.Log_Test_Suite_Start_To_Controller_Karaf</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:31:50.686160" elapsed="0.137844"/>
</kw>
<doc>Prepare both FailFast and Karaf logging, log that the caller suite has started.
This keyword is to be used in suite setup, and without it the other keywords may not work properly.</doc>
<status status="PASS" start="2026-06-06T03:31:49.728838" elapsed="1.095219"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.824589" level="INFO">${conn_id} = 7</msg>
<var>${conn_id}</var>
<arg>${ODL_SYSTEM_IP}</arg>
<arg>prompt=${DEFAULT_LINUX_PROMPT}</arg>
<arg>timeout=10s</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:31:50.824215" elapsed="0.000402"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:31:50.825143" level="INFO">${conn_id} = 7</msg>
<arg>${conn_id}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:31:50.824821" elapsed="0.000398"/>
</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-06-06T03:31:50.827047" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:31:50.827126" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:31:50.826759" elapsed="0.000392"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:50.827355" elapsed="0.000359"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:31:50.828774" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:31:51.174089" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:31:49 UTC 2026

  System load:  0.13               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:31:50 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:31:50.828250" elapsed="0.346007"/>
</kw>
<msg time="2026-06-06T03:31:51.174344" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:50.827888" elapsed="0.346536"/>
</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-06-06T03:31:50.826283" elapsed="0.348252"/>
</kw>
<msg time="2026-06-06T03:31:51.174590" 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-06-06T03:31:50.825888" elapsed="0.348748"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:31:50.825429" elapsed="0.349306"/>
</kw>
<kw name="Virtual_Env_Create" 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-06-06T03:31:51.181129" level="INFO">${cd_and_command} = cd '.' &amp;&amp; virtualenv /tmp/defaultvenv</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-06-06T03:31:51.180772" elapsed="0.000388"/>
</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-06-06T03:31:51.182695" level="INFO">Executing command 'cd '.' &amp;&amp; virtualenv /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:31:51.509247" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:31:51.509635" level="INFO">${stdout} = created virtual environment CPython3.10.12.final.0-64 in 152ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=b...</msg>
<msg time="2026-06-06T03:31:51.509812" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:31:51.509912" 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-06-06T03:31:51.182487" elapsed="0.327479"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:31:51.512038" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:31:51.511379" elapsed="0.000766"/>
</kw>
<msg time="2026-06-06T03:31:51.512366" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:31:51.512468" 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-06-06T03:31:51.510470" elapsed="0.002051"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:31:51.514027" 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-06-06T03:31:51.512943" elapsed="0.001146"/>
</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-06-06T03:31:51.516589" level="INFO">created virtual environment CPython3.10.12.final.0-64 in 152ms
  creator CPython3Posix(dest=/tmp/defaultvenv, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/jenkins/.local/share/virtualenv)
    added seed packages: pip==22.0.2, setuptools==59.6.0, wheel==0.37.1
  activators BashActivator,CShellActivator,FishActivator,NushellActivator,PowerShellActivator,PythonActivator</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:51.515993" elapsed="0.000779"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:51.517879" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:51.517206" elapsed="0.000768"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:31:51.518609" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:31:51.518273" elapsed="0.000421"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:31:51.515134" elapsed="0.003640"/>
</kw>
<status status="PASS" start="2026-06-06T03:31:51.514286" elapsed="0.004540"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:51.514233" elapsed="0.004630"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:31:51.519094" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:31:51.518944" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:51.518919" elapsed="0.000403"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:31:51.519540" elapsed="0.000045"/>
</return>
<status status="PASS" start="2026-06-06T03:31:51.519407" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:31:51.519383" elapsed="0.000308"/>
</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-06-06T03:31:51.519904" elapsed="0.000030"/>
</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-06-06T03:31:51.181923" elapsed="0.338152"/>
</kw>
<msg time="2026-06-06T03:31:51.520157" 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-06-06T03:31:51.181350" elapsed="0.338881"/>
</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 virtualenv /tmp/defaultvenv.
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-06-06T03:31:51.180090" elapsed="0.340298"/>
</kw>
<msg time="2026-06-06T03:31:51.520468" 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-06-06T03:31:51.175836" elapsed="0.344697"/>
</kw>
<arg>virtualenv ${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-06-06T03:31:51.175441" elapsed="0.345262"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<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-06-06T03:31:51.520931" elapsed="0.000461"/>
</kw>
<arg>upgrade_pip=False</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-06-06T03:31:51.175043" elapsed="0.346445"/>
</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-06-06T03:31:51.531174" level="INFO">${cd_and_command} = cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==4.0.5; 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-06-06T03:31:51.530836" elapsed="0.000367"/>
</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-06-06T03:31:51.533058" level="INFO">Executing command 'cd '.' &amp;&amp; source /tmp/defaultvenv/bin/activate; pip install exabgp==4.0.5; deactivate'.</msg>
<msg time="2026-06-06T03:32:15.741799" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:15.742337" level="INFO">${stdout} = Collecting exabgp==4.0.5
  Downloading exabgp-4.0.5-py3-none-any.whl (551 kB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 551.8/551.8 KB 7.7 MB/s eta 0:00:00
Installing collected packages: exabgp
Suc...</msg>
<msg time="2026-06-06T03:32:15.742456" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:32:15.742553" 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-06-06T03:31:51.532689" elapsed="24.209919"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:32:15.747482" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:32:15.746195" elapsed="0.001621"/>
</kw>
<msg time="2026-06-06T03:32:15.748147" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:32:15.748250" 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-06-06T03:32:15.743316" elapsed="0.004987"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:15.750939" 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-06-06T03:32:15.748853" elapsed="0.002150"/>
</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-06-06T03:32:15.754836" level="INFO">Collecting exabgp==4.0.5
  Downloading exabgp-4.0.5-py3-none-any.whl (551 kB)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 551.8/551.8 KB 7.7 MB/s eta 0:00:00
Installing collected packages: exabgp
Successfully installed exabgp-4.0.5</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:15.754484" elapsed="0.000426"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:15.755532" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:15.755211" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:15.756237" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:15.755911" elapsed="0.000394"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:32:15.753047" elapsed="0.003407"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:15.751309" elapsed="0.005241"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:15.751255" elapsed="0.005334"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:32:15.756841" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:15.756685" elapsed="0.000271"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:15.756660" elapsed="0.000325"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:32:15.757183" elapsed="0.000053"/>
</return>
<status status="PASS" start="2026-06-06T03:32:15.757043" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:15.757026" elapsed="0.000325"/>
</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-06-06T03:32:15.757507" elapsed="0.000024"/>
</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-06-06T03:31:51.532030" elapsed="24.225652"/>
</kw>
<msg time="2026-06-06T03:32:15.757744" 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-06-06T03:31:51.531369" elapsed="24.226433"/>
</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/defaultvenv/bin/activate; pip install exabgp==4.0.5; 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-06-06T03:31:51.530201" elapsed="24.227702"/>
</kw>
<msg time="2026-06-06T03:32:15.757963" 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-06-06T03:31:51.524580" elapsed="24.233445"/>
</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-06-06T03:31:51.523787" elapsed="24.234342"/>
</kw>
<msg time="2026-06-06T03:32:15.758182" 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-06-06T03:31:51.523229" elapsed="24.235001"/>
</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-06-06T03:31:51.522702" elapsed="24.235619"/>
</kw>
<msg time="2026-06-06T03:32:15.758366" 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-06-06T03:31:51.522152" elapsed="24.236259"/>
</kw>
<arg>exabgp==4.0.5</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-06-06T03:31:51.521787" elapsed="24.236707"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:15.758979" level="INFO">Creating Session using : alias=config-session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5b58390&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:32:15.758682" elapsed="0.000467"/>
</kw>
<kw name="Upload_Config_Files">
<for flavor="IN">
<iter>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.785752" level="INFO">[chan 3] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:32:15.795891" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/exabgp_configs/exabgp1.cfg' -&gt; '/home/jenkins//exabgp1.cfg'</msg>
<arg>${POLICIES_VAR}/exabgp_configs/exabgp${index}.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:15.759793" elapsed="0.036197"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:15.759635" elapsed="0.036430"/>
</iter>
<iter>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.804165" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/exabgp_configs/exabgp2.cfg' -&gt; '/home/jenkins//exabgp2.cfg'</msg>
<arg>${POLICIES_VAR}/exabgp_configs/exabgp${index}.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:15.796501" elapsed="0.007751"/>
</kw>
<var name="${index}">2</var>
<status status="PASS" start="2026-06-06T03:32:15.796229" elapsed="0.008078"/>
</iter>
<iter>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.810946" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/exabgp_configs/exabgp3.cfg' -&gt; '/home/jenkins//exabgp3.cfg'</msg>
<arg>${POLICIES_VAR}/exabgp_configs/exabgp${index}.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:15.804631" elapsed="0.006399"/>
</kw>
<var name="${index}">3</var>
<status status="PASS" start="2026-06-06T03:32:15.804431" elapsed="0.006713"/>
</iter>
<iter>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.817483" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/exabgp_configs/exabgp4.cfg' -&gt; '/home/jenkins//exabgp4.cfg'</msg>
<arg>${POLICIES_VAR}/exabgp_configs/exabgp${index}.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:15.811470" elapsed="0.006131"/>
</kw>
<var name="${index}">4</var>
<status status="PASS" start="2026-06-06T03:32:15.811272" elapsed="0.006419"/>
</iter>
<iter>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.824387" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/exabgp_configs/exabgp5.cfg' -&gt; '/home/jenkins//exabgp5.cfg'</msg>
<arg>${POLICIES_VAR}/exabgp_configs/exabgp${index}.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:15.818047" elapsed="0.006428"/>
</kw>
<var name="${index}">5</var>
<status status="PASS" start="2026-06-06T03:32:15.817831" elapsed="0.006701"/>
</iter>
<iter>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.831989" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/exabgp_configs/exabgp6.cfg' -&gt; '/home/jenkins//exabgp6.cfg'</msg>
<arg>${POLICIES_VAR}/exabgp_configs/exabgp${index}.cfg</arg>
<arg>.</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:15.824916" elapsed="0.007200"/>
</kw>
<var name="${index}">6</var>
<status status="PASS" start="2026-06-06T03:32:15.824706" elapsed="0.007495"/>
</iter>
<var>${index}</var>
<value>@{NUMBERS}</value>
<status status="PASS" start="2026-06-06T03:32:15.759495" elapsed="0.072772"/>
</for>
<kw name="List Files In Directory" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.840630" level="INFO">10 files:
exa4.cfg
exabgp1.cfg
exabgp2.cfg
exabgp3.cfg
exabgp4.cfg
exabgp5.cfg
exabgp6.cfg
exabgp_graceful_restart.cfg
exaipv4.cfg
exaipv6.cfg</msg>
<msg time="2026-06-06T03:32:15.840835" level="INFO">@{cfgfiles} = [ exa4.cfg | exabgp1.cfg | exabgp2.cfg | exabgp3.cfg | exabgp4.cfg | exabgp5.cfg | exabgp6.cfg | exabgp_graceful_restart.cfg | exaipv4.cfg | exaipv6.cfg ]</msg>
<var>@{cfgfiles}</var>
<arg>.</arg>
<arg>*.cfg</arg>
<doc>A wrapper for `List Directory` that returns only files.</doc>
<status status="PASS" start="2026-06-06T03:32:15.832597" elapsed="0.008278"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.841682" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:32:15.853761" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:15.841423" elapsed="0.012423"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.854463" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:32:15.903816" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:15.854145" elapsed="0.049862"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.904884" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exa4.cfg'.</msg>
<msg time="2026-06-06T03:32:15.956109" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:15.904466" elapsed="0.051845"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:15.957235" level="INFO">Executing command 'cat exa4.cfg'.</msg>
<msg time="2026-06-06T03:32:16.008124" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:16.008401" level="INFO">${stdout} = neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 4210010000;
    peer-as 4210010000;

    capability {
        route-refresh disable;
     ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:15.956842" elapsed="0.051626"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:16.009901" level="INFO">neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 4210010000;
    peer-as 4210010000;

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        ipv6 unicast;
    }

    static {
        route 2a04:6d80::1/128 next-hop self;
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:16.009103" elapsed="0.000920"/>
</kw>
<var name="${cfgfile}">exa4.cfg</var>
<status status="PASS" start="2026-06-06T03:32:15.841194" elapsed="0.168916"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.011185" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp1.cfg'.</msg>
<msg time="2026-06-06T03:32:16.060285" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.010776" elapsed="0.049717"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.061488" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp1.cfg'.</msg>
<msg time="2026-06-06T03:32:16.115998" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.061023" elapsed="0.055215"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.117131" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp1.cfg'.</msg>
<msg time="2026-06-06T03:32:16.168055" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.116749" elapsed="0.051482"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.168994" level="INFO">Executing command 'cat exabgp1.cfg'.</msg>
<msg time="2026-06-06T03:32:16.219994" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:16.220314" level="INFO">${stdout} = neighbor 10.30.170.38 {
    router-id 127.0.0.1;
    local-address 127.0.0.1;
    local-as 64496;
    peer-as 64496;

    static {
        route 1.1.1.1/24 {
            next-hop 11.0.255.254;
       ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.168673" elapsed="0.051703"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:16.221610" level="INFO">neighbor 10.30.170.38 {
    router-id 127.0.0.1;
    local-address 127.0.0.1;
    local-as 64496;
    peer-as 64496;

    static {
        route 1.1.1.1/24 {
            next-hop 11.0.255.254;
            community [ 30741:30741 30741:0 ];
        }
    }

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        all
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:16.220909" elapsed="0.000958"/>
</kw>
<var name="${cfgfile}">exabgp1.cfg</var>
<status status="PASS" start="2026-06-06T03:32:16.010391" elapsed="0.211557"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.223139" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp2.cfg'.</msg>
<msg time="2026-06-06T03:32:16.271976" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.222755" elapsed="0.049418"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.273064" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp2.cfg'.</msg>
<msg time="2026-06-06T03:32:16.319592" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.272675" elapsed="0.047085"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.320465" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp2.cfg'.</msg>
<msg time="2026-06-06T03:32:16.371746" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.320144" elapsed="0.051753"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.372625" level="INFO">Executing command 'cat exabgp2.cfg'.</msg>
<msg time="2026-06-06T03:32:16.419721" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:16.420012" level="INFO">${stdout} = neighbor 10.30.170.38 {
    router-id 127.0.0.2;
    local-address 127.0.0.2;
    local-as 64496;
    peer-as 64496;

    static {
        route 2.1.1.0/24 {
            next-hop 12.0.255.254;
       ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.372298" elapsed="0.047775"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:16.421221" level="INFO">neighbor 10.30.170.38 {
    router-id 127.0.0.2;
    local-address 127.0.0.2;
    local-as 64496;
    peer-as 64496;

    static {
        route 2.1.1.0/24 {
            next-hop 12.0.255.254;
        }
        route 2.2.1.0/24 {
            next-hop 12.1.255.254;
        }
        route 2.3.1.0/24 {
            next-hop 12.3.255.254;
        }
    }

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        all
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:16.420554" elapsed="0.000807"/>
</kw>
<var name="${cfgfile}">exabgp2.cfg</var>
<status status="PASS" start="2026-06-06T03:32:16.222376" elapsed="0.199066"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.422419" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp3.cfg'.</msg>
<msg time="2026-06-06T03:32:16.471909" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.422051" elapsed="0.050053"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.473003" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp3.cfg'.</msg>
<msg time="2026-06-06T03:32:16.519572" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.472574" elapsed="0.047178"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.520503" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp3.cfg'.</msg>
<msg time="2026-06-06T03:32:16.567419" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.520164" elapsed="0.047397"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.568307" level="INFO">Executing command 'cat exabgp3.cfg'.</msg>
<msg time="2026-06-06T03:32:16.615864" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:16.616173" level="INFO">${stdout} = neighbor 10.30.170.38 {
    router-id 127.0.0.3;
    local-address 127.0.0.3;
    local-as 64496;
    peer-as 64496;

    static {
        route 103.36.0.5/24 {
            rd 3548:478513974;
        ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.567985" elapsed="0.048249"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:16.617455" level="INFO">neighbor 10.30.170.38 {
    router-id 127.0.0.3;
    local-address 127.0.0.3;
    local-as 64496;
    peer-as 64496;

    static {
        route 103.36.0.5/24 {
            rd 3548:478513974;
            as-path [ 35000 64000 60000 ];
            next-hop 104.36.0.254;
            originator-id 27.4.5.6;
            local-preference 100;
            community [ 64000:43 ];
            extended-community [ target:24563:7.35.75.46 ];
            label 256;
        }
	}

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        all
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:16.616778" elapsed="0.000790"/>
</kw>
<var name="${cfgfile}">exabgp3.cfg</var>
<status status="PASS" start="2026-06-06T03:32:16.421727" elapsed="0.195947"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.618676" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp4.cfg'.</msg>
<msg time="2026-06-06T03:32:16.663732" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.618273" elapsed="0.045653"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.664775" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp4.cfg'.</msg>
<msg time="2026-06-06T03:32:16.711728" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.664384" elapsed="0.047489"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.712607" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp4.cfg'.</msg>
<msg time="2026-06-06T03:32:16.759682" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.712270" elapsed="0.047658"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.761044" level="INFO">Executing command 'cat exabgp4.cfg'.</msg>
<msg time="2026-06-06T03:32:16.809788" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:16.810255" level="INFO">${stdout} = neighbor 10.30.170.38 {
    router-id 127.0.0.4;
    local-address 127.0.0.4;
    local-as 64496;
    peer-as 64496;

    static {
        route 4.1.1.0/24 {
            next-hop 14.0.255.254;
       ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.760506" elapsed="0.049912"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:16.811451" level="INFO">neighbor 10.30.170.38 {
    router-id 127.0.0.4;
    local-address 127.0.0.4;
    local-as 64496;
    peer-as 64496;

    static {
        route 4.1.1.0/24 {
            next-hop 14.0.255.254;
            community [ 30740:30740 30740:0 ];
        }
    }

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        all
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:16.810905" elapsed="0.000616"/>
</kw>
<var name="${cfgfile}">exabgp4.cfg</var>
<status status="PASS" start="2026-06-06T03:32:16.617942" elapsed="0.193630"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.812274" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp5.cfg'.</msg>
<msg time="2026-06-06T03:32:16.859742" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.812018" elapsed="0.047938"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.860885" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp5.cfg'.</msg>
<msg time="2026-06-06T03:32:16.912462" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.860454" elapsed="0.052345"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.914948" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp5.cfg'.</msg>
<msg time="2026-06-06T03:32:16.963758" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.913509" elapsed="0.050510"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:16.964846" level="INFO">Executing command 'cat exabgp5.cfg'.</msg>
<msg time="2026-06-06T03:32:17.016016" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:17.016363" level="INFO">${stdout} = neighbor 10.30.170.38 {
    router-id 127.0.0.5;
    local-address 127.0.0.5;
    local-as 64496;
    peer-as 64496;

    static {
        route 5.1.1.0/24 {
            next-hop 15.0.255.254;
       ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:16.964474" elapsed="0.051954"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.017867" level="INFO">neighbor 10.30.170.38 {
    router-id 127.0.0.5;
    local-address 127.0.0.5;
    local-as 64496;
    peer-as 64496;

    static {
        route 5.1.1.0/24 {
            next-hop 15.0.255.254;
            extended-community 31740:31740 extended-community [ 32740:32740 32740:0 ];
        }
    }

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        all
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.017032" elapsed="0.000992"/>
</kw>
<var name="${cfgfile}">exabgp5.cfg</var>
<status status="PASS" start="2026-06-06T03:32:16.811785" elapsed="0.206346"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.019219" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.068338" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.018815" elapsed="0.049790"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.069823" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.120199" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.069275" elapsed="0.051223"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.121880" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.172556" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.121254" elapsed="0.051639"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.174119" level="INFO">Executing command 'cat exabgp6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.224344" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:17.224823" level="INFO">${stdout} = neighbor 10.30.170.38 {
    router-id 127.0.0.6;
    local-address 127.0.0.6;
    local-as 64496;
    peer-as 64496;

    static {
        route 2001:4B50:20C0::/48 {
            rd 3215:583457597;
  ...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.173544" elapsed="0.051348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.226420" level="INFO">neighbor 10.30.170.38 {
    router-id 127.0.0.6;
    local-address 127.0.0.6;
    local-as 64496;
    peer-as 64496;

    static {
        route 2001:4B50:20C0::/48 {
            rd 3215:583457597;
            as-path [ 25186 65000 64512 ];
            next-hop ::FFFF;
            originator-id 57.35.2.240;
            local-preference 100;
            community [ 65000:33 ];
            extended-community [ target:10283:4.249.92.120 ];
            label 926;
        }
    }

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        all
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.225591" elapsed="0.000942"/>
</kw>
<var name="${cfgfile}">exabgp6.cfg</var>
<status status="PASS" start="2026-06-06T03:32:17.018432" elapsed="0.208181"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.227736" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:32:17.276505" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.227292" elapsed="0.049542"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.278000" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:32:17.328231" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.277450" elapsed="0.051055"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.329873" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:32:17.380392" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.329315" elapsed="0.051381"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.381828" level="INFO">Executing command 'cat exabgp_graceful_restart.cfg'.</msg>
<msg time="2026-06-06T03:32:17.432246" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:17.432714" level="INFO">${stdout} = neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        graceful-restart 40;
    }

    family...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.381297" elapsed="0.051487"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.434318" level="INFO">neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        graceful-restart 40;
    }

    family {
        ipv6 unicast;
    }

    static {
        route 2a04:6d80::1/128 next-hop self;
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.433455" elapsed="0.000973"/>
</kw>
<var name="${cfgfile}">exabgp_graceful_restart.cfg</var>
<status status="PASS" start="2026-06-06T03:32:17.226939" elapsed="0.207568"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.435583" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:32:17.480390" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.435199" elapsed="0.045528"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.481930" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:32:17.532313" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.481348" elapsed="0.051235"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.533826" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:32:17.583963" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.533240" elapsed="0.050980"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.585354" level="INFO">Executing command 'cat exaipv4.cfg'.</msg>
<msg time="2026-06-06T03:32:17.636145" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:17.636542" level="INFO">${stdout} = neighbor 10.30.170.38 {
                  router-id 127.0.0.1;
                  local-address 127.0.0.1;
                  local-as 64496;
                  peer-as 64496;
                  family {
...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.584872" elapsed="0.051730"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.638047" level="INFO">neighbor 10.30.170.38 {
                  router-id 127.0.0.1;
                  local-address 127.0.0.1;
                  local-as 64496;
                  peer-as 64496;
                  family {
                        ipv4 unicast;
                  }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.637277" elapsed="0.000858"/>
</kw>
<var name="${cfgfile}">exaipv4.cfg</var>
<status status="PASS" start="2026-06-06T03:32:17.434839" elapsed="0.203354"/>
</iter>
<iter>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.639150" level="INFO">Executing command 'sed -i -e 's/ODLIP/10.30.170.38/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.688367" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ODLIP/${ODL_SYSTEM_IP}/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.638808" elapsed="0.049806"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.691311" level="INFO">Executing command 'sed -i -e 's/ROUTEREFRESH/disable/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.740000" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ROUTEREFRESH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.689151" elapsed="0.051055"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.741212" level="INFO">Executing command 'sed -i -e 's/ADDPATH/disable/g' exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.791614" level="INFO">Command exited with return code 0.</msg>
<arg>sed -i -e 's/ADDPATH/disable/g' ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.740759" elapsed="0.051039"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.792566" level="INFO">Executing command 'cat exaipv6.cfg'.</msg>
<msg time="2026-06-06T03:32:17.844905" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:17.845175" level="INFO">${stdout} = neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        route-refresh disable;
        add-pat...</msg>
<var>${stdout}</var>
<arg>cat ${cfgfile}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:17.792219" elapsed="0.052988"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.846141" level="INFO">neighbor ::1 {
    router-id 1.2.3.4;
    local-address 2607:f0d0:1002:0011:0000:0000:0000:0002;
    local-as 64496;
    peer-as 64496;

    capability {
        route-refresh disable;
        add-path disable;
    }

    family {
        ipv6 unicast;
    }

    static {
        route 2a04:6d80::1/128 next-hop self;
    }
}</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.845610" elapsed="0.000642"/>
</kw>
<var name="${cfgfile}">exaipv6.cfg</var>
<status status="PASS" start="2026-06-06T03:32:17.638465" elapsed="0.207864"/>
</iter>
<var>${cfgfile}</var>
<value>@{cfgfiles}</value>
<status status="PASS" start="2026-06-06T03:32:15.840966" elapsed="2.005442"/>
</for>
<doc>Uploads exabgp config files and replaces variables within those
config files with desired values.</doc>
<status status="PASS" start="2026-06-06T03:32:15.759373" elapsed="2.087183"/>
</kw>
<doc>Suite setup keyword.</doc>
<status status="PASS" start="2026-06-06T03:31:49.728451" elapsed="28.118253"/>
</kw>
<test id="s1-s20-t1" name="Verify_Rib_Empty" line="40">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:17.854453" elapsed="0.000231"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:17.854182" elapsed="0.000559"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:17.855870" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:17.855716" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.855687" elapsed="0.000265"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:17.860790" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:17.860680" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.860660" elapsed="0.000198"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.861909" 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-06-06T03:32:17.861471" elapsed="0.000465"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.862427" 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-06-06T03:32:17.862132" elapsed="0.000321"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:17.862497" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:32:17.862677" 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-06-06T03:32:17.861093" elapsed="0.001610"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:17.868079" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:17.867969" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.867949" elapsed="0.000199"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:17.869343" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:17.869235" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.869216" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:17.869911" 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-06-06T03:32:17.869569" elapsed="0.000369"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.870319" level="INFO">${current_connection_index} = 7</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-06-06T03:32:17.870101" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.902679" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:17.870899" elapsed="0.031908"/>
</kw>
<msg time="2026-06-06T03:32:17.903004" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:17.903051" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:17.870504" elapsed="0.032583"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:17.924965" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "E "m "p "t "y "[K"
[?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-06-06T03:32:17.903682" elapsed="0.021385"/>
</kw>
<msg time="2026-06-06T03:32:17.925228" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:17.925273" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "E "m "...</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-06-06T03:32:17.903285" elapsed="0.022024"/>
</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-06-06T03:32:17.925669" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:17.925394" elapsed="0.000333"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.925371" elapsed="0.000380"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.926196" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "E "m "p "t "y "[K"
[?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-06-06T03:32:17.925895" elapsed="0.000366"/>
</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-06-06T03:32:17.926544" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:17.926328" elapsed="0.000353"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.926310" elapsed="0.000397"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:17.926743" elapsed="0.000037"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:17.929443" elapsed="0.000175"/>
</kw>
<msg time="2026-06-06T03:32:17.929697" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:17.928270" elapsed="0.001564"/>
</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="NOT RUN" start="2026-06-06T03:32:17.930113" elapsed="0.000080"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.930452" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:17.927612" elapsed="0.003048"/>
</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-06-06T03:32:17.927060" elapsed="0.003758"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:17.868934" elapsed="0.061991"/>
</kw>
<msg time="2026-06-06T03:32:17.931023" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:17.931068" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "E "m "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:17.868301" elapsed="0.062804"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:17.931291" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:17.931183" elapsed="0.000168"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.931163" elapsed="0.000212"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.931805" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.932288" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:17.932359" elapsed="0.000015"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:17.867602" elapsed="0.064864"/>
</kw>
<msg time="2026-06-06T03:32:17.932561" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:17.932605" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "E "m "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:17.863084" elapsed="0.069572"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.932983" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:17.932734" elapsed="0.000302"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.932716" elapsed="0.000344"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:17.862940" elapsed="0.070144"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:17.862763" elapsed="0.070352"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:17.860305" elapsed="0.072866"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:17.855383" elapsed="0.077843"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:17.854901" elapsed="0.078369"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:17.848145" elapsed="0.085180"/>
</kw>
<kw name="Verify_Rib_Status_Empty">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.984324" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:17.983926" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:17.985240" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:17.984886" elapsed="0.000437">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:17.985418" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:17.984530" elapsed="0.000912"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.986046" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:17.985636" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:17.986379" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:17.986548" level="INFO">${template} = /rests/data/network-topology:network-topology/topology=example-ipv4-topology
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:17.986237" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.986995" level="INFO">/rests/data/network-topology:network-topology/topology=example-ipv4-topology
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.986746" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.988067" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:17.987768" elapsed="0.000344"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.988545" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:17.988273" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.988939" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.989147" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.989322" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:17.988801" elapsed="0.000578"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:17.988627" elapsed="0.000783"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:17.989459" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:32:17.989659" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:17.987430" elapsed="0.002256"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:17.987119" elapsed="0.002599"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:17.989893" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:17.989745" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:17.987094" elapsed="0.002873"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:17.990556" level="INFO">${final_text} = /rests/data/network-topology:network-topology/topology=example-ipv4-topology</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:17.990112" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:17.990633" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:17.983287" elapsed="0.007488"/>
</kw>
<msg time="2026-06-06T03:32:17.990830" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:17.970861" elapsed="0.020017"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.004080" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.016180" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.028240" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.028445" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.028622" elapsed="0.000035"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.029012" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.028866" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.028851" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.029373" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.029545" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.029764" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.028820" elapsed="0.000998"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.028715" elapsed="0.001129"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.029990" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.030066" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:18.030190" level="INFO">${uri} = /rests/data/network-topology:network-topology/topology=example-ipv4-topology</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:17.966470" elapsed="0.063746"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.031521" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.031252" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.031703" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.030891" elapsed="0.000837"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.032048" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.031798" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.032601" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.032312" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.032131" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.031780" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.035000" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.032857" elapsed="0.002170"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:18.035077" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:18.035270" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:18.030541" elapsed="0.004756"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.036533" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.036292" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.036706" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.035954" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:18.036938" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:18.036802" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.036783" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.037172" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.037345" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.037411" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:32:18.039464" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:18.035603" elapsed="0.003888"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.040907" level="INFO">/rests/data/network-topology:network-topology/topology=example-ipv4-topology</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.040637" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.041351" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.041108" elapsed="0.000288"/>
</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-06-06T03:32:18.051552" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology 
 path_url=/rests/data/network-topology:network-topology/topology=example-ipv4-topology 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:18.051894" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=example-ipv4-topology 
 status=200, reason=OK 
 headers={'Set-Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:32:18 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '223'} 
 body={"network-topology:topology":[{"topology-id":"example-ipv4-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]} 
 </msg>
<msg time="2026-06-06T03:32:18.052016" 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-06-06T03:32:18.043493" elapsed="0.008551"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.041463" elapsed="0.010626"/>
</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-06-06T03:32:18.052273" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.052116" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.041445" elapsed="0.010916"/>
</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-06-06T03:32:18.056616" level="INFO">{"network-topology:topology":[{"topology-id":"example-ipv4-topology","odl-bgp-topology-config:rib-id":"example-bgp-rib","server-provided":true,"topology-types":{"odl-bgp-topology-types:bgp-ipv4-reachability-topology":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.053389" elapsed="0.003315"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.053166" elapsed="0.003588"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.053148" elapsed="0.003641"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.060295" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.057176" elapsed="0.003184"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.056867" elapsed="0.003540"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.056843" elapsed="0.003598"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.061234" 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-06-06T03:32:18.060694" elapsed="0.000579"/>
</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-06-06T03:32:18.061756" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.061372" elapsed="0.000519"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.062425" 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-06-06T03:32:18.062121" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.061930" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.061345" elapsed="0.001164"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.063053" 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-06-06T03:32:18.062683" elapsed="0.000397"/>
</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-06-06T03:32:18.063385" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.063151" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.063935" 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-06-06T03:32:18.063624" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.063465" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.063132" elapsed="0.000886"/>
</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-06-06T03:32:18.064171" elapsed="0.000344"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:18.065000" 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-06-06T03:32:18.064698" elapsed="0.000329"/>
</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-06-06T03:32:18.065183" elapsed="0.002477"/>
</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-06-06T03:32:18.052740" elapsed="0.015000"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.067934" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.067821" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.067797" elapsed="0.000206"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:32:18.070786" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp...</msg>
<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="PASS" start="2026-06-06T03:32:18.068151" elapsed="0.002664"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:32:18.070867" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:18.071027" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:32:18.039820" elapsed="0.031234"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.071116" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:32:18.071266" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:17.944162" elapsed="0.127130"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.098905" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.098398" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.099761" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.099442" elapsed="0.000451">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.100069" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.099103" elapsed="0.000991"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.100789" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.100321" elapsed="0.000496"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.101149" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/topology_state/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.101311" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "example-ipv4-topology",
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.100979" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.101796" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "example-ipv4-topology",
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,
            "topology-types": {
                "odl-bgp-topology-types:bgp-ipv4-reachability-topology": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.101493" elapsed="0.000351"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:18.102323" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.101918" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.103093" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.102556" elapsed="0.000563"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.102411" elapsed="0.000743"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.101894" elapsed="0.001282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.103835" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "example-ipv4-topology",
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.103323" elapsed="0.000541"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.103916" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.097783" elapsed="0.006262"/>
</kw>
<msg time="2026-06-06T03:32:18.104099" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.085480" elapsed="0.018667"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.118016" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.130404" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/topology_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.142798" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.143012" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.143253" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.143681" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.143516" elapsed="0.000223"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.143498" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.143910" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.144082" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.144249" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.143460" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.143342" elapsed="0.000988"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.144478" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.144556" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:18.144717" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "example-ipv4-topology",
            "odl-bgp-topology-config:rib-id": "example-bgp-rib",
            "server-provided": true,...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.082862" elapsed="0.061886"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.144931" elapsed="0.002261"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:32:18.148306" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.147966" elapsed="0.000369"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:32:18.148795" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "odl-bgp-topology-config:rib-id": "example-bgp-rib",
   "server-provided": true,
   "topology-id": "example-ipv4-topology",
   "topology-types": {
    "odl-bgp...</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.148489" elapsed="0.000334"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:32:18.148981" elapsed="0.000354"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:32:18.147518" elapsed="0.001878"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.147273" elapsed="0.002158"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.149654" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.149457" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.147254" elapsed="0.002484"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:32:18.072472" elapsed="0.077314"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:32:18.071615" elapsed="0.078249"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.071375" elapsed="0.078537"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.071358" elapsed="0.078577"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.149969" elapsed="0.000034"/>
</return>
<arg>${POLICIES_VAR}/topology_state</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:32:17.938025" elapsed="0.212078"/>
</kw>
<arg>60s</arg>
<arg>3s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${POLICIES_VAR}/topology_state</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:32:17.933779" elapsed="0.216391"/>
</kw>
<doc>Checks that example-ipv4-topology is ready, and therefore full rib is ready to be configured.</doc>
<status status="PASS" start="2026-06-06T03:32:17.933469" elapsed="0.216817"/>
</kw>
<doc>Checks empty example-ipv4-topology ready.</doc>
<status status="PASS" start="2026-06-06T03:32:17.846847" elapsed="0.303560"/>
</test>
<test id="s1-s20-t2" name="Configure_App_Peer" line="44">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:18.154446" elapsed="0.000231"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:18.154181" elapsed="0.000555"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.155762" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.155620" elapsed="0.000189"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.155599" elapsed="0.000233"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.160912" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.160802" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.160783" elapsed="0.000199"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.162055" 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-06-06T03:32:18.161633" elapsed="0.000451"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.162588" 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-06-06T03:32:18.162269" elapsed="0.000346"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:18.162690" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:32:18.162864" 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-06-06T03:32:18.161222" elapsed="0.001669"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:18.168450" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.168335" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.168314" elapsed="0.000206"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:18.169806" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.169690" elapsed="0.000173"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.169667" elapsed="0.000223"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:18.170364" 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-06-06T03:32:18.170048" elapsed="0.000343"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:18.170805" level="INFO">${current_connection_index} = 7</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-06-06T03:32:18.170557" elapsed="0.000274"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:18.200954" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:18.171357" elapsed="0.029704"/>
</kw>
<msg time="2026-06-06T03:32:18.201229" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:18.201276" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:18.171010" elapsed="0.030303"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:18.222910" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:32:18.201971" elapsed="0.021052"/>
</kw>
<msg time="2026-06-06T03:32:18.223188" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:18.223245" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "...</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-06-06T03:32:18.201501" elapsed="0.021783"/>
</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-06-06T03:32:18.223615" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.223374" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.223347" elapsed="0.000371"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.224174" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:32:18.223863" elapsed="0.000446"/>
</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-06-06T03:32:18.224598" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.224378" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.224359" elapsed="0.000342"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:18.224738" elapsed="0.000033"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:18.227683" elapsed="0.000156"/>
</kw>
<msg time="2026-06-06T03:32:18.227905" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.226364" elapsed="0.001680"/>
</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="NOT RUN" start="2026-06-06T03:32:18.228543" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.228916" elapsed="0.000176"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:18.225686" elapsed="0.003532"/>
</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-06-06T03:32:18.225034" elapsed="0.004252"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:18.169322" elapsed="0.060066"/>
</kw>
<msg time="2026-06-06T03:32:18.229482" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:18.229527" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:18.168690" elapsed="0.060875"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:18.229827" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:18.229715" elapsed="0.000172"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.229692" elapsed="0.000219"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.230317" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.230701" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.230775" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:18.167976" elapsed="0.062909"/>
</kw>
<msg time="2026-06-06T03:32:18.230979" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:18.231023" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "C "o "n "f "i "g "u "r "e "_ "A "p "p "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:18.163286" elapsed="0.067774"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.231386" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.231136" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.231119" elapsed="0.000344"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:18.163137" elapsed="0.068350"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:18.162952" elapsed="0.068566"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:18.160415" elapsed="0.071158"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:18.155326" elapsed="0.076304"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:18.154891" elapsed="0.076815"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:18.151757" elapsed="0.080005"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.232505" level="INFO">&amp;{mapping} = { RIB_INSTANCE_NAME=example-bgp-rib | APP_PEER_ID=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib | IP=10.30.170.38 }</msg>
<var>&amp;{mapping}</var>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<arg>APP_PEER_ID=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.231942" elapsed="0.000591"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.266220" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.265839" elapsed="0.000411"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.267027" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.266765" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.267200" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.266414" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.267815" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.267392" elapsed="0.000452"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.268164" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.268345" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.268013" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.268795" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.268530" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.269910" level="INFO">mapping: {'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.269611" elapsed="0.000345"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.270704" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.270117" elapsed="0.000615"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.271449" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.271143" elapsed="0.000332"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.272304" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.272027" elapsed="0.000303"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.272385" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:32:18.272549" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.271684" elapsed="0.000889"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.272753" elapsed="0.000247"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.270982" elapsed="0.002060"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.273597" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.273292" elapsed="0.000390"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.274451" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.274240" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.274528" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.274696" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.273893" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.274872" elapsed="0.000221"/>
</kw>
<var name="${key}">APP_PEER_ID</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:32:18.273159" elapsed="0.001976"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.275688" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.275377" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.276473" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.276214" elapsed="0.000285"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.276549" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.276716" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.275898" elapsed="0.000843"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.276891" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.275246" elapsed="0.001911"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.277735" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.277398" elapsed="0.000363"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.278472" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.278263" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.278547" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.278709" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.277947" elapsed="0.000787"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.278887" elapsed="0.000220"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:32:18.277268" elapsed="0.001880"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.270791" elapsed="0.008391"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.279224" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.279383" level="INFO">${mapping_to_use} = {'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:18.269282" elapsed="0.010127"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.268923" elapsed="0.010518"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.279618" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.279468" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.268896" elapsed="0.010817"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.280488" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.279859" elapsed="0.000658"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.280568" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.265173" elapsed="0.015536"/>
</kw>
<msg time="2026-06-06T03:32:18.280765" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.252714" elapsed="0.028102"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.293137" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.305390" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.317477" elapsed="0.000075"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.317767" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.317983" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.318445" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.318270" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.318252" elapsed="0.000286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.318721" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.318923" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.319094" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.318212" elapsed="0.000935"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.318085" elapsed="0.001088"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.319319" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.319395" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:18.319533" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.248470" elapsed="0.071091"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.344179" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.343780" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.345002" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.344732" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.345180" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.344376" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.345783" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.345369" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.346120" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.346292" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/conf...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.345975" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.346744" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.346480" elapsed="0.000360"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:18.347228" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.346915" elapsed="0.000371"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.347774" level="INFO">${mapping_to_use} = {'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.347459" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.347313" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.346893" elapsed="0.000965"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.348627" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.348007" elapsed="0.000666"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.348725" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.343152" elapsed="0.005707"/>
</kw>
<msg time="2026-06-06T03:32:18.348913" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.330745" elapsed="0.018216"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.361215" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.373319" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.385382" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.385579" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.385784" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.386175" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.386029" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.386013" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.386396" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.386562" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.386743" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.385981" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.385869" elapsed="0.000995"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.387020" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.387097" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:18.387223" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
 ...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.329783" elapsed="0.057470"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.388560" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.388292" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.388745" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.387938" elapsed="0.000832"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.389092" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.388840" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.389682" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.389351" elapsed="0.000361"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.389172" elapsed="0.000575"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.388821" elapsed="0.000947"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.392069" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.389922" elapsed="0.002173"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:18.392146" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.392299" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:18.387588" elapsed="0.004736"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.393875" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.393602" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.394323" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.394084" elapsed="0.000288"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.394784" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.394522" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.395217" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.394979" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:18.396088" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:18.395884" elapsed="0.000230"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:18.396441" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:18.396267" elapsed="0.000199"/>
</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-06-06T03:32:18.396615" elapsed="0.000232"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.397256" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.397003" elapsed="0.000297"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:18.397342" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.397496" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:18.395459" elapsed="0.002099"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:18.412518" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '224', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;10.30.170.38&lt;/neighbor-address&gt;
    &lt;config&gt;
        &lt;peer-group&gt;application-peers&lt;/peer-group&gt;
    &lt;/config&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:18.412599" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=10.30.170.38', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:18.412778" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:18.400838" elapsed="0.011983"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.397632" elapsed="0.015253"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.413138" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.412922" elapsed="0.000310"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.397613" elapsed="0.015650"/>
</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-06-06T03:32:18.417963" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.414733" elapsed="0.003292"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.414404" elapsed="0.003669"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.414378" elapsed="0.003730"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.421786" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.418661" elapsed="0.003189"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.418187" elapsed="0.003709"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.418163" elapsed="0.003767"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.422764" 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-06-06T03:32:18.422159" elapsed="0.000643"/>
</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-06-06T03:32:18.423235" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.422902" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.424009" 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-06-06T03:32:18.423569" elapsed="0.000480"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.423348" elapsed="0.000750"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.422876" elapsed="0.001251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.424869" 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-06-06T03:32:18.424347" elapsed="0.000559"/>
</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-06-06T03:32:18.425330" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.425004" elapsed="0.000405"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.426112" 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-06-06T03:32:18.425695" elapsed="0.000454"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.425442" elapsed="0.000756"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.424979" elapsed="0.001248"/>
</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-06-06T03:32:18.426433" elapsed="0.000502"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:18.427570" 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-06-06T03:32:18.427173" elapsed="0.000433"/>
</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-06-06T03:32:18.427848" elapsed="0.002926"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:32:18.413797" elapsed="0.017081"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:18.431072" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:32:18.430955" elapsed="0.000178"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.430935" elapsed="0.000223"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:18.431309" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.431378" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:18.433595" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:32:18.392666" elapsed="0.040956"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.433721" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.433877" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:18.237334" elapsed="0.196568"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.434251" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.434011" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.433991" elapsed="0.000352"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.434376" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:18.232879" elapsed="0.201621"/>
</kw>
<kw name="Post_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Post_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.467669" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.467280" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.468410" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.468198" elapsed="0.000277">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.468567" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.467864" elapsed="0.000727"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.469154" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.468773" elapsed="0.000408"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.469477" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.469629" level="INFO">${template} = rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.469340" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.470101" level="INFO">rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.469858" elapsed="0.000288"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.471102" level="INFO">mapping: {'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.470843" elapsed="0.000346"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.471632" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.471355" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.472350" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.472051" elapsed="0.000359"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.473176" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.472952" elapsed="0.000250"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.473253" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:18.473405" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.472610" elapsed="0.000820"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.473581" elapsed="0.000263"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.471913" elapsed="0.001972"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.474426" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.474129" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.475180" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.474970" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.475256" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.475405" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.474636" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.475581" elapsed="0.000238"/>
</kw>
<var name="${key}">APP_PEER_ID</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:32:18.473997" elapsed="0.001862"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.476575" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.476104" elapsed="0.000496"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.477332" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.477121" elapsed="0.000237"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.477408" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.477557" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.476802" elapsed="0.000780"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.477761" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.475972" elapsed="0.002053"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.478572" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.478269" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.479324" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.479116" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.479399" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.479547" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.478796" elapsed="0.000775"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.479735" elapsed="0.000222"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:32:18.478137" elapsed="0.001861"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.471732" elapsed="0.008300"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.480076" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:18.480230" level="INFO">${mapping_to_use} = {'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:18.470500" elapsed="0.009756"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.470211" elapsed="0.010077"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.480463" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.480314" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.470193" elapsed="0.010379"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.481344" level="INFO">${final_text} = rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.480736" elapsed="0.000636"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.481422" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.466627" elapsed="0.014919"/>
</kw>
<msg time="2026-06-06T03:32:18.481600" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.454266" elapsed="0.027419"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.493680" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.505692" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.517629" elapsed="0.000058"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.517860" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.518040" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.518412" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.518267" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.518251" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.518633" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.518821" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.518992" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.518218" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.518116" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.519222" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.519299" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:18.519420" level="INFO">${uri} = rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.450061" elapsed="0.069386"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.543901" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/post_data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.543498" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.544702" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/post_data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.544435" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/post_data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.544874" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.544099" elapsed="0.000800"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.545450" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/post_data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.545065" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.545808" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/post_data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/post_data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.545977" level="INFO">${template} = &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;prefix&gt;10.0.0.17/32&lt;/prefix&gt;
    &lt;route-key&gt;10.0.0.17/32&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;as-path/&gt;...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.545652" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.546411" level="INFO">&lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;prefix&gt;10.0.0.17/32&lt;/prefix&gt;
    &lt;route-key&gt;10.0.0.17/32&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;10.11.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
    &lt;/attributes&gt;
&lt;/ipv4-route&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.546166" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:18.546850" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.546535" elapsed="0.000374"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.547375" level="INFO">${mapping_to_use} = {'RIB_INSTANCE_NAME': 'example-bgp-rib', 'APP_PEER_ID': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'IP': '10.30.170.38'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.547081" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.546935" elapsed="0.000502"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.546515" elapsed="0.000943"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.548075" level="INFO">${final_text} = &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;prefix&gt;10.0.0.17/32&lt;/prefix&gt;
    &lt;route-key&gt;10.0.0.17/32&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;as-path/&gt;...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.547602" elapsed="0.000503"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.548155" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.542884" elapsed="0.005398"/>
</kw>
<msg time="2026-06-06T03:32:18.548338" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.530469" elapsed="0.017915"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.560349" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.572490" elapsed="0.000058"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.584712" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.584909" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.585087" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.585472" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.585325" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.585310" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.585739" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.585920" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.586087" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.585277" elapsed="0.000862"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.585169" elapsed="0.000997"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.586315" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.586391" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:18.586519" level="INFO">${data} = &lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;prefix&gt;10.0.0.17/32&lt;/prefix&gt;
    &lt;route-key&gt;10.0.0.17/32&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;as-path/&gt;...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>name_prefix=post_</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.529511" elapsed="0.057037"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.587867" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.587587" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.588032" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.587238" elapsed="0.000818"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.588375" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.588126" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.588944" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.588635" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.588456" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.588108" elapsed="0.000919"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.591324" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.589179" elapsed="0.002171"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:18.591447" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:18.591602" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:18.586899" elapsed="0.004728"/>
</kw>
<kw name="Post_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.593159" level="INFO">rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.592908" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.593600" level="INFO">&lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;prefix&gt;10.0.0.17/32&lt;/prefix&gt;
    &lt;route-key&gt;10.0.0.17/32&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;10.11.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
    &lt;/attributes&gt;
&lt;/ipv4-route&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.593362" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.594100" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.593854" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.594532" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.594293" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:18.595392" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:18.595194" elapsed="0.000224"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:18.595760" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:18.595570" elapsed="0.000216"/>
</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-06-06T03:32:18.595935" elapsed="0.000216"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.596550" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.596306" elapsed="0.000288"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:18.596636" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:32:18.596811" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:18.594790" elapsed="0.002046"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="POST On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:18.609289" level="INFO">POST Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '458', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"&gt;
    &lt;path-id&gt;0&lt;/path-id&gt;
    &lt;prefix&gt;10.0.0.17/32&lt;/prefix&gt;
    &lt;route-key&gt;10.0.0.17/32&lt;/route-key&gt;
    &lt;attributes&gt;
        &lt;as-path/&gt;
        &lt;origin&gt;
            &lt;value&gt;igp&lt;/value&gt;
        &lt;/origin&gt;
        &lt;local-pref&gt;
            &lt;pref&gt;100&lt;/pref&gt;
        &lt;/local-pref&gt;
        &lt;ipv4-next-hop&gt;
            &lt;global&gt;10.11.1.1&lt;/global&gt;
        &lt;/ipv4-next-hop&gt;
    &lt;/attributes&gt;
&lt;/ipv4-route&gt; 
 </msg>
<msg time="2026-06-06T03:32:18.609348" level="INFO">POST Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=201, reason=Created 
 headers={'Location': 'http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route=10.0.0.17%2F32,0', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:18.609439" 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 POST request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:18.599104" elapsed="0.010361"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.596906" elapsed="0.012604"/>
</branch>
<branch type="ELSE">
<kw name="POST 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 POST request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.609742" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.609536" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.596888" elapsed="0.012950"/>
</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-06-06T03:32:18.617117" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.611954" elapsed="0.005259"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.611430" elapsed="0.005862"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.611389" elapsed="0.005958"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.620301" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.618072" elapsed="0.002274"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.617544" elapsed="0.002837"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.617503" elapsed="0.002902"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.620976" 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-06-06T03:32:18.620569" elapsed="0.000435"/>
</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-06-06T03:32:18.621317" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.621079" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.621891" 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-06-06T03:32:18.621559" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.621400" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.621061" elapsed="0.000913"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.622491" 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-06-06T03:32:18.622132" elapsed="0.000386"/>
</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-06-06T03:32:18.622881" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.622619" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.623423" 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-06-06T03:32:18.623123" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.622964" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.622597" 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-06-06T03:32:18.623671" elapsed="0.000348"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:18.624468" 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-06-06T03:32:18.624188" elapsed="0.000306"/>
</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-06-06T03:32:18.624663" elapsed="0.002242"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</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-06-06T03:32:18.610429" elapsed="0.016538"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:18.627150" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:18.627045" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.627024" elapsed="0.000210"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:18.627382" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.627450" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:18.629660" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>POST 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-06-06T03:32:18.591966" elapsed="0.037745"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.629782" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.629935" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>explicit_status_codes=${explicit_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Post_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:18.439123" elapsed="0.190837"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.630309" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.630074" elapsed="0.000301"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.630055" elapsed="0.000344"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.630433" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}/app_peer_route</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Post_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:18.434773" elapsed="0.195817"/>
</kw>
<doc>Configures bgp application peer, and configures it's routes.</doc>
<status status="PASS" start="2026-06-06T03:32:18.150929" elapsed="0.479802"/>
</test>
<test id="s1-s20-t3" name="Reconfigure_ODL_To_Accept_Connections" line="60">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:18.634203" elapsed="0.000211"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:18.633932" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.635464" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.635354" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.635334" elapsed="0.000199"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.642098" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.641990" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.641971" elapsed="0.000196"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.643172" 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-06-06T03:32:18.642786" elapsed="0.000413"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.643675" 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-06-06T03:32:18.643363" elapsed="0.000340"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:18.643749" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.643904" 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-06-06T03:32:18.642389" elapsed="0.001540"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:18.649302" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.649194" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.649174" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:18.650565" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:18.650457" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.650438" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:18.651107" 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-06-06T03:32:18.650809" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:18.651511" level="INFO">${current_connection_index} = 7</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-06-06T03:32:18.651292" elapsed="0.000245"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:18.682203" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:18.652055" elapsed="0.030305"/>
</kw>
<msg time="2026-06-06T03:32:18.682555" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:18.682602" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:18.651713" elapsed="0.030924"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:18.710858" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "[K"
[?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-06-06T03:32:18.683287" elapsed="0.027690"/>
</kw>
<msg time="2026-06-06T03:32:18.711141" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:18.711187" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "...</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-06-06T03:32:18.682883" elapsed="0.028340"/>
</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-06-06T03:32:18.711584" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.711320" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.711290" elapsed="0.000398"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.712148" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "D "L "_ "T "o "_ "A "c "c "e "p "t "_ "C "o "n "n "e "c "t "i "o "n "s "[K"
[?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-06-06T03:32:18.711834" elapsed="0.000456"/>
</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-06-06T03:32:18.712575" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.712358" elapsed="0.000272"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.712339" elapsed="0.000332"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:18.712712" elapsed="0.000042"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:18.715322" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:32:18.715531" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.714301" elapsed="0.001457"/>
</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="NOT RUN" start="2026-06-06T03:32:18.716046" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.716383" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:18.713606" elapsed="0.002961"/>
</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-06-06T03:32:18.713038" elapsed="0.003593"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:18.650155" elapsed="0.066596"/>
</kw>
<msg time="2026-06-06T03:32:18.716844" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:18.716888" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:18.649523" elapsed="0.067401"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:18.717308" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:18.717001" elapsed="0.000367"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.716982" elapsed="0.000411"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.717830" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.718169" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.718240" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:18.648849" elapsed="0.069499"/>
</kw>
<msg time="2026-06-06T03:32:18.718440" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:18.718485" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "R "e "c "o "n "f "i "g "u "r "e "_ "O "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:18.644294" elapsed="0.074226"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.718861" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.718595" elapsed="0.000319"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.718577" elapsed="0.000361"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:18.644152" elapsed="0.074810"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:18.643982" elapsed="0.075013"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:18.641586" elapsed="0.077463"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:18.635065" elapsed="0.084040"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:18.634622" elapsed="0.084529"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:18.631798" elapsed="0.087407"/>
</kw>
<for flavor="IN ZIP">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.720227" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.719634" elapsed="0.000621"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.753635" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.753238" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.754565" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.754283" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.754762" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.753937" elapsed="0.000850"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.755340" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.754954" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.755687" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.755862" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.755529" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.756297" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.756050" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.757353" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.757096" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.757863" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.757558" elapsed="0.000331"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.758802" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.758265" elapsed="0.000563"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.759831" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.759340" elapsed="0.000519"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.759913" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:32:18.760082" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.759018" elapsed="0.001089"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.760264" elapsed="0.000245"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:18.758127" elapsed="0.002425"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.761114" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.760818" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.762119" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.761659" elapsed="0.000487"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.762196" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.762346" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.761327" elapsed="0.001044"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.762522" elapsed="0.000237"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:18.760682" elapsed="0.002118"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.763386" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.763045" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.764368" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.763934" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.764446" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.764596" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.763597" elapsed="0.001023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.764802" elapsed="0.000221"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:18.762911" elapsed="0.002153"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.765601" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.765307" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.766585" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.766158" elapsed="0.000454"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.766678" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.766829" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.765843" elapsed="0.001010"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.767004" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.765176" elapsed="0.002088"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.767822" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.767509" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.768801" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.768349" elapsed="0.000480"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.768878" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.769028" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.768033" elapsed="0.001019"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.769202" elapsed="0.000217"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.767377" elapsed="0.002082"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.757946" elapsed="0.011548"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.769537" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.769735" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:18.756766" elapsed="0.012997"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.756427" elapsed="0.013369"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.769972" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.769823" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.756400" elapsed="0.013648"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.770850" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.770192" elapsed="0.000687"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.770928" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.752589" elapsed="0.018463"/>
</kw>
<msg time="2026-06-06T03:32:18.771107" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.739897" elapsed="0.031258"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.783690" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.795856" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.807939" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.808151" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.808334" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.808755" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.808588" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.808569" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.808979" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.809148" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.809313" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.808530" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.808416" elapsed="0.000975"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.809540" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.809616" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:32:18.809789" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.735677" elapsed="0.074140"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.836847" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.836434" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.837663" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.837385" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.837860" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.837045" elapsed="0.000840"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.838501" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.838108" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.838854" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.839030" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.838709" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.839470" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.839223" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:18.839936" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.839613" elapsed="0.000383"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.840469" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.840168" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.840021" elapsed="0.000511"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.839592" elapsed="0.000962"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.841549" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.840716" elapsed="0.000864"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.841631" elapsed="0.000049"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.835817" elapsed="0.005993"/>
</kw>
<msg time="2026-06-06T03:32:18.841879" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.823423" elapsed="0.018504"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.854234" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.866288" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.878446" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.878677" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.878881" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.879331" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.879176" elapsed="0.000224"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:18.879159" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.879583" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.879782" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.879955" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:18.879124" elapsed="0.000885"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.878971" elapsed="0.001071"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.880192" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.880270" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:18.880443" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.820695" elapsed="0.059780"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.881902" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.881571" elapsed="0.000408">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.882074" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.881204" elapsed="0.000895"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.882431" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.882172" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.883011" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.882712" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.882514" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.882153" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.885430" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.883250" elapsed="0.002207"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:18.885561" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:18.885778" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:18.880856" elapsed="0.004952"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.887205" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.886949" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.887654" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.887404" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.888271" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.887881" elapsed="0.000433"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.888720" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.888465" elapsed="0.000299"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:18.889570" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:18.889374" elapsed="0.000221"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:18.889958" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:18.889781" elapsed="0.000205"/>
</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-06-06T03:32:18.890168" elapsed="0.000208"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.890850" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.890530" elapsed="0.000363"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:18.890935" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.891088" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:18.888966" elapsed="0.002147"/>
</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-06-06T03:32:18.906818" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '2156', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.1&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:18.906970" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:18.907174" 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-06-06T03:32:18.893384" elapsed="0.013850"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.891182" elapsed="0.016154"/>
</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-06-06T03:32:18.907774" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.907397" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.891164" elapsed="0.016813"/>
</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-06-06T03:32:18.915438" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.910160" elapsed="0.005376"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.909609" elapsed="0.006006"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.909566" elapsed="0.006143"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.919555" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.916338" elapsed="0.003263"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.915838" elapsed="0.003798"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.915799" elapsed="0.003876"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.920249" 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-06-06T03:32:18.919854" elapsed="0.000496"/>
</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-06-06T03:32:18.920694" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.920429" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.921247" 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-06-06T03:32:18.920942" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.920779" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.920410" elapsed="0.000922"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.921889" 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-06-06T03:32:18.921490" elapsed="0.000426"/>
</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-06-06T03:32:18.922219" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.921987" elapsed="0.000289"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.922771" 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-06-06T03:32:18.922459" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.922300" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.921968" elapsed="0.000884"/>
</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-06-06T03:32:18.923047" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:18.923873" 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-06-06T03:32:18.923568" elapsed="0.000331"/>
</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-06-06T03:32:18.924055" elapsed="0.002275"/>
</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-06-06T03:32:18.908811" elapsed="0.017585"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:18.926575" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:32:18.926465" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.926446" elapsed="0.000238"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:18.926834" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:18.926902" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:18.929111" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:32:18.886143" elapsed="0.042994"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.929247" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.929406" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:18.724984" elapsed="0.204447"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.929823" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.929532" elapsed="0.000362"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.929514" elapsed="0.000404"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.929951" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}${/}${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:18.720550" elapsed="0.209531"/>
</kw>
<var name="${index}">1</var>
<var name="${peer_type}">ibgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:18.719472" elapsed="0.210650"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.931014" level="INFO">&amp;{mapping} = { IP=127.0.0.2 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.930419" elapsed="0.000623"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.964195" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:18.963809" elapsed="0.000416"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.965014" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:18.964748" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:18.965186" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:18.964395" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.965813" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:18.965378" elapsed="0.000463"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:18.966146" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:18.966307" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:18.966005" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.966750" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.966488" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.967765" level="INFO">mapping: {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:18.967490" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.968239" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.967970" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.968952" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.968634" elapsed="0.000344"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.970002" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.969489" elapsed="0.000541"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.970082" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:18.970287" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.969171" elapsed="0.001141"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.970467" elapsed="0.000253"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:32:18.968499" elapsed="0.002263"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.971304" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.971008" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.972284" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.971851" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.972362" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.972512" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.971515" elapsed="0.001022"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.972702" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:18.970875" elapsed="0.002092"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.973550" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.973252" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.974755" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.974298" elapsed="0.000484"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.974834" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.974985" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.973973" elapsed="0.001037"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.975162" elapsed="0.000220"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:18.973117" elapsed="0.002307"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.975980" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.975684" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.976957" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.976508" elapsed="0.000476"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.977035" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:18.977185" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.976191" elapsed="0.001019"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.977361" elapsed="0.000220"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.975536" elapsed="0.002085"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.978218" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:18.977915" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:18.979245" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.978802" elapsed="0.000470"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:18.979325" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:18.979476" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:18.978437" elapsed="0.001064"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:18.979669" elapsed="0.000224"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:18.977779" elapsed="0.002156"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.968319" elapsed="0.011651"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:18.980015" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:18.980174" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:18.967168" elapsed="0.013032"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:18.966870" elapsed="0.013363"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.980411" elapsed="0.000066"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:18.980260" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:18.966848" elapsed="0.013688"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:18.981349" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:18.980697" elapsed="0.000681"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:18.981427" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:18.963178" elapsed="0.018373"/>
</kw>
<msg time="2026-06-06T03:32:18.981608" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:18.950811" elapsed="0.030863"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:18.993873" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.006002" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.018052" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.018248" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.018425" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.018820" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.018669" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.018635" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.019042" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.019209" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.019374" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.018605" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.018502" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.019598" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.019687" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:19.019812" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:18.946590" elapsed="0.073282"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.046091" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.045692" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.046861" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.046619" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.047028" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.046283" elapsed="0.000769"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.047598" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.047215" elapsed="0.000410"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.047937" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.048086" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.047801" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.048513" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.048270" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:19.048961" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.048667" elapsed="0.000352"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.049483" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.049190" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.049045" elapsed="0.000500"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.048632" elapsed="0.000934"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.050527" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.049727" elapsed="0.000859"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.050652" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.045061" elapsed="0.005721"/>
</kw>
<msg time="2026-06-06T03:32:19.050848" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.032752" elapsed="0.018143"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.062953" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.075011" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.087118" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.087328" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.087505" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.087903" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.087756" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.087741" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.088126" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.088293" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.088459" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.087709" elapsed="0.000803"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.087584" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.088700" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.088778" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:19.088940" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.030128" elapsed="0.058842"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.090345" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.090090" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.090510" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.089713" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.090883" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.090605" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.091666" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.091145" elapsed="0.000549"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.090965" elapsed="0.000766"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.090586" elapsed="0.001167"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.094071" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.091908" elapsed="0.002190"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:19.094151" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.094306" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:19.089360" elapsed="0.004971"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.095733" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.095466" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.096175" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.095934" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.096667" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.096408" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.097113" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.096868" elapsed="0.000289"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:19.098002" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:19.097801" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:19.098355" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:19.098181" elapsed="0.000199"/>
</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-06-06T03:32:19.098529" elapsed="0.000218"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.099151" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.098904" elapsed="0.000331"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:19.099279" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.099442" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:19.097358" elapsed="0.002109"/>
</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-06-06T03:32:19.112919" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '2156', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.2&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:19.113026" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:19.113152" 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-06-06T03:32:19.101571" elapsed="0.011617"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.099538" elapsed="0.013713"/>
</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-06-06T03:32:19.113503" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.113288" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.099520" elapsed="0.014106"/>
</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-06-06T03:32:19.121109" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.115588" elapsed="0.005622"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.115095" elapsed="0.006195"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.115053" elapsed="0.006295"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.126618" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.122036" elapsed="0.004644"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.121476" elapsed="0.005241"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.121438" elapsed="0.005304"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.127323" 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-06-06T03:32:19.126924" elapsed="0.000427"/>
</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-06-06T03:32:19.127683" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.127422" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.128382" 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-06-06T03:32:19.127926" elapsed="0.000483"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.127766" elapsed="0.000728"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.127403" elapsed="0.001117"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.129074" 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-06-06T03:32:19.128701" elapsed="0.000400"/>
</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-06-06T03:32:19.129410" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.129172" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.129985" 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-06-06T03:32:19.129670" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.129492" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.129153" elapsed="0.000915"/>
</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-06-06T03:32:19.130223" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:19.131047" 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-06-06T03:32:19.130753" elapsed="0.000320"/>
</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-06-06T03:32:19.131231" elapsed="0.002250"/>
</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-06-06T03:32:19.114274" elapsed="0.019272"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:19.133856" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:32:19.133614" elapsed="0.000317"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.133594" elapsed="0.000362"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:19.134106" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.134175" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:19.136391" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:32:19.094675" elapsed="0.041744"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.136490" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:19.136674" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:18.935673" elapsed="0.201029"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.137085" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.136806" elapsed="0.000349"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.136787" elapsed="0.000392"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.137211" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}${/}${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:18.931309" elapsed="0.206026"/>
</kw>
<var name="${index}">2</var>
<var name="${peer_type}">ibgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:18.930246" elapsed="0.207131"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.138353" level="INFO">&amp;{mapping} = { IP=127.0.0.3 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.137702" elapsed="0.000680"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.171482" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.171085" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.172387" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.172044" elapsed="0.000419">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.172560" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.171702" elapsed="0.000883"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.173163" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.172771" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.173540" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.173719" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.173390" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.174185" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.173932" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.175200" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.174941" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.175687" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.175405" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.176384" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.176088" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.177408" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.176933" elapsed="0.000502"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.177488" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:19.177666" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.176597" elapsed="0.001096"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.177860" elapsed="0.000244"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:32:19.175951" elapsed="0.002193"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.178708" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.178393" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.179697" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.179245" elapsed="0.000479"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.179774" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.179925" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.178927" elapsed="0.001023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.180101" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:19.178260" elapsed="0.002104"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.180918" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.180606" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.182004" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.181438" elapsed="0.000597"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.182090" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.182243" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.181125" elapsed="0.001143"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.182421" elapsed="0.001809"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:19.180475" elapsed="0.003858"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.184957" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.184609" elapsed="0.000375"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.186018" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.185527" elapsed="0.000521"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.186103" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:32:19.186267" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.185196" elapsed="0.001096"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.186454" elapsed="0.000261"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.184465" elapsed="0.002292"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.187301" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.187001" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.188283" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.187852" elapsed="0.000458"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.188368" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.188520" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.187512" elapsed="0.001032"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.188712" elapsed="0.000222"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.186868" elapsed="0.002107"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.175768" elapsed="0.013242"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.189057" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:19.189215" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:19.174603" elapsed="0.014639"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.174305" elapsed="0.014970"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.189459" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.189304" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.174282" elapsed="0.015253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.190414" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.189694" elapsed="0.000749"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.190493" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.170435" elapsed="0.020182"/>
</kw>
<msg time="2026-06-06T03:32:19.190714" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.157868" elapsed="0.032898"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.203029" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.215277" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.227399" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.227599" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.227798" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.228331" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.228038" elapsed="0.000350"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.228021" elapsed="0.000391"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.228552" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.228735" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.228904" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.227988" elapsed="0.000969"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.227881" elapsed="0.001101"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.229127" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.229204" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:19.229328" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.153684" elapsed="0.075671"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.255769" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.255372" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.256556" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.256309" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.256755" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.255964" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.257336" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.256945" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.257681" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.257901" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.257528" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.258347" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.258100" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:19.258796" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.258486" elapsed="0.000369"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.259339" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.259026" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.258880" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.258466" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.260381" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.259573" elapsed="0.000842"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.260471" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.254753" elapsed="0.005846"/>
</kw>
<msg time="2026-06-06T03:32:19.260681" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.242330" elapsed="0.018400"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.272818" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.284857" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.296974" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.297214" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.297398" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.297839" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.297675" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.297654" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.298071" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.298238" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.298404" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.297604" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.297482" elapsed="0.001001"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.298631" elapsed="0.000034"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.298725" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:32:19.298909" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.239596" elapsed="0.059343"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.300346" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.300052" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.300516" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.299659" elapsed="0.000882"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.300885" elapsed="0.000244"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.300612" elapsed="0.000557"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.301704" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.301383" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.301196" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.300593" elapsed="0.001223"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.304145" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.301976" elapsed="0.002196"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:19.304226" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:19.304384" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:19.299296" elapsed="0.005113"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.305841" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.305557" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.306343" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.306101" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.306842" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.306577" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.307281" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.307040" elapsed="0.000284"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:19.308150" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:19.307953" elapsed="0.000223"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:19.308504" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:19.308328" elapsed="0.000201"/>
</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-06-06T03:32:19.308694" elapsed="0.000213"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.309309" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.309064" elapsed="0.000288"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:19.309394" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:19.309548" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:19.307529" elapsed="0.002044"/>
</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-06-06T03:32:19.321751" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '2156', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.3&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:19.321878" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:19.321989" 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-06-06T03:32:19.311719" elapsed="0.010297"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.309658" elapsed="0.012410"/>
</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-06-06T03:32:19.322251" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.322094" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.309625" elapsed="0.012715"/>
</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-06-06T03:32:19.325813" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.323310" elapsed="0.002555"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.323086" elapsed="0.002814"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.323065" elapsed="0.002861"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.328479" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.326207" elapsed="0.002319"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.325982" elapsed="0.002582"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.325965" elapsed="0.002624"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.329200" 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-06-06T03:32:19.328792" elapsed="0.000436"/>
</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-06-06T03:32:19.329540" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.329299" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.330139" 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-06-06T03:32:19.329831" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.329620" elapsed="0.000583"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.329280" elapsed="0.000944"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.330765" 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-06-06T03:32:19.330383" elapsed="0.000409"/>
</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-06-06T03:32:19.331102" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.330862" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.331652" 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-06-06T03:32:19.331343" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.331184" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.330843" elapsed="0.000893"/>
</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-06-06T03:32:19.331893" elapsed="0.000353"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:19.332727" 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-06-06T03:32:19.332410" elapsed="0.000343"/>
</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-06-06T03:32:19.332911" elapsed="0.002294"/>
</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-06-06T03:32:19.322717" elapsed="0.012557"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:19.335455" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:32:19.335342" elapsed="0.000185"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.335323" elapsed="0.000228"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:19.335716" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.335785" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:19.338033" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:32:19.304756" elapsed="0.033304"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.338226" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:19.338390" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:19.142964" elapsed="0.195451"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.338788" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.338514" elapsed="0.000345"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.338496" elapsed="0.000387"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.338917" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}${/}${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:19.138674" elapsed="0.200367"/>
</kw>
<var name="${index}">3</var>
<var name="${peer_type}">ebgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:19.137508" elapsed="0.201575"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.339985" level="INFO">&amp;{mapping} = { IP=127.0.0.4 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.339383" elapsed="0.000631"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.373496" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.373097" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.374410" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.374141" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.374583" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.373767" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.375178" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.374791" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.375509" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.375694" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.375367" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.376123" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.375879" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.377156" level="INFO">mapping: {'IP': '127.0.0.4', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.376898" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.377630" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.377359" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.378371" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.378072" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.379410" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.378920" elapsed="0.000517"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.379490" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:32:19.379739" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.378583" elapsed="0.001182"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.379931" elapsed="0.000243"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:32:19.377929" elapsed="0.002287"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.380782" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.380466" elapsed="0.000342"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.381772" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.381309" elapsed="0.000501"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.381862" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:19.382015" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.380992" elapsed="0.001048"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.382191" elapsed="0.000222"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:19.380332" elapsed="0.002122"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.383013" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.382714" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.384031" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.383568" elapsed="0.000490"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.384109" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.384259" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.383223" elapsed="0.001060"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.384433" elapsed="0.000433"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:19.382567" elapsed="0.002342"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.385472" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.385158" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.386799" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.386282" elapsed="0.000545"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.386882" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:32:19.387042" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.385786" elapsed="0.001280"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.387221" elapsed="0.000228"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.385023" elapsed="0.002468"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.388084" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.387758" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.389089" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.388617" elapsed="0.000499"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.389167" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.389319" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.388299" elapsed="0.001044"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.389493" elapsed="0.000239"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.387608" elapsed="0.002166"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.377727" elapsed="0.012098"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.389876" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:19.390036" level="INFO">${mapping_to_use} = {'IP': '127.0.0.4', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:19.376558" elapsed="0.013505"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.376253" elapsed="0.013843"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.390281" elapsed="0.000077"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.390126" elapsed="0.000271"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.376226" elapsed="0.014193"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.391265" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.390569" elapsed="0.000725"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.391344" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.372458" elapsed="0.019011"/>
</kw>
<msg time="2026-06-06T03:32:19.391527" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.359753" elapsed="0.031827"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.403841" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.415909" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.428043" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.428242" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.428426" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.428825" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.428677" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.428659" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.429046" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.429213" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.429378" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.428614" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.428505" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.429603" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.429692" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:19.429833" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.355507" elapsed="0.074392"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.456232" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.455844" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.457040" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.456789" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.457211" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.456430" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.457800" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.457398" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.458151" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.458317" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.458011" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.458763" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.458501" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:19.459213" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.458907" elapsed="0.000365"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.459755" level="INFO">${mapping_to_use} = {'IP': '127.0.0.4', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.459442" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.459297" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.458886" elapsed="0.000952"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.460804" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.459984" elapsed="0.000895"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.460935" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.455201" elapsed="0.005870"/>
</kw>
<msg time="2026-06-06T03:32:19.461140" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.442635" elapsed="0.018553"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.473415" elapsed="0.000061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.485691" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.498257" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.498500" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.498706" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.499144" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.498990" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.498969" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.499376" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.499545" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.499727" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.498925" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.498795" elapsed="0.001016"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.499959" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.500039" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:32:19.500238" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.439993" elapsed="0.060277"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.501846" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.501509" elapsed="0.000416">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.502021" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.501081" elapsed="0.000964"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.502388" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.502117" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.502961" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.502664" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.502469" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.502097" elapsed="0.000946"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.505333" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.503196" elapsed="0.002164"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:19.505411" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:19.505566" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:19.500710" elapsed="0.004881"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.507024" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.506767" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.507460" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.507224" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.507951" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.507706" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.508382" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.508144" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:19.509249" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:19.509047" elapsed="0.000229"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:19.509605" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:19.509428" elapsed="0.000203"/>
</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-06-06T03:32:19.509795" elapsed="0.000230"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.510432" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.510185" elapsed="0.000324"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:19.510553" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:19.510725" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:19.508625" elapsed="0.002126"/>
</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-06-06T03:32:19.528866" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '2156', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.4&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;false&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;EXTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:19.529037" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:19.529234" 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-06-06T03:32:19.513001" elapsed="0.016290"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.510823" elapsed="0.018570"/>
</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-06-06T03:32:19.529821" elapsed="0.000075"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.529451" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.510804" elapsed="0.019241"/>
</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-06-06T03:32:19.536221" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.532137" elapsed="0.004148"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.531622" elapsed="0.004714"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.531582" elapsed="0.004791"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.540155" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.536802" elapsed="0.003421"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.536456" elapsed="0.003817"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.536431" elapsed="0.003878"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.541137" 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-06-06T03:32:19.540551" elapsed="0.000626"/>
</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-06-06T03:32:19.541635" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.541282" elapsed="0.000462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.542360" 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-06-06T03:32:19.542055" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.541781" elapsed="0.000675"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.541254" elapsed="0.001226"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.543020" 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-06-06T03:32:19.542654" elapsed="0.000393"/>
</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-06-06T03:32:19.543351" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.543117" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.543902" 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-06-06T03:32:19.543590" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.543430" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.543098" elapsed="0.000889"/>
</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-06-06T03:32:19.544139" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:19.544975" 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-06-06T03:32:19.544677" elapsed="0.000324"/>
</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-06-06T03:32:19.545164" elapsed="0.002280"/>
</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-06-06T03:32:19.530847" elapsed="0.016684"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:19.547748" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:32:19.547611" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.547590" elapsed="0.000256"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:19.547999" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.548068" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:19.550317" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:32:19.505957" elapsed="0.044388"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.550413" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.550574" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:19.344905" elapsed="0.205695"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.550979" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.550720" elapsed="0.000328"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.550701" elapsed="0.000371"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.551105" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}${/}${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:19.340294" elapsed="0.210937"/>
</kw>
<var name="${index}">4</var>
<var name="${peer_type}">ebgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:19.339212" elapsed="0.212062"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.552175" level="INFO">&amp;{mapping} = { IP=127.0.0.5 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.551570" elapsed="0.000634"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.585339" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.584961" elapsed="0.000406"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.586250" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.585912" elapsed="0.000415">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.586422" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.585531" elapsed="0.000916"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.587021" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.586613" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.587355" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.587519" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.587213" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.587963" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.587718" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.588969" level="INFO">mapping: {'IP': '127.0.0.5', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.588710" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.589440" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.589175" elapsed="0.000291"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.590166" level="INFO">${value} = 127.0.0.5</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.589861" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.591202" level="INFO">${encoded} = 127.0.0.5</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.590718" elapsed="0.000511"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.591284" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:32:19.591445" level="INFO">${encoded_value} = 127.0.0.5</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.590380" elapsed="0.001089"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.591626" elapsed="0.000286"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.5</var>
<status status="PASS" start="2026-06-06T03:32:19.589713" elapsed="0.002242"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.592503" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.592205" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.593684" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.593219" elapsed="0.000494"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.593765" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.593962" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.592733" elapsed="0.001255"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.594145" elapsed="0.000341"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:19.592071" elapsed="0.002457"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.595098" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.594794" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.596098" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.595627" elapsed="0.000498"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.596176" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.596329" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.595310" elapsed="0.001043"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.596506" elapsed="0.000258"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:19.594656" elapsed="0.002193"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.597405" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.597101" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.598420" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.597977" elapsed="0.000469"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.598497" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.598664" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.597617" elapsed="0.001074"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.598845" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.596966" elapsed="0.002145"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.599678" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.599356" elapsed="0.000357"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.600837" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.600308" elapsed="0.000556"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.600916" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.601069" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.599937" elapsed="0.001157"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.601247" elapsed="0.000227"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.599224" elapsed="0.002292"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.589520" elapsed="0.012031"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.601595" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:19.601777" level="INFO">${mapping_to_use} = {'IP': '127.0.0.5', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:19.588372" elapsed="0.013431"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.588080" elapsed="0.013782"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.602045" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.601892" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.588060" elapsed="0.014063"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.602946" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.602268" elapsed="0.000708"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.603027" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.584333" elapsed="0.018820"/>
</kw>
<msg time="2026-06-06T03:32:19.603209" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.572056" elapsed="0.031203"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.615664" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.627863" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.639902" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.640096" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.640273" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.640656" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.640495" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.640480" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.640882" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.641048" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.641214" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.640451" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.640350" elapsed="0.000942"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.641436" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.641511" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:19.641632" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.567900" elapsed="0.073774"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.667387" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.667011" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.668162" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.667930" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.668327" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.667578" elapsed="0.000773"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.668914" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.668513" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.669237" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.669429" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.669101" elapsed="0.000357"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.669891" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.669615" elapsed="0.000348"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:19.670322" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.670030" elapsed="0.000350"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.670863" level="INFO">${mapping_to_use} = {'IP': '127.0.0.5', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.670550" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.670404" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.670011" elapsed="0.000935"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.671875" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.5&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.671091" elapsed="0.000815"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.671956" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.666384" elapsed="0.005695"/>
</kw>
<msg time="2026-06-06T03:32:19.672149" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.654065" elapsed="0.018130"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.685396" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.697449" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.709576" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.709804" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.710022" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.710430" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.710282" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.710263" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.710671" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.710842" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.711009" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.710224" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.710109" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.711241" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.711318" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:19.711498" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.5&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.651466" elapsed="0.060062"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.712955" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.712637" elapsed="0.000396">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.713127" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.712238" elapsed="0.000915"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.713482" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.713222" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.714073" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.713759" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.713564" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.713204" elapsed="0.000951"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.716464" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.714305" elapsed="0.002186"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:19.716542" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.716711" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:19.711888" elapsed="0.004849"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.718159" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.717902" elapsed="0.000502"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.718818" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.5&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.718560" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.719284" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.719041" elapsed="0.000286"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.719738" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.719478" elapsed="0.000305"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:19.720609" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:19.720409" elapsed="0.000227"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:19.720985" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:19.720808" elapsed="0.000203"/>
</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-06-06T03:32:19.721162" elapsed="0.000211"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.721801" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.721532" elapsed="0.000314"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:19.721905" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:19.722064" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:19.719989" elapsed="0.002100"/>
</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-06-06T03:32:19.786804" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '2155', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.5&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:19.786944" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:19.787082" 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-06-06T03:32:19.774411" elapsed="0.012735"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.722162" elapsed="0.065094"/>
</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-06-06T03:32:19.787709" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.787321" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.722143" elapsed="0.065771"/>
</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-06-06T03:32:19.795904" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.790199" elapsed="0.005813"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.789620" elapsed="0.006476"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.789576" elapsed="0.006582"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.800424" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.796873" elapsed="0.003599"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.796289" elapsed="0.004220"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.796250" elapsed="0.004284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.801154" 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-06-06T03:32:19.800748" elapsed="0.000435"/>
</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-06-06T03:32:19.801497" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.801255" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.802084" 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-06-06T03:32:19.801760" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.801580" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.801235" elapsed="0.000934"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.802709" 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-06-06T03:32:19.802330" elapsed="0.000407"/>
</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-06-06T03:32:19.803043" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.802808" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.803579" 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-06-06T03:32:19.803285" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.803125" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.802789" elapsed="0.000888"/>
</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-06-06T03:32:19.803832" elapsed="0.000354"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:19.804659" 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-06-06T03:32:19.804353" 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-06-06T03:32:19.804846" elapsed="0.002299"/>
</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-06-06T03:32:19.788795" elapsed="0.018418"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:19.807396" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:32:19.807284" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.807265" elapsed="0.000225"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:19.807656" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.807727" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:19.811148" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:32:19.717063" elapsed="0.094112"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.811307" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.811469" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:19.557108" elapsed="0.254386"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.811862" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.811593" elapsed="0.000338"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.811575" elapsed="0.000380"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.811988" elapsed="0.000025"/>
</return>
<arg>${POLICIES_VAR}${/}${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:19.552475" elapsed="0.259636"/>
</kw>
<var name="${index}">5</var>
<var name="${peer_type}">rr_client_peer</var>
<status status="PASS" start="2026-06-06T03:32:19.551403" elapsed="0.260750"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.813032" level="INFO">&amp;{mapping} = { IP=127.0.0.6 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.812438" elapsed="0.000626"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.846035" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.845627" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.846828" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.846564" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.847002" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.846230" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.847586" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.847201" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.847931" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.848094" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.847794" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.848519" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.848277" elapsed="0.000288"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.849525" level="INFO">mapping: {'IP': '127.0.0.6', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.849268" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.850033" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.849745" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.850738" level="INFO">${value} = 127.0.0.6</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.850424" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.851765" level="INFO">${encoded} = 127.0.0.6</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.851266" elapsed="0.000527"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.851882" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:19.852039" level="INFO">${encoded_value} = 127.0.0.6</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.850950" elapsed="0.001115"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.852222" elapsed="0.000231"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.6</var>
<status status="PASS" start="2026-06-06T03:32:19.850290" elapsed="0.002204"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.853208" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.852757" elapsed="0.000478"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.854226" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.853763" elapsed="0.000491"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.854307" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.854460" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.853424" elapsed="0.001061"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.854654" elapsed="0.000225"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:19.852607" elapsed="0.002315"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.855471" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.855168" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.856458" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.856025" elapsed="0.000460"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.856537" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.856719" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.855702" elapsed="0.001042"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.856900" elapsed="0.000225"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:19.855034" elapsed="0.002134"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.857735" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.857415" elapsed="0.000346"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.858771" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.858322" elapsed="0.000476"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.858850" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.859000" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.857996" elapsed="0.001028"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.859176" elapsed="0.000225"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.857281" elapsed="0.002162"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.860016" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:19.859704" elapsed="0.000339"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:19.861014" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.860555" elapsed="0.000488"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:19.861101" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:19.861255" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:19.860233" elapsed="0.001048"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:19.861434" elapsed="0.000242"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:19.859556" elapsed="0.002164"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.850116" elapsed="0.011640"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:19.861800" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.861978" level="INFO">${mapping_to_use} = {'IP': '127.0.0.6', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:19.848943" elapsed="0.013066"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.848633" elapsed="0.013409"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.862268" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.862112" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.848614" elapsed="0.013732"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.863138" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.862491" elapsed="0.000676"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.863217" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.845005" elapsed="0.018336"/>
</kw>
<msg time="2026-06-06T03:32:19.863397" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.832633" elapsed="0.030813"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.876239" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.888464" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.900567" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.900808" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.901001" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.901419" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.901267" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.901248" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.901659" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.901834" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.902028" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.901207" elapsed="0.000886"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.901089" elapsed="0.001032"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.902274" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.902353" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:32:19.902513" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.828461" elapsed="0.074145"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.928731" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.928309" elapsed="0.000451"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.929525" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.929268" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.929713" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.928927" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.930322" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.929927" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.930669" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:19.930836" level="INFO">${template} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:19.930512" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.931274" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;$IP&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;$HOLDTIME&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;$PASSIVE_MODE&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.931026" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:32:19.931755" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.931422" elapsed="0.000393"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.932286" level="INFO">${mapping_to_use} = {'IP': '127.0.0.6', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.931987" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.931841" elapsed="0.000507"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.931400" elapsed="0.000970"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.933382" level="INFO">${final_text} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.6&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:19.932563" elapsed="0.000850"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:19.933465" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:19.927663" elapsed="0.005933"/>
</kw>
<msg time="2026-06-06T03:32:19.933678" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:19.915200" elapsed="0.018529"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.946411" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.959009" elapsed="0.000055"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.971193" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.971418" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.971604" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.972035" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.971882" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:19.971864" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.972262" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.972428" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.972591" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:19.971824" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.971706" elapsed="0.000980"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.972834" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:19.972913" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:19.973109" level="INFO">${data} = &lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.6&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-...</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:19.912516" elapsed="0.060624"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:19.974769" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:19.974457" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:19.974940" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:19.974044" elapsed="0.000922"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:19.975318" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.975039" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.975939" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:19.975613" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.975428" elapsed="0.000573"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.975019" elapsed="0.001003"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.978343" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:19.976177" elapsed="0.002193"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:19.978424" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:19.978584" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:19.973633" elapsed="0.004977"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.980024" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.979768" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.980467" level="INFO">&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.6&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.980228" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.980956" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.980708" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.981399" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.981158" elapsed="0.000285"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:19.982282" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:32:19.982086" elapsed="0.000222"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:32:19.982706" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:32:19.982509" elapsed="0.000225"/>
</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-06-06T03:32:19.982886" elapsed="0.000216"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:19.983508" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:19.983260" elapsed="0.000293"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:32:19.983597" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:19.983773" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:32:19.981657" elapsed="0.002148"/>
</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-06-06T03:32:19.998203" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '2155', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions"&gt;
    &lt;neighbor-address&gt;127.0.0.6&lt;/neighbor-address&gt;
    &lt;route-reflector&gt;
        &lt;config&gt;
            &lt;route-reflector-client&gt;true&lt;/route-reflector-client&gt;
        &lt;/config&gt;
    &lt;/route-reflector&gt;
    &lt;timers&gt;
        &lt;config&gt;
            &lt;hold-time&gt;180&lt;/hold-time&gt;
        &lt;/config&gt;
    &lt;/timers&gt;
    &lt;transport&gt;
        &lt;config&gt;
            &lt;remote-port&gt;179&lt;/remote-port&gt;
            &lt;passive-mode&gt;true&lt;/passive-mode&gt;
        &lt;/config&gt;
    &lt;/transport&gt;
    &lt;config&gt;
        &lt;peer-type&gt;INTERNAL&lt;/peer-type&gt;
    &lt;/config&gt;
    &lt;afi-safis&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV4-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:IPV6-LABELLED-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV4-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L3VPN-IPV6-UNICAST&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name xmlns:x="http://openconfig.net/yang/bgp-types"&gt;x:L2VPN-EVPN&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;LINKSTATE&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV4-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
        &lt;afi-safi&gt;
            &lt;afi-safi-name&gt;IPV6-L3VPN-FLOW&lt;/afi-safi-name&gt;
        &lt;/afi-safi&gt;
    &lt;/afi-safis&gt;
&lt;/neighbor&gt; 
 </msg>
<msg time="2026-06-06T03:32:19.998434" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6 
 status=201, reason=Created 
 headers={'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:19.998756" 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-06-06T03:32:19.986120" elapsed="0.012704"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:19.983876" elapsed="0.015060"/>
</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-06-06T03:32:19.999408" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:19.998999" elapsed="0.000575"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:19.983857" elapsed="0.015767"/>
</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-06-06T03:32:20.007103" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.001870" elapsed="0.005278"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.001335" elapsed="0.005849"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.001292" elapsed="0.005917"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.009741" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.007486" elapsed="0.002303"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.007265" elapsed="0.002559"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.007248" elapsed="0.002601"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.010428" 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-06-06T03:32:20.010035" elapsed="0.000420"/>
</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-06-06T03:32:20.010832" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.010527" elapsed="0.000365"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.011393" 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-06-06T03:32:20.011084" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.010918" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.010508" elapsed="0.000970"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.012020" 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-06-06T03:32:20.011652" elapsed="0.000396"/>
</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-06-06T03:32:20.012359" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.012123" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.012917" 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-06-06T03:32:20.012601" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.012440" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.012105" elapsed="0.000896"/>
</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-06-06T03:32:20.013153" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:20.013993" 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-06-06T03:32:20.013688" elapsed="0.000332"/>
</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-06-06T03:32:20.014183" elapsed="0.002255"/>
</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-06-06T03:32:20.000476" elapsed="0.016027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:20.016702" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:32:20.016572" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.016552" elapsed="0.000246"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:32:20.016949" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.017017" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:20.019250" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:32:19.978958" elapsed="0.040319"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:20.019343" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:20.019510" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:19.817808" elapsed="0.201728"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.019893" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.019636" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.019619" elapsed="0.000366"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:20.020017" elapsed="0.000026"/>
</return>
<arg>${POLICIES_VAR}${/}${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:32:19.813335" elapsed="0.206805"/>
</kw>
<var name="${index}">6</var>
<var name="${peer_type}">rr_client_peer</var>
<status status="PASS" start="2026-06-06T03:32:19.812276" elapsed="0.207907"/>
</iter>
<var>${index}</var>
<var>${peer_type}</var>
<value>${NUMBERS}</value>
<value>${PEER_TYPES}</value>
<status status="PASS" start="2026-06-06T03:32:18.719273" elapsed="1.300949"/>
</for>
<doc>Configure BGP peer modules with initiate-connection set to false.
Configures 6 different peers, two internal, two external and two route-reflectors.</doc>
<status status="PASS" start="2026-06-06T03:32:18.631124" elapsed="1.389219"/>
</test>
<test id="s1-s20-t4" name="Start_Exabgps" line="76">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:20.023755" elapsed="0.000217"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:20.023467" elapsed="0.000562"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.025112" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.024996" elapsed="0.000163"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.024976" elapsed="0.000207"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.030332" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.030208" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.030189" elapsed="0.000213"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.031441" 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-06-06T03:32:20.031049" elapsed="0.000419"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.031946" 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-06-06T03:32:20.031629" elapsed="0.000343"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:20.032018" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:20.032172" 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-06-06T03:32:20.030629" elapsed="0.001568"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:20.037532" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.037423" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.037403" elapsed="0.000196"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:20.038849" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.038735" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.038716" elapsed="0.000202"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:20.039359" 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-06-06T03:32:20.039061" elapsed="0.000325"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.039789" level="INFO">${current_connection_index} = 7</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-06-06T03:32:20.039544" elapsed="0.000271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.070616" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.040314" elapsed="0.030421"/>
</kw>
<msg time="2026-06-06T03:32:20.070904" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:20.070951" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:20.039976" elapsed="0.031011"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.091049" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "a "r "t "_ "E "x "a "b "g "p "s "[K"
[?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-06-06T03:32:20.071598" elapsed="0.019561"/>
</kw>
<msg time="2026-06-06T03:32:20.091329" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:20.091374" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "a "r "t "_ "E "x "a "b "g "p "s "...</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-06-06T03:32:20.071164" elapsed="0.020246"/>
</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-06-06T03:32:20.091786" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.091502" elapsed="0.000342"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.091476" elapsed="0.000393"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.092331" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "a "r "t "_ "E "x "a "b "g "p "s "[K"
[?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-06-06T03:32:20.092015" elapsed="0.000382"/>
</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-06-06T03:32:20.092701" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.092464" elapsed="0.000292"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.092445" elapsed="0.000335"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:20.092817" elapsed="0.000035"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:20.095534" elapsed="0.000329"/>
</kw>
<msg time="2026-06-06T03:32:20.095927" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:20.094411" elapsed="0.001650"/>
</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="NOT RUN" start="2026-06-06T03:32:20.096509" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.096868" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:20.093755" elapsed="0.003299"/>
</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-06-06T03:32:20.093183" elapsed="0.003940"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:20.038406" elapsed="0.058819"/>
</kw>
<msg time="2026-06-06T03:32:20.097317" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:20.097362" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "a "r "t "_ "E "x "a "b "g "p "s "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:20.037766" elapsed="0.059632"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:20.097585" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:20.097476" elapsed="0.000184"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.097457" elapsed="0.000232"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.098120" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.098459" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.098531" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:20.037085" elapsed="0.061568"/>
</kw>
<msg time="2026-06-06T03:32:20.098751" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:20.098796" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "a "r "t "_ "E "x "a "b "g "p "s "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:20.032570" elapsed="0.066264"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.099159" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.098909" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.098892" elapsed="0.000344"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:20.032425" elapsed="0.066835"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:20.032253" elapsed="0.067039"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:20.029798" elapsed="0.069548"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:20.024703" elapsed="0.074700"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:20.024242" elapsed="0.075207"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:20.021204" elapsed="0.078300"/>
</kw>
<kw name="Virtual_Env_Activate_On_Current_Session" owner="SSHKeywords">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.101882" level="INFO">source /tmp/defaultvenv/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-06-06T03:32:20.100142" elapsed="0.001817"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.108043" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<msg time="2026-06-06T03:32:20.108138" level="INFO">${output} = [?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-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-06-06T03:32:20.102122" elapsed="0.006043"/>
</kw>
<if>
<branch type="IF" condition="${log_output}==${True}">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.108748" level="INFO">[?2004l[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.108481" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.108232" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.108213" elapsed="0.000642"/>
</if>
<arg>log_output=${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-06-06T03:32:20.099773" elapsed="0.009128"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.109629" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp1.cfg &gt; exa1.log &amp;</msg>
<var>${start_cmd}</var>
<arg>${CMD} exabgp${index}.cfg &gt; exa${index}.log &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.109279" elapsed="0.000395"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.110099" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp1.cfg &gt; exa1.log &amp;</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.109832" elapsed="0.000313"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.112151" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp1.cfg &gt; exa1.log &amp;</msg>
<msg time="2026-06-06T03:32:20.112240" level="INFO">${output} =  env exabgp.tcp.port=1790 exabgp --debug exabgp1.cfg &gt; exa1.log &amp;
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.110295" elapsed="0.001971"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.112684" level="INFO"> env exabgp.tcp.port=1790 exabgp --debug exabgp1.cfg &gt; exa1.log &amp;
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.112425" elapsed="0.000306"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:20.109143" elapsed="0.003622"/>
</iter>
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.113341" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp2.cfg &gt; exa2.log &amp;</msg>
<var>${start_cmd}</var>
<arg>${CMD} exabgp${index}.cfg &gt; exa${index}.log &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.112996" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.113780" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp2.cfg &gt; exa2.log &amp;</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.113522" elapsed="0.000303"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.114522" level="INFO">[?2004l[1] 6832</msg>
<msg time="2026-06-06T03:32:20.114609" level="INFO">${output} = [?2004l[1] 6832
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.114005" elapsed="0.000630"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.115075" level="INFO">[?2004l[1] 6832
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.114810" elapsed="0.000313"/>
</kw>
<var name="${index}">2</var>
<status status="PASS" start="2026-06-06T03:32:20.112863" elapsed="0.002293"/>
</iter>
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.115781" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp3.cfg &gt; exa3.log &amp;</msg>
<var>${start_cmd}</var>
<arg>${CMD} exabgp${index}.cfg &gt; exa${index}.log &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.115388" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.116203" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp3.cfg &gt; exa3.log &amp;</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.115964" elapsed="0.000285"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.117986" level="INFO">[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp2.cfg &gt; exa2.log &amp;</msg>
<msg time="2026-06-06T03:32:20.118076" level="INFO">${output} = [?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp2.cfg &gt; exa2.log &amp;
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.116396" elapsed="0.001708"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.118499" level="INFO">[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp2.cfg &gt; exa2.log &amp;
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.118260" elapsed="0.000286"/>
</kw>
<var name="${index}">3</var>
<status status="PASS" start="2026-06-06T03:32:20.115255" elapsed="0.003323"/>
</iter>
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.119165" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp4.cfg &gt; exa4.log &amp;</msg>
<var>${start_cmd}</var>
<arg>${CMD} exabgp${index}.cfg &gt; exa${index}.log &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.118823" elapsed="0.000368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.119583" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp4.cfg &gt; exa4.log &amp;</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.119345" elapsed="0.000282"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.120764" level="INFO">[?2004l[2] 6833</msg>
<msg time="2026-06-06T03:32:20.120851" level="INFO">${output} = [?2004l[2] 6833
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.119792" elapsed="0.001085"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.121288" level="INFO">[?2004l[2] 6833
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.121032" elapsed="0.000301"/>
</kw>
<var name="${index}">4</var>
<status status="PASS" start="2026-06-06T03:32:20.118692" elapsed="0.002696"/>
</iter>
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.122003" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp5.cfg &gt; exa5.log &amp;</msg>
<var>${start_cmd}</var>
<arg>${CMD} exabgp${index}.cfg &gt; exa${index}.log &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.121620" elapsed="0.000415"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.122433" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp5.cfg &gt; exa5.log &amp;</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.122196" elapsed="0.000282"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.123929" level="INFO">[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp3.cfg &gt; exa3.log &amp;</msg>
<msg time="2026-06-06T03:32:20.124017" level="INFO">${output} = [?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp3.cfg &gt; exa3.log &amp;
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.122625" elapsed="0.001468"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.124513" level="INFO">[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp3.cfg &gt; exa3.log &amp;
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.124269" elapsed="0.000293"/>
</kw>
<var name="${index}">5</var>
<status status="PASS" start="2026-06-06T03:32:20.121489" elapsed="0.003107"/>
</iter>
<iter>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.125383" level="INFO">${start_cmd} = env exabgp.tcp.port=1790 exabgp --debug exabgp6.cfg &gt; exa6.log &amp;</msg>
<var>${start_cmd}</var>
<arg>${CMD} exabgp${index}.cfg &gt; exa${index}.log &amp;</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.124846" elapsed="0.000565"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.125827" level="INFO">env exabgp.tcp.port=1790 exabgp --debug exabgp6.cfg &gt; exa6.log &amp;</msg>
<arg>${start_cmd}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.125567" elapsed="0.000305"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.126420" level="INFO">[?2004l[3] 6834</msg>
<msg time="2026-06-06T03:32:20.126505" level="INFO">${output} = [?2004l[3] 6834
</msg>
<var>${output}</var>
<arg>${start_cmd}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.126035" elapsed="0.000497"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.126975" level="INFO">[?2004l[3] 6834
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.126707" elapsed="0.000315"/>
</kw>
<var name="${index}">6</var>
<status status="PASS" start="2026-06-06T03:32:20.124713" elapsed="0.002357"/>
</iter>
<var>${index}</var>
<value>@{NUMBERS}</value>
<status status="PASS" start="2026-06-06T03:32:20.108990" elapsed="0.018110"/>
</for>
<doc>Start 6 exabgps as processes in background, each with it's own configuration.</doc>
<status status="PASS" start="2026-06-06T03:32:20.020668" elapsed="0.106559"/>
</test>
<test id="s1-s20-t5" name="Verify_Rib_Filled" line="86">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:20.130922" elapsed="0.000206"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:20.130657" elapsed="0.000526"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.132174" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.132060" elapsed="0.000159"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.132039" elapsed="0.000204"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.137108" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.137003" elapsed="0.000150"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.136985" elapsed="0.000190"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.138196" 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-06-06T03:32:20.137785" elapsed="0.000437"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.138819" 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-06-06T03:32:20.138382" elapsed="0.000463"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:20.138890" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:20.139043" 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-06-06T03:32:20.137395" elapsed="0.001672"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:20.144708" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.144578" elapsed="0.000176"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.144558" elapsed="0.000218"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:20.145940" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.145815" elapsed="0.000171"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.145796" elapsed="0.000213"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:20.146456" 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-06-06T03:32:20.146159" elapsed="0.000323"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.146869" level="INFO">${current_connection_index} = 7</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-06-06T03:32:20.146655" elapsed="0.000241"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.171917" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:20.147392" elapsed="0.024716"/>
</kw>
<msg time="2026-06-06T03:32:20.172362" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:20.172427" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:20.147057" elapsed="0.025421"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:20.195568" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:32:20.173419" elapsed="0.022282"/>
</kw>
<msg time="2026-06-06T03:32:20.195872" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:20.195919" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "F "i "...</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-06-06T03:32:20.172883" elapsed="0.023073"/>
</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-06-06T03:32:20.196498" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.196057" elapsed="0.000496"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.196027" elapsed="0.000553"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.197068" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "F "i "l "l "e "d "[K"
[?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-06-06T03:32:20.196744" elapsed="0.000390"/>
</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-06-06T03:32:20.197419" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.197202" elapsed="0.000271"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.197183" elapsed="0.000314"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:20.197535" elapsed="0.000039"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:20.200224" elapsed="0.000148"/>
</kw>
<msg time="2026-06-06T03:32:20.200433" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:20.199113" elapsed="0.001455"/>
</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="NOT RUN" start="2026-06-06T03:32:20.200864" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.201203" elapsed="0.000075"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:20.198450" elapsed="0.002936"/>
</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-06-06T03:32:20.197867" elapsed="0.003584"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:20.145494" elapsed="0.056083"/>
</kw>
<msg time="2026-06-06T03:32:20.201740" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:20.201803" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "F "i "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:20.144927" elapsed="0.056925"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:20.202141" elapsed="0.000037"/>
</return>
<status status="PASS" start="2026-06-06T03:32:20.201994" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.201930" elapsed="0.000327"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.202792" elapsed="0.000028"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.203175" elapsed="0.000026"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.203250" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:20.144239" elapsed="0.059122"/>
</kw>
<msg time="2026-06-06T03:32:20.203458" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:20.203502" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "V "e "r "i "f "y "_ "R "i "b "_ "F "i "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:20.139427" elapsed="0.064112"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.203891" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.203615" elapsed="0.000384"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.203597" elapsed="0.000429"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:20.139285" elapsed="0.064767"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:20.139119" elapsed="0.064971"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:20.136632" elapsed="0.067515"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:20.131773" elapsed="0.072433"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:20.131332" elapsed="0.072921"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:20.128514" elapsed="0.075794"/>
</kw>
<kw name="Verify_Rib_Status">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.259045" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.258658" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.261624" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.259583" elapsed="0.002133">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:20.261813" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:20.259244" elapsed="0.002594"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.262442" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:20.262038" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.262790" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:20.263531" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:20.262631" elapsed="0.000927"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.263986" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.263733" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.265033" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.264775" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.265508" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:20.265239" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.265877" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.266106" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.266283" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:20.265741" elapsed="0.000598"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.265586" elapsed="0.000783"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:20.266412" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:20.266571" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:20.264430" elapsed="0.002166"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.264098" elapsed="0.002531"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.266819" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.266669" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.264078" elapsed="0.002818"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.267497" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:20.267040" elapsed="0.000484"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:20.267621" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:20.258011" elapsed="0.009756"/>
</kw>
<msg time="2026-06-06T03:32:20.267822" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:20.245305" elapsed="0.022565"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.280419" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.292618" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.304735" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.304934" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.305117" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.305480" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.305336" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:20.305321" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.305715" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.305882" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.306071" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:20.305293" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.305192" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.306301" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.306376" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:20.306491" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:20.241063" elapsed="0.065453"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.307836" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.307567" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:20.307997" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:20.307179" elapsed="0.000843"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.308340" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.308093" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.308909" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.308600" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.308422" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.308074" elapsed="0.000918"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.311287" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:20.309144" elapsed="0.002175"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:20.311370" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:20.311523" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:20.306854" elapsed="0.004694"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.312788" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.312523" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rib_state/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:20.312945" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:20.312190" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:20.313174" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:20.313039" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.313021" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.313403" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.313573" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.313638" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:20.316989" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rib_state/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:20.311866" elapsed="0.005151"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.318468" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.318213" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.318931" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.318685" elapsed="0.000290"/>
</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-06-06T03:32:20.330535" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:20.333374" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Transfer-Encoding': 'chunked'} 
 body={"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://10.30.170.38","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-targe... (set the log level to DEBUG or TRACE to see the full content) 
 </msg>
<msg time="2026-06-06T03:32:20.333935" 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-06-06T03:32:20.321073" elapsed="0.012951"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.319042" elapsed="0.015084"/>
</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-06-06T03:32:20.334532" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.334186" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.319023" elapsed="0.015740"/>
</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-06-06T03:32:20.343095" level="INFO">{"bgp-rib:rib":[{"id":"example-bgp-rib","peer":[{"peer-id":"bgp://192.0.2.6","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"},{"peer-id":"bgp://10.30.170.38","supported-tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"}],"effective-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"route-key":"10.0.0.17/32","path-id":0,"prefix":"10.0.0.17/32","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv4-next-hop":{"global":"10.11.1.1"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"adj-rib-out":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family"},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family"},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family"}]},"adj-rib-in":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"route-key":"10.0.0.17/32","path-id":0,"prefix":"10.0.0.17/32","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv4-next-hop":{"global":"10.11.1.1"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]},"peer-role":"internal"}],"loc-rib":{"tables":[{"afi":"bgp-types:ipv4-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-mvpn:mcast-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"odl-bgp-evpn:l2vpn-address-family","safi":"odl-bgp-evpn:evpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-route-target-constrain:route-target-constrain-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-linkstate:linkstate-address-family","safi":"bgp-linkstate:linkstate-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-flowspec:flowspec-l3vpn-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv6-address-family","safi":"bgp-labeled-unicast:labeled-unicast-subsequent-address-family","attributes":{"uptodate":false}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:unicast-subsequent-address-family","attributes":{"uptodate":false},"bgp-inet:ipv4-routes":{"ipv4-route":[{"path-id":0,"route-key":"10.0.0.17/32","prefix":"10.0.0.17/32","attributes":{"origin":{"value":"igp"},"local-pref":{"pref":100},"ipv4-next-hop":{"global":"10.11.1.1"}}}]}},{"afi":"bgp-types:ipv4-address-family","safi":"bgp-types:mpls-labeled-vpn-subsequent-address-family","attributes":{"uptodate":false}}]}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.337067" elapsed="0.006256"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.336542" elapsed="0.006817"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.336499" elapsed="0.006886"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.346001" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.343683" elapsed="0.002365"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.343442" elapsed="0.002641"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.343424" elapsed="0.002684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.346681" 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-06-06T03:32:20.346276" elapsed="0.000433"/>
</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-06-06T03:32:20.347018" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.346780" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.347722" 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-06-06T03:32:20.347405" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.347100" elapsed="0.000685"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.346761" elapsed="0.001045"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.348327" 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-06-06T03:32:20.347966" elapsed="0.000387"/>
</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-06-06T03:32:20.348671" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.348424" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.349212" 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-06-06T03:32:20.348915" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.348754" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.348405" elapsed="0.000889"/>
</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-06-06T03:32:20.349444" elapsed="0.000362"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:20.350279" 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-06-06T03:32:20.349984" elapsed="0.000321"/>
</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-06-06T03:32:20.350459" elapsed="0.002247"/>
</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-06-06T03:32:20.335563" elapsed="0.017207"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.352948" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.352841" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.352821" elapsed="0.000195"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:32:20.362337" level="INFO">${text_normalized} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<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="PASS" start="2026-06-06T03:32:20.353164" elapsed="0.009209"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:32:20.362440" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:32:20.362626" level="INFO">${response_text} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:32:20.317332" elapsed="0.045336"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:20.362735" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:20.362889" level="INFO">${response_text} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:32:20.218200" elapsed="0.144716"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.363292" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.363006" elapsed="0.000418"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.362988" elapsed="0.000462"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:20.363485" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:32:20.363664" level="INFO">${output} = {
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "...</msg>
<var>${output}</var>
<arg>${POLICIES_VAR}/rib_state</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:32:20.212231" elapsed="0.151462"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.364151" level="INFO">{
 "bgp-rib:rib": [
  {
   "id": "example-bgp-rib",
   "loc-rib": {
    "tables": [
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "bgp-inet:ipv4-routes": {
       "ipv4-route": [
        {
         "attributes": {
          "ipv4-next-hop": {
           "global": "10.11.1.1"
          },
          "local-pref": {
           "pref": 100
          },
          "origin": {
           "value": "igp"
          }
         },
         "path-id": 0,
         "prefix": "10.0.0.17/32",
         "route-key": "10.0.0.17/32"
        }
       ]
      },
      "safi": "bgp-types:unicast-subsequent-address-family"
     },
     {
      "afi": "bgp-linkstate:linkstate-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-linkstate:linkstate-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-flowspec:flowspec-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv4-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-flowspec:flowspec-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
     },
     {
      "afi": "bgp-types:ipv6-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "bgp-types:unicast-subsequent-address-family"
     },
     {
      "afi": "odl-bgp-evpn:l2vpn-address-family",
      "attributes": {
       "uptodate": false
      },
      "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
     }
    ]
   },
   "peer": [
    {
     "adj-rib-in": {
      "tables": [
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "bgp-inet:ipv4-routes": {
         "ipv4-route": [
          {
           "attributes": {
            "ipv4-next-hop": {
             "global": "10.11.1.1"
            },
            "local-pref": {
             "pref": 100
            },
            "origin": {
             "value": "igp"
            }
           },
           "path-id": 0,
           "prefix": "10.0.0.17/32",
           "route-key": "10.0.0.17/32"
          }
         ]
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-linkstate:linkstate-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-linkstate:linkstate-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "odl-bgp-evpn:l2vpn-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
       }
      ]
     },
     "adj-rib-out": {
      "tables": [
       {
        "afi": "bgp-linkstate:linkstate-address-family",
        "safi": "bgp-linkstate:linkstate-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "odl-bgp-evpn:l2vpn-address-family",
        "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
       }
      ]
     },
     "effective-rib-in": {
      "tables": [
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "bgp-inet:ipv4-routes": {
         "ipv4-route": [
          {
           "attributes": {
            "ipv4-next-hop": {
             "global": "10.11.1.1"
            },
            "local-pref": {
             "pref": 100
            },
            "origin": {
             "value": "igp"
            }
           },
           "path-id": 0,
           "prefix": "10.0.0.17/32",
           "route-key": "10.0.0.17/32"
          }
         ]
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-linkstate:linkstate-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-linkstate:linkstate-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "odl-bgp-evpn:l2vpn-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
       }
      ]
     },
     "peer-id": "bgp://10.30.170.38",
     "peer-role": "internal",
     "supported-tables": [
      {
       "afi": "bgp-linkstate:linkstate-address-family",
       "safi": "bgp-linkstate:linkstate-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-flowspec:flowspec-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-types:unicast-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-flowspec:flowspec-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-types:unicast-subsequent-address-family"
      },
      {
       "afi": "odl-bgp-evpn:l2vpn-address-family",
       "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
      }
     ]
    },
    {
     "adj-rib-in": {
      "tables": [
       {
        "afi": "bgp-linkstate:linkstate-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-linkstate:linkstate-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "odl-bgp-evpn:l2vpn-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
       }
      ]
     },
     "adj-rib-out": {
      "tables": [
       {
        "afi": "bgp-linkstate:linkstate-address-family",
        "safi": "bgp-linkstate:linkstate-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "odl-bgp-evpn:l2vpn-address-family",
        "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
       }
      ]
     },
     "effective-rib-in": {
      "tables": [
       {
        "afi": "bgp-linkstate:linkstate-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-linkstate:linkstate-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv4-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-flowspec:flowspec-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
       },
       {
        "afi": "bgp-types:ipv6-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "bgp-types:unicast-subsequent-address-family"
       },
       {
        "afi": "odl-bgp-evpn:l2vpn-address-family",
        "attributes": {
         "uptodate": false
        },
        "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
       }
      ]
     },
     "peer-id": "bgp://192.0.2.6",
     "peer-role": "internal",
     "supported-tables": [
      {
       "afi": "bgp-linkstate:linkstate-address-family",
       "safi": "bgp-linkstate:linkstate-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-flowspec:flowspec-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-route-target-constrain:route-target-constrain-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv4-address-family",
       "safi": "bgp-types:unicast-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-flowspec:flowspec-l3vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-flowspec:flowspec-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-l3vpn-mcast:mcast-mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-labeled-unicast:labeled-unicast-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-mvpn:mcast-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-types:mpls-labeled-vpn-subsequent-address-family"
      },
      {
       "afi": "bgp-types:ipv6-address-family",
       "safi": "bgp-types:unicast-subsequent-address-family"
      },
      {
       "afi": "odl-bgp-evpn:l2vpn-address-family",
       "safi": "odl-bgp-evpn:evpn-subsequent-address-family"
      }
     ]
    }
   ]
  }
 ]
}
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.363866" elapsed="0.000578"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.365215" level="INFO">&amp;{mapping} = { IP=127.0.0.1 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:20.364810" elapsed="0.000433"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.413760" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.413350" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.414771" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.414349" elapsed="0.000499">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:20.414944" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:20.413997" elapsed="0.000972"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.415527" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:20.415138" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.415880" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:20.416046" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:20.415735" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.416477" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.416230" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.417684" level="INFO">mapping: {'IP': '127.0.0.1'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.417295" elapsed="0.000435"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.418235" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:20.417892" elapsed="0.000370"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.419871" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:20.418742" elapsed="0.001214"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:20.421787" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:20.421443" elapsed="0.000387"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:20.421961" elapsed="0.000107"/>
</return>
<msg time="2026-06-06T03:32:20.422332" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:20.420616" elapsed="0.001799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:20.422737" elapsed="0.000498"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:20.418517" elapsed="0.004885"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:20.418315" elapsed="0.005142"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:20.423506" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:20.423691" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:20.416932" elapsed="0.006787"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.416599" elapsed="0.007154"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.423941" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.423779" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.416577" elapsed="0.007442"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.424796" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:20.424164" elapsed="0.000662"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:20.424923" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:20.412716" elapsed="0.012340"/>
</kw>
<msg time="2026-06-06T03:32:20.425112" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:20.400062" elapsed="0.025100"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.437457" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.449558" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.461676" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.461875" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.462081" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.462448" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.462303" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:20.462288" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.462684" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.462856" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.463022" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:20.462259" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.462159" elapsed="0.000941"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.463248" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.463324" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:20.463442" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:20.395856" elapsed="0.067613"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.464801" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.464537" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:20.464963" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:20.464189" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.465305" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.465060" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.465872" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:20.465563" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:20.465387" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.465041" elapsed="0.000915"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.468569" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:20.466124" elapsed="0.002472"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:20.468662" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:20.468820" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:20.463861" elapsed="0.004984"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:20.470103" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.469837" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:20.470259" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:20.469484" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:20.470490" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:20.470354" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:20.470336" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.470739" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.470913" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.470980" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:20.472853" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:20.469156" elapsed="0.003723"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.474281" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.474028" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:20.474741" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:20.474481" elapsed="0.000304"/>
</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-06-06T03:32:20.481728" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:20.481910" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:20.482067" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</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="FAIL" start="2026-06-06T03:32:20.476891" elapsed="0.005619">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:20.474852" elapsed="0.007743">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</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-06-06T03:32:20.482803" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.482629" elapsed="0.000240"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:20.474833" elapsed="0.008060">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:20.483271" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.483404" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:20.483367" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:20.483349" elapsed="0.000121"/>
</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-06-06T03:32:20.483613" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.483701" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:20.473187" elapsed="0.010621">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.483883" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.373849" elapsed="0.110130">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:20.484258" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:20.484076" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:20.484056" elapsed="0.000298"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:20.484388" elapsed="0.000014"/>
</return>
<arg>${POLICIES_VAR}/effective_rib_in/peer_${index}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.369573" elapsed="0.114911">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.540970" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:23.540550" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:23.541971" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:23.541529" elapsed="0.000521">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:23.542230" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:23.541187" elapsed="0.001070"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.542873" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:23.542432" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:23.543223" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:23.543382" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:23.543074" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.543855" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:23.543574" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.545090" level="INFO">mapping: {'IP': '127.0.0.1'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:23.544692" elapsed="0.000447"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.545668" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:23.545309" elapsed="0.000395"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.547047" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:23.546165" elapsed="0.000964"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:23.548928" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:23.548584" elapsed="0.000387"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:23.549100" elapsed="0.000082"/>
</return>
<msg time="2026-06-06T03:32:23.549434" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:23.547795" elapsed="0.001720"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:23.549840" elapsed="0.000488"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:23.545968" elapsed="0.004490"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:23.545763" elapsed="0.004770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:23.550581" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:23.550770" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:23.544308" elapsed="0.006489"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:23.543984" elapsed="0.006846"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.551013" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:23.550857" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:23.543961" elapsed="0.007129"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.552008" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:23.551238" elapsed="0.000800"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:23.552091" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:23.539794" elapsed="0.012424"/>
</kw>
<msg time="2026-06-06T03:32:23.552273" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:23.527301" elapsed="0.025022"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.564730" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.576950" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.589207" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.589435" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.589629" elapsed="0.000082"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.590122" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:23.589967" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:23.589948" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.590352" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.590542" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.590741" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:23.589908" elapsed="0.000891"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.589787" elapsed="0.001040"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.590977" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.591058" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:23.591206" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:23.522909" elapsed="0.068326"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:23.592615" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:23.592331" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:23.592802" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:23.591944" elapsed="0.000883"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.593170" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:23.592899" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.593747" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:23.593434" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:23.593255" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:23.592880" elapsed="0.000951"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.596149" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:23.593984" elapsed="0.002192"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:23.596284" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:23.596444" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:23.591573" elapsed="0.004896"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:23.597720" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:23.597468" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:23.597880" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:23.597127" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:23.598115" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:32:23.597976" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:23.597957" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.598345" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.598531" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.598599" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:23.601069" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:23.596796" elapsed="0.004301"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.602571" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:23.602271" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:23.603046" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:23.602795" elapsed="0.000297"/>
</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-06-06T03:32:23.611492" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:23.611632" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:23.611767" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</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="FAIL" start="2026-06-06T03:32:23.605195" elapsed="0.006947">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:23.603160" elapsed="0.009067">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</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-06-06T03:32:23.612419" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:23.612261" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:23.603141" elapsed="0.009367">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:23.612907" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.613098" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:23.613057" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:23.613038" elapsed="0.000129"/>
</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-06-06T03:32:23.613322" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.613394" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:23.601420" elapsed="0.012082">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.613581" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:23.499618" elapsed="0.114076">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:23.613975" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:23.613792" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:23.613775" elapsed="0.000297"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:23.614104" elapsed="0.000015"/>
</return>
<arg>${POLICIES_VAR}/effective_rib_in/peer_${index}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:23.493407" elapsed="0.120795">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.677522" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:26.677065" elapsed="0.000492"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:26.678532" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:26.678124" elapsed="0.000486">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:26.678739" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:26.677762" elapsed="0.001003"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.679371" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:26.678936" elapsed="0.000463"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:26.679732" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:26.679903" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:26.679566" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.680345" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:26.680092" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.681596" level="INFO">mapping: {'IP': '127.0.0.1'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:26.681223" elapsed="0.000500"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.682229" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:26.681893" elapsed="0.000362"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.683564" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:26.682726" elapsed="0.000948"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:26.685446" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:26.685126" elapsed="0.000363"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:26.685617" elapsed="0.000096"/>
</return>
<msg time="2026-06-06T03:32:26.685963" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:26.684328" elapsed="0.001715"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:26.686339" elapsed="0.000593"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:26.682515" elapsed="0.004562"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:26.682315" elapsed="0.004803"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:26.687163" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:26.687327" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:26.680868" elapsed="0.006485"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:26.680476" elapsed="0.006910"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.687566" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:26.687413" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:26.680450" elapsed="0.007209"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.688387" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:26.687808" elapsed="0.000609"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:26.688466" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:26.676289" elapsed="0.012303"/>
</kw>
<msg time="2026-06-06T03:32:26.688734" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:26.663662" elapsed="0.025126"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.701420" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.713738" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.725988" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.726248" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.726433" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.726835" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:26.726686" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:26.726668" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.727087" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.727271" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.727473" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:26.726620" elapsed="0.000906"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.726513" elapsed="0.001039"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.727713" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.727791" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:26.727925" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:26.659103" elapsed="0.068850"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:26.729309" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:26.729018" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:26.729476" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:26.728636" elapsed="0.000865"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.729848" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:26.729572" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.730409" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:26.730111" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:26.729931" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:26.729554" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.732834" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:26.730658" elapsed="0.002204"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:26.732913" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:26.733069" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:26.728291" elapsed="0.004802"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:26.734376" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:26.734112" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:26.734578" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:26.733745" elapsed="0.000859"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:26.734840" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:26.734697" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:26.734677" elapsed="0.000304"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.735200" elapsed="0.000030"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.735391" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.735458" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:26.737507" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:26.733402" elapsed="0.004132"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.738953" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:26.738694" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:26.739424" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:26.739175" elapsed="0.000294"/>
</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-06-06T03:32:26.747236" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:26.747386" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:26.747505" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</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="FAIL" start="2026-06-06T03:32:26.741681" elapsed="0.006242">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:26.739537" elapsed="0.008479">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</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-06-06T03:32:26.748236" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:26.748055" elapsed="0.000254"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:26.739518" elapsed="0.008815">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:26.748770" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.748913" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:26.748871" elapsed="0.000085"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:26.748852" elapsed="0.000127"/>
</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-06-06T03:32:26.749126" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.749198" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:26.737863" elapsed="0.011445">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.749387" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:26.626173" elapsed="0.123312">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:26.749853" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:26.749662" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:26.749629" elapsed="0.000322"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:26.749984" elapsed="0.000014"/>
</return>
<arg>${POLICIES_VAR}/effective_rib_in/peer_${index}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:26.620192" elapsed="0.129891">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.804670" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:29.804220" elapsed="0.000486"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:29.805670" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:29.805247" elapsed="0.000502">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:29.805846" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:29.804894" elapsed="0.000977"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.806433" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:29.806039" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:29.806788" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:29.806953" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:29.806625" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.807387" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:29.807138" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.808632" level="INFO">mapping: {'IP': '127.0.0.1'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:29.808255" elapsed="0.000439"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.809186" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:29.808859" elapsed="0.000353"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.810507" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:29.809679" elapsed="0.000910"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:29.812404" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:29.812085" elapsed="0.000360"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:29.812571" elapsed="0.000223"/>
</return>
<msg time="2026-06-06T03:32:29.813059" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:29.811267" elapsed="0.001872"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:29.813438" elapsed="0.000507"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:29.809473" elapsed="0.004659"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:29.809270" elapsed="0.004905"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:29.814220" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:29.814380" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:29.807907" elapsed="0.006498"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:29.807543" elapsed="0.006895"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.814614" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:29.814463" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:29.807487" elapsed="0.007222"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.815469" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:29.814854" elapsed="0.000688"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:29.815610" elapsed="0.000127"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:29.803399" elapsed="0.012471"/>
</kw>
<msg time="2026-06-06T03:32:29.815945" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:29.790948" elapsed="0.025063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.828874" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.840901" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.853015" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.853233" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.853418" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.853842" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:29.853690" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:29.853671" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.854069" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.854238" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.854409" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:29.853616" elapsed="0.000905"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.853501" elapsed="0.001050"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.854721" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.854801" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:29.854945" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:29.786566" elapsed="0.068407"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:29.856350" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:29.856072" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:29.856520" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:29.855685" elapsed="0.000860"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.856894" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:29.856616" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.857456" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:29.857154" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:29.856977" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:29.856597" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.859944" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:29.857708" elapsed="0.002262"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:29.860023" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:29.860177" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:29.855303" elapsed="0.004898"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:29.861418" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:29.861185" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:29.861573" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:29.860849" elapsed="0.000748"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:29.861822" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:32:29.861684" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:29.861664" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.862052" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.862224" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.862289" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:32:29.865678" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:29.860508" elapsed="0.005199"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.867164" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:29.866903" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:29.867707" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:29.867411" elapsed="0.000340"/>
</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-06-06T03:32:29.875123" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:29.875260" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:29.875373" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</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="FAIL" start="2026-06-06T03:32:29.869861" elapsed="0.005946">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:29.867819" elapsed="0.008076">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</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-06-06T03:32:29.876090" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:29.875929" elapsed="0.000227"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:29.867800" elapsed="0.008380">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:29.876682" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.876875" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:29.876821" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:29.876796" elapsed="0.000169"/>
</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-06-06T03:32:29.877168" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.877266" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:29.866019" elapsed="0.011399">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.877525" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:29.764364" elapsed="0.113313">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:29.878063" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:29.877810" elapsed="0.000355"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:29.877787" elapsed="0.000411"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:29.878243" elapsed="0.000021"/>
</return>
<arg>${POLICIES_VAR}/effective_rib_in/peer_${index}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:29.759461" elapsed="0.118915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.934049" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:32.933606" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:32.935056" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:32.934619" elapsed="0.000516">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:32.935236" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:32.934267" elapsed="0.000995"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.935882" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:32.935438" elapsed="0.000472"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:32.936261" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:32.936429" level="INFO">${template} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:32.936108" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.936901" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F$IP/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:32.936624" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.938129" level="INFO">mapping: {'IP': '127.0.0.1'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:32.937739" elapsed="0.000437"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.938709" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:32.938343" elapsed="0.000394"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.940087" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:32.939197" elapsed="0.000975"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:32.941992" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:32.941666" elapsed="0.000370"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:32.942165" elapsed="0.000083"/>
</return>
<msg time="2026-06-06T03:32:32.942508" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:32.940853" elapsed="0.001738"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:32.942911" elapsed="0.000494"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:32.938999" elapsed="0.004544"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:32.938797" elapsed="0.004787"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:32.943629" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:32:32.943810" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:32.937362" elapsed="0.006474"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:32.937028" elapsed="0.006841"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.944113" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:32.943896" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:32.937003" elapsed="0.007194"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.944971" level="INFO">${final_text} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:32.944347" elapsed="0.000654"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:32.945106" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:32.932961" elapsed="0.012277"/>
</kw>
<msg time="2026-06-06T03:32:32.945296" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:32.920265" elapsed="0.025083"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.959045" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.971627" elapsed="0.000057"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.984317" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.984530" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.984731" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.985130" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:32.984979" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:32.984963" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.985354" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.985523" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.985706" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:32.984927" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:32.984815" elapsed="0.000974"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.985939" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:32.986015" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:32.986151" level="INFO">${uri} = rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:32.915771" elapsed="0.070408"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:32.987663" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:32.987346" elapsed="0.000401">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:32.987876" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:32.986963" elapsed="0.000950"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.988315" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:32.988031" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.988906" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:32.988583" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:32.988401" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:32.987991" elapsed="0.000998"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.991315" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:32.989147" elapsed="0.002195"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:32.991395" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:32.991553" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:32.986583" elapsed="0.004995"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:32.992873" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:32.992619" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:32.993033" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:32.992276" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:32.993269" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:32.993130" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:32.993111" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.993504" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:32.993695" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:32.993763" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:32.995822" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/effective_rib_in/peer_1/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:32.991904" elapsed="0.003944"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.997287" level="INFO">rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:32.997029" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:32.997755" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:32.997492" elapsed="0.000309"/>
</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-06-06T03:32:33.006082" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.006230" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:33.006331" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</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="FAIL" start="2026-06-06T03:32:32.999929" elapsed="0.006850">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:32.997869" elapsed="0.008997">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</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-06-06T03:32:33.007056" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.006899" elapsed="0.000222"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:32.997850" elapsed="0.009294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:33.007534" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.007687" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.007630" elapsed="0.000100"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:33.007612" elapsed="0.000140"/>
</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-06-06T03:32:33.007899" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.007970" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:32.996181" elapsed="0.011943">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.008205" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:32.892699" elapsed="0.115606">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.008620" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.008401" elapsed="0.000346"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:33.008384" elapsed="0.000397"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.008828" elapsed="0.000020"/>
</return>
<arg>${POLICIES_VAR}/effective_rib_in/peer_${index}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:32.886505" elapsed="0.122461">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<msg time="2026-06-06T03:32:33.009110" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 5 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>5x</arg>
<arg>3s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${POLICIES_VAR}/effective_rib_in/peer_${index}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:32:20.365410" elapsed="12.643834">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 5 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<var name="${index}">1</var>
<status status="FAIL" start="2026-06-06T03:32:20.364661" elapsed="12.644695">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 5 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</iter>
<var>${index}</var>
<value>@{NUMBERS}</value>
<status status="FAIL" start="2026-06-06T03:32:20.364501" elapsed="12.644990">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 5 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</for>
<kw name="Create Dictionary" owner="BuiltIn">
<var>&amp;{mapping}</var>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.009775" elapsed="0.000032"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<arg>5x</arg>
<arg>3s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${POLICIES_VAR}/app_peer_rib</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.010033" elapsed="0.000030"/>
</kw>
<doc>Verify output from effective-rib-in for each of the 6 exabgp peers and app peer.
First request is for full example-bgp-rib and it's output is logged for debug purposes.
Each of the peers have different output which is stored in folder by their respective
numbers as peer_${index} (peer_1, peer_2 ...)</doc>
<status status="FAIL" start="2026-06-06T03:32:20.208320" elapsed="12.801888">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 5 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</kw>
<doc>Verifies that sent routes are present in particular ribs.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:32:20.127847" elapsed="12.882572">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying 5 times. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/bgp-rib:bgp-rib/rib=example-bgp-rib/peer=bgp%3A%2F%2F127.0.0.1/effective-rib-in/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</status>
</test>
<test id="s1-s20-t6" name="Stop_All_Peers" line="91">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:33.015051" elapsed="0.000317"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:33.014681" elapsed="0.000767"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.016812" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.016691" elapsed="0.000167"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.016670" elapsed="0.000211"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.021934" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.021824" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.021806" elapsed="0.000197"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.023059" 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-06-06T03:32:33.022617" elapsed="0.000470"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.023562" 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-06-06T03:32:33.023253" elapsed="0.000335"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:33.023634" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:32:33.023814" 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-06-06T03:32:33.022229" elapsed="0.001610"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:33.029312" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.029201" elapsed="0.000158"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.029182" elapsed="0.000200"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:33.030704" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.030564" elapsed="0.000186"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.030545" elapsed="0.000228"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:33.031229" 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-06-06T03:32:33.030923" elapsed="0.000332"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.031659" level="INFO">${current_connection_index} = 7</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-06-06T03:32:33.031419" elapsed="0.000268"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.062342" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:33.032206" elapsed="0.030252"/>
</kw>
<msg time="2026-06-06T03:32:33.062621" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:33.062691" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:33.031852" elapsed="0.030876"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.083261" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "o "p "_ "A "l "l "_ "P "e "e "r "s "[K"
[?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-06-06T03:32:33.063346" elapsed="0.020021"/>
</kw>
<msg time="2026-06-06T03:32:33.083532" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:33.083579" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "o "p "_ "A "l "l "_ "P "e "e "r "...</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-06-06T03:32:33.062998" elapsed="0.020618"/>
</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-06-06T03:32:33.083969" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.083725" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.083702" elapsed="0.000365"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.084530" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "o "p "_ "A "l "l "_ "P "e "e "r "s "[K"
[?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-06-06T03:32:33.084221" elapsed="0.000376"/>
</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-06-06T03:32:33.084907" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.084684" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.084663" elapsed="0.000323"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:33.085022" elapsed="0.000034"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:33.087933" elapsed="0.000376"/>
</kw>
<msg time="2026-06-06T03:32:33.088375" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:33.086524" elapsed="0.001989"/>
</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="NOT RUN" start="2026-06-06T03:32:33.088824" elapsed="0.000077"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.089162" elapsed="0.000076"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:33.085888" elapsed="0.003469"/>
</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-06-06T03:32:33.085315" elapsed="0.004108"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:33.030253" elapsed="0.059270"/>
</kw>
<msg time="2026-06-06T03:32:33.089615" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:33.089679" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "o "p "_ "A "l "l "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:33.029535" elapsed="0.060183"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:33.089905" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:33.089796" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.089777" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.090397" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.090766" elapsed="0.000025"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.090839" elapsed="0.000017"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:33.028862" elapsed="0.062086"/>
</kw>
<msg time="2026-06-06T03:32:33.091042" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:33.091091" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "S "t "o "p "_ "A "l "l "_ "P "e "e "r "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:33.024282" elapsed="0.066846"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.091469" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.091215" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.091197" elapsed="0.000394"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:33.024132" elapsed="0.067488"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:33.023899" elapsed="0.067770"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:33.021438" elapsed="0.070289"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:33.016329" elapsed="0.075456"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:33.015680" elapsed="0.076153"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:33.011664" elapsed="0.080223"/>
</kw>
<kw name="Stop_All_ExaBgps" owner="ExaBgpLib">
<kw name="Read" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.092531" level="INFO">[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp4.cfg &gt; exa4.log &amp;
[?2004l[4] 6835
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp5.cfg &gt; exa5.log &amp;
[?2004l[5] 6836
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp6.cfg &gt; exa6.log &amp;
[?2004l[6] 6837
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax</msg>
<msg time="2026-06-06T03:32:33.092682" level="INFO">${output} = [?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp4.cfg &gt; exa4.log &amp;
[?2004l[4] 6835
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-b...</msg>
<var>${output}</var>
<doc>Consumes and returns everything available on the server output.</doc>
<status status="PASS" start="2026-06-06T03:32:33.092414" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.093121" level="INFO">[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp4.cfg &gt; exa4.log &amp;
[?2004l[4] 6835
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp5.cfg &gt; exa5.log &amp;
[?2004l[5] 6836
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; env exabgp.tcp.port=1790 exabgp --debug exabgp6.cfg &gt; exa6.log &amp;
[?2004l[6] 6837
[?2004h(defaultvenv) [jenkins@releng-26932-288-0-builder-0 ~]&gt; Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
Traceback (most recent call last):
  File "/tmp/defaultvenv/bin/exabgp", line 8, in &lt;module&gt;
    sys.exit(run_exabgp())
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/__init__.py", line 12, in run_exabgp
    from exabgp.application.bgp import main
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/application/bgp.py", line 22, in &lt;module&gt;
    from exabgp.reactor.loop import Reactor
  File "/tmp/defaultvenv/lib/python3.10/site-packages/exabgp/reactor/loop.py", line 24
    from exabgp.reactor.async import ASYNC
                        ^^^^^
SyntaxError: invalid syntax
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.092870" elapsed="0.000377"/>
</kw>
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.095882" level="INFO">ps axf | grep exabgp | grep -v grep | awk '{print "kill -9 " $1}' | sh</msg>
<msg time="2026-06-06T03:32:33.095974" level="INFO">${output} = ps axf | grep exabgp | grep -v grep | awk '{print "kill -9 " $1}' | sh
</msg>
<var>${output}</var>
<arg>${EXABGP_KILL_COMMAND}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:33.093402" elapsed="0.002599"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.096450" level="INFO">ps axf | grep exabgp | grep -v grep | awk '{print "kill -9 " $1}' | sh
</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.096193" elapsed="0.000304"/>
</kw>
<doc>Sends kill command to stop all exabgps running</doc>
<status status="PASS" start="2026-06-06T03:32:33.092137" elapsed="0.004415"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.105604" level="INFO">Executing command 'cat exa1.log'.</msg>
<msg time="2026-06-06T03:32:33.118271" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:33.118410" level="INFO">${output_log} = </msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:33.105458" elapsed="0.012987"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.119067" level="INFO"/>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.118709" elapsed="0.000417"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.119837" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa1.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa1.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:32:33.119368" elapsed="0.000547"/>
</kw>
<arg>exa${index}.log</arg>
<arg>exa${index}.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.105052" elapsed="0.014949"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:33.096846" elapsed="0.023231"/>
</iter>
<iter>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.131162" level="INFO">Executing command 'cat exa2.log'.</msg>
<msg time="2026-06-06T03:32:33.167930" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:33.168089" level="INFO">${output_log} = </msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:33.131024" elapsed="0.037100"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.168737" level="INFO"/>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.168352" elapsed="0.000445"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.169400" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa2.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa2.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:32:33.169034" elapsed="0.000442"/>
</kw>
<arg>exa${index}.log</arg>
<arg>exa${index}.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.130619" elapsed="0.038941"/>
</kw>
<var name="${index}">2</var>
<status status="PASS" start="2026-06-06T03:32:33.120197" elapsed="0.049411"/>
</iter>
<iter>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.180509" level="INFO">Executing command 'cat exa3.log'.</msg>
<msg time="2026-06-06T03:32:33.215890" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:33.216027" level="INFO">${output_log} = </msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:33.180372" elapsed="0.035706"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.216697" level="INFO"/>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.216309" elapsed="0.000450"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.217347" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa3.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa3.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:32:33.216995" elapsed="0.000427"/>
</kw>
<arg>exa${index}.log</arg>
<arg>exa${index}.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.179963" elapsed="0.037541"/>
</kw>
<var name="${index}">3</var>
<status status="PASS" start="2026-06-06T03:32:33.169748" elapsed="0.047804"/>
</iter>
<iter>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.228260" level="INFO">Executing command 'cat exa4.log'.</msg>
<msg time="2026-06-06T03:32:33.264118" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:33.264258" level="INFO">${output_log} = </msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:33.228118" elapsed="0.036176"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.264917" level="INFO"/>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.264526" elapsed="0.000450"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.265588" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa4.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa4.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:32:33.265215" elapsed="0.000473"/>
</kw>
<arg>exa${index}.log</arg>
<arg>exa${index}.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.227715" elapsed="0.038058"/>
</kw>
<var name="${index}">4</var>
<status status="PASS" start="2026-06-06T03:32:33.217694" elapsed="0.048127"/>
</iter>
<iter>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.278034" level="INFO">Executing command 'cat exa5.log'.</msg>
<msg time="2026-06-06T03:32:33.311536" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:33.311836" level="INFO">${output_log} = </msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:33.277838" elapsed="0.034035"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.312582" level="INFO"/>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.312172" elapsed="0.000490"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.313332" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa5.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa5.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:32:33.312929" elapsed="0.000480"/>
</kw>
<arg>exa${index}.log</arg>
<arg>exa${index}.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.277272" elapsed="0.036227"/>
</kw>
<var name="${index}">5</var>
<status status="PASS" start="2026-06-06T03:32:33.265941" elapsed="0.047608"/>
</iter>
<iter>
<kw name="Store_File_To_Workspace" owner="BGPcliKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.325518" level="INFO">Executing command 'cat exa6.log'.</msg>
<msg time="2026-06-06T03:32:33.360388" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:33.360675" level="INFO">${output_log} = </msg>
<var>${output_log}</var>
<arg>cat ${source_file_name}</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:33.325377" elapsed="0.035365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.361820" level="INFO"/>
<arg>${output_log}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.361151" elapsed="0.000775"/>
</kw>
<kw name="Create File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.362993" level="INFO" html="true">Created file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa6.log"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/exa6.log&lt;/a&gt;'.</msg>
<arg>${target_file_name}</arg>
<arg>${output_log}</arg>
<doc>Creates a file with the given content and encoding.</doc>
<status status="PASS" start="2026-06-06T03:32:33.362343" elapsed="0.000780"/>
</kw>
<arg>exa${index}.log</arg>
<arg>exa${index}.log</arg>
<doc>Store the ${source_file_name} to the workspace as ${target_file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.324970" elapsed="0.038300"/>
</kw>
<var name="${index}">6</var>
<status status="PASS" start="2026-06-06T03:32:33.313703" elapsed="0.049651"/>
</iter>
<var>${index}</var>
<value>@{NUMBERS}</value>
<status status="PASS" start="2026-06-06T03:32:33.096600" elapsed="0.266830"/>
</for>
<doc>Send command to kill all exabgp processes running on controller</doc>
<status status="PASS" start="2026-06-06T03:32:33.010920" elapsed="0.352806"/>
</test>
<test id="s1-s20-t7" name="Delete_Bgp_Peer_Configuration" line="98">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:33.370268" elapsed="0.000297"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:33.369900" elapsed="0.000762"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.372174" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.371948" elapsed="0.000296"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.371917" elapsed="0.000359"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.379356" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.379203" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.379177" elapsed="0.000276"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.380843" 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-06-06T03:32:33.380359" elapsed="0.000511"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.381328" 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-06-06T03:32:33.381032" elapsed="0.000322"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:33.381399" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:32:33.381560" 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-06-06T03:32:33.379794" elapsed="0.001790"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:33.386950" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.386840" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.386820" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:33.388371" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:33.388262" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.388243" elapsed="0.000196"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:33.388912" 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-06-06T03:32:33.388587" elapsed="0.000351"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.389317" level="INFO">${current_connection_index} = 7</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-06-06T03:32:33.389099" elapsed="0.000244"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.419330" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:33.389922" elapsed="0.029561"/>
</kw>
<msg time="2026-06-06T03:32:33.419759" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:33.419829" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:33.389507" elapsed="0.030377"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:33.443836" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:32:33.420637" elapsed="0.023315"/>
</kw>
<msg time="2026-06-06T03:32:33.444136" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:33.444182" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "...</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-06-06T03:32:33.420180" elapsed="0.024038"/>
</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-06-06T03:32:33.444547" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.444304" elapsed="0.000299"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.444281" elapsed="0.000347"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.445105" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "e "r "_ "C "o "n "f "i "g "u "r "a "t "i "o "n "[K"
[?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-06-06T03:32:33.444797" elapsed="0.000380"/>
</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-06-06T03:32:33.445466" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.445245" elapsed="0.000275"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.445226" elapsed="0.000318"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:33.445580" elapsed="0.000036"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:33.448248" elapsed="0.000147"/>
</kw>
<msg time="2026-06-06T03:32:33.448459" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:33.447097" elapsed="0.001495"/>
</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="NOT RUN" start="2026-06-06T03:32:33.449059" elapsed="0.000081"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.449406" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:33.446445" elapsed="0.003147"/>
</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-06-06T03:32:33.445893" elapsed="0.003786"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:33.387923" elapsed="0.061858"/>
</kw>
<msg time="2026-06-06T03:32:33.449872" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:33.449917" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:33.387169" elapsed="0.062786"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:33.450142" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:33.450032" elapsed="0.000170"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.450013" elapsed="0.000214"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.450784" elapsed="0.000026"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.451124" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.451195" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:33.386489" elapsed="0.064812"/>
</kw>
<msg time="2026-06-06T03:32:33.451394" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:33.451483" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "l "e "t "e "_ "B "g "p "_ "P "e "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:33.381971" elapsed="0.069555"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.451872" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.451604" elapsed="0.000323"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.451585" elapsed="0.000366"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:33.381828" elapsed="0.070147"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:33.381653" elapsed="0.070352"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:33.378692" elapsed="0.073368"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:33.371510" elapsed="0.080634"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:33.370884" elapsed="0.081308"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:33.365750" elapsed="0.086497"/>
</kw>
<for flavor="IN ZIP">
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.453282" level="INFO">&amp;{mapping} = { IP=127.0.0.1 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.452697" elapsed="0.000615"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.494917" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:33.494505" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.495739" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:33.495461" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:33.495914" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:33.495121" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.496561" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:33.496129" elapsed="0.000460"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.496921" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:33.497091" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:33.496772" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.497522" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.497275" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.498611" level="INFO">mapping: {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.498350" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.499107" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.498837" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.500068" level="INFO">${value} = 127.0.0.1</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.499506" elapsed="0.000600"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.500856" level="INFO">${encoded} = 127.0.0.1</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.500619" elapsed="0.000324"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.500998" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:32:33.501162" level="INFO">${encoded_value} = 127.0.0.1</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.500297" elapsed="0.000889"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.501344" elapsed="0.000248"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.1</var>
<status status="PASS" start="2026-06-06T03:32:33.499368" elapsed="0.002266"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.502198" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.501901" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.502959" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.502746" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.503034" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.503182" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.502409" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.503356" elapsed="0.000221"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:33.501767" elapsed="0.001850"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.504210" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.503877" elapsed="0.000359"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.504972" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.504759" elapsed="0.000238"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.505046" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:33.505194" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.504421" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.505367" elapsed="0.000220"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:33.503744" elapsed="0.001883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.506180" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.505886" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.506932" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.506723" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.507008" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:33.507156" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.506391" elapsed="0.000790"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.507331" elapsed="0.000224"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.505753" elapsed="0.001842"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.508162" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.507851" elapsed="0.000337"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.508920" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.508707" elapsed="0.000240"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.508995" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.509144" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.508374" elapsed="0.000794"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.509318" elapsed="0.000221"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.507720" elapsed="0.001859"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.499187" elapsed="0.010426"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.509671" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:33.509831" level="INFO">${mapping_to_use} = {'IP': '127.0.0.1', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:33.498021" elapsed="0.011870"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.497664" elapsed="0.012263"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.510106" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.509954" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.497625" elapsed="0.012559"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.511004" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:33.510330" elapsed="0.000703"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.511082" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.493875" elapsed="0.017330"/>
</kw>
<msg time="2026-06-06T03:32:33.511260" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:33.481566" elapsed="0.029743"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.523678" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.535733" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.547771" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.548079" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.548277" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.548678" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.548507" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:33.548491" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.548902" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.549069" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.549234" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:33.548460" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.548355" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.549457" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.549577" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:33.549726" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:33.477391" elapsed="0.072363"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.550884" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.550600" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:33.560703" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.560774" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.1 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.560907" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:33.553048" elapsed="0.007897"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.550998" elapsed="0.010006"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.561267" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.561042" elapsed="0.000315"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.550979" elapsed="0.010409"/>
</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-06-06T03:32:33.566678" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.562885" elapsed="0.003859"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.562533" elapsed="0.004263"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.562505" elapsed="0.004328"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.570599" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.567245" elapsed="0.003441"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.566915" elapsed="0.003822"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.566891" elapsed="0.003883"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.571590" 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-06-06T03:32:33.571027" elapsed="0.000603"/>
</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-06-06T03:32:33.572170" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.571756" elapsed="0.000509"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.572852" 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-06-06T03:32:33.572532" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.572301" elapsed="0.000615"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.571729" elapsed="0.001208"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.573457" 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-06-06T03:32:33.573097" elapsed="0.000387"/>
</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-06-06T03:32:33.573967" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.573559" elapsed="0.000478"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.574565" 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-06-06T03:32:33.574227" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.574062" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.573541" elapsed="0.001128"/>
</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-06-06T03:32:33.574844" elapsed="0.000355"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:33.575761" 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-06-06T03:32:33.575446" elapsed="0.000342"/>
</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-06-06T03:32:33.575944" elapsed="0.002449"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:33.561930" elapsed="0.016528"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:33.578505" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:32:33.580838" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:33.550018" elapsed="0.030850"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.580935" elapsed="0.000028"/>
</return>
<arg>${POLICIES_VAR}/${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:33.453546" elapsed="0.127517"/>
</kw>
<var name="${index}">1</var>
<var name="${peer_type}">ibgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:33.452517" elapsed="0.128587"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.581991" level="INFO">&amp;{mapping} = { IP=127.0.0.2 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.581390" elapsed="0.000630"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.623339" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:33.622956" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.624195" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:33.623912" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:33.624370" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:33.623549" elapsed="0.000846"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.624984" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:33.624566" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.625315" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ibgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:33.625476" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:33.625174" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.625923" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.625674" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.627027" level="INFO">mapping: {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.626762" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.627516" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.627234" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.628273" level="INFO">${value} = 127.0.0.2</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.627932" elapsed="0.000367"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.629143" level="INFO">${encoded} = 127.0.0.2</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.628859" elapsed="0.000386"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.629307" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:32:33.629473" level="INFO">${encoded_value} = 127.0.0.2</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.628509" elapsed="0.000990"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.629675" elapsed="0.000268"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.2</var>
<status status="PASS" start="2026-06-06T03:32:33.627792" elapsed="0.002203"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.632399" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.630248" elapsed="0.002180"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.633192" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.632974" elapsed="0.000246"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.633273" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:33.633430" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.632626" elapsed="0.000830"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.633616" elapsed="0.000245"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:33.630111" elapsed="0.003791"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.634468" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.634154" elapsed="0.000348"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.635267" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.635039" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.635346" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:33.635500" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.634717" elapsed="0.000807"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.635693" elapsed="0.000225"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:33.634019" elapsed="0.001942"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.636580" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.636257" elapsed="0.000350"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.637348" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.637135" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.637423" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.637574" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.636814" elapsed="0.000784"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.637778" elapsed="0.000232"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.636073" elapsed="0.001979"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.638623" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.638299" elapsed="0.000368"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.639390" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.639176" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.639467" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.639618" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.638857" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.639814" elapsed="0.000225"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.638165" elapsed="0.001916"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.627596" elapsed="0.012540"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.640182" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.640356" level="INFO">${mapping_to_use} = {'IP': '127.0.0.2', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:33.626399" elapsed="0.014027"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.626041" elapsed="0.014421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.640670" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.640489" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.626021" elapsed="0.014731"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.641585" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:33.640901" elapsed="0.000713"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.641684" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.622321" elapsed="0.019492"/>
</kw>
<msg time="2026-06-06T03:32:33.641869" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:33.609997" elapsed="0.031922"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.655045" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.667558" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ibgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.680025" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.680243" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.680427" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.680826" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.680676" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:33.680659" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.681052" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.681222" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.681389" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:33.680612" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.680506" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.681637" elapsed="0.000039"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.681783" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:32:33.681919" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:33.605808" elapsed="0.076139"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.683098" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.682826" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:33.691815" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.691873" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.2 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.691980" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:33.685309" elapsed="0.006697"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.683214" elapsed="0.008833"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.692270" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.692074" elapsed="0.000261"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.683195" elapsed="0.009162"/>
</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-06-06T03:32:33.697135" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.693831" elapsed="0.003368"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.693418" elapsed="0.003831"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.693391" elapsed="0.003895"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.700897" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.697710" elapsed="0.003252"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.697368" elapsed="0.003642"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.697343" elapsed="0.003702"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.701862" 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-06-06T03:32:33.701284" elapsed="0.000616"/>
</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-06-06T03:32:33.702343" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.702000" elapsed="0.000432"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.703150" 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-06-06T03:32:33.702719" elapsed="0.000471"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.702467" elapsed="0.000774"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.701974" elapsed="0.001299"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.704095" 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-06-06T03:32:33.703528" elapsed="0.000658"/>
</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-06-06T03:32:33.704660" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.704309" elapsed="0.000413"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.705297" 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-06-06T03:32:33.704919" elapsed="0.000413"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.704747" elapsed="0.000630"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.704273" elapsed="0.001132"/>
</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-06-06T03:32:33.705613" elapsed="0.000451"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:33.706621" 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-06-06T03:32:33.706301" elapsed="0.000375"/>
</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-06-06T03:32:33.706845" elapsed="0.002583"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:33.692843" elapsed="0.016675"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:33.709582" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:32:33.711863" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:33.682213" elapsed="0.029679"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.711947" elapsed="0.000028"/>
</return>
<arg>${POLICIES_VAR}/${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:33.582255" elapsed="0.129819"/>
</kw>
<var name="${index}">2</var>
<var name="${peer_type}">ibgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:33.581224" elapsed="0.130890"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.713049" level="INFO">&amp;{mapping} = { IP=127.0.0.3 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.712435" elapsed="0.000644"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.762598" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:33.762179" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.763461" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:33.763183" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:33.763658" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:33.762837" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.764266" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:33.763860" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.764606" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:33.764800" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:33.764460" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.765241" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.764990" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.766305" level="INFO">mapping: {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.766041" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.766815" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.766515" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.767535" level="INFO">${value} = 127.0.0.3</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.767235" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.768351" level="INFO">${encoded} = 127.0.0.3</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.768097" elapsed="0.000363"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.768526" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:32:33.768722" level="INFO">${encoded_value} = 127.0.0.3</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.767773" elapsed="0.000974"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.768910" elapsed="0.000253"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.3</var>
<status status="PASS" start="2026-06-06T03:32:33.767094" elapsed="0.002111"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.769977" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.769456" elapsed="0.000548"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.770744" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.770514" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.770821" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:33.770973" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.770193" elapsed="0.000805"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.771151" elapsed="0.000220"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:33.769322" elapsed="0.002090"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.771978" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.771674" elapsed="0.000330"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.772754" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.772525" elapsed="0.000255"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.772830" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.772980" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.772203" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.773157" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:33.771524" elapsed="0.001897"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.773986" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.773682" elapsed="0.000329"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.774749" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.774519" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.774825" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.774975" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.774198" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.775152" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.773533" elapsed="0.001883"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.775983" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.775682" elapsed="0.000328"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.776886" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.776666" elapsed="0.000247"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.776964" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:33.777116" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.776226" elapsed="0.000915"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.777292" elapsed="0.000223"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.775534" elapsed="0.002021"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.766902" elapsed="0.010688"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.777634" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:32:33.777816" level="INFO">${mapping_to_use} = {'IP': '127.0.0.3', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:33.765712" elapsed="0.012168"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.765375" elapsed="0.012541"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.778099" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.777945" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.765347" elapsed="0.012830"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.779015" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:33.778325" elapsed="0.000718"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.779093" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.761533" elapsed="0.017685"/>
</kw>
<msg time="2026-06-06T03:32:33.779274" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:33.748850" elapsed="0.030472"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.791734" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.803867" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.816027" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.816243" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.816425" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.816814" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.816665" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:33.816636" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.817036" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.817205" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.817374" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:33.816606" elapsed="0.000822"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.816501" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.817602" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.817732" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:33.817863" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:33.744207" elapsed="0.073683"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.819012" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.818757" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:33.828892" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.828941" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.3 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.829033" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:33.821171" elapsed="0.007888"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.819127" elapsed="0.009974"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.829280" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.829127" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.819109" elapsed="0.010255"/>
</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-06-06T03:32:33.832858" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.830375" elapsed="0.002544"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.830153" elapsed="0.002815"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.830134" elapsed="0.002870"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.836574" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.833392" elapsed="0.003265"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.833081" elapsed="0.003627"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.833058" elapsed="0.003686"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.837533" 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-06-06T03:32:33.836991" elapsed="0.000580"/>
</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-06-06T03:32:33.838031" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.837691" elapsed="0.000421"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.838821" 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-06-06T03:32:33.838374" elapsed="0.000485"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.838146" elapsed="0.000763"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.837664" elapsed="0.001275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.839693" 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-06-06T03:32:33.839161" elapsed="0.000571"/>
</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-06-06T03:32:33.840191" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.839831" elapsed="0.000443"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.840866" 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-06-06T03:32:33.840538" elapsed="0.000354"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.840308" elapsed="0.000621"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.839805" elapsed="0.001145"/>
</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-06-06T03:32:33.841103" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:33.841986" 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-06-06T03:32:33.841690" elapsed="0.000323"/>
</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-06-06T03:32:33.842171" elapsed="0.002454"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:33.829744" elapsed="0.014972"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:33.844767" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:32:33.846977" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:33.818159" elapsed="0.028846"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.847060" elapsed="0.000027"/>
</return>
<arg>${POLICIES_VAR}/${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:33.713328" elapsed="0.133858"/>
</kw>
<var name="${index}">3</var>
<var name="${peer_type}">ebgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:33.712263" elapsed="0.134964"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.848124" level="INFO">&amp;{mapping} = { IP=127.0.0.4 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.847518" elapsed="0.000658"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.889816" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:33.889419" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.890599" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:33.890352" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:33.890792" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:33.890014" elapsed="0.000803"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.891372" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:33.890985" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:33.891721" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/ebgp_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:33.891878" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:33.891566" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.892323" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.892061" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.893345" level="INFO">mapping: {'IP': '127.0.0.4', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.893088" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.893831" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.893549" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.894519" level="INFO">${value} = 127.0.0.4</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.894221" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.895284" level="INFO">${encoded} = 127.0.0.4</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.895065" elapsed="0.000295"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.895415" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:33.895579" level="INFO">${encoded_value} = 127.0.0.4</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.894747" elapsed="0.000857"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.895773" elapsed="0.000236"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.4</var>
<status status="PASS" start="2026-06-06T03:32:33.894087" elapsed="0.001964"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.896812" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.896323" elapsed="0.000515"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.897555" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.897344" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.897630" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:32:33.897800" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.897025" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.897975" elapsed="0.000220"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:33.896188" elapsed="0.002048"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.898798" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.898479" elapsed="0.000345"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.899534" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.899326" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.899608" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.899775" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.899008" elapsed="0.000791"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.899949" elapsed="0.000243"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:33.898348" elapsed="0.001886"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.900790" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.900478" elapsed="0.000338"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.901520" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.901311" elapsed="0.000239"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.901598" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.901770" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.900998" elapsed="0.000797"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.901943" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.900346" elapsed="0.001858"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.902758" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:33.902444" elapsed="0.000340"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:33.903489" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.903282" elapsed="0.000233"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:33.903563" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:33.903728" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:33.902967" elapsed="0.000786"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.903901" elapsed="0.000220"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:33.902314" elapsed="0.001872"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.893910" elapsed="0.010314"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:33.904266" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:33.904424" level="INFO">${mapping_to_use} = {'IP': '127.0.0.4', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:33.892763" elapsed="0.011726"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.892444" elapsed="0.012081"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.904718" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.904551" elapsed="0.000225"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.892421" elapsed="0.012376"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.905577" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:33.904939" elapsed="0.000667"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.905671" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:33.888800" elapsed="0.016996"/>
</kw>
<msg time="2026-06-06T03:32:33.905851" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:33.876339" elapsed="0.029561"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.918278" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.930346" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/ebgp_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.942430" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.942634" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.942828" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.943193" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.943049" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:33.943035" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.943410" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.943575" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.943754" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:33.943006" elapsed="0.000802"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.942903" elapsed="0.000931"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.943979" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:33.944087" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:33.944249" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:33.872080" elapsed="0.072196"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.945385" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.945132" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:33.954808" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.954857" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.4 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:33.954947" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:33.947485" elapsed="0.007488"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.945497" elapsed="0.009516"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:33.955189" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.955039" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.945479" elapsed="0.009791"/>
</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-06-06T03:32:33.959422" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.956314" elapsed="0.003168"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.956052" elapsed="0.003478"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.956034" elapsed="0.003531"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.963112" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:33.959973" elapsed="0.003203"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.959662" elapsed="0.003560"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.959620" elapsed="0.003637"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.964046" 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-06-06T03:32:33.963492" elapsed="0.000592"/>
</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-06-06T03:32:33.964549" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.964211" elapsed="0.000417"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.965332" 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-06-06T03:32:33.964913" elapsed="0.000456"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.964686" elapsed="0.000733"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.964155" elapsed="0.001293"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.966204" 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-06-06T03:32:33.965693" elapsed="0.000548"/>
</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-06-06T03:32:33.966691" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:33.966339" elapsed="0.000433"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.967442" 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-06-06T03:32:33.967028" elapsed="0.000451"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:33.966805" elapsed="0.000724"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:33.966313" elapsed="0.001246"/>
</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-06-06T03:32:33.967796" elapsed="0.000529"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:33.968906" 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-06-06T03:32:33.968605" elapsed="0.000327"/>
</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-06-06T03:32:33.969090" elapsed="0.002362"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:33.955627" elapsed="0.015888"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:33.971565" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:33.973904" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:33.944542" elapsed="0.029389"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:33.973986" elapsed="0.000028"/>
</return>
<arg>${POLICIES_VAR}/${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:33.848423" elapsed="0.125688"/>
</kw>
<var name="${index}">4</var>
<var name="${peer_type}">ebgp_peer</var>
<status status="PASS" start="2026-06-06T03:32:33.847350" elapsed="0.126800"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:33.975020" level="INFO">&amp;{mapping} = { IP=127.0.0.5 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:33.974427" elapsed="0.000622"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.016446" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:34.016046" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.017223" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:34.016991" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:34.017391" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:34.016654" elapsed="0.000761"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.017981" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:34.017579" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.018305" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:34.018448" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:34.018169" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.018896" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.018636" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.019900" level="INFO">mapping: {'IP': '127.0.0.5', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.019628" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.020397" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.020103" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.021095" level="INFO">${value} = 127.0.0.5</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.020799" elapsed="0.000321"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.021900" level="INFO">${encoded} = 127.0.0.5</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.021622" elapsed="0.000304"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.021978" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:34.022131" level="INFO">${encoded_value} = 127.0.0.5</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.021305" elapsed="0.000850"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.022308" elapsed="0.000233"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.5</var>
<status status="PASS" start="2026-06-06T03:32:34.020663" elapsed="0.001920"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.023303" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.022846" elapsed="0.000484"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.024060" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.023850" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.024135" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.024300" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.023517" elapsed="0.000808"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.024476" elapsed="0.000242"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:34.022713" elapsed="0.002047"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.025296" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.025001" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.026052" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.025844" elapsed="0.000234"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.026128" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:34.026276" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.025505" elapsed="0.000795"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.026448" elapsed="0.000234"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:34.024870" elapsed="0.001854"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.027259" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.026965" elapsed="0.000319"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.028008" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.027799" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.028083" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.028262" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.027467" elapsed="0.000823"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.028444" elapsed="0.000262"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:34.026834" elapsed="0.001914"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.029288" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.028991" elapsed="0.000322"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.030047" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.029838" elapsed="0.000235"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.030123" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.030272" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.029496" elapsed="0.000801"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.030445" elapsed="0.000234"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:34.028859" elapsed="0.001862"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.020472" elapsed="0.010284"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.030798" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:34.030956" level="INFO">${mapping_to_use} = {'IP': '127.0.0.5', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:34.019306" elapsed="0.011712"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.019011" elapsed="0.012043"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.031231" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.031080" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.018990" elapsed="0.012319"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.032094" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:34.031453" elapsed="0.000670"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.032172" elapsed="0.000052"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:34.015417" elapsed="0.016910"/>
</kw>
<msg time="2026-06-06T03:32:34.032383" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.003146" elapsed="0.029283"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.044770" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.056829" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.068905" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.069104" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.069282" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.069664" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.069505" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:34.069488" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.069889" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.070057" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.070222" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:34.069459" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.069357" elapsed="0.000944"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.070446" elapsed="0.000025"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.070583" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:32:34.070733" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:33.998922" elapsed="0.071839"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.071877" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.071606" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:34.082144" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.082191" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.5 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.082281" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:34.074053" elapsed="0.008253"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.071992" elapsed="0.010355"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.082544" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.082372" elapsed="0.000308"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.071974" elapsed="0.010745"/>
</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-06-06T03:32:34.087328" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.084104" elapsed="0.003284"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.083799" elapsed="0.003638"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.083773" elapsed="0.003699"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.090999" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.087879" elapsed="0.003183"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.087548" elapsed="0.003563"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.087525" elapsed="0.003619"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.091925" 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-06-06T03:32:34.091375" elapsed="0.000588"/>
</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-06-06T03:32:34.092431" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.092061" elapsed="0.000467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.093211" 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-06-06T03:32:34.092905" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.092570" elapsed="0.000704"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.092035" elapsed="0.001260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.093835" 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-06-06T03:32:34.093453" elapsed="0.000409"/>
</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-06-06T03:32:34.094172" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.093932" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.094728" 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-06-06T03:32:34.094411" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.094252" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.093914" elapsed="0.000897"/>
</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-06-06T03:32:34.094962" elapsed="0.000397"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:34.095833" 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-06-06T03:32:34.095527" elapsed="0.000333"/>
</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-06-06T03:32:34.096016" elapsed="0.002409"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:34.083207" elapsed="0.015284"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:34.098540" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:34.100791" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:34.071023" elapsed="0.029795"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.100872" elapsed="0.000028"/>
</return>
<arg>${POLICIES_VAR}/${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:33.975281" elapsed="0.125715"/>
</kw>
<var name="${index}">5</var>
<var name="${peer_type}">rr_client_peer</var>
<status status="PASS" start="2026-06-06T03:32:33.974265" elapsed="0.126771"/>
</iter>
<iter>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.101911" level="INFO">&amp;{mapping} = { IP=127.0.0.6 | HOLDTIME=180 | PASSIVE_MODE=true | BGP_RIB_OPENCONFIG=example-bgp-rib | RIB_INSTANCE_NAME=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=127.0.0.${index}</arg>
<arg>HOLDTIME=${HOLDTIME}</arg>
<arg>PASSIVE_MODE=true</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<arg>RIB_INSTANCE_NAME=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.101316" elapsed="0.000623"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.143206" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:34.142827" elapsed="0.000408"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.144006" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:34.143758" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:34.144178" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:34.143403" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.144805" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:34.144404" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.145135" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/rr_client_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:34.145289" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:34.144995" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.145739" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors/neighbor=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.145473" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.146754" level="INFO">mapping: {'IP': '127.0.0.6', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.146479" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.147222" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.146959" elapsed="0.000288"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.147929" level="INFO">${value} = 127.0.0.6</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.147613" elapsed="0.000341"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.148770" level="INFO">${encoded} = 127.0.0.6</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.148534" elapsed="0.000262"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.148848" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:34.149002" level="INFO">${encoded_value} = 127.0.0.6</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.148141" elapsed="0.000886"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.149179" elapsed="0.000231"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">127.0.0.6</var>
<status status="PASS" start="2026-06-06T03:32:34.147480" elapsed="0.001971"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.151510" level="INFO">${value} = 180</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.149709" elapsed="0.001828"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.152292" level="INFO">${encoded} = 180</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.152063" elapsed="0.000256"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.152370" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.152521" level="INFO">${encoded_value} = 180</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.151743" elapsed="0.000803"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.152714" elapsed="0.000223"/>
</kw>
<var name="${key}">HOLDTIME</var>
<var name="${value}">180</var>
<status status="PASS" start="2026-06-06T03:32:34.149563" elapsed="0.003416"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.153521" level="INFO">${value} = true</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.153224" elapsed="0.000326"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.154279" level="INFO">${encoded} = true</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.154068" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.154354" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:34.154502" level="INFO">${encoded_value} = true</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.153752" elapsed="0.000774"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.154696" elapsed="0.000223"/>
</kw>
<var name="${key}">PASSIVE_MODE</var>
<var name="${value}">true</var>
<status status="PASS" start="2026-06-06T03:32:34.153091" elapsed="0.001870"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.155498" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.155203" elapsed="0.000320"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.156273" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.156038" elapsed="0.000261"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.156350" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.156499" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.155724" elapsed="0.000799"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.156688" elapsed="0.000223"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:34.155073" elapsed="0.001879"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.157494" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.157196" elapsed="0.000323"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.158247" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.158037" elapsed="0.000236"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.158323" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:34.158472" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.157720" elapsed="0.000779"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.158667" elapsed="0.000223"/>
</kw>
<var name="${key}">RIB_INSTANCE_NAME</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:34.157064" elapsed="0.001867"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.147300" elapsed="0.011665"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.159008" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:34.159166" level="INFO">${mapping_to_use} = {'IP': '127.0.0.6', 'HOLDTIME': '180', 'PASSIVE_MODE': 'true', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib', 'RIB_INSTANCE_NAME': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:34.146159" elapsed="0.013074"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.145856" elapsed="0.013411"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.159442" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.159292" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.145835" elapsed="0.013684"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.160328" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:34.159676" elapsed="0.000682"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.160407" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:34.142197" elapsed="0.018333"/>
</kw>
<msg time="2026-06-06T03:32:34.160585" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.129770" elapsed="0.030862"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.172951" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.185280" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/rr_client_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.197374" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.197571" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.197769" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.198257" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.197990" elapsed="0.000327"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:34.197976" elapsed="0.000365"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.198484" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.198673" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.198843" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:34.197947" elapsed="0.000949"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.197844" elapsed="0.001079"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.199068" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.199176" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:34.199300" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:34.125566" elapsed="0.073761"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.200454" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.200174" elapsed="0.000326"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:34.209364" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.209411" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors/neighbor=127.0.0.6 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.209510" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:34.202568" elapsed="0.006969"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.200567" elapsed="0.009011"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.209779" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.209604" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.200549" elapsed="0.009314"/>
</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-06-06T03:32:34.213442" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.210863" elapsed="0.002639"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.210623" elapsed="0.002927"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.210605" elapsed="0.002981"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.217166" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.213994" elapsed="0.003236"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.213684" elapsed="0.003594"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.213658" elapsed="0.003654"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.218092" 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-06-06T03:32:34.217543" elapsed="0.000588"/>
</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-06-06T03:32:34.218565" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.218230" elapsed="0.000438"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.219349" 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-06-06T03:32:34.218932" elapsed="0.000454"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.218703" elapsed="0.000734"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.218203" elapsed="0.001263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.220247" 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-06-06T03:32:34.219707" elapsed="0.000579"/>
</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-06-06T03:32:34.220693" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.220387" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.221229" 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-06-06T03:32:34.220934" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.220775" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.220361" elapsed="0.000950"/>
</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-06-06T03:32:34.221461" elapsed="0.000417"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:34.222325" 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-06-06T03:32:34.222045" elapsed="0.000307"/>
</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-06-06T03:32:34.222505" elapsed="0.002416"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:34.210215" elapsed="0.014769"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:34.225031" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:34.227222" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:34.199589" elapsed="0.027660"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.227303" elapsed="0.000028"/>
</return>
<arg>${POLICIES_VAR}/${peer_type}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:34.102176" elapsed="0.125251"/>
</kw>
<var name="${index}">6</var>
<var name="${peer_type}">rr_client_peer</var>
<status status="PASS" start="2026-06-06T03:32:34.101153" elapsed="0.126312"/>
</iter>
<var>${index}</var>
<var>${peer_type}</var>
<value>${NUMBERS}</value>
<value>${PEER_TYPES}</value>
<status status="PASS" start="2026-06-06T03:32:33.452315" elapsed="0.775186"/>
</for>
<doc>Revert the BGP configuration to the original state: without any configured peers.</doc>
<status status="PASS" start="2026-06-06T03:32:33.364206" elapsed="0.863419"/>
</test>
<test id="s1-s20-t8" name="Deconfigure_App_Peer" line="113">
<kw name="Setup_Test_With_Logging_And_Without_Fast_Failing" owner="SetupUtils" type="SETUP">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:32:34.230926" elapsed="0.000208"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:32:34.230661" elapsed="0.000528"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Log_Testcase_Start_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.232185" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.232075" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.232056" elapsed="0.000230"/>
</if>
<kw name="Log_Message_To_Controller_Karaf" owner="KarafKeywords">
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.237106" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.236999" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.236981" elapsed="0.000193"/>
</if>
<kw name="List_Indices_Or_All" owner="ClusterManagement">
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.238216" 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-06-06T03:32:34.237826" elapsed="0.000417"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.238718" 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-06-06T03:32:34.238403" elapsed="0.000342"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:34.238789" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:34.238943" 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-06-06T03:32:34.237398" elapsed="0.001570"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Controller_Karaf_Command_With_Retry_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-06-06T03:32:34.244491" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.244381" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.244362" elapsed="0.000198"/>
</if>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<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-06-06T03:32:34.245772" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.245635" elapsed="0.000183"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.245616" elapsed="0.000225"/>
</if>
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:34.246286" 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-06-06T03:32:34.245986" elapsed="0.000327"/>
</kw>
<kw name="Switch Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.246709" level="INFO">${current_connection_index} = 7</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-06-06T03:32:34.246471" elapsed="0.000264"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Write" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.277757" level="INFO">log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "u "s "e "r "f "e "a "t "u "r "[78Ce "[A[78Cs</msg>
<arg>${command}</arg>
<doc>Writes the given ``text`` on the remote machine and appends a newline.</doc>
<status status="PASS" start="2026-06-06T03:32:34.247243" elapsed="0.030625"/>
</kw>
<msg time="2026-06-06T03:32:34.278082" level="INFO">${status_write} = PASS</msg>
<msg time="2026-06-06T03:32:34.278130" level="INFO">${message_write} = log:log " "R "O "B "O "T "[C "M "E "S "S "A "G "E ": "[C "S "t "a "r "t "i "n "g "[C "t "e "s "t "[C "b "g "p "c "e "p "- "...</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-06-06T03:32:34.246897" elapsed="0.031271"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Read Until Regexp" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.314296" level="INFO">". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:32:34.278713" elapsed="0.035689"/>
</kw>
<msg time="2026-06-06T03:32:34.314564" level="INFO">${status_wait} = PASS</msg>
<msg time="2026-06-06T03:32:34.314610" level="INFO">${message_wait} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "...</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-06-06T03:32:34.278343" elapsed="0.036324"/>
</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-06-06T03:32:34.314977" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.314749" elapsed="0.000283"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.314728" elapsed="0.000328"/>
</if>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.315497" level="INFO"> ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "p "p "_ "P "e "e "r "[K"
[?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-06-06T03:32:34.315198" elapsed="0.000369"/>
</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-06-06T03:32:34.315868" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.315633" elapsed="0.000290"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.315615" elapsed="0.000332"/>
</if>
<return>
<value>${message_wait}</value>
<status status="PASS" start="2026-06-06T03:32:34.315981" elapsed="0.000029"/>
</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">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:34.318547" elapsed="0.000162"/>
</kw>
<msg time="2026-06-06T03:32:34.318773" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.317457" elapsed="0.001448"/>
</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="NOT RUN" start="2026-06-06T03:32:34.319180" elapsed="0.000076"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.319518" elapsed="0.000074"/>
</kw>
<arg>${current_connection_index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:34.316833" elapsed="0.002892"/>
</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-06-06T03:32:34.316269" elapsed="0.003520"/>
</kw>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="PASS" start="2026-06-06T03:32:34.245332" elapsed="0.074555"/>
</kw>
<msg time="2026-06-06T03:32:34.319981" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:34.320025" level="INFO">${message} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "...</msg>
<var>${status}</var>
<var>${message}</var>
<arg>Execute_Controller_Karaf_Command_On_Background</arg>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:34.244726" elapsed="0.075337"/>
</kw>
<if>
<branch type="IF" condition="'${status}' == 'PASS'">
<return>
<value>${message}</value>
<status status="PASS" start="2026-06-06T03:32:34.320278" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:32:34.320139" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.320121" elapsed="0.000246"/>
</if>
<kw name="Open_Controller_Karaf_Console_On_Background" owner="KarafKeywords">
<arg>${member_index}</arg>
<doc>If there is a stored ssh connection index of connection to the controller's karaf console for 1,
close the previous connection. In any case create a new connection
to karaf console for 1, set correct prompt set and login to karaf console.
Store connection index for 1 and restore the previous active connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.320794" elapsed="0.000025"/>
</kw>
<kw name="Execute_Controller_Karaf_Command_On_Background" owner="KarafKeywords">
<var>${message}</var>
<arg>${command}</arg>
<arg>${member_index}</arg>
<doc>Send command to karaf without affecting current SSH connection. Read, log and return response.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.321135" elapsed="0.000024"/>
</kw>
<return>
<value>${message}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.321206" elapsed="0.000016"/>
</return>
<arg>log:log "ROBOT MESSAGE: ${message}"</arg>
<arg>member_index=${index}</arg>
<doc>Attemp to send command to karaf for ${member_index}, if fail then open connection and try again.</doc>
<status status="PASS" start="2026-06-06T03:32:34.244025" elapsed="0.077289"/>
</kw>
<msg time="2026-06-06T03:32:34.321408" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:34.321451" level="INFO">${output} =  ". "t "x "t ". "B "g "p "[C "P "o "l "i "c "i "e "s "[C "D "e "f "a "u "l "t ". "D "e "c "o "n "f "i "g "u "r "e "_ "A "...</msg>
<var>${status}</var>
<var>${output}</var>
<arg>Execute_Controller_Karaf_Command_With_Retry_On_Background</arg>
<arg>log:log "ROBOT MESSAGE: ${message}"</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-06-06T03:32:34.239330" elapsed="0.082158"/>
</kw>
<if>
<branch type="IF" condition="not ${tolerate_failure} and &quot;${status}&quot; != &quot;PASS&quot;">
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.321873" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.321602" elapsed="0.000325"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.321583" elapsed="0.000368"/>
</if>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:34.239189" elapsed="0.082786"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:34.239021" elapsed="0.082984"/>
</for>
<arg>Starting test ${SUITE_NAME}.${TEST_NAME}</arg>
<arg>${member_index_list}</arg>
<doc>Make sure this resource is initialized. Send a message into the controller's karaf log file on every node listed (or all).
By default, failure while processing a node is silently ignored, unless ${tolerate_failure} is False.</doc>
<status status="PASS" start="2026-06-06T03:32:34.236625" elapsed="0.085433"/>
</kw>
<arg>member_index_list=${member_index_list}</arg>
<doc>Log test case name to karaf log, useful in test case setup.</doc>
<status status="PASS" start="2026-06-06T03:32:34.231788" elapsed="0.090324"/>
</kw>
<arg>KarafKeywords.Log_Testcase_Start_To_Controller_Karaf</arg>
<arg>member_index_list=${member_index_list}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:34.231340" elapsed="0.090817"/>
</kw>
<doc>Test case setup which explicitly ignores previous failure and logs test case name to Karaf log.
Needed if the recommended default is to be overriden.</doc>
<status status="PASS" start="2026-06-06T03:32:34.228544" elapsed="0.093664"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.322854" level="INFO">&amp;{mapping} = { IP=10.30.170.38 | BGP_RIB_OPENCONFIG=example-bgp-rib }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${ODL_SYSTEM_IP}</arg>
<arg>BGP_RIB_OPENCONFIG=${RIB_INSTANCE}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.322376" elapsed="0.000506"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.364915" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:34.364518" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.365698" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:34.365441" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:34.365870" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:34.365107" elapsed="0.000787"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.366448" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:34.366061" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.366790" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:34.366937" level="INFO">${template} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-ext...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:34.366635" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.367364" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,$BGP_RIB_OPENCONFIG/bgp-openconfig-extensions:bgp/neighbors
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.367120" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.368384" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.368108" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.368867" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.368589" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.369539" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.369243" elapsed="0.000324"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.370306" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.370088" elapsed="0.000245"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.370383" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.370533" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.369769" elapsed="0.000788"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.370724" elapsed="0.000235"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:32:34.369110" elapsed="0.001930"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.371587" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.371288" elapsed="0.000325"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.372525" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.372136" elapsed="0.000415"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.372602" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.372771" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.371817" elapsed="0.000979"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.372949" elapsed="0.000226"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:34.371155" elapsed="0.002060"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.368941" elapsed="0.004309"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.373292" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:34.373448" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:34.367787" elapsed="0.005686"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.367477" elapsed="0.006029"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.373700" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.373531" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.367457" elapsed="0.006321"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.374498" level="INFO">${final_text} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:34.373923" elapsed="0.000604"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.374577" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:34.363873" elapsed="0.010844"/>
</kw>
<msg time="2026-06-06T03:32:34.374773" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.351416" elapsed="0.023404"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.386847" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.399021" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.411082" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.411279" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.411497" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.411883" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.411737" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:34.411722" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.412106" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.412307" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.412482" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:34.411692" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.411574" elapsed="0.000991"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.412729" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.412806" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:34.412927" level="INFO">${uri} = rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensi...</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:34.347168" elapsed="0.065785"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.414063" level="INFO">rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.413813" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:34.424337" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors 
 path_url=/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.424402" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types%3ABGP,example-bgp-rib/bgp-openconfig-extensions:bgp/neighbors 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.424526" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:34.416167" elapsed="0.008395"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.414176" elapsed="0.010442"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.424896" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.424682" elapsed="0.000300"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.414158" elapsed="0.010853"/>
</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-06-06T03:32:34.429887" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.426392" elapsed="0.003557"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.426085" elapsed="0.003913"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.426059" elapsed="0.003974"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.433586" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.430426" elapsed="0.003242"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.430114" elapsed="0.003604"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.430090" elapsed="0.003663"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.434514" 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-06-06T03:32:34.433984" elapsed="0.000568"/>
</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-06-06T03:32:34.435009" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.434670" elapsed="0.000465"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.435846" 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-06-06T03:32:34.435402" elapsed="0.000481"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.435173" elapsed="0.000760"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.434624" elapsed="0.001338"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.436692" 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-06-06T03:32:34.436186" elapsed="0.000533"/>
</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-06-06T03:32:34.437024" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.436789" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.437561" 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-06-06T03:32:34.437265" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.437105" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.436771" elapsed="0.000889"/>
</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-06-06T03:32:34.437813" elapsed="0.000350"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:34.438615" 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-06-06T03:32:34.438330" elapsed="0.000328"/>
</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-06-06T03:32:34.438817" elapsed="0.002264"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:34.425496" elapsed="0.015649"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:34.441192" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:34.443389" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:34.413219" elapsed="0.030197"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.443470" elapsed="0.000027"/>
</return>
<arg>${POLICIES_VAR}/app_peer</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:34.323106" elapsed="0.120486"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.484823" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:34.484428" elapsed="0.000424"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.485574" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:34.485352" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:34.485754" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:34.485016" elapsed="0.000763"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.486329" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:34.485945" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:34.486666" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/bgpfunctional/bgppolicies/app_peer_route/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:34.486802" level="INFO">${template} = rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:34.486517" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.487226" level="INFO">rests/data/bgp-rib:application-rib=$IP/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.486984" elapsed="0.000287"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.488305" level="INFO">mapping: {'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.488018" elapsed="0.000334"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.488794" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.488513" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.489627" level="INFO">${value} = 10.30.170.38</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.489316" elapsed="0.000352"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.490395" level="INFO">${encoded} = 10.30.170.38</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.490180" elapsed="0.000241"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.490472" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.490623" level="INFO">${encoded_value} = 10.30.170.38</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.489860" elapsed="0.000802"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.490818" elapsed="0.000223"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.170.38</var>
<status status="PASS" start="2026-06-06T03:32:34.489038" elapsed="0.002044"/>
</iter>
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.491621" level="INFO">${value} = example-bgp-rib</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:32:34.491325" elapsed="0.000336"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:34.492406" level="INFO">${encoded} = example-bgp-rib</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.492166" elapsed="0.000266"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:32:34.492483" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.492633" level="INFO">${encoded_value} = example-bgp-rib</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:32:34.491849" elapsed="0.000828"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:34.492832" elapsed="0.000221"/>
</kw>
<var name="${key}">BGP_RIB_OPENCONFIG</var>
<var name="${value}">example-bgp-rib</var>
<status status="PASS" start="2026-06-06T03:32:34.491194" elapsed="0.001901"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.488870" elapsed="0.004260"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:34.493173" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:34.493328" level="INFO">${mapping_to_use} = {'IP': '10.30.170.38', 'BGP_RIB_OPENCONFIG': 'example-bgp-rib'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:34.487686" elapsed="0.005668"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.487337" elapsed="0.006049"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.493560" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.493411" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.487318" elapsed="0.006317"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.494356" level="INFO">${final_text} = rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:34.493799" elapsed="0.000586"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.494434" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="PASS" start="2026-06-06T03:32:34.483793" elapsed="0.010764"/>
</kw>
<msg time="2026-06-06T03:32:34.494611" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.471418" elapsed="0.023256"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.506693" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.518898" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name} exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route.vanadium/${file_name},
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/bgpfunct/../../../variables/bgpfunctional/bgppolicies/app_peer_route/${file_name}.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.531037" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.531233" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.531410" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.531785" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.531626" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:34.531612" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.532006" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.532175" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.532365" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:34.531584" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.531485" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.532591" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.532681" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:34.532800" level="INFO">${uri} = rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:34.467240" elapsed="0.065586"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.533934" level="INFO">rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.533675" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:34.544119" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 path_url=/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0ptt59zit9o154xpfaa28bbtr29.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.544182" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/bgp-rib:application-rib=10.30.170.38/tables=bgp-types%3Aipv4-address-family,bgp-types%3Aunicast-subsequent-address-family/bgp-inet:ipv4-routes 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:34.544325" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:32:34.536250" elapsed="0.008114"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.534047" elapsed="0.010377"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:34.544748" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.544460" elapsed="0.000377"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.534029" elapsed="0.010881"/>
</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-06-06T03:32:34.549537" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.546338" elapsed="0.003260"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.546032" elapsed="0.003634"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.546006" elapsed="0.003698"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.553241" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.550092" elapsed="0.003213"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.549782" elapsed="0.003571"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.549759" elapsed="0.003627"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.554156" 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-06-06T03:32:34.553613" elapsed="0.000581"/>
</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-06-06T03:32:34.554628" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.554293" elapsed="0.000439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.555405" 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-06-06T03:32:34.554989" elapsed="0.000453"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.554765" elapsed="0.000726"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.554267" elapsed="0.001253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.556262" 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-06-06T03:32:34.555760" elapsed="0.000571"/>
</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-06-06T03:32:34.556778" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.556429" elapsed="0.000430"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.557526" 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-06-06T03:32:34.557115" elapsed="0.000447"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.556892" elapsed="0.000720"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.556403" elapsed="0.001237"/>
</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-06-06T03:32:34.557870" elapsed="0.000478"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:32:34.559004" 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-06-06T03:32:34.558578" elapsed="0.000462"/>
</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-06-06T03:32:34.559255" elapsed="0.002718"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:32:34.545404" elapsed="0.016632"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:32:34.562083" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.564279" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:32:34.533085" elapsed="0.031222"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:32:34.564361" elapsed="0.000028"/>
</return>
<arg>${POLICIES_VAR}/app_peer_route</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${CONFIG_SESSION}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:32:34.443834" elapsed="0.120650"/>
</kw>
<doc>Revert the BGP configuration to the original state: without application peer</doc>
<status status="PASS" start="2026-06-06T03:32:34.227966" elapsed="0.336640"/>
</test>
<kw name="Stop_Suite" type="TEARDOWN">
<kw name="Virtual_Env_Delete" 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-06-06T03:32:34.570856" level="INFO">${cd_and_command} = cd '.' &amp;&amp; rm -rf /tmp/defaultvenv</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-06-06T03:32:34.570505" elapsed="0.000379"/>
</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-06-06T03:32:34.572346" level="INFO">Executing command 'cd '.' &amp;&amp; rm -rf /tmp/defaultvenv'.</msg>
<msg time="2026-06-06T03:32:34.625949" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:34.626287" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:32:34.626393" level="INFO">${stderr} = </msg>
<msg time="2026-06-06T03:32:34.626492" 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-06-06T03:32:34.572125" elapsed="0.054422"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.629005" level="INFO">Length is 0.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="PASS" start="2026-06-06T03:32:34.628328" elapsed="0.000780"/>
</kw>
<msg time="2026-06-06T03:32:34.629321" level="INFO">${emptiness_status} = PASS</msg>
<msg time="2026-06-06T03:32:34.629417" 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-06-06T03:32:34.627181" elapsed="0.002286"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.630853" 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-06-06T03:32:34.629875" elapsed="0.001037"/>
</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-06-06T03:32:34.633490" level="INFO"/>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.633033" elapsed="0.000537"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.634247" level="INFO"/>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.633863" elapsed="0.000450"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.634961" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.634559" 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-06-06T03:32:34.632111" elapsed="0.003022"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:34.631103" elapsed="0.004085"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.631051" elapsed="0.004177"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.635459" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.635309" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.635285" elapsed="0.000278"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:32:34.635789" elapsed="0.000048"/>
</return>
<status status="PASS" start="2026-06-06T03:32:34.635658" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.635616" elapsed="0.000305"/>
</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-06-06T03:32:34.636131" elapsed="0.000030"/>
</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-06-06T03:32:34.571561" elapsed="0.064789"/>
</kw>
<msg time="2026-06-06T03:32:34.636432" 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-06-06T03:32:34.571045" elapsed="0.065479"/>
</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 rm -rf /tmp/defaultvenv.
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-06-06T03:32:34.569891" elapsed="0.066771"/>
</kw>
<msg time="2026-06-06T03:32:34.636740" 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-06-06T03:32:34.566005" elapsed="0.070817"/>
</kw>
<arg>rm -rf ${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-06-06T03:32:34.565628" elapsed="0.071303"/>
</kw>
<doc>Deletes a directory with virtual env.</doc>
<status status="PASS" start="2026-06-06T03:32:34.565402" elapsed="0.071603"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:32:34.637212" elapsed="0.000614"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:34.638154" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:32:34.638048" elapsed="0.000225"/>
</kw>
<doc>Suite teardown keyword</doc>
<status status="PASS" start="2026-06-06T03:32:34.565144" elapsed="0.073204"/>
</kw>
<doc>Functional test for bgp routing policies

Copyright (c) 2018 AT&amp;T Intellectual Property. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

This suite uses 7 peers: app peer, 2x rr-client, 2x ebgp, 2x ibgp
Tests results on effective-rib-in dependant on their respective configurations.
Peers 1,2,4,5 are testing multiple ipv4 routes with additional arguments.
Peers 3,6 have ipv4 and ipv6 mpls-labeled routes.</doc>
<status status="FAIL" start="2026-06-06T03:31:49.642849" elapsed="44.995544"/>
</suite>
<suite id="s1-s21" name="Tcpmd5User" source="/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/tcpmd5user.robot">
<kw name="Set_It_Up" type="SETUP">
<kw name="Setup_Karaf_Keywords" owner="KarafKeywords">
<kw name="ClusterManagement_Setup" owner="ClusterManagement">
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.732387" 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-06-06T03:32:34.728376" elapsed="0.004047"/>
</kw>
<if>
<branch type="IF" condition="${already_done}">
<return>
<status status="NOT RUN" start="2026-06-06T03:32:34.732676" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.732526" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.732500" elapsed="0.000319"/>
</if>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.733330" 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-06-06T03:32:34.732976" elapsed="0.000398"/>
</kw>
<kw name="Get Variable Value" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.733867" 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-06-06T03:32:34.733530" elapsed="0.000363"/>
</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-06-06T03:32:34.734388" elapsed="0.000316"/>
</kw>
<msg time="2026-06-06T03:32:34.734804" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:32:34.734850" 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-06-06T03:32:34.734052" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.735410" 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-06-06T03:32:34.735033" elapsed="0.000403"/>
</kw>
<kw name="ClusterManagement__Compute_Derived_Variables" owner="ClusterManagement">
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.736425" level="INFO">@{member_index_list} = [ ]</msg>
<var>@{member_index_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:32:34.736145" elapsed="0.000306"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.736866" level="INFO">@{session_list} = [ ]</msg>
<var>@{session_list}</var>
<doc>Returns a list containing given items.</doc>
<status status="PASS" start="2026-06-06T03:32:34.736593" elapsed="0.000299"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.737334" 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-06-06T03:32:34.737043" elapsed="0.000317"/>
</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-06-06T03:32:34.740476" elapsed="0.000235"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.741195" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:32:34.740868" elapsed="0.000353"/>
</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-06-06T03:32:34.741369" elapsed="0.000236"/>
</kw>
<kw name="Resolve_Http_Session_For_Member" owner="ClusterManagement">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.742410" 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-06-06T03:32:34.742112" elapsed="0.000325"/>
</kw>
<return>
<value>${session}</value>
<status status="PASS" start="2026-06-06T03:32:34.742483" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:32:34.742664" 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-06-06T03:32:34.741823" elapsed="0.000868"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:34.743284" level="INFO">Creating Session using : alias=ClusterManagement__session_1, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5959e90&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-06-06T03:32:34.742847" elapsed="0.000619"/>
</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-06-06T03:32:34.743625" elapsed="0.000208"/>
</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-06-06T03:32:34.739904" elapsed="0.003991"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:34.739721" elapsed="0.004220"/>
</iter>
<var>${index}</var>
<value>1</value>
<value>${int_of_members+1}</value>
<status status="PASS" start="2026-06-06T03:32:34.737418" elapsed="0.006556"/>
</for>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.744555" 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-06-06T03:32:34.744131" elapsed="0.000471"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.745155" level="INFO">${ClusterManagement__index_to_ip_mapping} = {1: '10.30.170.38'}</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-06-06T03:32:34.744775" elapsed="0.000423"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.746161" 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-06-06T03:32:34.745351" elapsed="0.000854"/>
</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-06-06T03:32:34.735704" elapsed="0.010560"/>
</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-06-06T03:32:34.727992" elapsed="0.018327"/>
</kw>
<if>
<branch type="IF" condition="'${IS_KARAF_APPL}' == 'False'">
<return>
<value>Not A Karaf App</value>
<status status="NOT RUN" start="2026-06-06T03:32:34.746533" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:34.746421" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.746401" elapsed="0.000199"/>
</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-06-06T03:32:34.749695" 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-06-06T03:32:34.749299" elapsed="0.000424"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.750171" 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-06-06T03:32:34.749877" elapsed="0.000319"/>
</kw>
<return>
<value>${return_list_copy}</value>
<status status="PASS" start="2026-06-06T03:32:34.750242" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:34.750396" 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-06-06T03:32:34.748980" elapsed="0.001440"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Run_Bash_Command_On_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:34.751405" level="INFO">${member_ip} = 10.30.170.38</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-06-06T03:32:34.751143" elapsed="0.000288"/>
</kw>
<kw name="Run_Keyword_Preserve_Connection" owner="SSHKeywords">
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.752259" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:32:34.752390" 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-06-06T03:32:34.752089" elapsed="0.000327"/>
</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-06-06T03:32:34.755068" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:34.754756" elapsed="0.000483"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:34.754736" elapsed="0.000530"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.755539" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

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

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:32:34.755409" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.756806" level="INFO">Attempting to execute command "iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save" on remote system "10.30.170.38" by user "jenkins" with keyfile pass "any" and prompt "&gt;" and password ""</msg>
<arg>Attempting to execute command "${cmd}" on remote system "${system}" by user "${user}" with keyfile pass "${keyfile_pass}" and prompt "${prompt}" and password "${password}"</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:34.755854" elapsed="0.001000"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.757662" 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-06-06T03:32:34.757005" elapsed="0.000685"/>
</kw>
<kw name="Flexible_SSH_Login" owner="SSHKeywords">
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:32:34.759124" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:32:34.759327" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:32:34.758415" elapsed="0.000961"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.759690" elapsed="0.000624"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:32:34.761796" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:32:35.106464" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:31:49 UTC 2026

  System load:  0.13               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:31:51 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:32:34.761386" elapsed="0.345521"/>
</kw>
<msg time="2026-06-06T03:32:35.107246" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:34.760651" elapsed="0.346945"/>
</kw>
<arg>${user}</arg>
<arg>${password}</arg>
<doc>On active SSH session: if given non-empty password, do Login, else do Login With Public Key.</doc>
<status status="PASS" start="2026-06-06T03:32:34.757902" elapsed="0.350244"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.109403" level="INFO">Executing command 'iptables -I INPUT -p tcp --dport 8101 -j ACCEPT; iptables-save'.</msg>
<msg time="2026-06-06T03:32:35.122702" level="INFO">Command exited with return code 4.</msg>
<msg time="2026-06-06T03:32:35.123056" level="INFO">${stdout} = </msg>
<msg time="2026-06-06T03:32:35.123160" 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-06-06T03:32:35.108759" elapsed="0.014456"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:32:35.123595" elapsed="0.000542"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:35.125780" 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-06-06T03:32:35.124601" elapsed="0.001288"/>
</kw>
<if>
<branch type="IF" condition="&quot;${return_stdout}&quot;!=&quot;True&quot;">
<return>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:32:35.126419" elapsed="0.000043"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:35.126069" elapsed="0.000466"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:35.126013" elapsed="0.000574"/>
</if>
<if>
<branch type="IF" condition="&quot;${return_stderr}&quot;!=&quot;True&quot;">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:32:35.127036" elapsed="0.000061"/>
</return>
<status status="PASS" start="2026-06-06T03:32:35.126745" elapsed="0.000427"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:35.126706" elapsed="0.000521"/>
</if>
<return>
<value>${stdout}</value>
<value>${stderr}</value>
<status status="NOT RUN" start="2026-06-06T03:32:35.127300" elapsed="0.000032"/>
</return>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords" type="TEARDOWN">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:35.132275" elapsed="0.001074"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:32:35.133697" elapsed="0.000577"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:32:35.134525" elapsed="0.000296"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:35.128037" elapsed="0.006899"/>
</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-06-06T03:32:34.754248" elapsed="0.380822"/>
</kw>
<msg time="2026-06-06T03:32:35.135145" 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-06-06T03:32:34.753557" elapsed="0.381664"/>
</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-06-06T03:32:34.753079" elapsed="0.382255"/>
</kw>
<msg time="2026-06-06T03:32:35.135393" 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-06-06T03:32:34.752566" elapsed="0.382890"/>
</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-06-06T03:32:35.140279" elapsed="0.000792"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:32:35.141426" elapsed="0.000331"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:32:35.141899" elapsed="0.000099"/>
</kw>
<arg>${current_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:35.135877" elapsed="0.006173"/>
</kw>
<msg time="2026-06-06T03:32:35.142144" 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-06-06T03:32:34.751665" elapsed="0.390504"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:35.142587" level="INFO"/>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:35.142338" elapsed="0.000291"/>
</kw>
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:32:35.142688" elapsed="0.000030"/>
</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-06-06T03:32:34.750794" elapsed="0.392023"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:34.750603" elapsed="0.392253"/>
</iter>
<var>${index}</var>
<value>@{index_list}</value>
<status status="PASS" start="2026-06-06T03:32:34.750472" elapsed="0.392421"/>
</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-06-06T03:32:34.746828" elapsed="0.396168"/>
</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-06-06T03:32:35.143151" 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-06-06T03:32:35.157272" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:35.157158" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:35.157138" elapsed="0.000204"/>
</if>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.157630" level="INFO">index=None
host=None
alias=None
port=22
timeout=3 seconds
newline=

prompt=None
term_type=vt100
width=80
height=24
path_separator=/
encoding=utf8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:32:35.157753" 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-06-06T03:32:35.157491" elapsed="0.000289"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:35.158188" level="INFO">{}</msg>
<arg>${connection_index_dict}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:35.157926" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:35.158622" level="INFO">1</msg>
<arg>${member_index}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:35.158379" elapsed="0.000304"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:35.159456" 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-06-06T03:32:35.159194" elapsed="0.000377">Dictionary does not contain key '1'.</status>
</kw>
<msg time="2026-06-06T03:32:35.159694" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:32:35.159742" 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-06-06T03:32:35.158837" elapsed="0.000928"/>
</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-06-06T03:32:35.160059" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:35.159841" elapsed="0.000293"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:35.159822" elapsed="0.000337"/>
</if>
<kw name="Resolve_IP_Address_For_Member" owner="ClusterManagement">
<kw name="Get From Dictionary" owner="Collections">
<msg time="2026-06-06T03:32:35.160939" level="INFO">${ip_address} = 10.30.170.38</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-06-06T03:32:35.160669" elapsed="0.000296"/>
</kw>
<return>
<value>${ip_address}</value>
<status status="PASS" start="2026-06-06T03:32:35.161013" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:35.161163" level="INFO">${odl_ip} = 10.30.170.38</msg>
<var>${odl_ip}</var>
<arg>${member_index}</arg>
<doc>Return node IP address of given index.</doc>
<status status="PASS" start="2026-06-06T03:32:35.160353" elapsed="0.000834"/>
</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-06-06T03:32:35.161336" elapsed="0.000426"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.162033" level="INFO">index=4
host=10.30.170.38
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-06-06T03:32:35.162133" level="INFO">${karaf_connection_object} = index=4
host=10.30.170.38
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-06-06T03:32:35.161927" elapsed="0.000233"/>
</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-06-06T03:32:35.162301" elapsed="0.002222"/>
</kw>
<kw name="Login" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.164956" level="INFO">Logging into '10.30.170.38:8101' as 'karaf'.</msg>
<msg time="2026-06-06T03:32:35.327909" level="INFO">Read output: [33m                                                                                           
[33m    ________                       ________                .__  .__       .__     __       
[33m    \_____  \ ______   ____   ____ \______ \ _____  ___.__.|  | |__| ____ |  |___/  |_     
[33m     /   |   \\____ \_/ __ \ /    \ |    |  \\__  \&lt;   |  ||  | |  |/ ___\|  |  \   __\    
[33m    /    |    \  |_&gt; &gt;  ___/|   |  \|    `   \/ __ \\___  ||  |_|  / /_/  &gt;   Y  \  |      
[33m    \_______  /   __/ \___  &gt;___|  /_______  (____  / ____||____/__\___  /|___|  /__|      
[33m            \/|__|        \/     \/        \/     \/\/            /_____/      \/          
[33m                                                                                           

Hit '[1m&lt;tab&gt;[0m' for a list of available commands
and '[1m[cmd] --help[0m' for help on a specific command.
Hit '[1m&lt;ctrl-d&gt;[0m' or type '[1msystem:shutdown[0m' or '[1mlogout[0m' to shutdown OpenDaylight.

[?1h=[90m~[0m                                                                                [?2004hopendaylight-user</msg>
<arg>${KARAF_USER}</arg>
<arg>${KARAF_PASSWORD}</arg>
<arg>loglevel=${loglevel}</arg>
<doc>Logs into the SSH server with the given ``username`` and ``password``.</doc>
<status status="PASS" start="2026-06-06T03:32:35.164695" elapsed="0.163474"/>
</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-06-06T03:32:35.334073" elapsed="0.000589"/>
</kw>
<kw name="Open Connection" owner="SSHLibrary">
<arg>127.0.0.1</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:32:35.335091" elapsed="0.000243"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:32:35.335549" elapsed="0.000170"/>
</kw>
<arg>${current_ssh_connection_object.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:35.330203" elapsed="0.005595"/>
</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-06-06T03:32:35.329051" elapsed="0.006817"/>
</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-06-06T03:32:35.156871" elapsed="0.179075"/>
</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-06-06T03:32:35.144092" elapsed="0.191926"/>
</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-06-06T03:32:35.143727" elapsed="0.192372"/>
</kw>
<var name="${index}">1</var>
<status status="PASS" start="2026-06-06T03:32:35.143578" elapsed="0.192584"/>
</iter>
<var>${index}</var>
<value>@{ClusterManagement__member_index_list}</value>
<status status="PASS" start="2026-06-06T03:32:35.143426" elapsed="0.192790"/>
</for>
<doc>Initialize ClusterManagement. Open ssh karaf connections to each ODL.</doc>
<status status="PASS" start="2026-06-06T03:32:34.727583" elapsed="0.608720"/>
</kw>
<kw name="Create_Default_Session" owner="TemplatedRequests">
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:35.340938" level="INFO">Creating Session using : alias=default, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e5a04790&gt;, timeout=5, proxies=None, verify=False,                     debug=0 </msg>
<arg>default</arg>
<arg>url=${url}</arg>
<arg>auth=${auth}</arg>
<arg>timeout=${timeout}</arg>
<arg>max_retries=${max_retries}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:32:35.340526" elapsed="0.000551"/>
</kw>
<doc>Create "default" session to ${url} with authentication and connection parameters.
This Keyword is in this Resource only so that user do not need to call RequestsLibrary directly.</doc>
<status status="PASS" start="2026-06-06T03:32:35.340107" elapsed="0.001038"/>
</kw>
<kw name="Initialize_Artifact_Deployment_And_Usage" owner="NexusKeywords">
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.346266" level="INFO">${odl_connection} = 6</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-06-06T03:32:35.345889" elapsed="0.000403"/>
</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-06-06T03:32:35.347934" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:32:35.348012" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:32:35.347633" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:35.348188" elapsed="0.000344"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.349378" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:32:35.688696" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:31:49 UTC 2026

  System load:  0.13               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:32:35 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:32:35.349063" elapsed="0.339813"/>
</kw>
<msg time="2026-06-06T03:32:35.688966" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:35.348711" elapsed="0.340350"/>
</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-06-06T03:32:35.347203" elapsed="0.341981"/>
</kw>
<msg time="2026-06-06T03:32:35.689239" 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-06-06T03:32:35.346816" elapsed="0.342471"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:32:35.346468" elapsed="0.342896"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-06-06T03:32:35.689421" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:32:35.689665" level="INFO">${odl} = 6</msg>
<var>${odl}</var>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:32:35.345580" elapsed="0.344210"/>
</kw>
<kw name="Put File" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.701893" level="INFO">[chan 1] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:32:35.710064" level="INFO">'/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/../../tools/deployment/search.sh' -&gt; '/home/jenkins//search.sh'</msg>
<arg>/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/../../tools/deployment/search.sh</arg>
<doc>Uploads file(s) from the local machine to the remote machine.</doc>
<status status="PASS" start="2026-06-06T03:32:35.690020" elapsed="0.020204"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:32:35.710692" elapsed="0.000617"/>
</kw>
<if>
<branch type="IF" condition="not (${tools_system_connect})">
<return>
<status status="NOT RUN" start="2026-06-06T03:32:35.711870" elapsed="0.000041"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:35.711496" elapsed="0.000484"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:35.711440" elapsed="0.000597"/>
</if>
<kw name="Open_Connection_To_Tools_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.719847" level="INFO">${tools_connection} = 7</msg>
<var>${tools_connection}</var>
<arg>${ip_address}</arg>
<arg>prompt=${prompt}</arg>
<arg>timeout=${timeout}</arg>
<doc>Opens a new SSH connection to the given ``host`` and ``port``.</doc>
<status status="PASS" start="2026-06-06T03:32:35.719221" elapsed="0.000665"/>
</kw>
<kw name="Flexible_Mininet_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-06-06T03:32:35.722401" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:32:35.722516" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:32:35.721984" elapsed="0.000570"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:35.722805" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:32:35.724592" level="INFO">Logging into '10.30.171.194:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:32:36.432292" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-153-generic x86_64)

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

 System information as of Sat Jun  6 03:32:36 UTC 2026

  System load:  0.1                Processes:             105
  Usage of /:   19.7% of 38.58GB   Users logged in:       0
  Memory usage: 4%                 IPv4 address for ens3: 10.30.171.194
  Swap usage:   0%


Expanded Security Maintenance for Applications is not enabled.

0 updates can be applied immediately.

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


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


Last login: Sat Jun  6 03:31:00 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Logs into the SSH server using key-based authentication.</doc>
<status status="PASS" start="2026-06-06T03:32:35.724080" elapsed="0.708476"/>
</kw>
<msg time="2026-06-06T03:32:36.432731" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:35.723535" elapsed="0.709318"/>
</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-06-06T03:32:35.721323" elapsed="0.711680"/>
</kw>
<msg time="2026-06-06T03:32:36.433061" 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-06-06T03:32:35.720695" elapsed="0.712417"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Mininet machine.</doc>
<status status="PASS" start="2026-06-06T03:32:35.720165" elapsed="0.713036"/>
</kw>
<return>
<value>${tools_connection}</value>
<status status="PASS" start="2026-06-06T03:32:36.433269" elapsed="0.000057"/>
</return>
<doc>Open a connection to the tools system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:32:35.718671" elapsed="0.714821"/>
</kw>
<doc>Places search utility to ODL system, which will be needed for version detection.
By default also initialize a SSH connection to Tools system,
as following Keywords assume a working connection towards target system.</doc>
<status status="PASS" start="2026-06-06T03:32:35.341415" elapsed="1.092141"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:36.434098" level="INFO">index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:32:36.434221" level="INFO">${current_connection} = index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:32:36.433873" elapsed="0.000377"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.437450" level="INFO">${current_prompt} = &gt;</msg>
<var>${current_prompt}</var>
<arg>${current_connection.prompt}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:36.434408" elapsed="0.003073"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.437932" level="INFO">&gt;</msg>
<arg>${current_prompt}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:36.437662" elapsed="0.000317"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.442258" level="INFO">${prompt} = &gt;</msg>
<arg>${prompt}</arg>
<arg>${current_prompt}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:32:36.438148" elapsed="0.004159"/>
</kw>
<kw name="Create Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:32:36.442815" level="INFO">Creating Session using : alias=session, url=http://10.30.170.38:8181, headers={},                     cookies={}, auth=&lt;requests.auth.HTTPBasicAuth object at 0x7557e595b390&gt;, timeout=None, proxies=None, verify=False,                     debug=0 </msg>
<arg>${CONFIG_SESSION}</arg>
<arg>http://${ODL_SYSTEM_IP}:${RESTCONFPORT}</arg>
<arg>auth=${AUTH}</arg>
<doc>Create Session: create a HTTP session to a server</doc>
<status status="PASS" start="2026-06-06T03:32:36.442474" elapsed="0.000702"/>
</kw>
<kw name="Deploy_Test_Tool" owner="NexusKeywords">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.461791" level="INFO">${name_prefix} = pcep-pcc-mock-</msg>
<var>${name_prefix}</var>
<arg>${artifact}-</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:36.461217" elapsed="0.000613"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.462487" level="INFO">${extension} = jar</msg>
<var>${extension}</var>
<arg>'${component}'=='odl-micro'</arg>
<arg>tar</arg>
<arg>jar</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:36.462041" elapsed="0.000473"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.463216" level="INFO">${name_suffix} = -executable.jar</msg>
<var>${name_suffix}</var>
<arg>"${suffix}" != ""</arg>
<arg>-${suffix}.${extension}</arg>
<arg>.${extension}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:36.462806" elapsed="0.000436"/>
</kw>
<kw name="Deploy_Artifact" owner="NexusKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${explicit_url}""" != ""</arg>
<arg>Deploy_From_Url</arg>
<arg>${explicit_url}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.464704" elapsed="0.000328"/>
</kw>
<kw name="Fetch From Left" owner="String">
<msg time="2026-06-06T03:32:36.465424" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>${BUNDLE_URL}</arg>
<arg>/org/opendaylight</arg>
<doc>Returns contents of the ``string`` before the first occurrence of ``marker``.</doc>
<status status="PASS" start="2026-06-06T03:32:36.465196" elapsed="0.000255"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.466027" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>'${urlbase}' != '${BUNDLE_URL}'</arg>
<arg>${urlbase}</arg>
<arg>${fallback_url}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:36.465615" elapsed="0.000440"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Magnesium" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.485091" elapsed="0.000509"/>
</kw>
<arg>magnesium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'carpeople'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:32:36.484570" elapsed="0.001145"/>
</kw>
<msg time="2026-06-06T03:32:36.485777" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>magnesium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.475897" elapsed="0.009956"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>carpeople</arg>
<doc>Compare magnesium to vanadium and in case vanadium is at most magnesium,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:32:36.475363" elapsed="0.010573"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Aluminium" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.504811" elapsed="0.000540"/>
</kw>
<arg>aluminium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'netconf'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:32:36.504196" elapsed="0.001253"/>
</kw>
<msg time="2026-06-06T03:32:36.505510" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>aluminium</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.495311" elapsed="0.010274"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>netconf</arg>
<doc>Compare aluminium to vanadium and in case vanadium is at most aluminium,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:32:36.494937" elapsed="0.010751"/>
</kw>
<kw name="Run_Keyword_If_At_Most_Silicon" owner="CompareStream">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Run_Keyword_If_At_Most" owner="CompareStream">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${Stream_dict}[${ODL_STREAM}] &lt;= ${Stream_dict}[${upper_bound}]</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.524450" elapsed="0.000580"/>
</kw>
<arg>silicon</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Compare ${upper_bound} to vanadium and in case vanadium is at most ${upper_bound},
run Collections.Remove_Values_From_List [['mdsal', 'odlparent', 'yangtools', 'carpeople', 'netconf', 'bgpcep'], 'bgpcep'] {} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:32:36.523905" elapsed="0.001228"/>
</kw>
<msg time="2026-06-06T03:32:36.525199" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Run_Keyword_If_At_Most</arg>
<arg>silicon</arg>
<arg>${kw_name}</arg>
<arg>@{varargs}</arg>
<arg>&amp;{kwargs}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.515170" elapsed="0.010107"/>
</kw>
<arg>Collections.Remove_Values_From_List</arg>
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>bgpcep</arg>
<doc>Compare silicon to vanadium and in case vanadium is at most silicon,
run ${kw_name} @{varargs} &amp;{kwargs} and return its value.</doc>
<status status="PASS" start="2026-06-06T03:32:36.514721" elapsed="0.010637"/>
</kw>
<if>
<branch type="IF" condition="'${build_version}'=='${EMPTY}'">
<kw name="NexusKeywords__Detect_Version_To_Pull" owner="NexusKeywords">
<kw name="NexusKeywords__Get_Items_To_Look_At" owner="NexusKeywords">
<kw name="Dictionary Should Contain Key" owner="Collections">
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<arg>Component not supported by NexusKeywords version detection: ${component}</arg>
<doc>Fails if ``key`` is not found from ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:32:36.528475" elapsed="0.000341"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Get From Dictionary" owner="Collections">
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<doc>Returns a value from the given ``dictionary`` based on the given ``key``.</doc>
<status status="PASS" start="2026-06-06T03:32:36.529493" elapsed="0.000204"/>
</kw>
<msg time="2026-06-06T03:32:36.529750" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Collections.Get_From_Dictionary</arg>
<arg>${COMPONENT_MAPPING}</arg>
<arg>${component}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.529134" elapsed="0.000670"/>
</kw>
<msg time="2026-06-06T03:32:36.529919" level="INFO">${itemlist} = pcep-impl</msg>
<var>${itemlist}</var>
<arg>${component}</arg>
<doc>Get a list of items that might contain the version number that we are looking for.</doc>
<status status="PASS" start="2026-06-06T03:32:36.528203" elapsed="0.001741"/>
</kw>
<kw name="Get Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:36.530273" level="INFO">index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<msg time="2026-06-06T03:32:36.530376" level="INFO">${current_ssh_connection} = index=7
host=10.30.171.194
alias=None
port=22
timeout=10 seconds
newline=

prompt=&gt;
term_type=vt100
width=80
height=24
path_separator=/
encoding=UTF-8
escape_ansi=False
encoding_errors=strict</msg>
<var>${current_ssh_connection}</var>
<doc>Returns information about the connection.</doc>
<status status="PASS" start="2026-06-06T03:32:36.530104" elapsed="0.000302"/>
</kw>
<kw name="Open_Connection_To_ODL_System" owner="SSHKeywords">
<kw name="Open Connection" owner="SSHLibrary">
<msg time="2026-06-06T03:32:36.535254" level="INFO">${odl_connection} = 8</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-06-06T03:32:36.534830" elapsed="0.000451"/>
</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-06-06T03:32:36.537136" level="INFO">Length is 0.</msg>
<msg time="2026-06-06T03:32:36.537218" level="INFO">${pwd_length} = 0</msg>
<var>${pwd_length}</var>
<arg>${password}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:32:36.536680" elapsed="0.000563"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>${pwd_length} &gt; 0</arg>
<arg>SSHLibrary.Login</arg>
<arg>${user}</arg>
<arg>${password}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.537399" elapsed="0.000372"/>
</kw>
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Login With Public Key" owner="SSHLibrary">
<msg time="2026-06-06T03:32:36.539527" level="INFO">Logging into '10.30.170.38:22' as 'jenkins'.</msg>
<msg time="2026-06-06T03:32:36.870788" level="INFO">Read output: Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 5.15.0-173-generic x86_64)

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

 System information as of Sat Jun  6 03:31:49 UTC 2026

  System load:  0.13               Processes:             123
  Usage of /:   11.3% of 77.35GB   Users logged in:       0
  Memory usage: 10%                IPv4 address for ens3: 10.30.170.38
  Swap usage:   0%                 IPv6 address for ens3: 2607:f0d0:1002:11::2


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 Jun  6 03:32:35 2026 from 10.30.170.78
[?2004h[jenkins@releng-26932-288-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-06-06T03:32:36.538295" elapsed="0.332737"/>
</kw>
<msg time="2026-06-06T03:32:36.871151" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>SSHLibrary.Login With Public Key</arg>
<arg>${user}</arg>
<arg>${USER_HOME}/.ssh/${SSH_KEY}</arg>
<arg>${KEYFILE_PASS}</arg>
<arg>delay=${delay}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.537937" elapsed="0.333334"/>
</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-06-06T03:32:36.536215" elapsed="0.335210"/>
</kw>
<msg time="2026-06-06T03:32:36.871486" 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-06-06T03:32:36.535818" elapsed="0.335719"/>
</kw>
<doc>Call Flexible SSH Login, but with default values suitable for Controller machine.</doc>
<status status="PASS" start="2026-06-06T03:32:36.535463" elapsed="0.336158"/>
</kw>
<return>
<value>${odl_connection}</value>
<status status="PASS" start="2026-06-06T03:32:36.871707" elapsed="0.000060"/>
</return>
<doc>Open a connection to the ODL system at ${ip_address} and return its identifier.</doc>
<status status="PASS" start="2026-06-06T03:32:36.534514" elapsed="0.337421"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:36.872610" level="INFO">Executing command 'sh search.sh /tmp/karaf-0.24.0/system pcep-impl'.</msg>
<msg time="2026-06-06T03:32:36.915875" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:36.916188" level="INFO">${version} = 2.0.0
org/opendaylight/bgpcep</msg>
<msg time="2026-06-06T03:32:36.916299" level="INFO">${result} = 0</msg>
<var>${version}</var>
<var>${result}</var>
<arg>sh search.sh ${WORKSPACE}/${BUNDLEFOLDER}/system ${itemlist}</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:36.872228" elapsed="0.044129"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="PASS" start="2026-06-06T03:32:36.916886" elapsed="0.000615"/>
</kw>
<kw name="Restore_Current_Ssh_Connection_From_Index" owner="SSHKeywords">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Switch Connection" owner="SSHLibrary">
<arg>${connection_index}</arg>
<doc>Switches the active connection by index or alias.</doc>
<status status="PASS" start="2026-06-06T03:32:36.925488" elapsed="0.000151"/>
</kw>
<msg time="2026-06-06T03:32:36.925699" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>${connection_index} is not None</arg>
<arg>SSHLibrary.Switch Connection</arg>
<arg>${connection_index}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:36.924236" elapsed="0.001527"/>
</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="NOT RUN" start="2026-06-06T03:32:36.925925" elapsed="0.000022"/>
</kw>
<kw name="Close Connection" owner="SSHLibrary">
<doc>Closes the current connection.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:36.926081" elapsed="0.000135"/>
</kw>
<arg>${current_ssh_connection.index}</arg>
<doc>Restore active SSH connection in SSHLibrary to given index.</doc>
<status status="PASS" start="2026-06-06T03:32:36.918175" elapsed="0.008111"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.926719" level="INFO">2.0.0
org/opendaylight/bgpcep</msg>
<arg>${version}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:36.926435" elapsed="0.000330"/>
</kw>
<if>
<branch type="IF" condition="${result}!=0">
<kw name="Fail" owner="BuiltIn">
<arg>Component "${component}": searching for "${itemlist}" found no version, cannot locate test tool.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:36.927111" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:36.926874" elapsed="0.000291"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:36.926836" elapsed="0.000360"/>
</if>
<kw name="Split String" owner="String">
<msg time="2026-06-06T03:32:36.927610" level="INFO">${version} = 2.0.0</msg>
<msg time="2026-06-06T03:32:36.927953" level="INFO">${location} = org/opendaylight/bgpcep</msg>
<var>${version}</var>
<var>${location}</var>
<arg>${version}</arg>
<arg>max_split=1</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="PASS" start="2026-06-06T03:32:36.927347" elapsed="0.000640"/>
</kw>
<return>
<value>${version}</value>
<value>${location}</value>
<status status="PASS" start="2026-06-06T03:32:36.928064" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:32:36.928277" level="INFO">${version} = 2.0.0</msg>
<msg time="2026-06-06T03:32:36.928321" level="INFO">${location} = org/opendaylight/bgpcep</msg>
<var>${version}</var>
<var>${location}</var>
<arg>${component}</arg>
<doc>Determine the exact Nexus directory to be used as a source for a particular test tool
Figure out what version of the tool needs to be pulled out of the
Nexus by looking at the version directory of the subsystem from
which the tool is being pulled. This code is REALLY UGLY but there
is no way around it until the bug
https://bugs.opendaylight.org/show_bug.cgi?id=5206 gets fixed.
I also don't want to depend on maven-metadata-local.xml and other
bits and pieces of ODL distribution which are not required for ODL
to function properly.</doc>
<status status="PASS" start="2026-06-06T03:32:36.527826" elapsed="0.400519"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:36.525475" elapsed="0.402914"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${version}</var>
<var>${location}</var>
<arg>${build_version}</arg>
<arg>${build_location}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:36.928584" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:36.928421" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:36.525437" elapsed="0.403266"/>
</if>
<if>
<branch type="IF" condition="'SNAPSHOT' in '${version}'">
<kw name="Remove Values From List" owner="Collections">
<arg>${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>netconf</arg>
<arg>bgpcep</arg>
<doc>Removes all occurrences of given ``values`` from ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:36.929032" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:36.928777" elapsed="0.000318"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:36.928753" elapsed="0.000366"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.929930" level="INFO">${is_staged} = "TRUE"</msg>
<var>${is_staged}</var>
<arg>"opendaylight.release" not in '${urlbase}' and "opendaylight.snapshot" not in '${urlbase}'</arg>
<arg>"TRUE"</arg>
<arg>"FALSE"</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:36.929265" elapsed="0.000699"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.930744" level="INFO">${is_mri_component} = "TRUE"</msg>
<var>${is_mri_component}</var>
<arg>'${component}' in ${RELEASE_INTEGRATED_COMPONENTS}</arg>
<arg>"TRUE"</arg>
<arg>"FALSE"</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:36.930183" elapsed="0.000592"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.931477" level="INFO">${urlbase} = https://nexus.opendaylight.org/content/repositories//autorelease-9869</msg>
<var>${urlbase}</var>
<arg>${is_mri_component} == "TRUE" and ${is_staged} == "FALSE"</arg>
<arg>${NEXUS_RELEASE_BASE_URL}</arg>
<arg>${urlbase}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:36.930974" elapsed="0.000534"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:36.932171" level="INFO">${url} = https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0</msg>
<var>${url}</var>
<arg>${urlbase}/${location}/${artifact}/${version}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:36.931718" elapsed="0.000487"/>
</kw>
<kw name="Execute_Command_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:36.934628" level="INFO">Executing command 'curl -L https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml'.</msg>
<msg time="2026-06-06T03:32:37.050050" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:37.050592" level="INFO">${stdout} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autore...</msg>
<msg time="2026-06-06T03:32:37.050819" level="INFO">${stderr} =   % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0   ...</msg>
<msg time="2026-06-06T03:32:37.050935" 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-06-06T03:32:36.934384" elapsed="0.116615"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.054569" level="INFO">Length is 316.</msg>
<msg time="2026-06-06T03:32:37.054825" level="FAIL">'  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1098    0  1098    0     0  11897      0 --:--:-- --:--:-- --:--:-- 11934' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.053884" elapsed="0.001117">'  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1098    0  1098    0     0  11897      0 --:--:-- --:--:-- --:--:-- 11934' should be empty.</status>
</kw>
<msg time="2026-06-06T03:32:37.055242" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:32:37.055342" level="INFO">${result} = '  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0  ...</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-06-06T03:32:37.051808" elapsed="0.003752"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.057015" 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-06-06T03:32:37.055965" elapsed="0.001109"/>
</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-06-06T03:32:37.059590" level="INFO">&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8"/&gt;

    &lt;link rel="icon" type="image/png" href="https://nexus.opendaylight.org/favicon.png"&gt;
    &lt;!--[if IE]&gt;
    &lt;link rel="SHORTCUT ICON" href="https://nexus.opendaylight.org/favicon.ico"/&gt;
    &lt;![endif]--&gt;

    &lt;link rel="stylesheet" href="https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02" type="text/css" media="screen" title="no title" charset="utf-8"&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/h1&gt;
    &lt;p&gt;Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/p&gt;
  &lt;/body&gt;
&lt;/html&gt;</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.059022" elapsed="0.000732"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.060639" level="INFO">  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0100  1098    0  1098    0     0  11897      0 --:--:-- --:--:-- --:--:-- 11934</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.060104" elapsed="0.000720"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.061527" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.061148" elapsed="0.000422"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:32:37.058166" elapsed="0.003464"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:37.057284" elapsed="0.004401"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.057223" elapsed="0.004497"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.061893" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:37.061781" elapsed="0.000165"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.061763" elapsed="0.000205"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="PASS" start="2026-06-06T03:32:37.062110" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:32:37.062020" elapsed="0.000157"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.062004" elapsed="0.000197"/>
</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-06-06T03:32:37.062340" elapsed="0.000022"/>
</kw>
<arg>${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-06-06T03:32:36.933726" elapsed="0.128739"/>
</kw>
<msg time="2026-06-06T03:32:37.062528" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${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-06-06T03:32:36.932987" elapsed="0.129590"/>
</kw>
<msg time="2026-06-06T03:32:37.062751" level="INFO">${metadata} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autore...</msg>
<var>${metadata}</var>
<arg>curl -L ${url}/maven-metadata.xml</arg>
<doc>A wrapper for Execute_Command_Passes with return_success_only=False
Also, log_on_success defaults to True (but is customizable, unlike return_success_only)..</doc>
<status status="PASS" start="2026-06-06T03:32:36.932472" elapsed="0.130308"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Execute_Command_Should_Pass" owner="SSHKeywords">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Execute_Command_Passes" owner="SSHKeywords">
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:37.065096" level="INFO">Executing command 'echo "&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8"/&gt;

    &lt;link rel="icon" type="image/png" href="https://nexus.opendaylight.org/favicon.png"&gt;
    &lt;!--[if IE]&gt;
    &lt;link rel="SHORTCUT ICON" href="https://nexus.opendaylight.org/favicon.ico"/&gt;
    &lt;![endif]--&gt;

    &lt;link rel="stylesheet" href="https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02" type="text/css" media="screen" title="no title" charset="utf-8"&gt;
  &lt;/head&gt;
  &lt;body&gt;
    &lt;h1&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/h1&gt;
    &lt;p&gt;Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/p&gt;
  &lt;/body&gt;
&lt;/html&gt;" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1'.</msg>
<msg time="2026-06-06T03:32:37.099610" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:37.099978" level="INFO">${stdout} = &lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autore...</msg>
<msg time="2026-06-06T03:32:37.100223" level="INFO">${stderr} = bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text...</msg>
<msg time="2026-06-06T03:32:37.100327" 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-06-06T03:32:37.064897" elapsed="0.035484"/>
</kw>
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Should Be Empty" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.102421" level="INFO">Length is 253.</msg>
<msg time="2026-06-06T03:32:37.102626" level="FAIL">'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory' should be empty.</msg>
<arg>${stderr}</arg>
<doc>Verifies that the given item is empty.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.101780" elapsed="0.001049">'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory' should be empty.</status>
</kw>
<msg time="2026-06-06T03:32:37.103069" level="INFO">${emptiness_status} = FAIL</msg>
<msg time="2026-06-06T03:32:37.103168" level="INFO">${result} = 'bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=tex...</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-06-06T03:32:37.100922" elapsed="0.002304"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.104605" level="INFO">${success} = False</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-06-06T03:32:37.103590" elapsed="0.001158"/>
</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-06-06T03:32:37.106565" level="INFO">&lt;html&gt;
  &lt;head&gt;
    &lt;title&gt;404 - Path /org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/maven-metadata.xml not found in local storage of repository &amp;quot;autorelease-9869 (staging: closed)&amp;quot; [id=autorelease-9869]&lt;/title&gt;
    &lt;meta http-equiv=Content-Type content=text/html</msg>
<arg>${stdout}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.106212" elapsed="0.000425"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.107386" level="INFO">bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</msg>
<arg>${stderr}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.107049" elapsed="0.000406"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.108017" level="INFO">0</msg>
<arg>${rc}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.107677" elapsed="0.000400"/>
</kw>
<arg>${stdout}</arg>
<arg>${stderr}</arg>
<arg>${rc}</arg>
<doc>Log everything returned by SSHLibrary.Execute_Command</doc>
<status status="PASS" start="2026-06-06T03:32:37.105682" elapsed="0.002474"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:37.104955" elapsed="0.003252"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.104898" elapsed="0.003348"/>
</if>
<if>
<branch type="IF" condition="${return_success_only}">
<return>
<value>${success}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.108479" elapsed="0.000024"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:37.108328" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.108303" elapsed="0.000276"/>
</if>
<if>
<branch type="IF" condition="${success}">
<return>
<value>${stdout}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.108829" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:37.108676" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.108631" elapsed="0.000292"/>
</if>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.109620" level="FAIL">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</msg>
<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="FAIL" start="2026-06-06T03:32:37.109117" elapsed="0.000624">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<arg>${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="FAIL" start="2026-06-06T03:32:37.064307" elapsed="0.045609">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<msg time="2026-06-06T03:32:37.110003" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Execute_Command_Passes</arg>
<arg>${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="FAIL" start="2026-06-06T03:32:37.063766" elapsed="0.046310"/>
</kw>
<arg>echo "${metadata}" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1</arg>
<arg>stderr_must_be_empty=${True}</arg>
<doc>A wrapper for Execute_Command_Passes with return_success_only=False
Also, log_on_success defaults to True (but is customizable, unlike return_success_only)..</doc>
<status status="FAIL" start="2026-06-06T03:32:37.063332" elapsed="0.047246">Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonatype-content.css?2.14.20-02 type=text/css media=screen title=no: No such file or directory</status>
</kw>
<msg time="2026-06-06T03:32:37.110831" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:32:37.110899" level="INFO">${namepart} = Got rc: 0 or stderr was not empty: bash: line 8: ICON href=https://nexus.opendaylight.org/favicon.ico/&gt;
    &lt;![endif]--&gt;

    &lt;link rel=stylesheet href=https://nexus.opendaylight.org/static/css/Sonaty...</msg>
<var>${status}</var>
<var>${namepart}</var>
<arg>SSHKeywords.Execute_Command_Should_Pass</arg>
<arg>echo "${metadata}" | grep value | head -n 1 | cut -d '&gt;' -f 2 | cut -d '&lt;' -f 1</arg>
<arg>stderr_must_be_empty=${True}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:32:37.062940" elapsed="0.047998"/>
</kw>
<kw name="Get Length" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.111567" level="INFO">Length is 288.</msg>
<msg time="2026-06-06T03:32:37.111699" level="INFO">${length} = 288</msg>
<var>${length}</var>
<arg>${namepart}</arg>
<doc>Returns and logs the length of the given item as an integer.</doc>
<status status="PASS" start="2026-06-06T03:32:37.111173" elapsed="0.000563"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.112551" level="INFO">${namepart} = 2.0.0</msg>
<var>${namepart}</var>
<arg>"${status}" != "PASS" or ${length} == 0</arg>
<arg>${version}</arg>
<arg>${namepart}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:37.111964" elapsed="0.000625"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.113400" level="INFO">${filename} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${filename}</var>
<arg>${name_prefix}${namepart}${name_suffix}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:37.112898" elapsed="0.000542"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.113859" level="INFO">pcep-pcc-mock-2.0.0-executable.jar</msg>
<arg>${filename}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.113593" elapsed="0.000311"/>
</kw>
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.114369" level="INFO">${url} = https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${url}</var>
<arg>${url}/${filename}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:37.114052" elapsed="0.000344"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:37.114765" level="INFO">Executing command 'wget -q -N 'https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar' 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:32:37.171282" level="INFO">Command exited with return code 8.</msg>
<msg time="2026-06-06T03:32:37.171590" level="INFO">${response} = </msg>
<msg time="2026-06-06T03:32:37.171736" level="INFO">${result} = 8</msg>
<var>${response}</var>
<var>${result}</var>
<arg>wget -q -N '${url}' 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:37.114559" elapsed="0.057237"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.172947" level="INFO"/>
<arg>${response}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.172228" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${result} == 0">
<return>
<value>${filename}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.173600" elapsed="0.000067"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:37.173228" elapsed="0.000519"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.173171" elapsed="0.000632"/>
</if>
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:32:37.174686" level="INFO">${release_url} = https://nexus.opendaylight.org/content/repositories//opendaylight.release/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${release_url}</var>
<arg>${url}</arg>
<arg>autorelease-[0-9]{4}</arg>
<arg>opendaylight.release</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:32:37.174131" elapsed="0.000620"/>
</kw>
<kw name="Execute Command" owner="SSHLibrary">
<msg time="2026-06-06T03:32:37.175505" level="INFO">Executing command 'wget -q -N 'https://nexus.opendaylight.org/content/repositories//opendaylight.release/org/opendaylight/bgpcep/pcep-pcc-mock/2.0.0/pcep-pcc-mock-2.0.0-executable.jar' 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:32:37.248149" level="INFO">Command exited with return code 0.</msg>
<msg time="2026-06-06T03:32:37.248406" level="INFO">${response} = </msg>
<msg time="2026-06-06T03:32:37.248506" level="INFO">${result} = 0</msg>
<var>${response}</var>
<var>${result}</var>
<arg>wget -q -N '${release_url}' 2&gt;&amp;1</arg>
<arg>return_rc=True</arg>
<doc>Executes ``command`` on the remote machine and returns its outputs.</doc>
<status status="PASS" start="2026-06-06T03:32:37.175111" elapsed="0.073446"/>
</kw>
<if>
<branch type="IF" condition="${result} != 0">
<kw name="Fail" owner="BuiltIn">
<arg>Artifact "${artifact}" in component "${component}" could not be downloaded from ${release_url} nor ${url}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.249302" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.248810" elapsed="0.000617"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.248757" elapsed="0.000725"/>
</if>
<return>
<value>${filename}</value>
<status status="PASS" start="2026-06-06T03:32:37.249557" elapsed="0.000081"/>
</return>
<msg time="2026-06-06T03:32:37.249981" level="INFO">${filename} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${filename}</var>
<arg>${component}</arg>
<arg>${artifact}</arg>
<arg>${name_prefix}</arg>
<arg>${name_suffix}</arg>
<arg>${fallback_url}</arg>
<arg>${explicit_url}</arg>
<arg>${build_version}</arg>
<arg>${build_location}</arg>
<doc>Deploy the specified artifact from Nexus to the cwd of the machine to which the active SSHLibrary connection points.
bgpcep is a name part of an artifact present in system/ of ODl installation with the same version as pcep-pcc-mock should have.
Must have https://nexus.opendaylight.org/content/repositories//autorelease-9869/org/opendaylight/integration/karaf/0.24.0/karaf-0.24.0.zip variable set to the URL from which the
tested ODL distribution was downloaded and this place must be
inside a repository created by a standard distribution
construction job. If this is detected to ne be the case, fallback URL is used.
If  is non-empty, Deploy_From_Utrl is called instead.
TODO: Allow deploying to a specific directory, we have SSHKeywords.Execute_Command_At_Cwd_Should_Pass now.</doc>
<status status="PASS" start="2026-06-06T03:32:36.464004" elapsed="0.786033"/>
</kw>
<return>
<value>${filename}</value>
<status status="PASS" start="2026-06-06T03:32:37.250197" elapsed="0.000060"/>
</return>
<msg time="2026-06-06T03:32:37.250537" level="INFO">${name} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<var>${name}</var>
<arg>bgpcep</arg>
<arg>pcep-pcc-mock</arg>
<doc>Deploy a test tool.
The test tools have naming convention of the form
"&lt;repository_url&gt;/some/dir/somewhere/&lt;tool-name&gt;/&lt;tool-name&gt;-&lt;version-tag&gt;-${suffix}.jar"
where "&lt;tool-name&gt;" is the name of the tool and "&lt;version-tag&gt;" is
the version tag that is digged out of the maven metadata. This
keyword calculates ${name_prefix} and ${name_suffix} for
"Deploy_Artifact" and then calls "Deploy_Artifact" to do the real
work of deploying the artifact.</doc>
<status status="PASS" start="2026-06-06T03:32:36.455091" elapsed="0.795503"/>
</kw>
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.258940" level="INFO">${filename} = pcep-pcc-mock-2.0.0-executable.jar</msg>
<arg>${filename}</arg>
<arg>${name}</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:32:37.251154" elapsed="0.007833"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.263772" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:32:37.259506" elapsed="0.004312"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:32:37.259240" elapsed="0.004638"/>
</kw>
<doc>Create SSH session to Mininet machine, prepare HTTP client session to Controller.
Figure out latest pcc-mock version and download it from Nexus to Mininet.
Also, delete and create directories for json diff handling.</doc>
<status status="PASS" start="2026-06-06T03:32:34.727135" elapsed="2.536795"/>
</kw>
<test id="s1-s21-t1" name="Topology_Precondition" line="49">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.265481" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.265267" elapsed="0.000273"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.265249" elapsed="0.000316"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:32:37.265075" elapsed="0.000536"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.306192" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:37.305776" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:37.307145" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.306772" elapsed="0.000473">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:37.307344" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:37.306416" elapsed="0.000953"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.307953" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:37.307540" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:37.308288" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:37.308521" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:37.308136" elapsed="0.000411"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.308987" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.308733" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.310096" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.309840" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.310586" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:37.310297" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.310996" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.311204" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.311377" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:37.310864" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.310702" elapsed="0.000766"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:37.311519" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:32:37.311795" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:37.309485" elapsed="0.002336"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:37.309132" elapsed="0.002722"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.312025" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.311882" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.309099" elapsed="0.003094"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.312873" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:37.312338" elapsed="0.000563"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:37.312951" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:37.305139" elapsed="0.007938"/>
</kw>
<msg time="2026-06-06T03:32:37.313136" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:37.304013" elapsed="0.009179"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.313731" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.314232" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.314769" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.314954" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.315125" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.315504" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.315354" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:37.315338" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.315995" elapsed="0.000030"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.316213" elapsed="0.000025"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.316417" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:37.315307" elapsed="0.001179"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.315201" elapsed="0.001321"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.316756" elapsed="0.000034"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.316861" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:32:37.317032" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:37.299376" elapsed="0.017693"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:37.322527" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.322152" elapsed="0.000471">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:37.322752" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:37.318017" elapsed="0.004761"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.323122" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.322860" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.323717" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:37.323397" elapsed="0.000347"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:37.323206" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.322837" elapsed="0.000964"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.326274" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:37.323950" elapsed="0.002352"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:37.326357" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:32:37.326525" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:37.317559" elapsed="0.008992"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:37.327833" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.327569" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:37.327992" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:37.327226" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:37.328227" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:37.328089" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:37.328070" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.328452" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.328620" elapsed="0.000036"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.328705" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:32:37.330682" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:37.326891" elapsed="0.003819"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.332137" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.331875" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:37.332582" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:37.332332" elapsed="0.000294"/>
</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-06-06T03:32:37.343525" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:37.343739" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Set-Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:32:37 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:37.343938" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:37.334829" elapsed="0.009557">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:37.332712" elapsed="0.011770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:37.344697" elapsed="0.000060"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.344519" elapsed="0.000286"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:37.332692" elapsed="0.012139">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:37.345237" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.345374" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:37.345336" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:37.345318" elapsed="0.000122"/>
</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-06-06T03:32:37.345584" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.345678" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:37.331030" elapsed="0.014759">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.345864" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.276382" elapsed="0.069577">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:37.346233" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:37.346053" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:37.346036" elapsed="0.000295"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:37.346364" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.270262" elapsed="0.076198">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.395531" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:38.394977" elapsed="0.000597"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:38.396476" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:38.396139" elapsed="0.000443">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:38.396731" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:38.395786" elapsed="0.000974"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.397394" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:38.396975" elapsed="0.000448"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:38.397985" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:38.398208" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:38.397790" elapsed="0.000446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.398682" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:38.398403" elapsed="0.000353"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.399889" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:38.399585" elapsed="0.000352"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.400389" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:38.400099" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.400824" elapsed="0.000026"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.401054" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.401256" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:38.400674" elapsed="0.000643"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.400487" elapsed="0.000864"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:38.401409" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:32:38.401601" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:38.399242" elapsed="0.002385"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:38.398864" elapsed="0.002823"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.401871" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:38.401717" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:38.398827" elapsed="0.003123"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.402576" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:38.402095" elapsed="0.000510"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:38.402675" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:38.394128" elapsed="0.008688"/>
</kw>
<msg time="2026-06-06T03:32:38.402877" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:38.392872" elapsed="0.010061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.403451" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.403984" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.404488" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.404942" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.405123" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.405812" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:38.405633" elapsed="0.000246"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:38.405615" elapsed="0.000289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.406075" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.406254" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.406415" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:38.405584" elapsed="0.000884"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.405203" elapsed="0.001292"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.406636" elapsed="0.000039"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.406733" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:38.406879" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:38.388138" elapsed="0.018775"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:38.408264" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:38.407972" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:38.408445" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:38.407582" elapsed="0.000887"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.408812" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:38.408545" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.409418" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:38.409117" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:38.408920" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:38.408526" elapsed="0.000976"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.412105" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:38.409671" elapsed="0.002462"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:38.412186" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:38.412345" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:38.407247" elapsed="0.005123"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:38.413674" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:38.413409" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:38.413910" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:38.413066" elapsed="0.000872"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:38.414175" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:38.414029" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:38.414007" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.414409" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.414582" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.414666" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:38.416679" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:38.412693" elapsed="0.004015"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.418204" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:38.417924" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:38.418662" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:38.418402" elapsed="0.000305"/>
</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-06-06T03:32:38.426403" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:38.426605" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:38.426761" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:38.421102" elapsed="0.006138">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:38.418776" elapsed="0.008563">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:38.427546" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:38.427377" elapsed="0.000237"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:38.418757" elapsed="0.008898">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:38.428090" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.428242" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:38.428199" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:38.428175" elapsed="0.000134"/>
</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-06-06T03:32:38.428459" elapsed="0.000025"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.428534" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:38.417069" elapsed="0.011593">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.428741" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:38.364548" elapsed="0.064294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:38.429243" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:38.429046" elapsed="0.000274"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:38.429026" elapsed="0.000319"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:38.429379" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:38.357811" elapsed="0.071673">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.475210" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:39.474811" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:39.476033" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:39.475764" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:39.476210" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:39.475418" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.476793" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:39.476393" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:39.477142" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:39.477314" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:39.476974" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.477770" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:39.477493" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.479021" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:39.478757" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.479501" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:39.479225" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.479882" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.480084" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.480255" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:39.479752" elapsed="0.000561"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.479588" elapsed="0.000755"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:39.480392" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:39.480560" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:39.478418" elapsed="0.002167"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:39.477898" elapsed="0.002720"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.480805" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:39.480660" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:39.477872" elapsed="0.003009"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.481478" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:39.481019" elapsed="0.000486"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:39.481614" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:39.474190" elapsed="0.007571"/>
</kw>
<msg time="2026-06-06T03:32:39.481817" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:39.473295" elapsed="0.008570"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.482358" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.482876" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.483372" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.483554" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.483741" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.484096" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:39.483957" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:39.483942" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.484311" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.484473" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.484633" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:39.483915" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.483816" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.484869" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.484943" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:39.485059" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:39.469015" elapsed="0.016097"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:39.486387" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:39.486150" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:39.486544" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:39.485815" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.486897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:39.486653" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.487439" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:39.487149" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:39.486978" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:39.486620" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.490068" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:39.487679" elapsed="0.002416"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:39.490147" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:39.490300" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:39.485468" elapsed="0.004857"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:39.491518" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:39.491287" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:39.491689" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:39.490958" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:39.491923" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:39.491787" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:39.491769" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.492148" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.492313" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.492378" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:39.494331" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:39.490623" elapsed="0.003734"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.495747" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:39.495478" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:39.496180" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:39.495941" 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-06-06T03:32:39.503220" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:39.503360" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:39.503453" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:39.498374" elapsed="0.005506">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:39.496289" elapsed="0.007712">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:39.504186" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:39.504037" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:39.496271" elapsed="0.008005">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:39.504654" elapsed="0.000031"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.504797" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:39.504759" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:39.504741" elapsed="0.000121"/>
</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-06-06T03:32:39.505000" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.505104" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:39.494675" elapsed="0.010536">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.505286" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:39.446524" elapsed="0.058857">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:39.505662" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:39.505473" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:39.505456" elapsed="0.000305"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:39.505794" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:39.438765" elapsed="0.067123">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.551041" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:40.550623" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:40.551865" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:40.551578" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:40.552040" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:40.551246" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.552613" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:40.552222" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:40.552964" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:40.553145" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:40.552819" elapsed="0.000445"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.553708" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:40.553436" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.554736" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:40.554458" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.555211" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:40.554938" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.555568" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.555784" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.555954" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:40.555438" elapsed="0.000574"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.555294" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:40.556090" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:40.556258" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:40.554133" elapsed="0.002151"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:40.553836" elapsed="0.002481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.556485" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:40.556343" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:40.553812" elapsed="0.002750"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.557164" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:40.556716" elapsed="0.000477"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:40.557255" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:40.550007" elapsed="0.007375"/>
</kw>
<msg time="2026-06-06T03:32:40.557437" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:40.549068" elapsed="0.008418"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.557996" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.558498" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.559212" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.559433" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.559604" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.559985" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:40.559843" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:40.559828" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.560209" elapsed="0.000037"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.560425" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.560591" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:40.559799" elapsed="0.000864"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.559696" elapsed="0.000999"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.560840" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.560916" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:40.561034" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:40.544787" elapsed="0.016274"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:40.562321" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:40.562082" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:40.562479" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:40.561746" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.562834" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:40.562575" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.563381" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:40.563088" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:40.562917" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:40.562556" elapsed="0.000907"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.565842" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:40.563609" elapsed="0.002260"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:40.565922" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:40.566076" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:40.561409" elapsed="0.004692"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:40.567316" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:40.567071" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:40.567473" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:40.566738" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:40.567974" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:32:40.567570" elapsed="0.000491"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:40.567549" elapsed="0.000547"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.568346" elapsed="0.000026"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.568524" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.568592" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:40.570558" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:40.566396" elapsed="0.004189"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.572006" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:40.571743" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:40.572440" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:40.572199" elapsed="0.000285"/>
</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-06-06T03:32:40.579752" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:40.579890" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:40.579988" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:40.574935" elapsed="0.005425">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:40.572551" elapsed="0.007891">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:40.580624" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:40.580475" elapsed="0.000234"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:40.572532" elapsed="0.008201">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:40.581097" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.581230" elapsed="0.000037"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:40.581192" elapsed="0.000105"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:40.581174" elapsed="0.000145"/>
</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-06-06T03:32:40.581458" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.581530" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:40.570915" elapsed="0.010717">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.581732" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:40.522143" elapsed="0.059684">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:40.582094" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:40.581921" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:40.581903" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:40.582257" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:40.515846" elapsed="0.066511">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.629277" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:41.628880" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:41.630144" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:41.629882" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:41.630319" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:41.629508" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.630917" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:41.630506" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:41.631275" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:41.631447" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:41.631119" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.631893" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:41.631626" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.633155" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:41.632895" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.633663" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:41.633357" elapsed="0.000333"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.634029" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.634232" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.634402" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:41.633897" elapsed="0.000562"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.633749" elapsed="0.000742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:41.634538" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:41.634725" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:41.632550" elapsed="0.002200"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:41.632019" elapsed="0.002764"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.634953" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:41.634810" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:41.631995" elapsed="0.003035"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.635614" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:41.635168" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:41.635717" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:41.628248" elapsed="0.007598"/>
</kw>
<msg time="2026-06-06T03:32:41.635959" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:41.627305" elapsed="0.008704"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.636504" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.637027" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.637562" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.637763" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.637934" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.638294" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:41.638155" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:41.638139" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.638510" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.638685" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.638847" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:41.638111" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.638009" elapsed="0.000917"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.639065" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.639140" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:41.639258" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:41.622801" elapsed="0.016483"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:41.640505" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:41.640270" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:41.640677" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:41.639935" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.641055" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:41.640812" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.641658" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:41.641306" elapsed="0.000380"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:41.641136" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:41.640792" elapsed="0.000957"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.644265" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:41.641898" elapsed="0.002394"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:41.644345" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:41.644502" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:41.639599" elapsed="0.004928"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:41.645855" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:41.645590" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:41.646041" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:41.645172" elapsed="0.000900"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:41.646325" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:32:41.646167" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:41.646141" elapsed="0.000285"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.646593" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.646823" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.646892" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:41.648967" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:41.644848" elapsed="0.004147"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.650410" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:41.650151" elapsed="0.000306"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:41.650873" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:41.650607" elapsed="0.000310"/>
</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-06-06T03:32:41.657787" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:41.657925" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:41.658022" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:41.653086" elapsed="0.005301">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:41.650984" elapsed="0.007485">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:41.658669" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:41.658502" elapsed="0.000238"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:41.650966" elapsed="0.007798">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:41.659174" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.659308" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:41.659270" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:41.659253" elapsed="0.000117"/>
</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-06-06T03:32:41.659508" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.659577" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:41.649302" elapsed="0.010397">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.659774" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:41.599452" elapsed="0.060415">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:41.660129" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:41.659958" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:41.659941" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:41.660258" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:41.591020" elapsed="0.069332">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.706664" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:42.706191" elapsed="0.000509"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:42.707517" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:42.707220" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:42.707711" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:42.706873" elapsed="0.000863"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.708344" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:42.707900" elapsed="0.000476"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:42.708704" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:42.708877" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:42.708537" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.709349" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:42.709054" elapsed="0.000347"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.710472" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:42.710159" elapsed="0.000359"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.711048" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:42.710763" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.711470" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.711694" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.711864" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:42.711334" elapsed="0.000587"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.711150" elapsed="0.000802"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:42.712002" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:42.712172" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:42.709831" elapsed="0.002368"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:42.709481" elapsed="0.002763"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.712450" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:42.712282" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:42.709456" elapsed="0.003075"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.713152" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:42.712687" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:42.713244" elapsed="0.000041"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:42.705509" elapsed="0.007895"/>
</kw>
<msg time="2026-06-06T03:32:42.713460" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:42.704549" elapsed="0.008962"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.714055" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.714614" elapsed="0.000045"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.716972" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.717164" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.717384" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.717822" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:42.717675" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:42.717655" elapsed="0.000287"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.718079" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.718264" elapsed="0.000030"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.718484" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:42.717569" elapsed="0.000988"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.717467" elapsed="0.001128"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.718793" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.718874" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:42.719007" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:42.700004" elapsed="0.019038"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:42.720414" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:42.720127" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:42.720581" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:42.719784" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.720944" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:42.720697" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.721543" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:42.721202" elapsed="0.000368"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:42.721026" elapsed="0.000610"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:42.720677" elapsed="0.001011"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.724181" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:42.721867" elapsed="0.002348"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:42.724290" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:32:42.724463" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:42.719435" elapsed="0.005054"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:42.725867" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:42.725543" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:42.726030" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:42.725152" elapsed="0.000902"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:42.726295" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:32:42.726128" elapsed="0.000241"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:42.726108" elapsed="0.000286"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.726541" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.726728" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.726799" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:42.728810" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:42.724807" elapsed="0.004073"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.730433" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:42.730126" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:42.730902" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:42.730634" elapsed="0.000313"/>
</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-06-06T03:32:42.738581" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:42.738787" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:42.738933" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:42.733375" elapsed="0.005987">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:42.731015" elapsed="0.008433">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:42.739636" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:42.739482" elapsed="0.000243"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:42.730997" elapsed="0.008752">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:42.740176" elapsed="0.000032"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.740335" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:42.740297" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:42.740276" elapsed="0.000126"/>
</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-06-06T03:32:42.740562" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.740665" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:42.729192" elapsed="0.011601">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.740869" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:42.677080" elapsed="0.063883">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:42.741228" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:42.741055" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:42.741037" elapsed="0.000286"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:42.741355" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:42.670838" elapsed="0.070610">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.787190" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:43.786782" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:43.788034" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:43.787758" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:43.788217" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:43.787399" elapsed="0.000855"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.788843" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:43.788422" elapsed="0.000449"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:43.789181" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:43.789439" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:43.789033" elapsed="0.000435"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.790010" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:43.789626" elapsed="0.000434"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.791286" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:43.790782" elapsed="0.000550"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.791786" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:43.791490" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.792153" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.792360" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.792530" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:43.792018" elapsed="0.000571"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.791871" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:43.792688" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:32:43.792861" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:43.790443" elapsed="0.002444"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:43.790142" elapsed="0.002778"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.793091" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:43.792946" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:43.790117" elapsed="0.003051"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.793806" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:43.793306" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:43.793885" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:43.786135" elapsed="0.007876"/>
</kw>
<msg time="2026-06-06T03:32:43.794067" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:43.785155" elapsed="0.008964"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.794702" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.795210" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.795726" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.795912" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.796081" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.796441" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:43.796302" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:43.796287" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.796672" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.796837" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.796995" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:43.796258" elapsed="0.000790"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.796157" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.797212" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.797286" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:43.797405" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:43.780721" elapsed="0.016711"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:43.798721" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:43.798450" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:43.798888" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:43.798112" elapsed="0.000801"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.799226" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:43.798985" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.799830" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:43.799516" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:43.799342" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:43.798965" elapsed="0.000949"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.802497" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:43.800060" elapsed="0.002465"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:43.802577" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:43.802750" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:43.797762" elapsed="0.005014"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:43.803988" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:43.803748" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:43.804146" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:43.803398" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:43.804378" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:32:43.804242" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:43.804223" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.804601" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.804784" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.804851" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:32:43.806923" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:43.803075" elapsed="0.003875"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.808332" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:43.808081" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:43.808785" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:43.808525" elapsed="0.000304"/>
</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-06-06T03:32:43.815738" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:43.815879" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:43.815973" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:43.811012" elapsed="0.005327">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:43.808896" elapsed="0.007523">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:43.816598" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:43.816452" elapsed="0.000228"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:43.808877" elapsed="0.007827">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:43.817071" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.817246" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:43.817208" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:43.817189" elapsed="0.000120"/>
</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-06-06T03:32:43.817446" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.817517" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:43.807256" elapsed="0.010363">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.817712" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:43.757547" elapsed="0.060295">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:43.818109" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:43.817936" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:43.817918" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:43.818238" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:43.751108" elapsed="0.067225">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.868025" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:44.867607" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:44.868852" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:44.868566" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:44.869022" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:44.868235" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.869593" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:44.869207" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:44.869936" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:44.870136" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:44.869791" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.870564" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:44.870316" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.871581" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:44.871323" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.872077" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:44.871796" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.872443" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.872737" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.872908" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:44.872313" elapsed="0.000653"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.872164" elapsed="0.000835"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:44.873078" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:32:44.873265" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:44.871005" elapsed="0.002285"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:44.870703" elapsed="0.002620"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.873494" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:44.873350" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:44.870677" elapsed="0.002892"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.874184" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:44.873722" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:44.874262" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:44.866852" elapsed="0.007534"/>
</kw>
<msg time="2026-06-06T03:32:44.874441" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:44.865897" elapsed="0.008592"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.875000" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.875499" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.876217" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.876402" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.876572" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.876950" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:44.876809" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:44.876794" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.877163" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.877369" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.877530" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:44.876766" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.876663" elapsed="0.000945"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.877766" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.877843" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:44.877998" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:44.860925" elapsed="0.017101"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:44.879282" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:44.879043" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:44.879442" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:44.878712" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.879794" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:44.879537" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.880351" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:44.880058" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:44.879876" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:44.879518" elapsed="0.000915"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.882985" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:44.880578" elapsed="0.002434"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:44.883064" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:44.883216" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:44.878373" elapsed="0.004868"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:44.884434" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:44.884199" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:44.884591" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:44.883872" elapsed="0.000744"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:44.884842" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:44.884704" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:44.884685" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.885066" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.885264" elapsed="0.000032"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.885359" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:32:44.887846" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:44.883537" elapsed="0.004341"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.889580" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:44.889223" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:44.890177" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:44.889838" elapsed="0.000392"/>
</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-06-06T03:32:44.900759" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:44.900914" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:44.901017" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:44.893141" elapsed="0.008264">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:44.890309" elapsed="0.011181">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:44.901687" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:44.901523" elapsed="0.000230"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:44.890284" elapsed="0.011493">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:44.902170" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.902304" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:44.902267" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:44.902249" elapsed="0.000118"/>
</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-06-06T03:32:44.902506" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.902575" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:44.888261" elapsed="0.014434">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.902769" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:44.837259" elapsed="0.065603">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:44.903128" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:44.902955" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:44.902938" elapsed="0.000286"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:44.903256" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:44.828697" elapsed="0.074653">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.955285" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:45.954886" elapsed="0.000566"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:45.956244" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:45.955983" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:45.956428" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:45.955629" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.957032" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:45.956616" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:45.957361" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:45.957518" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:45.957217" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.957971" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:45.957713" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.959281" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:45.959015" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.959795" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:45.959499" elapsed="0.000323"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.960162" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.960365" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.960533" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:45.960030" elapsed="0.000561"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.959882" elapsed="0.000740"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:45.960687" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:32:45.960859" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:45.958684" elapsed="0.002201"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:45.958098" elapsed="0.002824"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.961088" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:45.960947" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:45.958074" elapsed="0.003091"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.961775" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:45.961304" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:45.961852" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:45.954189" elapsed="0.007788"/>
</kw>
<msg time="2026-06-06T03:32:45.962032" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:45.953216" elapsed="0.008863"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.962604" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.963191" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.963711" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.963902" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.964071" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.964466" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:45.964322" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:45.964306" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.964701" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.964868" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.965037" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:45.964273" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.964146" elapsed="0.000971"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.965256" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.965332" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:45.965449" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:45.948260" elapsed="0.017216"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:45.966759" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:45.966500" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:45.966922" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:45.966165" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.967326" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:45.967024" elapsed="0.000368"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.967943" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:45.967591" elapsed="0.000381"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:45.967418" elapsed="0.000596"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:45.967000" elapsed="0.001036"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.970636" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:45.968185" elapsed="0.002495"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:45.970767" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:45.970926" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:45.965809" elapsed="0.005142"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:45.972151" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:45.971918" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:45.972305" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:45.971568" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:45.972536" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:45.972401" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:45.972382" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.972772" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.972937" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.973002" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:45.974956" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:45.971248" elapsed="0.003734"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.976364" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:45.976116" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:45.976815" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:45.976555" elapsed="0.000303"/>
</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-06-06T03:32:45.987185" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:45.987323" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:45.987423" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:45.979015" elapsed="0.008797">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:45.976925" elapsed="0.010970">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:45.988082" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:45.987928" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:45.976906" elapsed="0.011264">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:45.988549" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.988701" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:45.988661" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:45.988627" elapsed="0.000138"/>
</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-06-06T03:32:45.988902" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.988974" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:45.975293" elapsed="0.013785">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.989211" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:45.920519" elapsed="0.068817">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:45.989686" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:45.989460" elapsed="0.000319"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:45.989438" elapsed="0.000372"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:45.989852" elapsed="0.000018"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:45.913154" elapsed="0.076815">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.039095" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:47.038696" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:47.039917" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:47.039622" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:47.040087" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:47.039296" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.040673" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:47.040268" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:47.040998" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:47.041162" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:47.040856" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.041582" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:47.041337" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.042600" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:47.042346" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.043080" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:47.042813" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.043435" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.043631" elapsed="0.000040"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.043815" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:47.043307" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.043162" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:47.044013" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:32:47.044184" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:47.042021" elapsed="0.002188"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:47.041722" elapsed="0.002519"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.044406" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:47.044267" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:47.041697" elapsed="0.002784"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.045074" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:47.044614" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:47.045150" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:47.038054" elapsed="0.007218"/>
</kw>
<msg time="2026-06-06T03:32:47.045325" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:47.037156" elapsed="0.008216"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.045870" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.046461" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.047172" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.047358" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.047525" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.047895" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:47.047757" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:47.047742" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.048107" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.048266" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.048424" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:47.047713" elapsed="0.000764"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.047599" elapsed="0.000904"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.048690" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.048768" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:47.048884" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:47.032876" elapsed="0.016034"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:47.050127" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:47.049891" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:47.050285" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:47.049539" elapsed="0.000828"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.050719" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:47.050452" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.051270" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:47.050974" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:47.050803" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:47.050432" elapsed="0.000919"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.053702" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:47.051494" elapsed="0.002235"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:47.053780" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:47.053931" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:47.049221" elapsed="0.004735"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:47.055312" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:47.054974" elapsed="0.000427">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:47.055545" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:47.054597" elapsed="0.000983"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:47.055891" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:32:47.055700" elapsed="0.000278"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:47.055673" elapsed="0.000339"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.056207" elapsed="0.000030"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.056433" elapsed="0.000029"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.056524" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:32:47.059206" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:47.054249" elapsed="0.004994"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.061225" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:47.060872" elapsed="0.000416"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:47.061856" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:47.061492" elapsed="0.000430"/>
</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-06-06T03:32:47.070181" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:47.070426" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:47.070530" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:47.064508" elapsed="0.006446">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:47.062013" elapsed="0.009054">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:47.071321" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:47.071113" elapsed="0.000298"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:47.061988" elapsed="0.009457">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:47.071967" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.072150" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:47.072099" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:47.072075" elapsed="0.000163"/>
</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-06-06T03:32:47.072425" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.072524" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:47.059673" elapsed="0.013016">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.072793" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:47.007141" elapsed="0.065781">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:47.073284" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:47.073047" elapsed="0.000336"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:47.073024" elapsed="0.000392"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:47.073460" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:46.998014" elapsed="0.075576">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.120724" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:48.120309" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:48.121524" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:48.121261" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:48.121718" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:48.120928" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.122388" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:48.121995" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:48.122763" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:48.122919" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:48.122602" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.123505" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:48.123256" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.126236" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:48.125973" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.126760" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:48.126438" elapsed="0.000349"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.127117" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.127318" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.127487" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:48.126987" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.126843" elapsed="0.000733"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:48.127624" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:32:48.127808" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:48.125628" elapsed="0.002205"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:48.123631" elapsed="0.004236"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.128041" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:48.127893" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:48.123607" elapsed="0.004511"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.128718" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:48.128255" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:48.128795" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:48.119705" elapsed="0.009214"/>
</kw>
<msg time="2026-06-06T03:32:48.128973" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:48.118823" elapsed="0.010198"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.129511" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.130026" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.130592" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.130792" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.130960" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.131311" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:48.131175" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:48.131159" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.131524" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.131701" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.131861" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:48.131132" elapsed="0.000783"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.131034" elapsed="0.000910"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.132082" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.132157" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:48.132274" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:48.114415" elapsed="0.017884"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:48.133524" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:48.133280" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:48.133700" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:48.132940" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.134036" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:48.133797" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.134597" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:48.134284" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:48.134116" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:48.133778" elapsed="0.000919"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.137334" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:48.134843" elapsed="0.002518"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:48.137414" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:48.137569" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:48.132606" elapsed="0.004988"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:48.138837" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:48.138585" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:48.139029" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:48.138231" elapsed="0.000823"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:48.139262" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:48.139126" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:48.139107" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.139484" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.139662" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.139729" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:48.141670" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:48.137906" elapsed="0.003792"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.143092" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:48.142840" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:48.143527" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:48.143284" elapsed="0.000285"/>
</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-06-06T03:32:48.150905" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:48.151043" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:48.151145" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:48.145739" elapsed="0.005765">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:48.143635" elapsed="0.007948">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:48.151781" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:48.151616" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:48.143616" elapsed="0.008254">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:48.152232" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.152365" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:48.152328" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:48.152310" elapsed="0.000118"/>
</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-06-06T03:32:48.152565" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.152634" elapsed="0.000032"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:48.141992" elapsed="0.010814">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.152885" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:48.091715" elapsed="0.061270">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:48.153288" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:48.153113" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:48.153095" elapsed="0.000290"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:48.153418" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:48.082269" elapsed="0.071243">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.200545" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:49.200148" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:49.201347" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:49.201099" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:49.201515" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:49.200766" elapsed="0.000775"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.202117" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:49.201726" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:49.202444" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:49.202604" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:49.202301" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.203291" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:49.203001" elapsed="0.000339"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.204336" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:49.204074" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.204845" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:49.204555" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.205200" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.205400" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.205568" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:49.205069" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.204928" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:49.205722" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:49.205887" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:49.203741" elapsed="0.002171"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:49.203416" elapsed="0.002528"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.206112" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:49.205970" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:49.203393" elapsed="0.002796"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.206835" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:49.206327" elapsed="0.000602"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:49.206982" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:49.199519" elapsed="0.007591"/>
</kw>
<msg time="2026-06-06T03:32:49.207165" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:49.198633" elapsed="0.008581"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.207815" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.208336" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.208863" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.209046" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.209215" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.209794" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:49.209623" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:49.209608" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.210014" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.210177" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.210340" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:49.209578" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.209290" elapsed="0.001131"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.210563" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.210670" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:49.210793" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:49.194339" elapsed="0.016480"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:49.212094" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:49.211856" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:49.212252" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:49.211502" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.212589" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:49.212348" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.213155" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:49.212861" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:49.212689" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:49.212329" elapsed="0.000911"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.215668" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:49.213387" elapsed="0.002309"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:49.215749" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:49.215905" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:49.211180" elapsed="0.004751"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:49.217152" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:49.216917" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:49.217308" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:49.216553" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:49.217541" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:49.217405" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:49.217386" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.217802" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.217971" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.218038" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:49.220050" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:49.216230" elapsed="0.003847"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.221460" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:49.221210" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:49.221918" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:49.221669" elapsed="0.000294"/>
</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-06-06T03:32:49.230151" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:49.230282" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:49.230376" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:49.224345" elapsed="0.006431">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:49.222030" elapsed="0.008864">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:49.231084" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:49.230928" elapsed="0.000222"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:49.222011" elapsed="0.009163">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:49.231540" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.231693" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:49.231636" elapsed="0.000100"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:49.231618" elapsed="0.000141"/>
</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-06-06T03:32:49.231899" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.231976" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:49.220377" elapsed="0.011702">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.232153" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:49.171735" elapsed="0.060511">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:49.232511" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:49.232338" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:49.232321" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:49.232655" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:49.163550" elapsed="0.069202">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.278461" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:50.277902" elapsed="0.000591"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:50.279301" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:50.279039" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:50.279475" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:50.278678" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.280063" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:50.279675" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:50.280390" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:50.280581" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:50.280247" elapsed="0.000453"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.281121" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:50.280861" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.282377" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:50.282117" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.282899" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:50.282577" elapsed="0.000348"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.283260" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.283462" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.283632" elapsed="0.000036"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:50.283130" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.282984" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:50.283787" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:50.283954" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:50.281782" elapsed="0.002197"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:50.281249" elapsed="0.002763"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.284177" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:50.284037" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:50.281225" elapsed="0.003029"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.284852" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:50.284391" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:50.284930" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:50.277258" elapsed="0.007795"/>
</kw>
<msg time="2026-06-06T03:32:50.285107" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:50.276268" elapsed="0.008886"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.285656" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.286155" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.286662" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.286897" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.287069" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.287424" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:50.287285" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:50.287270" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.287637" elapsed="0.000035"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.287815" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.287975" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:50.287242" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.287143" elapsed="0.000911"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.288194" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.288270" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:50.288387" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:50.271972" elapsed="0.016441"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:50.289627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:50.289392" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:50.289803" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:50.289060" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.290138" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:50.289899" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.290695" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:50.290388" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:50.290219" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:50.289880" elapsed="0.000898"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.293332" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:50.290968" elapsed="0.002391"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:50.293412" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:50.293566" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:50.288741" elapsed="0.004850"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:50.294811" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:50.294562" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:50.294981" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:50.294232" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:50.295210" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:32:50.295075" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:50.295056" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.295466" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.295633" elapsed="0.000035"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.295715" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:50.297634" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:50.293909" elapsed="0.003765"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.299243" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:50.298789" elapsed="0.000508"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:50.299722" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:50.299460" elapsed="0.000306"/>
</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-06-06T03:32:50.307613" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:50.307769" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:50.307864" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:50.301913" elapsed="0.006332">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:50.299832" elapsed="0.008494">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:50.308507" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:50.308358" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:50.299814" elapsed="0.008780">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:50.308986" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.309121" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:50.309083" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:50.309066" elapsed="0.000119"/>
</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-06-06T03:32:50.309320" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.309390" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:50.297972" elapsed="0.011520">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.309566" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:50.249480" elapsed="0.060196">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:50.309943" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:50.309771" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:50.309754" elapsed="0.000286"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:50.310126" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:50.242367" elapsed="0.067860">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.356463" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:51.356052" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:51.357311" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:51.357034" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:51.357487" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:51.356688" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.358095" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:51.357692" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:51.358432" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:51.358603" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:51.358280" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.359096" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:51.358801" elapsed="0.000347"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.360143" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:51.359865" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.360632" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:51.360351" elapsed="0.000332"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.361030" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.361251" elapsed="0.000043"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.361459" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:51.360889" elapsed="0.000629"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.360741" elapsed="0.000808"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:51.361599" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:51.361787" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:51.359524" elapsed="0.002290"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:51.359225" elapsed="0.002621"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.362016" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:51.361871" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:51.359202" elapsed="0.002916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.362746" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:51.362266" elapsed="0.000510"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:51.362826" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:51.355396" elapsed="0.007556"/>
</kw>
<msg time="2026-06-06T03:32:51.363101" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:51.354469" elapsed="0.008694"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.363679" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.364179" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.364868" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.365086" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.365269" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.365625" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:51.365484" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:51.365469" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.365860" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.366025" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.366208" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:51.365441" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.365344" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.366461" elapsed="0.000025"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.366547" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:51.366684" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:51.350042" elapsed="0.016670"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:51.368039" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:51.367801" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:51.368195" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:51.367446" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.368564" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:51.368325" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.369122" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:51.368831" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:51.368659" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:51.368306" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.371571" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:51.369352" elapsed="0.002246"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:51.371669" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:32:51.371824" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:51.367114" elapsed="0.004735"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:51.373046" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:51.372811" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:51.373210" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:51.372465" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:51.373441" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:51.373305" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:51.373286" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.373680" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.373851" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.373916" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:51.375836" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:51.372146" elapsed="0.003716"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.377222" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:51.376973" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:51.377667" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:51.377413" elapsed="0.000299"/>
</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-06-06T03:32:51.385246" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:51.385405" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:51.385524" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:51.380012" elapsed="0.005926">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:51.377778" elapsed="0.008249">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:51.386258" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:51.386068" elapsed="0.000257"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:51.377760" elapsed="0.008589">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:51.386830" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.386971" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:51.386931" elapsed="0.000123"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:51.386912" elapsed="0.000166"/>
</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-06-06T03:32:51.387220" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.387291" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:51.376159" elapsed="0.011238">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.387472" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:51.326852" elapsed="0.060715">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:51.387851" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:51.387675" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:51.387656" elapsed="0.000291"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:51.387980" elapsed="0.000018"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:51.320480" elapsed="0.067608">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.443259" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:52.442824" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:52.444103" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:52.443813" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:52.444275" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:52.443465" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.444864" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:52.444459" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:52.445190" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:52.445370" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:52.445048" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.445813" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:52.445547" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.447041" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:52.446779" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.447621" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:52.447347" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.447995" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.448203" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.448373" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:52.447864" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.447721" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:52.448508" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:52.448695" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:52.446443" elapsed="0.002279"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:52.445935" elapsed="0.002820"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.448922" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:52.448780" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:52.445912" elapsed="0.003088"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.449579" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:52.449137" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:52.449674" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:52.442198" elapsed="0.007602"/>
</kw>
<msg time="2026-06-06T03:32:52.449855" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:52.440987" elapsed="0.008915"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.450391" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.450911" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.451426" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.451608" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.451801" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.452155" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:52.452017" elapsed="0.000236"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:52.452002" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.452417" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.452580" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.452758" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:52.451974" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.451876" elapsed="0.000962"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.452976" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.453050" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:52.453165" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:52.436560" elapsed="0.016630"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:52.454401" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:52.454166" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:52.454558" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:52.453832" elapsed="0.000751"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.454908" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:52.454668" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.455473" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:52.455158" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:52.454988" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:52.454635" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.458045" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:52.455714" elapsed="0.002358"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:52.458123" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:52.458275" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:52.453498" elapsed="0.004802"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:52.459517" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:52.459284" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:52.459687" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:52.458923" elapsed="0.000790"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:52.459918" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:32:52.459783" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:52.459764" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.460139" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.460301" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.460365" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:52.462267" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:52.458591" elapsed="0.003734"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.463754" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:52.463489" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:52.464194" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:52.463947" elapsed="0.000290"/>
</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-06-06T03:32:52.471079" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:52.471260" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:52.471358" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:52.466350" elapsed="0.005395">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:52.464302" elapsed="0.007524">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:52.472007" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:52.471859" elapsed="0.000236"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:52.464284" elapsed="0.007846">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:52.472684" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.472878" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:52.472823" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:52.472798" elapsed="0.000175"/>
</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-06-06T03:32:52.473179" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.473281" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:52.462626" elapsed="0.010802">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.473536" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:52.403221" elapsed="0.070472">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:52.474076" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:52.473828" elapsed="0.000354"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:52.473804" elapsed="0.000415"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:52.474266" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:52.394154" elapsed="0.080251">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.522342" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:53.521946" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:53.523144" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:53.522890" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:53.523314" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:53.522545" elapsed="0.000793"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.523926" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:53.523518" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:53.524249" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:53.524416" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:53.524106" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.524859" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:53.524592" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.525861" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:53.525589" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.526328" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:53.526056" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.526696" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.526893" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.527057" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:53.526552" elapsed="0.000561"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.526408" elapsed="0.000736"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:53.527193" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:53.527369" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:53.525269" elapsed="0.002130"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:53.524980" elapsed="0.002455"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.527601" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:53.527460" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:53.524957" elapsed="0.002736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.528440" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:53.527831" elapsed="0.000637"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:53.528516" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:53.521317" elapsed="0.007348"/>
</kw>
<msg time="2026-06-06T03:32:53.528720" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:53.520441" elapsed="0.008327"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.529310" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.529826" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.530328" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.530507" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.530690" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.531224" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:53.531083" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:53.531068" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.531472" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.531652" elapsed="0.000026"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.531824" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:53.531039" elapsed="0.000839"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.530766" elapsed="0.001137"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.532042" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.532117" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:32:53.532240" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:53.516205" elapsed="0.016061"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:53.533478" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:53.533242" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:53.533633" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:53.532912" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.533985" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:53.533746" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.534564" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:53.534272" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:53.534103" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:53.533727" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.537016" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:53.534816" elapsed="0.002228"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:53.537096" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:32:53.537248" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:53.532577" elapsed="0.004696"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:53.538466" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:53.538233" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:53.538624" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:53.537904" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:53.538875" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:53.538737" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:53.538718" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.539099" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.539264" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.539330" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:53.541288" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:53.537567" elapsed="0.003747"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.542713" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:53.542446" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:53.543152" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:53.542907" elapsed="0.000289"/>
</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-06-06T03:32:53.550581" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:53.550741" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:53.550847" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:53.545498" elapsed="0.005710">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:53.543262" elapsed="0.008029">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:53.551487" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:53.551323" elapsed="0.000229"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:53.543244" elapsed="0.008331">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:53.551955" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.552128" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:53.552088" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:53.552067" elapsed="0.000124"/>
</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-06-06T03:32:53.552328" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.552398" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:53.541616" elapsed="0.010885">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.552574" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:53.493775" elapsed="0.058915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:53.552955" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:53.552784" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:53.552767" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:53.553084" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:53.486725" elapsed="0.066451">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.599995" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:54.599509" elapsed="0.000521"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:54.600839" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:54.600557" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:54.601016" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:54.600212" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.601610" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:54.601207" elapsed="0.000454"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:54.602021" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:54.602196" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:54.601854" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.602632" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:54.602381" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.603954" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:54.603407" elapsed="0.000600"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.604543" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:54.604193" elapsed="0.000388"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.604954" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.605228" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.605402" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:54.604818" elapsed="0.000643"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.604660" elapsed="0.000832"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:54.605542" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:32:54.605731" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:54.603086" elapsed="0.002672"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:54.602780" elapsed="0.003012"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.605963" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:54.605818" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:54.602756" elapsed="0.003288"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.606664" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:54.606189" elapsed="0.000505"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:54.606744" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:54.598803" elapsed="0.008067"/>
</kw>
<msg time="2026-06-06T03:32:54.606927" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:54.597851" elapsed="0.009124"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.607468" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.608018" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.608515" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.608715" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.608885" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.609242" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:54.609102" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:54.609087" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.609456" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.609673" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.609838" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:54.609059" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.608961" elapsed="0.000958"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.610060" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.610136" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:54.610258" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:54.593276" elapsed="0.017008"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:54.611518" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:54.611279" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:54.611735" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:54.610942" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.612091" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:54.611846" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.612657" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:54.612347" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:54.612178" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:54.611825" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.615500" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:54.612925" elapsed="0.002636"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:54.615617" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:32:54.615793" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:54.610601" elapsed="0.005217"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:54.617179" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:54.616902" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:54.617339" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:54.616483" elapsed="0.000882"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:54.617575" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:32:54.617437" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:54.617418" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.617819" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.617985" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.618050" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:54.620015" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:54.616151" elapsed="0.003892"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.621475" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:54.621183" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:54.621964" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:54.621689" elapsed="0.000320"/>
</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-06-06T03:32:54.629005" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:54.629158" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:54.629258" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:54.624223" elapsed="0.005404">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:54.622079" elapsed="0.007652">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:54.629917" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:54.629764" elapsed="0.000234"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:54.622059" elapsed="0.007967">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:54.630468" elapsed="0.000030"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.630632" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:54.630584" elapsed="0.000125"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:54.630561" elapsed="0.000178"/>
</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-06-06T03:32:54.630925" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.631021" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:54.620349" elapsed="0.010812">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.631263" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:54.569985" elapsed="0.061394">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:54.631698" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:54.631475" elapsed="0.000298"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:54.631457" elapsed="0.000341"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:54.631831" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:54.563133" elapsed="0.068796">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.680074" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:55.679580" elapsed="0.000619"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:55.680994" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:55.680733" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:55.681166" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:55.680378" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.681755" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:55.681350" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:55.682082" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:55.682254" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:55.681938" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.682765" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:55.682481" elapsed="0.000332"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.683970" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:55.683588" elapsed="0.000430"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.684474" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:55.684186" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.684872" elapsed="0.000027"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.685083" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.685262" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:55.684734" elapsed="0.000587"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.684562" elapsed="0.000790"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:55.685401" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:32:55.685577" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:55.683212" elapsed="0.002393"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:55.682894" elapsed="0.002745"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.685827" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:55.685683" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:55.682868" elapsed="0.003042"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.686517" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:55.686051" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:55.686595" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:55.678754" elapsed="0.007987"/>
</kw>
<msg time="2026-06-06T03:32:55.686799" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:55.677817" elapsed="0.009034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.687353" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.688016" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.688776" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.688965" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.689134" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.689513" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:55.689354" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:55.689338" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.689745" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.689907" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.690065" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:55.689310" elapsed="0.000807"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.689212" elapsed="0.000931"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.690281" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.690355" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:55.690473" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:55.673360" elapsed="0.017138"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:55.692262" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:55.691479" elapsed="0.000865">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:55.692439" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:55.691142" elapsed="0.001322"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.692795" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:55.692535" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.693386" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:55.693073" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:55.692877" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:55.692516" elapsed="0.000955"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.695895" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:55.693616" elapsed="0.002307"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:55.696041" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:32:55.696208" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:55.690824" elapsed="0.005410"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:55.697474" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:55.697228" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:55.697637" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:55.696892" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:55.697894" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:32:55.697754" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:55.697734" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.698125" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.698301" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.698369" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:32:55.700418" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:55.696544" elapsed="0.003902"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.701909" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:55.701624" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:55.702380" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:55.702105" elapsed="0.000319"/>
</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-06-06T03:32:55.710923" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:55.711073" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:55.711187" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:55.704875" elapsed="0.006717">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:55.702491" elapsed="0.009209">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:55.711941" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:55.711760" elapsed="0.000249"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:55.702473" elapsed="0.009560">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:55.712438" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.712578" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:55.712537" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:55.712518" elapsed="0.000141"/>
</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-06-06T03:32:55.712830" elapsed="0.000025"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.712905" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:55.700781" elapsed="0.012232">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.713157" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:55.650183" elapsed="0.063116">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:55.713697" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:55.713429" elapsed="0.000371"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:55.713405" elapsed="0.000429"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:55.713879" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:55.643058" elapsed="0.070957">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.759986" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:56.759531" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:56.760811" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:56.760525" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:56.760981" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:56.760189" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.761584" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:56.761165" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:56.761930" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:56.762219" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:56.761786" elapsed="0.000460"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.762672" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:56.762398" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.763947" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:56.763653" elapsed="0.000341"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.764423" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:56.764151" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.764796" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.764998" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.765167" elapsed="0.000024"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:56.764665" elapsed="0.000563"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.764506" elapsed="0.000751"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:56.765363" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:32:56.765534" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:56.763316" elapsed="0.002243"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:56.762797" elapsed="0.002794"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.765775" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:56.765616" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:56.762775" elapsed="0.003077"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.766439" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:56.765988" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:56.766517" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:56.758919" elapsed="0.007740"/>
</kw>
<msg time="2026-06-06T03:32:56.766717" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:56.757974" elapsed="0.008791"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.767253" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.767792" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.768334" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.768522" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.768713" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.769074" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:56.768935" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:56.768920" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.769296" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.769457" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.769615" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:56.768891" elapsed="0.000796"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.768791" elapsed="0.000922"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.769942" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.770028" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:32:56.770156" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:56.753496" elapsed="0.016688"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:56.771439" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:56.771184" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:56.771607" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:56.770847" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.771997" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:56.771727" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.772550" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:56.772252" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:56.772080" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:56.771708" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.775204" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:56.772805" elapsed="0.002428"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:56.775287" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:32:56.775447" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:56.770501" elapsed="0.004973"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:56.776730" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:56.776482" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:56.776888" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:56.776152" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:56.777118" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:56.776983" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:56.776965" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.777346" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.777509" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.777576" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:56.779504" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:56.775789" elapsed="0.003742"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.780949" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:56.780697" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:56.781386" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:56.781145" elapsed="0.000284"/>
</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-06-06T03:32:56.788516" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:56.788743" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:56.788854" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:56.783548" elapsed="0.005752">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:56.781494" elapsed="0.007901">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:56.789617" elapsed="0.000044"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:56.789431" elapsed="0.000285"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:56.781476" elapsed="0.008272">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:56.790162" elapsed="0.000029"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.790307" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:56.790269" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:56.790250" elapsed="0.000127"/>
</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-06-06T03:32:56.790534" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.790622" elapsed="0.000037"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:56.779847" elapsed="0.010911">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.790853" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:56.727993" elapsed="0.062968">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:56.791271" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:56.791070" elapsed="0.000416"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:56.791051" elapsed="0.000459"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:56.791543" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:56.719801" elapsed="0.071878">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.840257" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:57.839820" elapsed="0.000472"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:57.841284" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:57.841001" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:57.841469" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:57.840656" elapsed="0.000840"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.842166" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:57.841761" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:57.842514" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:57.842692" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:57.842361" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.843135" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:57.842874" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.844236" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:57.843921" elapsed="0.000362"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.844736" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:57.844442" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.845096" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.845355" elapsed="0.000034"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.845594" elapsed="0.000039"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:57.844964" elapsed="0.000744"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:57.844820" elapsed="0.000932"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:57.845818" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:32:57.846052" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:57.843571" elapsed="0.002519"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:57.843263" elapsed="0.002873"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.846376" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:57.846173" elapsed="0.000280"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:57.843239" elapsed="0.003245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.847392" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:57.846707" elapsed="0.000727"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:57.847506" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:57.839175" elapsed="0.008539"/>
</kw>
<msg time="2026-06-06T03:32:57.847794" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:57.838209" elapsed="0.009657"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.848623" elapsed="0.000061"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.849376" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.850447" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.850730" elapsed="0.000032"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.850973" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.851482" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:57.851287" elapsed="0.000275"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:57.851265" elapsed="0.000331"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.851808" elapsed="0.000030"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.852036" elapsed="0.000083"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.852334" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:57.851224" elapsed="0.001186"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:57.851082" elapsed="0.001365"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.852665" elapsed="0.000031"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:57.852775" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:32:57.852941" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:57.833673" elapsed="0.019304"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:57.854322" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:57.854047" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:57.854493" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:57.853700" elapsed="0.000818"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.854861" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:57.854590" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.855433" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:57.855130" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:57.854945" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:57.854571" elapsed="0.000947"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.857989" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:57.855722" elapsed="0.002294"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:57.858069" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:32:57.858223" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:57.853358" elapsed="0.004890"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:57.859489" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:57.859245" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:57.859701" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:57.858904" elapsed="0.000823"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:57.859944" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:32:57.859805" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:57.859786" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.860214" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:57.860389" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:57.860458" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:32:57.862375" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:57.858562" elapsed="0.003840"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.863806" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:57.863534" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:57.864286" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:57.864001" elapsed="0.000331"/>
</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-06-06T03:32:58.821839" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:32:58.822039" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:32:58.822206" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:57.868142" elapsed="0.954529">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:57.864401" elapsed="0.958381">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:32:58.823099" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:58.822829" elapsed="0.000345"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:57.864382" elapsed="0.958817">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:32:58.823863" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:58.824032" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:32:58.823984" elapsed="0.000099"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:58.823962" elapsed="0.000144"/>
</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-06-06T03:32:58.824290" elapsed="0.000027"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:32:58.824369" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:57.862724" elapsed="0.961757">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:58.824557" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:57.810112" elapsed="1.014555">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:58.825021" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:58.824834" elapsed="0.000282"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:58.824815" elapsed="0.000337"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:58.825200" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:57.801754" elapsed="1.023568">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.873572" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:59.873163" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:59.874501" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:59.874171" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:59.874694" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:59.873798" elapsed="0.000922"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.875375" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:59.874881" elapsed="0.000535"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:32:59.875907" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:32:59.876220" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:32:59.875667" elapsed="0.000590"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.876745" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:59.876457" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.878098" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:59.877558" elapsed="0.000587"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.878592" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:32:59.878306" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.879019" elapsed="0.000032"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.879270" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.879447" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:32:59.878848" elapsed="0.000657"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:32:59.878696" elapsed="0.000840"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:32:59.879588" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:32:59.879795" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:32:59.877227" elapsed="0.002594"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:59.876878" elapsed="0.002976"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.880034" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:59.879880" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:59.876853" elapsed="0.003265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.880754" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:32:59.880259" elapsed="0.000583"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:32:59.880895" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:32:59.872476" elapsed="0.008552"/>
</kw>
<msg time="2026-06-06T03:32:59.881093" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:32:59.871530" elapsed="0.009615"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.881672" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.882199" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.882785" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.882975" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.883164" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.883529" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:59.883389" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:32:59.883373" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.883945" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.884180" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.884451" elapsed="0.000034"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:32:59.883345" elapsed="0.001192"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:32:59.883242" elapsed="0.001338"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.884824" elapsed="0.000035"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:32:59.884946" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:32:59.885125" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:32:59.866952" elapsed="0.018213"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:59.887188" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:59.886763" elapsed="0.000539">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:59.887460" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:59.886175" elapsed="0.001323"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.888014" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:32:59.887617" elapsed="0.000479"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.888831" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:32:59.888482" elapsed="0.000381"/>
</kw>
<status status="PASS" start="2026-06-06T03:32:59.888137" elapsed="0.000771"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:59.887583" elapsed="0.001348"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.891594" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:32:59.889135" elapsed="0.002486"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:32:59.891696" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:32:59.891877" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:59.885695" elapsed="0.006211"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:32:59.893601" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:32:59.893338" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:32:59.893785" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:32:59.892892" elapsed="0.000918"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:32:59.894101" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:32:59.893896" elapsed="0.000297"/>
</branch>
<status status="PASS" start="2026-06-06T03:32:59.893868" elapsed="0.000367"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.894457" elapsed="0.000033"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:32:59.894733" elapsed="0.000034"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:32:59.894839" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:32:59.897304" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:32:59.892349" elapsed="0.004985"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.898953" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:59.898550" elapsed="0.000457"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:32:59.899441" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:32:59.899183" elapsed="0.000303"/>
</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-06-06T03:33:00.713218" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:00.713560" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:00.713875" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:32:59.901773" elapsed="0.812991">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:32:59.899556" elapsed="0.815541">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:00.715747" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:00.715222" elapsed="0.000701"/>
</branch>
<status status="FAIL" start="2026-06-06T03:32:59.899535" elapsed="0.816450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:00.717037" elapsed="0.000078"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:00.717392" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:00.717296" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:00.717249" elapsed="0.000301"/>
</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-06-06T03:33:00.717917" elapsed="0.000053"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:00.718086" elapsed="0.000037"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:32:59.897688" elapsed="0.820655">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:00.718524" elapsed="0.000039"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:32:59.842724" elapsed="0.876061">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:00.719427" elapsed="0.000057"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:00.719010" elapsed="0.000591"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:00.718968" elapsed="0.000721"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:00.719773" elapsed="0.000035"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:32:59.835455" elapsed="0.884547">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.769118" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:01.768714" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:01.769929" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:01.769674" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:01.770100" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:01.769323" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.770688" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:01.770285" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:01.771014" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:01.771179" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:01.770871" elapsed="0.000437"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.771734" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:01.771465" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.772789" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:01.772494" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.773261" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:01.772988" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.773624" elapsed="0.000049"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.773855" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.774026" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:01.773493" elapsed="0.000591"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.773347" elapsed="0.000767"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:01.774161" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:01.774332" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:01.772173" elapsed="0.002187"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:01.771861" elapsed="0.002531"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.774561" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:01.774418" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:01.771836" elapsed="0.002801"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.775315" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:01.774844" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:01.775393" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:01.768068" elapsed="0.007451"/>
</kw>
<msg time="2026-06-06T03:33:01.775574" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:01.766993" elapsed="0.008631"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.776139" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.776635" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.777179" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.777409" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.777579" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.777953" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:01.777814" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:01.777798" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.778167" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.778327" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.778484" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:01.777770" elapsed="0.000767"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.777668" elapsed="0.000894"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.778716" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.778792" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:01.778913" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:01.762567" elapsed="0.016372"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:01.780414" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:01.780152" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:01.780580" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:01.779582" elapsed="0.001023"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.780981" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:01.780733" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.781532" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:01.781235" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:01.781063" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:01.780712" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.784275" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:01.781779" elapsed="0.002529"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:01.784371" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:33:01.784551" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:01.779254" elapsed="0.005322"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:01.786082" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:01.785803" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:01.786249" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:01.785356" elapsed="0.000919"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:01.786506" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:01.786352" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:01.786331" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.786826" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.786996" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.787063" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:01.789036" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:01.784991" elapsed="0.004071"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.790575" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:01.790302" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:01.791034" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:01.790789" elapsed="0.000290"/>
</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-06-06T03:33:01.797987" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:01.798129" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:01.798270" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:01.793319" elapsed="0.005367">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:01.791148" elapsed="0.007622">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:01.798957" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:01.798805" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:01.791128" elapsed="0.007917">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:01.799438" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.799592" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:01.799553" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:01.799535" elapsed="0.000141"/>
</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-06-06T03:33:01.799816" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.799902" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:01.789439" elapsed="0.010570">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.800081" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:01.737187" elapsed="0.062987">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:01.800450" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:01.800264" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:01.800248" elapsed="0.000298"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:01.800629" elapsed="0.000033"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:01.728161" elapsed="0.072627">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.850635" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:02.850226" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:02.851446" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:02.851192" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:02.851652" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:02.850857" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.852235" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:02.851842" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:02.852565" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:02.852753" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:02.852419" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.853211" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:02.852957" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.854241" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:02.853982" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.854729" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:02.854441" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.855091" elapsed="0.000036"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.855308" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.855483" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:02.854959" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:02.854813" elapsed="0.000760"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:02.855622" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:33:02.855806" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:02.853660" elapsed="0.002172"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:02.853338" elapsed="0.002527"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.856035" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:02.855892" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:02.853314" elapsed="0.002800"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.856724" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:02.856252" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:02.856803" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:02.849587" elapsed="0.007359"/>
</kw>
<msg time="2026-06-06T03:33:02.857065" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:02.847850" elapsed="0.009266"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.857618" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.858145" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.858870" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.859060" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.859230" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.859588" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:02.859450" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:02.859435" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.859820" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.859979" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.860138" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:02.859406" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:02.859307" elapsed="0.000910"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.860357" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:02.860432" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:02.860551" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:02.842007" elapsed="0.018570"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:02.861881" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:02.861608" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:02.862048" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:02.861263" elapsed="0.000810"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.862437" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:02.862184" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.863007" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:02.862709" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:02.862518" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:02.862164" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.865521" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:02.863236" elapsed="0.002312"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:02.865600" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:02.865773" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:02.860936" elapsed="0.004862"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:02.867009" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:02.866770" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:02.867168" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:02.866419" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:02.867399" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:02.867263" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:02.867244" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.867623" elapsed="0.000038"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:02.867809" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:02.867874" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:02.869854" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:02.866097" elapsed="0.003785"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.871354" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:02.871010" elapsed="0.000397"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:02.871832" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:02.871559" elapsed="0.000319"/>
</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-06-06T03:33:04.156149" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:04.156472" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:04.156771" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:02.874242" elapsed="1.283622">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:02.871948" elapsed="1.286138">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:04.158682" elapsed="0.000081"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:04.158176" elapsed="0.000701"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:02.871928" elapsed="1.287008">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:04.160146" elapsed="0.000066"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:04.160494" elapsed="0.000035"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:04.160395" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:04.160350" elapsed="0.000339"/>
</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-06-06T03:33:04.161061" elapsed="0.000088"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:04.161273" elapsed="0.000038"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:02.870192" elapsed="1.291342">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:04.161748" elapsed="0.000039"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:02.816800" elapsed="1.345237">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:04.163020" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:04.162386" elapsed="0.000878"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:04.162323" elapsed="0.001027"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:04.163469" elapsed="0.000043"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:02.810532" elapsed="1.353284">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.211223" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:05.210818" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:05.212169" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:05.211844" elapsed="0.000412">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:05.212364" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:05.211428" elapsed="0.000965"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.213031" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:05.212583" elapsed="0.000476"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:05.213397" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:05.213571" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:05.213219" elapsed="0.000378"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.214120" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:05.213816" elapsed="0.000363"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.215462" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:05.215194" elapsed="0.000315"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.216038" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:05.215757" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.216402" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.216610" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.216798" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:05.216269" elapsed="0.000588"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:05.216124" elapsed="0.000764"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:05.216937" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:05.217106" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:05.214863" elapsed="0.002269"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:05.214273" elapsed="0.002891"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.217360" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:05.217190" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:05.214245" elapsed="0.003194"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.218048" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:05.217578" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:05.218126" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:05.210181" elapsed="0.008073"/>
</kw>
<msg time="2026-06-06T03:33:05.218310" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:05.209268" elapsed="0.009090"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.218867" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.219375" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.219891" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.220071" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.220239" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.220621" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:05.220478" elapsed="0.000259"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:05.220461" elapsed="0.000301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.220902" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.221069" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.221230" elapsed="0.000064"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:05.220424" elapsed="0.000908"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:05.220314" elapsed="0.001045"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.221506" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:05.221583" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:05.221720" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:05.204975" elapsed="0.016771"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:05.223001" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:05.222746" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:05.223173" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:05.222395" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.223512" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:05.223272" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.224078" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:05.223783" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:05.223593" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:05.223252" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.226725" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:05.224305" elapsed="0.002448"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:05.226807" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:05.226961" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:05.222072" elapsed="0.004914"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:05.228248" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:05.227995" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:05.228407" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:05.227607" elapsed="0.000824"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:05.228690" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:33:05.228502" elapsed="0.000258"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:05.228482" elapsed="0.000304"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.228929" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:05.229095" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:05.229175" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:33:05.231190" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:05.227285" elapsed="0.003968"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.232685" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:05.232409" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:05.233129" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:05.232879" elapsed="0.000306"/>
</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-06-06T03:33:07.779785" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:07.779978" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:07.780118" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:05.235357" elapsed="2.545171">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:05.233271" elapsed="2.547359">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:07.780920" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:07.780691" elapsed="0.000298"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:05.233237" elapsed="2.547777">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:07.781471" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:07.781618" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:07.781575" elapsed="0.000131"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:07.781554" elapsed="0.000176"/>
</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-06-06T03:33:07.781872" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:07.781943" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:05.231563" elapsed="2.550492">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:07.782131" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:05.182390" elapsed="2.599838">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:07.782523" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:07.782333" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:07.782310" elapsed="0.000311"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:07.782669" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:05.173411" elapsed="2.609358">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.830505" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:08.830102" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:08.831366" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:08.831105" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:08.831541" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:08.830765" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.832197" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:08.831784" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:08.832564" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:08.832753" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:08.832409" elapsed="0.000384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.833204" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:08.832950" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.834333" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:08.834051" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.834922" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:08.834552" elapsed="0.000402"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.835376" elapsed="0.000029"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.835628" elapsed="0.000049"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.835870" elapsed="0.000026"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:08.835206" elapsed="0.000735"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.835024" elapsed="0.000954"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:08.836038" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:33:08.836244" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:08.833696" elapsed="0.002579"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:08.833354" elapsed="0.002962"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.836543" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:08.836354" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:08.833326" elapsed="0.003328"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.837321" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:08.836830" elapsed="0.000519"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:08.837400" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:08.829418" elapsed="0.008109"/>
</kw>
<msg time="2026-06-06T03:33:08.837585" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:08.828439" elapsed="0.009198"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.838255" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.838820" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.839721" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.839963" elapsed="0.000029"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.840193" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.840693" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:08.840491" elapsed="0.000279"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:08.840469" elapsed="0.000333"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.840976" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.841191" elapsed="0.000029"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.841405" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:08.840430" elapsed="0.001046"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.840298" elapsed="0.001212"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.841725" elapsed="0.000030"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.841831" elapsed="0.000062"/>
</return>
<msg time="2026-06-06T03:33:08.842034" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:08.823496" elapsed="0.018573"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:08.843739" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:08.843389" elapsed="0.000450">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:08.843954" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:08.842935" elapsed="0.001049"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.844377" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:08.844067" elapsed="0.000419"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.845026" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:08.844707" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:08.844514" elapsed="0.000574"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:08.844045" elapsed="0.001067"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.848002" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:08.845270" elapsed="0.002760"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:08.848083" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:33:08.848264" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:08.842483" elapsed="0.005808"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:08.849542" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:08.849296" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:08.849723" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:08.848941" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:08.849997" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:08.849821" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:08.849802" elapsed="0.000280"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.850249" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.850423" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.850488" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:08.852457" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:08.848596" elapsed="0.003888"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.853935" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:08.853632" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:08.854390" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:08.854138" elapsed="0.000296"/>
</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-06-06T03:33:08.864001" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:08.864157" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:08.864289" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:08.859094" elapsed="0.005632">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:08.854500" elapsed="0.010319">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:08.865020" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:08.864857" elapsed="0.000229"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:08.854481" elapsed="0.010630">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:08.865552" elapsed="0.000029"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.865778" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:08.865735" elapsed="0.000149"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:08.865714" elapsed="0.000208"/>
</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-06-06T03:33:08.866073" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.866145" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:08.852805" elapsed="0.013450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.866331" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:08.798579" elapsed="0.067848">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:08.866774" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:08.866519" elapsed="0.000363"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:08.866502" elapsed="0.000416"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:08.866965" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:08.791790" elapsed="0.075315">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.914965" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:09.914541" elapsed="0.000460"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:09.915821" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:09.915522" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:09.916005" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:09.915172" elapsed="0.000859"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.916579" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:09.916190" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:09.916927" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:09.917199" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:09.916783" elapsed="0.000444"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.917632" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:09.917381" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.972660" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:09.918407" elapsed="0.054325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.973255" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:09.972953" elapsed="0.000330"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.973634" elapsed="0.000037"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.973946" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.974147" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:09.973500" elapsed="0.000706"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.973343" elapsed="0.000894"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:09.974287" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:33:09.974465" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:09.918090" elapsed="0.056400"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:09.917779" elapsed="0.056745"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.974718" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:09.974553" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:09.917755" elapsed="0.057041"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.975422" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:09.974936" elapsed="0.000514"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:09.975500" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:09.913890" elapsed="0.061735"/>
</kw>
<msg time="2026-06-06T03:33:09.975699" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:09.912979" elapsed="0.062774"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.976254" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.976770" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.977266" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.977446" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.977612" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.977983" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:09.977847" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:09.977831" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.978232" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.978431" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.978592" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:09.977802" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.977702" elapsed="0.000986"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.978831" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.978908" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:09.979027" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:09.908665" elapsed="0.070388"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:09.980330" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:09.980059" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:09.980502" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:09.979720" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.981055" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:09.980599" elapsed="0.000514"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.981605" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:09.981309" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:09.981138" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:09.980578" elapsed="0.001129"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.984278" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:09.981856" elapsed="0.002449"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:09.984358" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:33:09.984512" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:09.979366" elapsed="0.005171"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:09.985769" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:09.985513" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:09.985928" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:09.985176" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:09.986196" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:09.986056" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:09.986006" elapsed="0.000276"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.986424" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:09.986591" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.986673" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:09.988599" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:09.984852" elapsed="0.003774"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.990091" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:09.989783" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:09.990539" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:09.990290" elapsed="0.000294"/>
</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-06-06T03:33:09.997882" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:09.998015" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:09.998158" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:09.992755" elapsed="0.005770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:09.990667" elapsed="0.007940">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:09.998828" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:09.998670" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:09.990633" elapsed="0.008286">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:09.999298" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.999434" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:09.999395" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:09.999377" elapsed="0.000121"/>
</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-06-06T03:33:09.999636" elapsed="0.000037"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.999724" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:09.988943" elapsed="0.010887">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:09.999905" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:09.884854" elapsed="0.115145">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:10.000267" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:10.000091" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:10.000074" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:10.000396" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:09.876493" elapsed="0.124000">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.045848" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:11.045430" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:11.046789" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:11.046513" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:11.046965" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:11.046154" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.047544" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:11.047151" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:11.047892" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:11.048057" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:11.047745" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.048491" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:11.048238" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.049522" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:11.049261" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.050014" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:11.049741" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.050399" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.050602" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.050787" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:11.050267" elapsed="0.000581"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.050095" elapsed="0.000782"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:11.050923" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:11.051089" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:11.048939" elapsed="0.002176"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:11.048619" elapsed="0.002529"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.051315" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:11.051173" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:11.048593" elapsed="0.002800"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.052000" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:11.051530" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:11.052078" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:11.044814" elapsed="0.007390"/>
</kw>
<msg time="2026-06-06T03:33:11.052259" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:11.043928" elapsed="0.008379"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.052820" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.053363" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.054071" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.054275" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.054449" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.054831" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:11.054689" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:11.054672" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.055051" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.055214" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.055374" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:11.054628" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.054526" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.055596" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.055689" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:11.055808" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:11.039602" elapsed="0.016233"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:11.057068" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:11.056826" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:11.057229" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:11.056474" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.057564" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:11.057325" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.058172" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:11.057843" elapsed="0.000385"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:11.057662" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:11.057306" elapsed="0.000981"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.060789" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:11.058444" elapsed="0.002372"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:11.060902" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:33:11.061082" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:11.056151" elapsed="0.004956"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:11.062387" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:11.062129" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:11.062545" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:11.061789" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:11.062793" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:11.062654" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:11.062621" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.063016" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.063182" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.063247" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:11.065238" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:11.061424" elapsed="0.003849"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.066746" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:11.066472" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:11.067185" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:11.066942" elapsed="0.000286"/>
</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-06-06T03:33:11.074036" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:11.074178" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:11.074306" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:11.069531" elapsed="0.005198">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:11.067294" elapsed="0.007524">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:11.075023" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:11.074854" elapsed="0.000236"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:11.067276" elapsed="0.007837">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:11.075506" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.075661" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:11.075605" elapsed="0.000102"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:11.075586" elapsed="0.000143"/>
</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-06-06T03:33:11.075870" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.075940" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:11.065586" elapsed="0.010461">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.076178" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:11.017080" elapsed="0.059196">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:11.076545" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:11.076371" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:11.076353" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:11.076691" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:11.010732" elapsed="0.066056">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.125061" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:12.124655" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:12.125890" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:12.125602" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:12.126066" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:12.125265" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.126679" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:12.126254" elapsed="0.000453"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:12.127012" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:12.127242" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:12.126867" elapsed="0.000403"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.127931" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:12.127426" elapsed="0.000552"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.128970" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:12.128706" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.129448" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:12.129173" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.129828" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.130028" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.130196" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:12.129696" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.129531" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:12.130437" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:33:12.130616" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:12.128362" elapsed="0.002294"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:12.128057" elapsed="0.002633"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.130862" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:12.130717" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:12.128033" elapsed="0.002906"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.131528" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:12.131078" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:12.131606" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:12.124019" elapsed="0.007731"/>
</kw>
<msg time="2026-06-06T03:33:12.131807" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:12.123058" elapsed="0.008796"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.132346" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.132863" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.133360" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.133542" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.133724" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.134077" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:12.133938" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:12.133923" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.134290" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.134474" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.134651" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:12.133896" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.133799" elapsed="0.000933"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.134911" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.134990" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:12.135109" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:12.118548" elapsed="0.016587"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:12.136361" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:12.136123" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:12.136521" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:12.135789" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.136877" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:12.136616" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.137428" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:12.137133" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:12.136959" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:12.136598" elapsed="0.000912"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.140083" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:12.137671" elapsed="0.002439"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:12.140164" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:12.140319" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:12.135452" elapsed="0.004893"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:12.141554" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:12.141320" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:12.141735" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:12.140987" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:12.141970" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:12.141832" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:12.141813" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.142193" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.142358" elapsed="0.000035"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.142439" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:33:12.144372" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:12.140660" elapsed="0.003739"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.145803" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:12.145533" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:12.146240" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:12.145997" elapsed="0.000286"/>
</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-06-06T03:33:12.153068" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:12.153256" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:12.153358" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:12.148442" elapsed="0.005332">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:12.146349" elapsed="0.007509">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:12.154045" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:12.153892" elapsed="0.000220"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:12.146330" elapsed="0.007806">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:12.154615" elapsed="0.000058"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.154834" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:12.154780" elapsed="0.000113"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:12.154755" elapsed="0.000168"/>
</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-06-06T03:33:12.155116" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.155214" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:12.144725" elapsed="0.010633">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.155459" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:12.094970" elapsed="0.060617">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:12.155972" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:12.155736" elapsed="0.000336"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:12.155712" elapsed="0.000394"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:12.156151" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:12.086237" elapsed="0.070046">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.203180" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:13.202773" elapsed="0.000441"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:13.204001" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:13.203741" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:13.204173" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:13.203385" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.204869" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:13.204452" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:13.205224" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:13.205386" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:13.205057" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.205843" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:13.205567" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.206982" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:13.206714" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.207465" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:13.207188" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.207875" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.208093" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.208266" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:13.207718" elapsed="0.000608"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.207550" elapsed="0.000805"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:13.208404" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:33:13.208579" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:13.206316" elapsed="0.002288"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:13.205973" elapsed="0.002681"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.208838" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:13.208684" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:13.205949" elapsed="0.002967"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.209536" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:13.209056" elapsed="0.000509"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:13.209615" elapsed="0.000050"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:13.202117" elapsed="0.007649"/>
</kw>
<msg time="2026-06-06T03:33:13.209824" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:13.201131" elapsed="0.008747"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.210388" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.211172" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.211774" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.211967" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.212141" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.212519" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:13.212375" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:13.212358" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.212761" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.212927" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.213089" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:13.212326" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.212221" elapsed="0.000948"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.213311" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.213391" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:33:13.213531" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:13.195924" elapsed="0.017633"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:13.215021" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:13.214725" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:13.215192" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:13.214265" elapsed="0.000951"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.215555" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:13.215292" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.216158" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:13.215844" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:13.215661" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:13.215271" elapsed="0.000973"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.218749" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:13.216393" elapsed="0.002386"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:13.218838" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:33:13.219011" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:13.213908" elapsed="0.005129"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:13.220409" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:13.220127" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:13.220680" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:13.219767" elapsed="0.000940"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:13.220932" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:13.220784" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:13.220764" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.221161" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.221328" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.221395" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:13.223617" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:13.219379" elapsed="0.004288"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.225210" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:13.224923" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:13.225672" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:13.225409" elapsed="0.000310"/>
</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-06-06T03:33:13.232606" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:13.232789" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:13.232911" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:13.227950" elapsed="0.005355">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:13.225790" elapsed="0.007613">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:13.233633" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:13.233443" elapsed="0.000276"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:13.225769" elapsed="0.007975">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:13.234168" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.234311" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:13.234270" elapsed="0.000085"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:13.234250" elapsed="0.000128"/>
</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-06-06T03:33:13.234519" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.234637" elapsed="0.000034"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:13.224040" elapsed="0.010728">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.234845" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:13.173268" elapsed="0.061673">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:13.235291" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:13.235110" elapsed="0.000254"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:13.235092" elapsed="0.000296"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:13.235422" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:13.166188" elapsed="0.069331">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.282218" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:14.281821" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:14.283081" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:14.282801" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:14.283254" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:14.282419" elapsed="0.000860"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.283866" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:14.283438" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:14.284191" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:14.284393" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:14.284048" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.284841" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:14.284572" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.285860" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:14.285580" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.286331" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:14.286061" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.286699" elapsed="0.000058"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.286946" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.287115" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:14.286552" elapsed="0.000620"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.286411" elapsed="0.000792"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:14.287250" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:14.287416" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:14.285264" elapsed="0.002177"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:14.284967" elapsed="0.002505"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.287653" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:14.287497" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:14.284943" elapsed="0.002788"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.288315" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:14.287870" elapsed="0.000569"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:14.288491" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:14.281185" elapsed="0.007434"/>
</kw>
<msg time="2026-06-06T03:33:14.288690" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:14.280241" elapsed="0.008498"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.289232" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.289748" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.290244" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.290425" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.290591" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.290984" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:14.290844" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:14.290829" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.291200" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.291362" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.291521" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:14.290799" elapsed="0.000775"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.290682" elapsed="0.000918"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.291755" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.291836" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:14.291954" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:14.275820" elapsed="0.016160"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:14.293440" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:14.293191" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:14.293605" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:14.292852" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.293963" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:14.293718" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.294510" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:14.294214" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:14.294045" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:14.293699" elapsed="0.000894"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.297044" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:14.294797" elapsed="0.002274"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:14.297123" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:14.297280" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:14.292332" elapsed="0.004973"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:14.298514" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:14.298277" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:14.298686" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:14.297946" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:14.298939" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:14.298803" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:14.298784" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.299161" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.299326" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.299390" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:14.301313" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:14.297608" elapsed="0.003731"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.302743" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:14.302458" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:14.303195" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:14.302950" elapsed="0.000289"/>
</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-06-06T03:33:14.310112" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:14.310247" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:14.310341" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:14.305395" elapsed="0.005349">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:14.303304" elapsed="0.007568">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:14.311057" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:14.310906" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:14.303286" elapsed="0.007859">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:14.311518" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.311666" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:14.311613" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:14.311595" elapsed="0.000141"/>
</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-06-06T03:33:14.311877" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.311947" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:14.301638" elapsed="0.010410">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.312122" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:14.252662" elapsed="0.059553">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:14.312476" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:14.312306" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:14.312289" elapsed="0.000283"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:14.312605" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:14.244855" elapsed="0.067861">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.359801" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:15.359375" elapsed="0.000460"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:15.360685" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:15.360369" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:15.360865" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:15.360010" elapsed="0.000880"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.361461" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:15.361057" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:15.361818" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:15.361987" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:15.361669" elapsed="0.000405"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.362508" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:15.362237" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.363595" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:15.363297" elapsed="0.000361"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.364102" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:15.363820" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.364512" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.364746" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.364921" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:15.364352" elapsed="0.000627"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.364200" elapsed="0.000811"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:15.365061" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:15.365232" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:15.362970" elapsed="0.002287"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:15.362637" elapsed="0.002654"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.365462" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:15.365317" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:15.362613" elapsed="0.002927"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.366170" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:15.365701" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:15.366251" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:15.358764" elapsed="0.007614"/>
</kw>
<msg time="2026-06-06T03:33:15.366435" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:15.357858" elapsed="0.008639"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.367022" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.367530" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.368050" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.368309" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.368491" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.369078" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:15.368934" elapsed="0.000205"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:15.368918" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.369303" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.369469" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.369633" elapsed="0.000037"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:15.368888" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.368570" elapsed="0.001162"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.369876" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.369954" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:15.370072" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:15.353457" elapsed="0.016642"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:15.371347" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:15.371107" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:15.371506" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:15.370768" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.371869" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:15.371605" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.372469" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:15.372138" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:15.371952" elapsed="0.000593"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:15.371586" elapsed="0.000981"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.375006" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:15.372745" elapsed="0.002289"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:15.375086" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:15.375252" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:15.370426" elapsed="0.004851"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:15.376533" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:15.376293" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:15.376728" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:15.375926" elapsed="0.000870"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:15.377018" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:15.376875" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:15.376855" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.377299" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.377470" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.377537" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:15.379506" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:15.375579" elapsed="0.003953"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.380991" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:15.380733" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:15.381449" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:15.381200" elapsed="0.000293"/>
</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-06-06T03:33:15.389092" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:15.389236" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:15.389342" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:15.383886" elapsed="0.005863">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:15.381561" elapsed="0.008275">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:15.390018" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:15.389869" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:15.381542" elapsed="0.008566">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:15.390473" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.390608" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:15.390570" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:15.390552" elapsed="0.000140"/>
</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-06-06T03:33:15.390829" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.390901" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:15.379854" elapsed="0.011151">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.391082" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:15.330365" elapsed="0.060829">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:15.391464" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:15.391290" elapsed="0.000246"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:15.391272" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:15.391629" elapsed="0.000031"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:15.321529" elapsed="0.070217">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.439522" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:16.439119" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:16.440352" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:16.440093" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:16.440526" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:16.439748" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.441130" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:16.440737" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:16.441464" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:16.441736" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:16.441317" elapsed="0.000446"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.442177" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:16.441926" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.443512" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:16.442989" elapsed="0.000571"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.444029" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:16.443741" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.444397" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.444600" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.444791" elapsed="0.000024"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:16.444264" elapsed="0.000587"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.444114" elapsed="0.000769"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:16.444933" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:33:16.445104" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:16.442627" elapsed="0.002502"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:16.442307" elapsed="0.002854"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.445330" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:16.445187" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:16.442282" elapsed="0.003125"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.446061" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:16.445545" elapsed="0.000544"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:16.446139" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:16.438445" elapsed="0.007821"/>
</kw>
<msg time="2026-06-06T03:33:16.446391" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:16.437483" elapsed="0.008960"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.446979" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.447488" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.448009" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.448194" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.448367" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.448752" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:16.448595" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:16.448578" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.448969" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.449131" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.449291" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:16.448547" elapsed="0.000797"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.448444" elapsed="0.000927"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.449513" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.449589" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:33:16.449735" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:16.432998" elapsed="0.016764"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:16.451298" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:16.450838" elapsed="0.000537">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:16.451470" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:16.450427" elapsed="0.001068"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.451895" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:16.451621" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.452448" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:16.452149" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:16.451978" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:16.451602" elapsed="0.000930"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.455218" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:16.452694" elapsed="0.002552"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:16.455302" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:33:16.455470" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:16.450085" elapsed="0.005409"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:16.456842" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:16.456551" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:16.457034" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:16.456202" elapsed="0.000862"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:16.457291" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:16.457147" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:16.457127" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.457518" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.457703" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.457771" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:16.459734" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:16.455836" elapsed="0.003924"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.461181" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:16.460918" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:16.461619" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:16.461374" elapsed="0.000306"/>
</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-06-06T03:33:16.469164" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:16.469315" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:16.469435" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:16.463885" elapsed="0.005983">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:16.461750" elapsed="0.008211">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:16.470185" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:16.470000" elapsed="0.000251"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:16.461731" elapsed="0.008543">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:16.470822" elapsed="0.000029"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.470968" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:16.470926" elapsed="0.000089"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:16.470907" elapsed="0.000129"/>
</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-06-06T03:33:16.471177" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.471247" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:16.460073" elapsed="0.011285">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.471434" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:16.409130" elapsed="0.062400">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:16.471821" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:16.471624" elapsed="0.000270"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:16.471607" elapsed="0.000310"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:16.471949" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:16.401259" elapsed="0.070788">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.518382" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:17.517977" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:17.519197" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:17.518941" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:17.519372" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:17.518586" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.520001" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:17.519559" elapsed="0.000471"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:17.520335" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:17.520505" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:17.520188" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.520962" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:17.520703" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.522006" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:17.521733" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.522597" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:17.522316" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.522977" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.523185" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.523359" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:17.522845" elapsed="0.000575"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.522698" elapsed="0.000752"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:17.523499" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:17.523685" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:17.521392" elapsed="0.002321"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:17.521091" elapsed="0.002656"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.523931" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:17.523784" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:17.521067" elapsed="0.002946"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.524610" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:17.524151" elapsed="0.000504"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:17.524709" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:17.517337" elapsed="0.007507"/>
</kw>
<msg time="2026-06-06T03:33:17.524900" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:17.516444" elapsed="0.008505"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.525448" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.525971" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.526674" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.526864" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.527038" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.527399" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:17.527260" elapsed="0.000232"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:17.527244" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.527672" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.527863" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.528030" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:17.527216" elapsed="0.000869"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.527116" elapsed="0.000995"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.528253" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.528330" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:17.528447" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:17.512132" elapsed="0.016342"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:17.529700" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:17.529452" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:17.529858" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:17.529123" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.530191" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:17.529953" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.530749" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:17.530441" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:17.530272" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:17.529935" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.533197" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:17.530980" elapsed="0.002244"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:17.533276" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:17.533429" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:17.528806" elapsed="0.004647"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:17.534660" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:17.534408" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:17.534818" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:17.534083" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:17.535048" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:17.534912" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:17.534893" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.535270" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.535431" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.535497" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:17.537425" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:17.533761" elapsed="0.003725"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.538890" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:17.538620" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:17.539331" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:17.539085" elapsed="0.000290"/>
</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-06-06T03:33:17.546404" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:17.546543" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:17.546658" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:17.541703" elapsed="0.005518">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:17.539443" elapsed="0.007859">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:17.547481" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:17.547335" elapsed="0.000228"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:17.539424" elapsed="0.008163">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:17.547978" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.548115" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:17.548077" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:17.548059" elapsed="0.000121"/>
</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-06-06T03:33:17.548318" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.548391" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:17.537807" elapsed="0.010689">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.548571" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:17.488249" elapsed="0.060434">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:17.548959" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:17.548780" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:17.548762" elapsed="0.000296"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:17.549091" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:17.481558" elapsed="0.067630">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.597801" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:18.597385" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:18.598615" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:18.598342" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:18.598824" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:18.598008" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.599404" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:18.599013" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:18.599752" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:18.599960" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:18.599588" elapsed="0.000400"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.600392" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:18.600143" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.601724" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:18.601412" elapsed="0.000360"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.602208" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:18.601933" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.602567" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.602806" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.602976" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:18.602436" elapsed="0.000597"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.602291" elapsed="0.000773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:18.603113" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:18.603280" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:18.601088" elapsed="0.002217"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:18.600518" elapsed="0.002821"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.603507" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:18.603365" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:18.600493" elapsed="0.003090"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.604192" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:18.603738" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:18.604270" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:18.596765" elapsed="0.007628"/>
</kw>
<msg time="2026-06-06T03:33:18.604449" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:18.595809" elapsed="0.008688"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.605081" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.605585" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.606169" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.606357" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.606527" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.606935" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:18.606789" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:18.606773" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.607150" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.607310" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.607468" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:18.606742" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.606602" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.607748" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.607827" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:33:18.607950" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:18.591335" elapsed="0.016641"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:18.609368" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:18.609041" elapsed="0.000402">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:18.609540" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:18.608694" elapsed="0.000872"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.609906" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:18.609653" elapsed="0.000364"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.610518" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:18.610219" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:18.610045" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:18.609618" elapsed="0.000982"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.613247" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:18.610777" elapsed="0.002498"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:18.613330" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:18.613491" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:18.608343" elapsed="0.005173"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:18.614877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:18.614554" elapsed="0.000394">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:18.615042" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:18.614210" elapsed="0.000857"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:18.615300" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:33:18.615141" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:18.615121" elapsed="0.000274"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.615540" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.615726" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.615802" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:33:18.617818" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:18.613865" elapsed="0.003987"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.619293" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:18.619030" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:18.619752" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:18.619484" elapsed="0.000316"/>
</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-06-06T03:33:18.627161" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:18.627308" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:18.627418" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:18.622162" elapsed="0.005670">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:18.619988" elapsed="0.007933">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:18.628121" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:18.627958" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:18.619866" elapsed="0.008348">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:18.628624" elapsed="0.000043"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.628860" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:18.628815" elapsed="0.000091"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:18.628796" elapsed="0.000133"/>
</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-06-06T03:33:18.629227" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.629298" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:18.618170" elapsed="0.011237">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.629484" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:18.568083" elapsed="0.061495">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:18.629889" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:18.629689" elapsed="0.000295"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:18.629671" elapsed="0.000363"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:18.630081" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:18.558213" elapsed="0.072008">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.675365" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:19.674971" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:19.676886" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:19.676596" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:19.677061" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:19.676247" elapsed="0.000839"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.677633" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:19.677246" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:19.677976" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:19.678154" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:19.677832" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.678580" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:19.678333" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.679660" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:19.679357" elapsed="0.000351"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.680136" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:19.679865" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.680489" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.680795" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.680966" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:19.680361" elapsed="0.000663"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.680218" elapsed="0.000984"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:19.681251" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:19.681419" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:19.679040" elapsed="0.002404"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:19.678730" elapsed="0.002747"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.681658" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:19.681503" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:19.678705" elapsed="0.003031"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.682319" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:19.681873" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:19.682396" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:19.674353" elapsed="0.008166"/>
</kw>
<msg time="2026-06-06T03:33:19.682574" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:19.673464" elapsed="0.009159"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.683138" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.683675" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.684349" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.684534" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.684720" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.685079" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:19.684940" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:19.684925" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.685295" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.685496" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.685674" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:19.684896" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.684797" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.685904" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.685981" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:19.686098" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:19.669183" elapsed="0.016941"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:19.687338" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:19.687100" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:19.687530" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:19.686771" elapsed="0.000784"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.687889" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:19.687625" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.688430" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:19.688139" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:19.687970" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:19.687606" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.690895" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:19.688671" elapsed="0.002250"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:19.690973" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:33:19.691124" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:19.686438" elapsed="0.004711"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:19.692356" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:19.692122" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:19.692510" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:19.691794" elapsed="0.000741"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:19.692757" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:19.692605" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:19.692586" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.692984" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.693149" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.693214" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:19.696760" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:19.691454" elapsed="0.005334"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.698204" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:19.697914" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:19.698661" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:19.698399" elapsed="0.000309"/>
</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-06-06T03:33:19.705412" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:19.705545" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:19.705669" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:19.700881" elapsed="0.005161">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:19.698775" elapsed="0.007348">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:19.706307" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:19.706157" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:19.698757" elapsed="0.007639">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:19.706778" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.706915" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:19.706875" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:19.706857" elapsed="0.000122"/>
</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-06-06T03:33:19.707117" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.707188" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:19.697090" elapsed="0.010215">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.707381" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:19.646755" elapsed="0.060719">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:19.707758" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:19.707566" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:19.707549" elapsed="0.000306"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:19.707887" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:19.640203" elapsed="0.067777">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.755732" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:20.755316" elapsed="0.000604"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:20.756750" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:20.756452" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:20.756930" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:20.756100" elapsed="0.000855"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.757510" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:20.757118" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:20.757875" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:20.758046" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:20.757715" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.758473" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:20.758226" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.759484" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:20.759228" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.759969" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:20.759699" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.760325" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.760524" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.760706" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:20.760197" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.760053" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:20.760845" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:33:20.761021" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:20.758908" elapsed="0.002138"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:20.758597" elapsed="0.002481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.761245" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:20.761103" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:20.758573" elapsed="0.002749"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.761949" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:20.761459" elapsed="0.000518"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:20.762026" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:20.754709" elapsed="0.007441"/>
</kw>
<msg time="2026-06-06T03:33:20.762205" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:20.753811" elapsed="0.008441"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.762757" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.763297" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.763809" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.763990" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.764158" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.764516" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:20.764375" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:20.764361" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.764748" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.764915" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.765077" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:20.764333" elapsed="0.000796"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.764234" elapsed="0.000920"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.765293" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.765368" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:20.765484" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:20.749251" elapsed="0.016259"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:20.766970" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:20.766522" elapsed="0.000672">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:20.767287" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:20.766189" elapsed="0.001123"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.767624" elapsed="0.000060"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:20.767382" elapsed="0.000340"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.768214" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:20.767918" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:20.767748" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:20.767364" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.770948" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:20.768448" elapsed="0.002527"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:20.771075" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:20.771235" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:20.765858" elapsed="0.005402"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:20.772476" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:20.772228" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:20.772634" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:20.771896" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:20.772883" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:20.772747" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:20.772728" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.773105" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.773270" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.773335" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:20.775290" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:20.771557" elapsed="0.003760"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.776716" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:20.776446" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:20.777158" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:20.776912" elapsed="0.000290"/>
</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-06-06T03:33:20.784625" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:20.784853" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:20.785002" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:20.779370" elapsed="0.006238">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:20.777268" elapsed="0.008493">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:20.786033" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:20.785811" elapsed="0.000314"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:20.777250" elapsed="0.008909">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:20.786832" elapsed="0.000046"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.787080" elapsed="0.000026"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:20.787012" elapsed="0.000146"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:20.786979" elapsed="0.000220"/>
</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-06-06T03:33:20.787457" elapsed="0.000036"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.787581" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:20.775617" elapsed="0.012176">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.787994" elapsed="0.000026"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:20.726515" elapsed="0.061637">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:20.788605" elapsed="0.000068"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:20.788303" elapsed="0.000456"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:20.788277" elapsed="0.000520"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:20.788851" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:20.717635" elapsed="0.071385">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.833748" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:21.833301" elapsed="0.000481"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:21.834543" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:21.834285" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:21.834731" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:21.833950" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.835311" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:21.834921" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:21.835652" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:21.835917" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:21.835496" elapsed="0.000449"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.836348" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:21.836099" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.837425" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:21.837145" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.837917" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:21.837626" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.838268" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.838467" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.838634" elapsed="0.000036"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:21.838139" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.837998" elapsed="0.000742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:21.838855" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:21.839024" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:21.836826" elapsed="0.002223"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:21.836480" elapsed="0.002603"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.839251" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:21.839108" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:21.836447" elapsed="0.002895"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.839954" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:21.839483" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:21.840034" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:21.832695" elapsed="0.007464"/>
</kw>
<msg time="2026-06-06T03:33:21.840214" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:21.831825" elapsed="0.008446"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.840799" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.841304" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.842068" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.842264" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.842435" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.842834" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:21.842684" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:21.842667" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.843052" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.843216" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.843378" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:21.842625" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.842524" elapsed="0.000945"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.843656" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.843736" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:33:21.843863" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:21.827505" elapsed="0.016384"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:21.845134" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:21.844899" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:21.845306" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:21.844545" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.845703" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:21.845434" elapsed="0.000340"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.846271" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:21.845966" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:21.845798" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:21.845415" elapsed="0.000941"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.848810" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:21.846502" elapsed="0.002335"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:21.848890" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:33:21.849055" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:21.844216" elapsed="0.004865"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:21.850331" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:21.850098" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:21.850488" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:21.849744" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:21.850735" elapsed="0.000038"/>
</return>
<status status="PASS" start="2026-06-06T03:33:21.850583" elapsed="0.000235"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:21.850564" elapsed="0.000289"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.850994" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.851157" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.851223" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:21.853222" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:21.849393" elapsed="0.003855"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.854710" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:21.854440" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:21.855173" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:21.854918" elapsed="0.000298"/>
</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-06-06T03:33:21.862422" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:21.862593" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:21.862708" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:21.857624" elapsed="0.005479">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:21.855281" elapsed="0.007904">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:21.863368" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:21.863219" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:21.855263" elapsed="0.008194">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:21.863882" elapsed="0.000034"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.864038" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:21.863999" elapsed="0.000091"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:21.863980" elapsed="0.000133"/>
</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-06-06T03:33:21.864254" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.864326" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:21.853602" elapsed="0.010827">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.864504" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:21.804916" elapsed="0.059683">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:21.864892" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:21.864708" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:21.864691" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:21.865022" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:21.798555" elapsed="0.066564">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.909835" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:22.909420" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:22.910680" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:22.910404" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:22.910852" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:22.910039" elapsed="0.000838"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.911570" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:22.911172" elapsed="0.000426"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:22.911917" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:22.912077" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:22.911770" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.912502" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:22.912255" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.913778" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:22.913500" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.914273" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:22.913979" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.914627" elapsed="0.000041"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.914865" elapsed="0.000027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.915039" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:22.914496" elapsed="0.000600"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.914354" elapsed="0.000773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:22.915174" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:22.915342" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:22.913178" elapsed="0.002189"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:22.912628" elapsed="0.002772"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.915567" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:22.915426" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:22.912604" elapsed="0.003053"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.916266" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:22.915797" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:22.916344" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:22.908807" elapsed="0.007661"/>
</kw>
<msg time="2026-06-06T03:33:22.916523" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:22.907886" elapsed="0.008684"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.917074" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.917572" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.918141" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.918324" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.918490" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.918865" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:22.918727" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:22.918711" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.919081" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.919243" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.919401" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:22.918682" elapsed="0.000772"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.918565" elapsed="0.000915"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.919619" elapsed="0.000034"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.919710" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:22.919829" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:22.903499" elapsed="0.016355"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:22.921079" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:22.920838" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:22.921240" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:22.920486" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.921576" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:22.921336" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.922199" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:22.921855" elapsed="0.000370"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:22.921681" elapsed="0.000580"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:22.921316" elapsed="0.000966"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.924831" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:22.922428" elapsed="0.002430"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:22.924909" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:22.925062" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:22.920166" elapsed="0.004920"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:22.926302" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:22.926049" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:22.926496" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:22.925714" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:22.926749" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:22.926593" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:22.926574" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.926974" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.927138" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.927204" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:22.929120" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:22.925380" elapsed="0.003767"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.930538" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:22.930289" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:22.930991" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:22.930746" elapsed="0.000289"/>
</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-06-06T03:33:22.938053" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:22.938192" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:22.938297" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:22.933261" elapsed="0.005538">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:22.931101" elapsed="0.007782">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:22.939070" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:22.938918" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:22.931082" elapsed="0.008076">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:22.939539" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.939696" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:22.939637" elapsed="0.000102"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:22.939618" elapsed="0.000144"/>
</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-06-06T03:33:22.939898" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.939969" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:22.929449" elapsed="0.010625">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.940149" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:22.880969" elapsed="0.059274">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:22.940574" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:22.940395" elapsed="0.000266"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:22.940377" elapsed="0.000310"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:22.940720" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:22.874464" elapsed="0.066352">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.986571" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:23.986170" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:23.987386" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:23.987131" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:23.987559" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:23.986792" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.988172" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:23.987763" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:23.988519" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:23.988706" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:23.988369" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.989142" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:23.988889" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.990164" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:23.989906" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.990635" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:23.990363" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.991015" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.991217" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.991387" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:23.990883" elapsed="0.000562"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:23.990733" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:23.991525" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:23.991709" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:23.989571" elapsed="0.002164"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:23.989267" elapsed="0.002500"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.991951" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:23.991794" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:23.989244" elapsed="0.002784"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.992619" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:23.992169" elapsed="0.000562"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:23.992785" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:23.985537" elapsed="0.007376"/>
</kw>
<msg time="2026-06-06T03:33:23.992967" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:23.984597" elapsed="0.008418"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.993511" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.994050" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.994759" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.994947" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.995115" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.995470" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:23.995332" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:23.995317" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.995701" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.995865" elapsed="0.000044"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.996053" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:23.995290" elapsed="0.000818"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:23.995190" elapsed="0.000943"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.996272" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:23.996348" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:23.996465" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:23.980155" elapsed="0.016335"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:23.997762" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:23.997510" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:23.997919" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:23.997178" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:23.998253" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:23.998014" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:23.998815" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:23.998503" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:23.998334" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:23.997995" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:24.001286" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:23.999049" elapsed="0.002265"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:24.001365" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:24.001518" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:23.996859" elapsed="0.004684"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:24.002865" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:24.002613" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:24.003023" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:24.002282" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:24.003259" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:24.003123" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:24.003104" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:24.003481" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:24.003661" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:24.003728" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:24.005657" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:24.001960" elapsed="0.003724"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:24.007056" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:24.006807" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:24.007489" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:24.007247" elapsed="0.000285"/>
</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-06-06T03:33:24.014668" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:24.014813" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:24.014913" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:24.009856" elapsed="0.005431">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:24.007597" elapsed="0.007813">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:24.015601" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:24.015445" elapsed="0.000238"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:24.007578" elapsed="0.008130">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:24.016102" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:24.016236" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:24.016197" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:24.016179" elapsed="0.000120"/>
</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-06-06T03:33:24.016440" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:24.016509" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:24.005987" elapsed="0.010626">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:24.016705" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:23.956942" elapsed="0.059858">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:24.017070" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:24.016892" elapsed="0.000250"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:24.016875" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:24.017199" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:23.950522" elapsed="0.066771">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.062532" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:25.062132" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:25.063358" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:25.063100" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:25.063531" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:25.062768" elapsed="0.000788"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.064131" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:25.063734" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:25.064461" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:25.064631" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:25.064318" elapsed="0.000441"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.065395" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:25.064922" elapsed="0.000520"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.066430" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:25.066171" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.066963" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:25.066685" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.067323" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.067523" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.067705" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:25.067194" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.067046" elapsed="0.000748"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:25.067842" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:25.068009" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:25.065844" elapsed="0.002191"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:25.065520" elapsed="0.002550"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.068235" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:25.068095" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:25.065497" elapsed="0.002814"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.068920" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:25.068446" elapsed="0.000502"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:25.068998" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:25.061465" elapsed="0.007656"/>
</kw>
<msg time="2026-06-06T03:33:25.069175" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:25.060536" elapsed="0.008686"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.069724" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.070241" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.070789" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.071011" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.071184" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.071542" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:25.071404" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:25.071388" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.071795" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.071958" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.072118" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:25.071360" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.071259" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.072354" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.072431" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:25.072552" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:25.055743" elapsed="0.016835"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:25.073876" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:25.073580" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:25.074071" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:25.073237" elapsed="0.000870"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.074434" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:25.074192" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.075015" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:25.074723" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:25.074532" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:25.074172" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.079176" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:25.075240" elapsed="0.003964"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:25.079257" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:25.079413" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:25.072911" elapsed="0.006527"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:25.080902" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:25.080628" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:25.081069" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:25.080249" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:25.081320" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:25.081171" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:25.081150" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.081606" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.081793" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.081860" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:25.083847" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:25.079905" elapsed="0.003969"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.085281" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:25.085019" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:25.085733" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:25.085474" elapsed="0.000303"/>
</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-06-06T03:33:25.092687" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:25.092830" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:25.092949" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:25.088162" elapsed="0.005300">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:25.085843" elapsed="0.007763">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:25.093967" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:25.093697" elapsed="0.000390"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:25.085825" elapsed="0.008306">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:25.094759" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.094952" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:25.094898" elapsed="0.000115"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:25.094874" elapsed="0.000171"/>
</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-06-06T03:33:25.095354" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.095452" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:25.084186" elapsed="0.011413">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.095729" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:25.033155" elapsed="0.062708">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:25.096238" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:25.095994" elapsed="0.000344"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:25.095969" elapsed="0.000402"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:25.096522" elapsed="0.000028"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:25.026825" elapsed="0.069902">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.152585" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:26.152083" elapsed="0.000544"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:26.153801" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:26.153326" elapsed="0.000613">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:26.154064" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:26.152876" elapsed="0.001220"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.154896" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:26.154312" elapsed="0.000621"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:26.155332" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:26.155538" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:26.155146" elapsed="0.000425"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.156129" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:26.155800" elapsed="0.000391"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.157475" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:26.157143" elapsed="0.000390"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.158144" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:26.157764" elapsed="0.000412"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.158609" elapsed="0.000045"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.158901" elapsed="0.000033"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.159131" elapsed="0.000027"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:26.158433" elapsed="0.000773"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.158248" elapsed="0.000997"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:26.159309" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:33:26.159521" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:26.156712" elapsed="0.002842"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:26.156292" elapsed="0.003303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.159845" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:26.159627" elapsed="0.000298"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:26.156261" elapsed="0.003692"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.160728" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:26.160139" elapsed="0.000627"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:26.160830" elapsed="0.000039"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:26.151259" elapsed="0.009737"/>
</kw>
<msg time="2026-06-06T03:33:26.161135" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:26.150053" elapsed="0.011148"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.161914" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.162577" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.163257" elapsed="0.000032"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.163499" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.163747" elapsed="0.000029"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.164504" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:26.164315" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:26.164292" elapsed="0.000316"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.164816" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.165042" elapsed="0.000027"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.165257" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:26.164255" elapsed="0.001070"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.163850" elapsed="0.001509"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.165545" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.165662" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:33:26.165843" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:26.143964" elapsed="0.021915"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:26.167510" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:26.167191" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:26.167743" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:26.166734" elapsed="0.001044"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.168277" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:26.167955" elapsed="0.000394"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.169016" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:26.168603" elapsed="0.000447"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:26.168382" elapsed="0.000714"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:26.167929" elapsed="0.001195"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.172466" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:26.169322" elapsed="0.003178"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:26.172566" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:33:26.172796" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:26.166293" elapsed="0.006536"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:26.174436" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:26.174134" elapsed="0.000383">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:26.174635" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:26.173629" elapsed="0.001057"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:26.174966" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:33:26.174786" elapsed="0.000257"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:26.174760" elapsed="0.000316"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.175265" elapsed="0.000027"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.175479" elapsed="0.000025"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.175561" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:33:26.178297" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:26.173216" elapsed="0.005114"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.180159" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:26.179827" elapsed="0.000392"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:26.180762" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:26.180413" elapsed="0.000408"/>
</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-06-06T03:33:26.189384" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:26.189558" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:26.189737" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:26.184099" elapsed="0.006139">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:26.180910" elapsed="0.009437">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:26.190601" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:26.190393" elapsed="0.000312"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:26.180884" elapsed="0.009858">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:26.191339" elapsed="0.000033"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.191516" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:26.191466" elapsed="0.000105"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:26.191442" elapsed="0.000158"/>
</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-06-06T03:33:26.191811" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.191908" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:26.178747" elapsed="0.013304">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.192148" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:26.112309" elapsed="0.079964">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:26.192620" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:26.192395" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:26.192372" elapsed="0.000399"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:26.192815" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:26.103471" elapsed="0.089475">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.238055" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:27.237615" elapsed="0.000473"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:27.238869" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:27.238588" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:27.239041" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:27.238257" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.239612" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:27.239225" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:27.239984" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:27.240152" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:27.239838" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.240579" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:27.240329" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.241879" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:27.241586" elapsed="0.000341"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.242430" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:27.242154" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.242802" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.243002" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.243175" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:27.242668" elapsed="0.000566"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.242511" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:27.243312" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:27.243478" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:27.241260" elapsed="0.002244"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:27.240721" elapsed="0.002815"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.243718" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:27.243562" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:27.240697" elapsed="0.003098"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.244375" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:27.243932" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:27.244453" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:27.236997" elapsed="0.007580"/>
</kw>
<msg time="2026-06-06T03:33:27.244632" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:27.236114" elapsed="0.008582"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.245243" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.245768" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.246288" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.246470" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.246654" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.247016" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:27.246874" elapsed="0.000268"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:27.246859" elapsed="0.000309"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.247307" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.247471" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.247632" elapsed="0.000035"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:27.246831" elapsed="0.000871"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.246731" elapsed="0.000997"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.247870" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.247946" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:27.248062" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:27.231823" elapsed="0.016264"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:27.249321" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:27.249077" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:27.249482" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:27.248739" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.249868" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:27.249577" elapsed="0.000349"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.250413" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:27.250119" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:27.249950" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:27.249559" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.253066" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:27.250654" elapsed="0.002439"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:27.253150" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:27.253305" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:27.248402" elapsed="0.004928"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:27.254552" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:27.254316" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:27.254727" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:27.253983" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:27.254963" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:27.254826" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:27.254806" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.255191" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.255357" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.255435" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:27.257380" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:27.253627" elapsed="0.003825"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.258867" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:27.258597" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:27.259308" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:27.259062" elapsed="0.000291"/>
</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-06-06T03:33:27.265828" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:27.265966" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:27.266066" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:27.261492" elapsed="0.004945">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:27.259419" elapsed="0.007101">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:27.266723" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:27.266553" elapsed="0.000237"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:27.259400" elapsed="0.007415">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:27.267188" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.267324" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:27.267285" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:27.267267" elapsed="0.000125"/>
</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-06-06T03:33:27.267534" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.267606" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:27.257775" elapsed="0.009953">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.267806" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:27.209207" elapsed="0.058696">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:27.268178" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:27.267999" elapsed="0.000254"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:27.267981" elapsed="0.000298"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:27.268313" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:27.202598" elapsed="0.065811">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.320465" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:28.320066" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:28.321279" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:28.321021" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:28.321449" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:28.320685" elapsed="0.000789"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.322043" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:28.321637" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:28.322372" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:28.322550" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:28.322229" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.322997" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:28.322744" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.324019" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:28.323757" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.324493" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:28.324221" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.324865" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.325070" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.325242" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:28.324733" elapsed="0.000567"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.324574" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:28.325378" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:28.325544" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:28.323423" elapsed="0.002146"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:28.323121" elapsed="0.002482"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.325785" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:28.325627" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:28.323098" elapsed="0.002764"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.326478" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:28.326000" elapsed="0.000507"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:28.326558" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:28.319438" elapsed="0.007265"/>
</kw>
<msg time="2026-06-06T03:33:28.326759" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:28.318527" elapsed="0.008280"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.327359" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.327887" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.328593" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.328797" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.328971" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.329332" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:28.329192" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:28.329177" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.329549" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.329727" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.329890" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:28.329148" elapsed="0.000796"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.329047" elapsed="0.000923"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.330109" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.330185" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:28.330302" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:28.314177" elapsed="0.016151"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:28.331584" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:28.331348" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:28.331767" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:28.331015" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.332100" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:28.331862" elapsed="0.000327"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.332705" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:28.332390" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:28.332217" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:28.331843" elapsed="0.000947"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.335177" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:28.332935" elapsed="0.002269"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:28.335255" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:28.335409" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:28.330687" elapsed="0.004747"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:28.336637" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:28.336405" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:28.336812" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:28.336073" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:28.337045" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:28.336909" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:28.336889" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.337268" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.337432" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.337497" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:33:28.339451" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:28.335753" elapsed="0.003724"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.340860" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:28.340594" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:28.341293" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:28.341051" elapsed="0.000286"/>
</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-06-06T03:33:28.348346" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:28.348522" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:28.348682" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:28.343674" elapsed="0.005495">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:28.341403" elapsed="0.007879">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:28.349533" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:28.349328" elapsed="0.000297"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:28.341385" elapsed="0.008295">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:28.350192" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.350448" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:28.350392" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:28.350347" elapsed="0.000194"/>
</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-06-06T03:33:28.350756" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.350856" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:28.339792" elapsed="0.011208">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.351104" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:28.284469" elapsed="0.066766">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:28.351602" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:28.351364" elapsed="0.000360"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:28.351340" elapsed="0.000418"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:28.351804" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:28.274438" elapsed="0.077496">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.397862" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:29.397450" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:29.398675" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:29.398401" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:29.398844" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:29.398064" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.399420" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:29.399029" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:29.399787" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:29.399990" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:29.399627" elapsed="0.000390"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.400417" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:29.400168" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.401656" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:29.401382" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.402129" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:29.401860" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.402509" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.402798" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.402972" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:29.402380" elapsed="0.000651"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.402222" elapsed="0.000839"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:29.403108" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:29.403280" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:29.401060" elapsed="0.002246"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:29.400539" elapsed="0.002799"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.403505" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:29.403363" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:29.400516" elapsed="0.003081"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.404195" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:29.403753" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:29.404279" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:29.396846" elapsed="0.007556"/>
</kw>
<msg time="2026-06-06T03:33:29.404457" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:29.395978" elapsed="0.008526"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.405011" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.405532" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.406080" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.406268" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.406439" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.406809" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:29.406669" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:29.406652" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.407023" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.407222" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.407386" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:29.406610" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.406513" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.407624" elapsed="0.000037"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.407720" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:29.407841" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:29.391681" elapsed="0.016195"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:29.409125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:29.408889" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:29.409287" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:29.408537" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.409668" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:29.409384" elapsed="0.000345"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.410217" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:29.409922" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:29.409754" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:29.409364" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.412851" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:29.410445" elapsed="0.002433"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:29.412932" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:29.413086" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:29.408216" elapsed="0.004895"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:29.414304" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:29.414072" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:29.414459" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:29.413738" elapsed="0.000745"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:29.414707" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:29.414554" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:29.414535" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.414927" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.415092" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.415157" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:29.417094" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:29.413406" elapsed="0.003714"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.418521" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:29.418234" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:29.418975" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:29.418728" elapsed="0.000291"/>
</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-06-06T03:33:29.425705" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:29.425844" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:29.425937" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:29.421164" elapsed="0.005130">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:29.419085" elapsed="0.007292">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:29.426558" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:29.426410" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:29.419067" elapsed="0.007595">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:29.427023" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.427155" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:29.427118" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:29.427101" elapsed="0.000122"/>
</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-06-06T03:33:29.427358" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.427427" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:29.417420" elapsed="0.010151">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.427662" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:29.369156" elapsed="0.058603">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:29.428039" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:29.427851" elapsed="0.000260"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:29.427834" elapsed="0.000301"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:29.428167" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:29.361148" elapsed="0.067114">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.473348" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:30.472931" elapsed="0.000520"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:30.474244" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:30.473980" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:30.474414" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:30.473624" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.475003" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:30.474599" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:30.475329" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:30.475543" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:30.475186" elapsed="0.000384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.475996" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:30.475743" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.477004" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:30.476747" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.477497" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:30.477228" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.477866" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.478069" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.478236" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:30.477736" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.477578" elapsed="0.000746"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:30.478371" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:30.478535" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:30.476414" elapsed="0.002147"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:30.476119" elapsed="0.002474"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.478775" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:30.478617" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:30.476097" elapsed="0.002757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.479435" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:30.478991" elapsed="0.000472"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:30.479512" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:30.472305" elapsed="0.007332"/>
</kw>
<msg time="2026-06-06T03:33:30.479708" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:30.471432" elapsed="0.008325"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.480248" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.482513" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.483044" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.483230" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.483401" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.483777" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:30.483621" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:30.483605" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.484003" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.484167" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.484328" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:30.483577" elapsed="0.000805"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.483477" elapsed="0.000932"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.484550" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.484627" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:30.484765" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:30.467115" elapsed="0.017677"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:30.486067" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:30.485822" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:30.486229" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:30.485467" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.486562" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:30.486323" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.487129" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:30.486835" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:30.486666" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:30.486305" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.489761" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:30.487357" elapsed="0.002431"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:30.489878" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:30.490037" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:30.485141" elapsed="0.004921"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:30.491269" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:30.491034" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:30.491427" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:30.490701" elapsed="0.000751"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:30.491677" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:30.491523" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:30.491504" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.491905" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.492069" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.492135" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:30.494223" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:30.490364" elapsed="0.003886"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.495625" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:30.495370" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:30.496086" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:30.495837" elapsed="0.000295"/>
</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-06-06T03:33:30.504318" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:30.504461" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:30.504580" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:30.498392" elapsed="0.006601">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:30.496200" elapsed="0.008880">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:30.505267" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:30.505116" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:30.496181" elapsed="0.009174">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:30.505773" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.505915" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:30.505874" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:30.505855" elapsed="0.000124"/>
</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-06-06T03:33:30.506118" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.506189" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:30.494550" elapsed="0.011751">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.506435" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:30.444638" elapsed="0.061895">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:30.506820" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:30.506628" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:30.506610" elapsed="0.000306"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:30.506950" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:30.438381" elapsed="0.068665">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.553855" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:31.553442" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:31.554660" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:31.554391" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:31.554834" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:31.554057" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.555425" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:31.555033" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:31.555769" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:31.555932" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:31.555610" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.556376" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:31.556113" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.557439" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:31.557139" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.558099" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:31.557733" elapsed="0.000394"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.558462" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.558681" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.558851" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:31.558331" elapsed="0.000601"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.558184" elapsed="0.000779"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:31.559079" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:33:31.559250" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:31.556820" elapsed="0.002455"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:31.556499" elapsed="0.002808"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.559475" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:31.559333" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:31.556476" elapsed="0.003075"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.560150" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:31.559703" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:31.560227" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:31.552823" elapsed="0.007527"/>
</kw>
<msg time="2026-06-06T03:33:31.560404" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:31.551905" elapsed="0.008547"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.560971" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.561474" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.561990" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.562172" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.562339" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.562707" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:31.562553" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:31.562538" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.562950" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.563114" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.563279" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:31.562511" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.562413" elapsed="0.000944"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.563553" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.563631" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:31.563765" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:31.547171" elapsed="0.016620"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:31.565197" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:31.564772" elapsed="0.000491">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:31.565357" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:31.564422" elapsed="0.000960"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.565711" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:31.565454" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.566261" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:31.565966" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:31.565794" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:31.565435" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.568989" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:31.566538" elapsed="0.002478"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:31.569070" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:31.569228" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:31.564106" elapsed="0.005150"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:31.570460" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:31.570225" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:31.570617" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:31.569892" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:31.570877" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:31.570730" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:31.570711" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.571102" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.571266" elapsed="0.000019"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.571330" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:31.573264" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:31.569553" elapsed="0.003738"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.574734" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:31.574463" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:31.575209" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:31.574963" elapsed="0.000290"/>
</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-06-06T03:33:31.581984" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:31.582167" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:31.582270" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:31.577393" elapsed="0.005240">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:31.575318" elapsed="0.007416">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:31.582941" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:31.582767" elapsed="0.000241"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:31.575300" elapsed="0.007732">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:31.583400" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.583533" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:31.583495" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:31.583477" elapsed="0.000120"/>
</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-06-06T03:33:31.583751" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.583822" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:31.573589" elapsed="0.010337">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.584000" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:31.524325" elapsed="0.059770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:31.584366" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:31.584189" elapsed="0.000250"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:31.584171" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:31.584495" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:31.516430" elapsed="0.068162">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.630791" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:32.630311" elapsed="0.000517"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:32.631611" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:32.631347" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:32.631806" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:32.631006" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.632498" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:32.632085" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:32.632856" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:32.633016" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:32.632703" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.633486" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:32.633225" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.634545" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:32.634275" elapsed="0.000318"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.635052" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:32.634771" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.635415" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.635620" elapsed="0.000040"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.635812" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:32.635281" elapsed="0.000591"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.635135" elapsed="0.000768"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:32.635951" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:32.636122" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:32.633947" elapsed="0.002200"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:32.633616" elapsed="0.002565"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.636357" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:32.636207" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:32.633592" elapsed="0.002844"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.637077" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:32.636577" elapsed="0.000535"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:32.637167" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:32.629504" elapsed="0.007793"/>
</kw>
<msg time="2026-06-06T03:33:32.637354" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:32.628293" elapsed="0.009110"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.637924" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.638429" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.639194" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.639384" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.639557" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.639940" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:32.639797" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:32.639781" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.640159" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.640322" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.640484" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:32.639752" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.639634" elapsed="0.000930"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.640722" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.640801" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:32.640920" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:32.623765" elapsed="0.017181"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:32.644693" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:32.643965" elapsed="0.000905">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:32.645170" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:32.642996" elapsed="0.002235"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.646059" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:32.645416" elapsed="0.000777"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.647450" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:32.646691" elapsed="0.000820"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:32.646253" elapsed="0.001341"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:32.645363" elapsed="0.002319"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.653276" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:32.648028" elapsed="0.005314"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:32.653464" elapsed="0.000083"/>
</return>
<msg time="2026-06-06T03:33:32.653888" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:32.641992" elapsed="0.011954"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:32.656794" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:32.656191" elapsed="0.000760">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:32.657302" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:32.655380" elapsed="0.001948"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:32.657543" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:32.657403" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:32.657383" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.657790" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.657959" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.658026" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:32.660011" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:32.654625" elapsed="0.005414"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.661491" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:32.661226" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:32.661954" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:32.661704" elapsed="0.000295"/>
</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-06-06T03:33:32.668889" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:32.669059" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:32.669159" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:32.664398" elapsed="0.005144">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:32.662080" elapsed="0.007547">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:32.669836" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:32.669684" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:32.662060" elapsed="0.007865">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:32.670301" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.670435" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:32.670397" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:32.670379" elapsed="0.000120"/>
</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-06-06T03:33:32.670637" elapsed="0.000039"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.670726" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:32.660360" elapsed="0.010472">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.670905" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:32.600881" elapsed="0.070121">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:32.671351" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:32.671161" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:32.671142" elapsed="0.000308"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:32.671483" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:32.594594" elapsed="0.077000">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.715889" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:33.715455" elapsed="0.000468"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:33.716749" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:33.716431" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:33.716924" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:33.716093" elapsed="0.000857"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.717547" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:33.717121" elapsed="0.000455"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:33.717900" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:33.718139" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:33.717753" elapsed="0.000414"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.718580" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:33.718326" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.719956" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:33.719660" elapsed="0.000357"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.720490" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:33.720194" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.720868" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.721101" elapsed="0.000033"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.721295" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:33.720734" elapsed="0.000620"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.720573" elapsed="0.000811"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:33.721440" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:33:33.721617" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:33.719272" elapsed="0.002388"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:33.718731" elapsed="0.002965"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.721866" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:33.721721" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:33.718707" elapsed="0.003234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.722551" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:33.722100" elapsed="0.000555"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:33.722710" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:33.714824" elapsed="0.008016"/>
</kw>
<msg time="2026-06-06T03:33:33.722896" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:33.713939" elapsed="0.009005"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.723438" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.723995" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.724494" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.724713" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.724889" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.725246" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:33.725107" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:33.725092" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.725461" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.725623" elapsed="0.000037"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.725803" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:33.725064" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.724966" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.726021" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.726097" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:33.726214" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:33.709394" elapsed="0.016846"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:33.727567" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:33.727308" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:33.727766" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:33.726968" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.728112" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:33.727870" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.728701" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:33.728361" elapsed="0.000367"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:33.728194" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:33.727851" elapsed="0.000933"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.731541" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:33.728930" elapsed="0.002643"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:33.731660" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:33.731826" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:33.726595" elapsed="0.005256"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:33.733122" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:33.732854" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:33.733284" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:33.732504" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:33.733569" elapsed="0.000034"/>
</return>
<status status="PASS" start="2026-06-06T03:33:33.733391" elapsed="0.000279"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:33.733365" elapsed="0.000343"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.733866" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.734083" elapsed="0.000029"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.734175" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:33:33.736180" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:33.732152" elapsed="0.004056"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.737775" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:33.737364" elapsed="0.000457"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:33.738214" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:33.737969" elapsed="0.000290"/>
</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-06-06T03:33:33.745380" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:33.745610" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:33.745822" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:33.740492" elapsed="0.005980">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:33.738329" elapsed="0.008372">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:33.747052" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:33.746772" elapsed="0.000405"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:33.738309" elapsed="0.008913">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:33.747966" elapsed="0.000048"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.748215" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:33.748144" elapsed="0.000154"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:33.748110" elapsed="0.000236"/>
</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-06-06T03:33:33.748602" elapsed="0.000069"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.748763" elapsed="0.000031"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:33.736510" elapsed="0.012448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.749100" elapsed="0.000029"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:33.685304" elapsed="0.063971">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:33.749789" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:33.749448" elapsed="0.000479"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:33.749416" elapsed="0.000558"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:33.750031" elapsed="0.000025"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:33.678578" elapsed="0.071627">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.798198" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:34.797771" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:34.799062" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:34.798761" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:34.799249" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:34.798408" elapsed="0.000866"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.799860" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:34.799444" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:34.800203" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:34.800388" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:34.800049" elapsed="0.000473"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.800961" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:34.800698" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.802002" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:34.801737" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.802520" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:34.802235" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.802908" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.803115" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.803287" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:34.802774" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.802604" elapsed="0.000773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:34.803430" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:34.803601" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:34.801394" elapsed="0.002233"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:34.801089" elapsed="0.002589"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.803850" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:34.803704" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:34.801065" elapsed="0.002863"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.804519" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:34.804067" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:34.804597" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:34.797131" elapsed="0.007610"/>
</kw>
<msg time="2026-06-06T03:33:34.804796" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:34.796087" elapsed="0.008757"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.805335" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.805871" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.806608" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.806850" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.807022" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.807377" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:34.807239" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:34.807224" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.807591" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.807769" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.807929" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:34.807197" elapsed="0.000784"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.807098" elapsed="0.000909"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.808146" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.808221" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:34.808339" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:34.791697" elapsed="0.016667"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:34.809575" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:34.809341" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:34.809748" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:34.809008" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.810087" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:34.809844" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.810672" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:34.810362" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:34.810187" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:34.809825" elapsed="0.000931"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.813110" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:34.810904" elapsed="0.002234"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:34.813190" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:34.813344" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:34.808692" elapsed="0.004676"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:34.814599" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:34.814360" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:34.814775" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:34.814006" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:34.815013" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:34.814874" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:34.814855" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.815278" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.815446" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.815513" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:34.817427" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:34.813684" elapsed="0.003770"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.818907" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:34.818635" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:34.819345" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:34.819102" elapsed="0.000287"/>
</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-06-06T03:33:34.826735" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:34.826874" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:34.826972" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:34.821697" elapsed="0.005669">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:34.819455" elapsed="0.008002">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:34.827656" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:34.827490" elapsed="0.000233"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:34.819436" elapsed="0.008311">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:34.828116" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.828248" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:34.828211" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:34.828192" elapsed="0.000120"/>
</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-06-06T03:33:34.828452" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.828521" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:34.817771" elapsed="0.010855">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.828716" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:34.769001" elapsed="0.059813">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:34.829081" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:34.828907" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:34.828890" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:34.829247" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:34.761726" elapsed="0.067620">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.874963" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:35.874544" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:35.875781" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:35.875505" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:35.875958" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:35.875168" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.876528" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:35.876144" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:35.876870" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:35.877054" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:35.876726" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.879248" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:35.877234" elapsed="0.002062"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.880271" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:35.880009" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.880760" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:35.880471" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.881160" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.881363" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.881531" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:35.880981" elapsed="0.000607"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.880839" elapsed="0.000780"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:35.881684" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:35.881851" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:35.879686" elapsed="0.002191"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:35.879374" elapsed="0.002534"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.882075" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:35.881933" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:35.879350" elapsed="0.002801"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.882755" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:35.882285" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:35.882831" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:35.873937" elapsed="0.009018"/>
</kw>
<msg time="2026-06-06T03:33:35.883066" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:35.873042" elapsed="0.010072"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.883604" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.884120" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.884622" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.884820" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.884987" elapsed="0.000034"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.885358" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:35.885219" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:35.885203" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.885572" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.885750" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.885912" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:35.885175" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.885077" elapsed="0.000913"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.886129" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.886204" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:35.886319" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:35.868652" elapsed="0.017694"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:35.887553" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:35.887317" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:35.887729" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:35.886987" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.888098" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:35.887858" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.888659" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:35.888349" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:35.888180" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:35.887838" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.891306" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:35.888890" elapsed="0.002450"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:35.891393" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:35.891550" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:35.886668" elapsed="0.004906"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:35.892803" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:35.892545" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:35.892961" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:35.892211" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:35.893282" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:35.893135" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:35.893114" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.893514" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.893699" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.893768" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:35.895860" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:35.891888" elapsed="0.004002"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.897345" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:35.897090" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:35.897801" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:35.897539" elapsed="0.000306"/>
</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-06-06T03:33:35.905064" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:35.905243" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:35.905390" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:35.899987" elapsed="0.005829">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:35.897912" elapsed="0.008000">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:35.906144" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:35.905952" elapsed="0.000260"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:35.897893" elapsed="0.008343">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:35.906755" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.906900" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:35.906858" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:35.906838" elapsed="0.000130"/>
</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-06-06T03:33:35.907108" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.907178" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:35.896192" elapsed="0.011096">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.907363" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:35.846304" elapsed="0.061154">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:35.907741" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:35.907551" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:35.907534" elapsed="0.000307"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:35.907873" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:35.836978" elapsed="0.070991">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.956303" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:36.955892" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:36.957122" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:36.956862" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:36.957297" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:36.956513" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.957889" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:36.957483" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:36.958218" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:36.958385" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:36.958076" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.958839" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:36.958568" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.959874" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:36.959597" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.960459" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:36.960181" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.960834" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.961037" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.961207" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:36.960702" elapsed="0.000563"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.960542" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:36.961344" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:36.961512" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:36.959273" elapsed="0.002265"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:36.958966" elapsed="0.002604"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.961754" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:36.961595" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:36.958942" elapsed="0.002890"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.962416" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:36.961970" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:36.962494" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:36.955256" elapsed="0.007362"/>
</kw>
<msg time="2026-06-06T03:33:36.962690" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:36.954331" elapsed="0.008408"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.963232" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.963748" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.964265" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.964445" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.964612" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.965193" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:36.965050" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:36.965034" elapsed="0.000301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.965473" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.965651" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.965816" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:36.965005" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.964704" elapsed="0.001192"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.966037" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.966114" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:36.966232" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:36.949793" elapsed="0.016465"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:36.967487" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:36.967244" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:36.967660" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:36.966909" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.967999" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:36.967759" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.968571" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:36.968277" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:36.968107" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:36.967740" elapsed="0.000938"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.971068" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:36.968826" elapsed="0.002269"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:36.971147" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:36.971300" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:36.966572" elapsed="0.004753"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:36.972548" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:36.972312" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:36.972723" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:36.971955" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:36.972958" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:36.972821" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:36.972801" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.973182" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.973348" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.973414" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:36.975358" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:36.971619" elapsed="0.003813"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.976896" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:36.976617" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:36.977339" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:36.977092" elapsed="0.000292"/>
</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-06-06T03:33:36.984554" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:36.984723" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:36.984830" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:36.979763" elapsed="0.005455">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:36.977451" elapsed="0.007850">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:36.985492" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:36.985335" elapsed="0.000221"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:36.977432" elapsed="0.008148">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:36.985989" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.986126" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:36.986087" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:36.986069" elapsed="0.000123"/>
</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-06-06T03:33:36.986331" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.986403" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:36.975774" elapsed="0.010735">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.986583" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:36.926373" elapsed="0.060321">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:36.986964" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:36.986790" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:36.986773" elapsed="0.000288"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:36.987094" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:36.917311" elapsed="0.069879">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.038099" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:38.037701" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:38.038939" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:38.038635" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:38.039113" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:38.038301" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.039744" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:38.039329" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:38.040073" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:38.040336" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:38.039929" elapsed="0.000434"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.040794" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:38.040519" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.042080" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:38.041818" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.042563" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:38.042283" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.042967" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.043169" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.043379" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:38.042832" elapsed="0.000606"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.042678" elapsed="0.000792"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:38.043520" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:38.043709" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:38.041474" elapsed="0.002261"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:38.040919" elapsed="0.002850"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.043939" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:38.043796" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:38.040895" elapsed="0.003120"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.044611" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:38.044155" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:38.044707" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:38.037067" elapsed="0.007770"/>
</kw>
<msg time="2026-06-06T03:33:38.044894" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:38.036135" elapsed="0.008807"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.045517" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.046061" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.046564" elapsed="0.000031"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.046779" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.046950" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.047356" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:38.047170" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:38.047155" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.047575" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.047754" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.047916" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:38.047127" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.047026" elapsed="0.000967"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.048134" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.048209" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:38.048329" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:38.031656" elapsed="0.016699"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:38.049584" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:38.049340" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:38.049765" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:38.049005" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.050103" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:38.049861" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.050712" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:38.050391" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:38.050219" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:38.049842" elapsed="0.000954"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.053373" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:38.050942" elapsed="0.002466"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:38.053472" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:38.053662" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:38.048684" elapsed="0.005007"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:38.055026" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:38.054719" elapsed="0.000396">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:38.055288" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:38.054328" elapsed="0.000999"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:38.055613" elapsed="0.000058"/>
</return>
<status status="PASS" start="2026-06-06T03:33:38.055425" elapsed="0.000295"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:38.055400" elapsed="0.000356"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.055951" elapsed="0.000031"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.056185" elapsed="0.000028"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.056274" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:33:38.059016" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:38.053998" elapsed="0.005057"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.060750" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:38.060449" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:38.061201" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:38.060949" elapsed="0.000296"/>
</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-06-06T03:33:38.072862" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:38.073086" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:38.073259" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:38.063568" elapsed="0.010317">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:38.061315" elapsed="0.012701">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:38.074357" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:38.074074" elapsed="0.000382"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:38.061296" elapsed="0.013196">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:38.075116" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.075497" elapsed="0.000025"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:38.075432" elapsed="0.000134"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:38.075398" elapsed="0.000203"/>
</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-06-06T03:33:38.075833" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.075934" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:38.059523" elapsed="0.016570">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.076199" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:38.007894" elapsed="0.068441">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:38.077093" elapsed="0.000077"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:38.076468" elapsed="0.000830"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:38.076442" elapsed="0.000919"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:38.077446" elapsed="0.000035"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:37.998772" elapsed="0.078971">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.122978" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:39.122546" elapsed="0.000465"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:39.123792" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:39.123518" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:39.123963" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:39.123183" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.124549" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:39.124153" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:39.124894" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:39.125061" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:39.124749" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.125487" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:39.125239" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.126495" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:39.126240" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.127001" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:39.126732" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.127351" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.127628" elapsed="0.000039"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.127817" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:39.127222" elapsed="0.000653"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.127081" elapsed="0.000825"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:39.127952" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:39.128119" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:39.125924" elapsed="0.002221"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:39.125611" elapsed="0.002567"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.128347" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:39.128204" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:39.125588" elapsed="0.002837"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.129025" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:39.128562" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:39.129103" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:39.121943" elapsed="0.007284"/>
</kw>
<msg time="2026-06-06T03:33:39.129282" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:39.121032" elapsed="0.008297"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.129836" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.130337" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.131069" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.131256" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.131427" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.131804" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:39.131662" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:39.131632" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.132019" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.132219" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.132385" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:39.131603" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.131503" elapsed="0.000963"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.132613" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.132706" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:39.132822" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:39.116578" elapsed="0.016270"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:39.134062" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:39.133826" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:39.134219" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:39.133477" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.134550" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:39.134314" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.135145" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:39.134852" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:39.134680" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:39.134295" elapsed="0.000931"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.137572" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:39.135370" elapsed="0.002228"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:39.137662" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:39.137817" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:39.133159" elapsed="0.004682"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:39.139042" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:39.138809" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:39.139196" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:39.138447" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:39.139425" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:39.139290" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:39.139272" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.139661" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.139828" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.139893" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:39.141815" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:39.138133" elapsed="0.003708"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.143510" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:39.143113" elapsed="0.000464"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:39.144093" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:39.143805" elapsed="0.000334"/>
</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-06-06T03:33:39.150597" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:39.150763" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:39.150864" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:39.146615" elapsed="0.004647">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:39.144207" elapsed="0.007141">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:39.151542" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:39.151382" elapsed="0.000228"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:39.144188" elapsed="0.007446">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:39.152040" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.152176" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:39.152137" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:39.152119" elapsed="0.000121"/>
</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-06-06T03:33:39.152398" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.152474" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:39.142136" elapsed="0.010449">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.152676" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:39.094140" elapsed="0.058636">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:39.153048" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:39.152871" elapsed="0.000250"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:39.152854" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:39.153179" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:39.087945" elapsed="0.065331">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.202368" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:40.201941" elapsed="0.000550"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:40.203300" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:40.203039" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:40.203472" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:40.202692" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.204061" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:40.203672" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:40.204390" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:40.204549" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:40.204246" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.204994" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:40.204743" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.206305" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:40.206041" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.206799" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:40.206508" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.207162" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.207362" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.207530" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:40.207030" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.206882" elapsed="0.000735"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:40.207680" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:33:40.207851" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:40.205682" elapsed="0.002195"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:40.205120" elapsed="0.002789"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.208078" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:40.207936" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:40.205095" elapsed="0.003059"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.208762" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:40.208290" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:40.208839" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:40.201301" elapsed="0.007664"/>
</kw>
<msg time="2026-06-06T03:33:40.209019" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:40.200347" elapsed="0.008721"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.209565" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.210154" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.210668" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.210851" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.211021" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.211383" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:40.211243" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:40.211228" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.211597" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.211773" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.211934" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:40.211198" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.211097" elapsed="0.000915"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.212150" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.212225" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:40.212344" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:40.195787" elapsed="0.016583"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:40.213634" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:40.213373" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:40.213830" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:40.213033" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.214186" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:40.213928" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.214754" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:40.214440" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:40.214268" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:40.213908" elapsed="0.000930"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.217480" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:40.214983" elapsed="0.002527"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:40.217620" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:33:40.217809" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:40.212701" elapsed="0.005134"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:40.219251" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:40.218981" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:40.219419" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:40.218600" elapsed="0.000845"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:40.219696" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:33:40.219520" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:40.219500" elapsed="0.000284"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.219929" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.220097" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.220164" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:40.222189" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:40.218219" elapsed="0.004004"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.223746" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:40.223439" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:40.224195" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:40.223947" elapsed="0.000293"/>
</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-06-06T03:33:40.231484" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:40.231624" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:40.231753" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:40.226450" elapsed="0.005688">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:40.224311" elapsed="0.007915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:40.232420" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:40.232263" elapsed="0.000221"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:40.224291" elapsed="0.008217">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:40.232929" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.233068" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:40.233028" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:40.233009" elapsed="0.000125"/>
</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-06-06T03:33:40.233273" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.233343" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:40.222565" elapsed="0.010886">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.233597" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:40.168974" elapsed="0.064737">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:40.234004" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:40.233806" elapsed="0.000272"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:40.233789" elapsed="0.000313"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:40.234135" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:40.159363" elapsed="0.074869">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.282819" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:41.282405" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:41.283601" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:41.283348" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:41.283787" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:41.283018" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.284364" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:41.283973" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:41.284704" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:41.284869" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:41.284546" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.285292" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:41.285043" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.286317" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:41.286061" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.286808" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:41.286516" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.287160" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.287361" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.287527" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:41.287032" elapsed="0.000554"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.286890" elapsed="0.000725"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:41.287739" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:41.287910" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:41.285741" elapsed="0.002194"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:41.285415" elapsed="0.002552"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.288133" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:41.287992" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:41.285392" elapsed="0.002817"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.288803" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:41.288344" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:41.288881" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:41.281787" elapsed="0.007218"/>
</kw>
<msg time="2026-06-06T03:33:41.289060" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:41.280884" elapsed="0.008222"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.289626" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.290142" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.290635" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.290833" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.291000" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.291532" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:41.291392" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:41.291378" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.291765" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.291929" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.292091" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:41.291349" elapsed="0.000795"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.291076" elapsed="0.001094"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.292343" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.292421" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:41.292537" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:41.276615" elapsed="0.015948"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:41.293828" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:41.293576" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:41.293986" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:41.293207" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.294320" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:41.294082" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.294882" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:41.294571" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:41.294402" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:41.294063" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.297288" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:41.295108" elapsed="0.002206"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:41.297366" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:41.297519" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:41.292889" elapsed="0.004680"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:41.298848" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:41.298541" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:41.299033" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:41.298210" elapsed="0.000852"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:41.299294" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:33:41.299143" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:41.299121" elapsed="0.000261"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.299535" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.299720" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.299789" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:41.301741" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:41.297890" elapsed="0.003877"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.303172" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:41.302920" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:41.303651" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:41.303366" elapsed="0.000332"/>
</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-06-06T03:33:41.310808" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:41.311036" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:41.311209" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:41.306086" elapsed="0.005541">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:41.303764" elapsed="0.007985">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:41.311993" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:41.311792" elapsed="0.000270"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:41.303746" elapsed="0.008342">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:41.312510" elapsed="0.000031"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.312678" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:41.312618" elapsed="0.000107"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:41.312598" elapsed="0.000150"/>
</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-06-06T03:33:41.312892" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.312964" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:41.302062" elapsed="0.011012">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.313150" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:41.252969" elapsed="0.060279">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:41.313525" elapsed="0.000096"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:41.313344" elapsed="0.000352"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:41.313326" elapsed="0.000397"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:41.313758" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:41.246719" elapsed="0.067141">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.361789" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:42.361366" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:42.362599" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:42.362332" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:42.362792" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:42.361998" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.363521" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:42.363124" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:42.363874" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:42.364033" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:42.363729" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.364465" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:42.364213" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.366142" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:42.365359" elapsed="0.000839"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.366682" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:42.366377" elapsed="0.000332"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.367061" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.367278" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.367446" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:42.366927" elapsed="0.000575"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.366769" elapsed="0.000765"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:42.367585" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:33:42.367779" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:42.364922" elapsed="0.002882"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:42.364591" elapsed="0.003245"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.368008" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:42.367863" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:42.364567" elapsed="0.003516"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.368749" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:42.368252" elapsed="0.000526"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:42.368828" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:42.360716" elapsed="0.008239"/>
</kw>
<msg time="2026-06-06T03:33:42.369011" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:42.359807" elapsed="0.009255"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.369585" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.370106" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.370695" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.370880" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.371049" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.371445" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:42.371300" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:42.371282" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.371678" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.371844" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.372003" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:42.371243" elapsed="0.000813"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.371125" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.372221" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.372296" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:42.372418" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:42.355383" elapsed="0.017062"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:42.373871" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:42.373565" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:42.374044" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:42.373115" elapsed="0.000953"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.374383" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:42.374140" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.374947" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:42.374637" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:42.374464" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:42.374120" elapsed="0.000910"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.377675" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:42.375182" elapsed="0.002521"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:42.377757" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:42.377913" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:42.372779" elapsed="0.005159"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:42.379284" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:42.379050" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:42.379488" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:42.378555" elapsed="0.000958"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:42.379738" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:42.379585" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:42.379565" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.379962" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.380127" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.380194" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:42.382167" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:42.378233" elapsed="0.003961"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.383580" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:42.383329" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:42.384035" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:42.383788" elapsed="0.000291"/>
</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-06-06T03:33:42.390916" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:42.391051" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:42.391144" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:42.386251" elapsed="0.005256">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:42.384145" elapsed="0.007444">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:42.391787" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:42.391621" elapsed="0.000232"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:42.384126" elapsed="0.007750">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:42.392246" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.392379" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:42.392341" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:42.392324" elapsed="0.000118"/>
</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-06-06T03:33:42.392580" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.392664" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:42.382495" elapsed="0.010273">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.392843" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:42.332631" elapsed="0.060307">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:42.393339" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:42.393072" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:42.393053" elapsed="0.000385"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:42.393471" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:42.323792" elapsed="0.069776">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.439997" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:43.439580" elapsed="0.000451"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:43.440806" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:43.440532" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:43.441010" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:43.440199" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.441586" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:43.441198" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:43.441933" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:43.442109" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:43.441789" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.442537" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:43.442287" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.443557" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:43.443300" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.444047" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:43.443775" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.444401" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.444602" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.444788" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:43.444272" elapsed="0.000574"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.444129" elapsed="0.000762"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:43.444948" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:43.445115" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:43.442981" elapsed="0.002160"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:43.442682" elapsed="0.002492"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.445342" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:43.445199" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:43.442658" elapsed="0.002762"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.446030" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:43.445558" elapsed="0.000682"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:43.446297" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:43.438973" elapsed="0.007456"/>
</kw>
<msg time="2026-06-06T03:33:43.446485" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:43.438098" elapsed="0.008436"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.447047" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.447580" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.448299" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.448486" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.448673" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.449055" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:43.448912" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:43.448896" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.449276" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.449440" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.449608" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:43.448853" elapsed="0.000827"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.448751" elapsed="0.000955"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.449848" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.449926" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:43.450043" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:43.433794" elapsed="0.016275"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:43.451350" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:43.451109" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:43.451511" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:43.450770" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.451869" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:43.451609" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.452419" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:43.452123" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:43.451952" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:43.451590" elapsed="0.000913"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.454924" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:43.452664" elapsed="0.002287"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:43.455002" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:43.455157" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:43.450427" elapsed="0.004755"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:43.456371" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:43.456139" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:43.456527" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:43.455810" elapsed="0.000742"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:43.456774" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:43.456622" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:43.456604" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.457010" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.457172" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.457236" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:43.459164" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:43.455477" elapsed="0.003713"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.460560" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:43.460312" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:43.461040" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:43.460769" elapsed="0.000315"/>
</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-06-06T03:33:43.468071" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:43.468206" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:43.468300" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:43.463376" elapsed="0.005308">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:43.461150" elapsed="0.007656">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:43.469001" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:43.468841" elapsed="0.000226"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:43.461131" elapsed="0.007960">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:43.469463" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.469600" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:43.469560" elapsed="0.000100"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:43.469541" elapsed="0.000143"/>
</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-06-06T03:33:43.469822" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.469893" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:43.459492" elapsed="0.010503">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.470068" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:43.411167" elapsed="0.058994">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:43.470424" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:43.470253" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:43.470236" elapsed="0.000283"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:43.470552" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:43.403757" elapsed="0.066903">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.516179" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:44.515772" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:44.517033" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:44.516763" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:44.517214" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:44.516384" elapsed="0.000855"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.517847" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:44.517419" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:44.518190" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:44.518367" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:44.518039" elapsed="0.000425"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.518898" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:44.518624" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.520211" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:44.519947" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.520751" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:44.520417" elapsed="0.000362"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.521123" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.521323" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.521491" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:44.520990" elapsed="0.000557"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.520838" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:44.521630" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:33:44.521820" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:44.519585" elapsed="0.002261"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:44.519030" elapsed="0.002848"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.522046" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:44.521904" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:44.519004" elapsed="0.003118"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.522761" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:44.522261" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:44.522842" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:44.515139" elapsed="0.007836"/>
</kw>
<msg time="2026-06-06T03:33:44.523034" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:44.514220" elapsed="0.008866"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.523601" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.524129" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.524627" elapsed="0.000055"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.524903" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.525076" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.525445" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:44.525305" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:44.525288" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.525675" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.525839" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.525998" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:44.525259" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.525155" elapsed="0.000923"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.526218" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.526293" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:44.526415" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:44.509886" elapsed="0.016556"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:44.527810" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:44.527486" elapsed="0.000408">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:44.528005" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:44.527126" elapsed="0.000906"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.528358" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:44.528106" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.528976" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:44.528613" elapsed="0.000390"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:44.528441" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:44.528086" elapsed="0.000973"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.531714" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:44.529208" elapsed="0.002535"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:44.531796" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:44.531954" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:44.526781" elapsed="0.005199"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:44.533388" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:44.533143" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:44.533548" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:44.532610" elapsed="0.000962"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:44.533948" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:44.533659" elapsed="0.000348"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:44.533625" elapsed="0.000406"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.534229" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.534397" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.534462" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:44.536405" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:44.532282" elapsed="0.004149"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.537857" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:44.537581" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:44.538320" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:44.538050" elapsed="0.000320"/>
</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-06-06T03:33:44.545204" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:44.545350" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:44.545461" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:44.540522" elapsed="0.005379">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:44.538443" elapsed="0.007565">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:44.546261" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:44.546060" elapsed="0.000274"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:44.538423" elapsed="0.007937">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:44.546798" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.546942" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:44.546901" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:44.546881" elapsed="0.000129"/>
</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-06-06T03:33:44.547153" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.547223" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:44.536766" elapsed="0.010569">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.547412" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:44.487328" elapsed="0.060182">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:44.547815" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:44.547606" elapsed="0.000286"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:44.547589" elapsed="0.000328"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:44.548021" elapsed="0.000029"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:44.480147" elapsed="0.068018">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.594597" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:45.594202" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:45.595406" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:45.595153" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:45.595576" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:45.594820" elapsed="0.000781"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.596165" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:45.595776" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:45.596506" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:45.596692" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:45.596347" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.597122" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:45.596871" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.598146" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:45.597888" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.598617" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:45.598348" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.598989" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.599190" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.599357" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:45.598858" elapsed="0.000557"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.598714" elapsed="0.000730"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:45.599492" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:45.599670" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:45.597547" elapsed="0.002150"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:45.597247" elapsed="0.002483"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.599896" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:45.599755" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:45.597224" elapsed="0.002749"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.600566" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:45.600111" elapsed="0.000483"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:45.600657" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:45.593576" elapsed="0.007207"/>
</kw>
<msg time="2026-06-06T03:33:45.600897" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:45.592691" elapsed="0.008256"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.601444" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.602144" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.602674" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.602859" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.603029" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.603391" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:45.603250" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:45.603234" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.603607" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.603787" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.603948" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:45.603205" elapsed="0.000797"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.603105" elapsed="0.000922"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.604170" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.604246" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:45.604362" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:45.588294" elapsed="0.016094"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:45.605671" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:45.605422" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:45.605829" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:45.605092" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.606200" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:45.605959" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.606766" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:45.606453" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:45.606283" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:45.605940" elapsed="0.000910"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.609336" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:45.606996" elapsed="0.002366"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:45.609414" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:33:45.609566" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:45.604770" elapsed="0.004821"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:45.610813" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:45.610547" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:45.610970" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:45.610217" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:45.611200" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:45.611065" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:45.611047" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.611422" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.611585" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.611670" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:33:45.615197" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:45.609899" elapsed="0.005326"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.616630" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:45.616346" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:45.617090" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:45.616842" elapsed="0.000293"/>
</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-06-06T03:33:45.624105" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:45.624239" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:45.624342" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:45.619284" elapsed="0.005485">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:45.617201" elapsed="0.007650">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:45.625034" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:45.624884" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:45.617183" elapsed="0.007939">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:45.625526" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.625694" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:45.625623" elapsed="0.000133"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:45.625605" elapsed="0.000185"/>
</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-06-06T03:33:45.625995" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.626098" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:45.615521" elapsed="0.010728">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.626357" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:45.565816" elapsed="0.060679">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:45.626901" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:45.626629" elapsed="0.000379"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:45.626604" elapsed="0.000439"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:45.627092" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:45.556546" elapsed="0.070683">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.677486" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:46.677079" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:46.678334" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:46.678054" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:46.678509" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:46.677713" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.679108" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:46.678713" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:46.679459" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:46.679709" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:46.679295" elapsed="0.000442"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.680150" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:46.679895" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.681195" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:46.680934" elapsed="0.000307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.681754" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:46.681457" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.682120" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.682323" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.682493" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:46.681987" elapsed="0.000564"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.681839" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:46.682633" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:33:46.682821" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:46.680595" elapsed="0.002252"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:46.680276" elapsed="0.002603"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.683049" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:46.682905" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:46.680251" elapsed="0.002875"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.683734" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:46.683266" elapsed="0.000497"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:46.683813" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:46.676363" elapsed="0.007576"/>
</kw>
<msg time="2026-06-06T03:33:46.683993" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:46.675399" elapsed="0.008643"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.684569" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.685088" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.685586" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.685782" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.685950" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.686306" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:46.686166" elapsed="0.000230"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:46.686151" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.686559" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.686748" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.686914" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:46.686123" elapsed="0.000846"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.686024" elapsed="0.000971"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.687137" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.687214" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:46.687334" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:46.670612" elapsed="0.016748"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:46.688876" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:46.688403" elapsed="0.000541">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:46.689040" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:46.688069" elapsed="0.000996"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.689379" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:46.689138" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.689944" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:46.689631" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:46.689461" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:46.689118" elapsed="0.000910"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.692429" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:46.690182" elapsed="0.002291"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:46.692537" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:46.692710" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:46.687744" elapsed="0.004992"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:46.693948" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:46.693711" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:46.694105" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:46.693363" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:46.694339" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:46.694201" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:46.694182" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.694565" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.694747" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.694814" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:46.696783" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:46.693041" elapsed="0.003805"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.698235" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:46.697983" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:46.698691" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:46.698430" elapsed="0.000306"/>
</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-06-06T03:33:46.705769" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:46.705923" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:46.706035" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:46.700893" elapsed="0.005530">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:46.698804" elapsed="0.007712">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:46.706759" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:46.706555" elapsed="0.000272"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:46.698785" elapsed="0.008067">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:46.707264" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.707404" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:46.707364" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:46.707345" elapsed="0.000125"/>
</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-06-06T03:33:46.707610" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.707701" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:46.697152" elapsed="0.010660">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.707886" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:46.645473" elapsed="0.062509">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:46.708252" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:46.708076" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:46.708059" elapsed="0.000290"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:46.708381" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:46.637000" elapsed="0.071534">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.756520" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:47.756112" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:47.757374" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:47.757118" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:47.757544" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:47.756759" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.758155" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:47.757759" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:47.758492" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:47.758681" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:47.758343" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.759126" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:47.758865" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.760187" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:47.759926" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.760743" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:47.760392" elapsed="0.000379"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.761110" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.761313" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.761482" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:47.760979" elapsed="0.000561"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.760832" elapsed="0.000738"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:47.761617" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:33:47.761806" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:47.759579" elapsed="0.002252"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:47.759254" elapsed="0.002610"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.762030" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:47.761889" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:47.759230" elapsed="0.002877"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.762723" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:47.762244" elapsed="0.000509"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:47.762804" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:47.755472" elapsed="0.007457"/>
</kw>
<msg time="2026-06-06T03:33:47.762984" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:47.754559" elapsed="0.008476"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.763591" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.764118" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.764875" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.765065" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.765239" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.765602" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:47.765462" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:47.765447" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.765836" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.766001" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.766162" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:47.765418" elapsed="0.000798"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.765316" elapsed="0.000926"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.766383" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.766459" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:47.766578" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:47.750145" elapsed="0.016459"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:47.767873" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:47.767609" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:47.768038" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:47.767263" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.768374" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:47.768133" elapsed="0.000343"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.769024" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:47.768722" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:47.768504" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:47.768114" elapsed="0.000994"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.771523" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:47.769254" elapsed="0.002296"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:47.771601" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:47.771775" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:47.766942" elapsed="0.004858"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:47.773066" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:47.772812" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:47.773224" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:47.772433" elapsed="0.000816"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:47.773456" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:47.773320" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:47.773301" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.773696" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.773862" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.773926" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:47.775856" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:47.772107" elapsed="0.003775"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.777311" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:47.777059" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:47.777764" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:47.777504" elapsed="0.000304"/>
</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-06-06T03:33:47.784973" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:47.785110" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:47.785207" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:47.780208" elapsed="0.005359">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:47.777874" elapsed="0.007795">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:47.785924" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:47.785705" elapsed="0.000309"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:47.777855" elapsed="0.008194">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:47.786563" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.786831" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:47.786775" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:47.786747" elapsed="0.000176"/>
</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-06-06T03:33:47.787118" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.787219" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:47.776182" elapsed="0.011209">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.787501" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:47.726997" elapsed="0.060642">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:47.788050" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:47.787806" elapsed="0.000347"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:47.787778" elapsed="0.000408"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:47.788233" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:47.718151" elapsed="0.070222">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.833779" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:48.833356" elapsed="0.000458"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:48.834585" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:48.834320" elapsed="0.000365">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:48.834782" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:48.833984" elapsed="0.000823"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.835357" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:48.834968" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:48.835701" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:48.835872" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:48.835539" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.836340" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:48.836050" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.837589" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:48.837327" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.838082" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:48.837808" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.838438" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.838720" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.838894" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:48.838307" elapsed="0.000646"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.838162" elapsed="0.000822"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:48.839032" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:48.839199" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:48.837004" elapsed="0.002220"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:48.836468" elapsed="0.002789"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.839425" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:48.839283" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:48.836442" elapsed="0.003059"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.840105" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:48.839639" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:48.840183" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:48.832747" elapsed="0.007578"/>
</kw>
<msg time="2026-06-06T03:33:48.840381" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:48.831793" elapsed="0.008636"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.840939" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.841444" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.841963" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.842146" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.842313" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.842685" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:48.842531" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:48.842516" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.842905" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.843105" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.843275" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:48.842487" elapsed="0.000848"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.842387" elapsed="0.000974"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.843503" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.843581" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:48.843716" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:48.827500" elapsed="0.016243"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:48.845011" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:48.844774" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:48.845167" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:48.844420" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.845501" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:48.845263" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.846055" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:48.845765" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:48.845580" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:48.845244" elapsed="0.000893"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.848728" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:48.846287" elapsed="0.002468"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:48.848807" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:48.848962" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:48.844059" elapsed="0.004928"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:48.850178" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:48.849944" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:48.850333" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:48.849596" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:48.850563" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:48.850427" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:48.850409" elapsed="0.000252"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.850804" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.850967" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.851032" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:48.853001" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:48.849281" elapsed="0.003747"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.854442" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:48.854153" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:48.854900" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:48.854636" elapsed="0.000307"/>
</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-06-06T03:33:48.862072" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:48.862245" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:48.862375" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:48.857097" elapsed="0.005788">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:48.855010" elapsed="0.007988">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:48.863248" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:48.863044" elapsed="0.000294"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:48.854991" elapsed="0.008380">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:48.863896" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.864083" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:48.864031" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:48.864006" elapsed="0.000165"/>
</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-06-06T03:33:48.864363" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.864502" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:48.853331" elapsed="0.011335">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.864772" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:48.803989" elapsed="0.060915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:48.865273" elapsed="0.000047"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:48.865033" elapsed="0.000355"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:48.865010" elapsed="0.000413"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:48.865473" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:48.795972" elapsed="0.069634">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.911431" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:49.910994" elapsed="0.000541"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:49.912330" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:49.912072" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:49.912503" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:49.911732" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.913099" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:49.912705" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:49.913426" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:49.913584" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:49.913282" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.914033" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:49.913782" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.915119" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:49.914794" elapsed="0.000379"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.915614" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:49.915339" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.915992" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.916196" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.916365" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:49.915860" elapsed="0.000563"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.915714" elapsed="0.000739"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:49.916500" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:49.916685" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:49.914457" elapsed="0.002254"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:49.914157" elapsed="0.002587"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.916938" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:49.916769" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:49.914133" elapsed="0.002883"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.917632" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:49.917162" elapsed="0.000515"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:49.917728" elapsed="0.000039"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:49.910333" elapsed="0.007536"/>
</kw>
<msg time="2026-06-06T03:33:49.917925" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:49.909421" elapsed="0.008552"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.918469" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.919060" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.919808" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.919997" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.920170" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.920544" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:49.920394" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:49.920378" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.920789" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.920953" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.921114" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:49.920349" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.920249" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.921341" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.921416" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:49.921538" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:49.905085" elapsed="0.016479"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:49.922845" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:49.922572" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:49.923015" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:49.922226" elapsed="0.000883"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.923458" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:49.923196" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.924036" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:49.923734" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:49.923541" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:49.923172" elapsed="0.000946"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.926491" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:49.924262" elapsed="0.002255"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:49.926624" elapsed="0.000055"/>
</return>
<msg time="2026-06-06T03:33:49.926815" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:49.921900" elapsed="0.004941"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:49.928198" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:49.927932" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:49.928374" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:49.927563" elapsed="0.000837"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:49.928621" elapsed="0.000045"/>
</return>
<status status="PASS" start="2026-06-06T03:33:49.928474" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:49.928454" elapsed="0.000274"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.928872" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.929040" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.929106" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:49.931135" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:49.927209" elapsed="0.003961"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.932706" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:49.932405" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:49.933151" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:49.932906" elapsed="0.000290"/>
</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-06-06T03:33:49.940385" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:49.940572" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:49.940758" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:49.935694" elapsed="0.005599">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:49.933266" elapsed="0.008147">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:49.941706" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:49.941463" elapsed="0.000340"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:49.933246" elapsed="0.008592">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:49.942395" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.942592" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:49.942534" elapsed="0.000143"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:49.942508" elapsed="0.000204"/>
</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-06-06T03:33:49.942916" elapsed="0.000040"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.943028" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:49.931539" elapsed="0.011682">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.943432" elapsed="0.000026"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:49.882149" elapsed="0.061433">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:49.944006" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:49.943750" elapsed="0.000362"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:49.943724" elapsed="0.000423"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:49.944196" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:49.875858" elapsed="0.068478">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:50.993876" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:50.993448" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:50.994715" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:50.994421" elapsed="0.000378">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:50.994895" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:50.994085" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:50.995477" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:50.995080" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:50.995847" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:50.996126" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:50.995690" elapsed="0.000464"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:50.996885" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:50.996311" elapsed="0.000647"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:50.998037" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:50.997775" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:50.998518" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:50.998241" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:50.998898" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:50.999102" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:50.999269" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:50.998767" elapsed="0.000559"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:50.998601" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:50.999478" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:33:50.999677" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:50.997411" elapsed="0.002293"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:50.997044" elapsed="0.002692"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:50.999908" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:50.999764" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:50.997017" elapsed="0.002969"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:51.000597" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:51.000126" elapsed="0.000499"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:51.000695" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:50.992746" elapsed="0.008081"/>
</kw>
<msg time="2026-06-06T03:33:51.000886" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:50.991741" elapsed="0.009239"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.001491" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.002029" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.002544" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.002749" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.002922" elapsed="0.000162"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.003441" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:51.003299" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:51.003282" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.003699" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.003871" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.004060" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:51.003251" elapsed="0.000884"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.003144" elapsed="0.001023"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.004365" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.004445" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:51.004581" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:50.987048" elapsed="0.017563"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:51.005960" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:51.005681" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:51.006131" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:51.005308" elapsed="0.000848"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.006480" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:51.006229" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:51.007050" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:51.006750" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:51.006561" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:51.006209" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:51.011366" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:51.007287" elapsed="0.004110"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:51.011458" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:33:51.011627" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:51.004954" elapsed="0.006716"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:51.013024" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:51.012728" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:51.013194" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:51.012355" elapsed="0.000864"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:51.013438" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:51.013293" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:51.013273" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.013682" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.013851" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.013917" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:51.015857" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:51.012006" elapsed="0.003878"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:51.017339" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:51.017066" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:51.017808" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:51.017538" elapsed="0.000320"/>
</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-06-06T03:33:51.024400" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:51.024631" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:51.024793" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:51.020062" elapsed="0.005195">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:51.017929" elapsed="0.007424">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:51.025582" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:51.025392" elapsed="0.000273"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:51.017909" elapsed="0.007782">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:51.026122" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.026267" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:51.026225" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:51.026205" elapsed="0.000129"/>
</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-06-06T03:33:51.026474" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.026546" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:51.016196" elapsed="0.010476">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.026749" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:50.963227" elapsed="0.063624">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:51.027124" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:51.026944" elapsed="0.000252"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:51.026926" elapsed="0.000295"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:51.027253" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:50.954563" elapsed="0.072786">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.071258" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:52.070852" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:52.072083" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:52.071825" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:52.072257" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:52.071467" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.072923" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:52.072510" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:52.073254" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:52.073414" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:52.073109" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.073868" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:52.073597" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.074909" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:52.074631" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.075380" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:52.075112" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.075754" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.075959" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.076131" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:52.075606" elapsed="0.000584"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.075462" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:52.076269" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:52.076435" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:52.074308" elapsed="0.002153"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:52.073995" elapsed="0.002500"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.076687" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:52.076521" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:52.073971" elapsed="0.002795"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.077380" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:52.076909" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:52.077460" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:52.070219" elapsed="0.007368"/>
</kw>
<msg time="2026-06-06T03:33:52.077660" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:52.069290" elapsed="0.008424"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.078273" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.078803" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.079358" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.079542" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.079731" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.080294" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:52.080148" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:52.080131" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.080516" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.080697" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.080864" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:52.080101" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.079808" elapsed="0.001137"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.081086" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.081162" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:52.081278" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:52.064995" elapsed="0.016309"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:52.082560" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:52.082313" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:52.082743" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:52.081960" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.083082" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:52.082839" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.083630" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:52.083334" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:52.083164" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:52.082821" elapsed="0.000911"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.086128" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:52.083879" elapsed="0.002276"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:52.086246" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:52.086404" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:52.081617" elapsed="0.004812"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:52.087635" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:52.087399" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:52.087849" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:52.087066" elapsed="0.000809"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:52.088085" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:52.087947" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:52.087928" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.088310" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.088476" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.088543" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:52.090493" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:52.086744" elapsed="0.003776"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.091920" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:52.091665" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:52.092360" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:52.092115" elapsed="0.000289"/>
</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-06-06T03:33:52.099031" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:52.099180" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:52.099287" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:52.094792" elapsed="0.004903">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:52.092471" elapsed="0.007311">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:52.099997" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:52.099819" elapsed="0.000246"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:52.092452" elapsed="0.007638">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:52.100492" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.100631" elapsed="0.000031"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:52.100591" elapsed="0.000101"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:52.100573" elapsed="0.000142"/>
</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-06-06T03:33:52.100855" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.100927" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:52.090838" elapsed="0.010199">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.101112" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:52.042372" elapsed="0.058836">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:52.101539" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:52.101362" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:52.101343" elapsed="0.000293"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:52.101689" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:52.035010" elapsed="0.066777">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.147286" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:53.146880" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:53.148109" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:53.147844" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:53.148282" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:53.147490" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.148872" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:53.148465" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:53.149207" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:53.149375" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:53.149061" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.149821" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:53.149554" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.151221" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:53.150932" elapsed="0.000337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.151746" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:53.151431" elapsed="0.000342"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.152121" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.152325" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.152497" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:53.151989" elapsed="0.000564"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.151833" elapsed="0.000752"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:53.152634" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:33:53.152824" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:53.150488" elapsed="0.002363"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:53.149947" elapsed="0.002936"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.153051" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:53.152909" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:53.149922" elapsed="0.003205"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.153740" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:53.153264" elapsed="0.000569"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:53.153885" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:53.146216" elapsed="0.007800"/>
</kw>
<msg time="2026-06-06T03:33:53.154072" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:53.145311" elapsed="0.008811"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.154624" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.155201" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.155717" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.155901" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.156069" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.156428" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:53.156287" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:53.156272" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.156661" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.156827" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.156992" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:53.156244" elapsed="0.000802"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.156145" elapsed="0.000927"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.157213" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.157291" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:53.157411" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:53.140940" elapsed="0.016498"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:53.158795" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:53.158514" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:53.158962" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:53.158161" elapsed="0.000826"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.159301" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:53.159059" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.159964" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:53.159552" elapsed="0.000448"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:53.159383" elapsed="0.000661"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:53.159040" elapsed="0.001027"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.162810" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:53.160219" elapsed="0.002621"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:53.162893" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:53.163051" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:53.157825" elapsed="0.005251"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:53.164315" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:53.164069" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:53.164477" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:53.163728" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:53.164732" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:53.164574" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:53.164555" elapsed="0.000262"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.164958" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.165123" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.165189" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:53.167154" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:53.163382" elapsed="0.003799"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.168578" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:53.168321" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:53.169040" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:53.168790" elapsed="0.000294"/>
</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-06-06T03:33:53.175374" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:53.175518" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:53.175621" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:53.171301" elapsed="0.004730">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:53.169151" elapsed="0.007026">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:53.176371" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:53.176214" elapsed="0.000226"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:53.169133" elapsed="0.007338">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:53.176887" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.177030" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:53.176991" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:53.176972" elapsed="0.000123"/>
</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-06-06T03:33:53.177234" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.177304" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:53.167487" elapsed="0.009922">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.177484" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:53.118210" elapsed="0.059370">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:53.177868" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:53.177692" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:53.177673" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:53.177998" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:53.110292" elapsed="0.067802">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.224903" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:54.224471" elapsed="0.000467"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:54.225738" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:54.225450" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:54.225916" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:54.225113" elapsed="0.000831"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.226545" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:54.226140" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:54.226954" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:54.227131" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:54.226791" elapsed="0.000441"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.227663" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:54.227391" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.228805" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:54.228504" elapsed="0.000349"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.229380" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:54.229034" elapsed="0.000377"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.229830" elapsed="0.000027"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.230082" elapsed="0.000030"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.230271" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:54.229671" elapsed="0.000661"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.229479" elapsed="0.000884"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:54.230415" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:54.230589" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:54.228155" elapsed="0.002459"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:54.227797" elapsed="0.002867"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.230865" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:54.230693" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:54.227772" elapsed="0.003175"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.231594" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:54.231122" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:54.231690" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:54.223795" elapsed="0.008027"/>
</kw>
<msg time="2026-06-06T03:33:54.231879" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:54.222538" elapsed="0.009391"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.232444" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.232985" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.233762" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.233999" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.234175" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.234538" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:54.234398" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:54.234383" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.234818" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.235010" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.235175" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:54.234354" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.234253" elapsed="0.001002"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.235396" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.235473" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:54.235594" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:54.217679" elapsed="0.017941"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:54.236908" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:54.236660" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:54.237082" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:54.236309" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.237421" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:54.237177" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.238007" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:54.237695" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:54.237504" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:54.237159" elapsed="0.000939"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.240552" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:54.238277" elapsed="0.002302"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:54.240632" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:33:54.240811" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:54.235979" elapsed="0.004857"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:54.242118" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:54.241863" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:54.242276" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:54.241490" elapsed="0.000811"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:54.242510" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:54.242371" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:54.242353" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.242796" elapsed="0.000055"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.243026" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.243096" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:54.245062" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:54.241153" elapsed="0.003943"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.246533" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:54.246277" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:54.247031" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:54.246746" elapsed="0.000330"/>
</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-06-06T03:33:54.253993" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:54.254133" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:54.254229" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:54.249540" elapsed="0.005060">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:54.247144" elapsed="0.007558">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:54.254931" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:54.254738" elapsed="0.000263"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:54.247125" elapsed="0.007900">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:54.255437" elapsed="0.000029"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.255577" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:54.255539" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:54.255521" elapsed="0.000134"/>
</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-06-06T03:33:54.255800" elapsed="0.000027"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.255886" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:54.245412" elapsed="0.010597">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.256088" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:54.194228" elapsed="0.061958">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:54.256459" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:54.256281" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:54.256263" elapsed="0.000293"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:54.256624" elapsed="0.000038"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:54.187633" elapsed="0.069125">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.299244" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:55.298841" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:55.300056" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:55.299798" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:55.300229" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:55.299449" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.300819" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:55.300412" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:55.301151" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:55.301314" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:55.301007" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.301770" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:55.301499" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.303016" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:55.302749" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.303492" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:55.303220" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.303869" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.304075" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.304242" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:55.303738" elapsed="0.000560"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.303573" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:55.304377" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:33:55.304544" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:55.302408" elapsed="0.002161"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:55.301897" elapsed="0.002704"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.304789" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:55.304626" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:55.301873" elapsed="0.002992"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.305455" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:55.305001" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:55.305531" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:55.298172" elapsed="0.007500"/>
</kw>
<msg time="2026-06-06T03:33:55.305779" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:55.297290" elapsed="0.008540"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.306354" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.306877" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.307379" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.307559" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.307750" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.308109" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:55.307970" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:55.307955" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.308324" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.308486" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.308662" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:55.307926" elapsed="0.000791"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.307828" elapsed="0.000915"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.308883" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.308959" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:55.309081" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:55.293010" elapsed="0.016098"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:55.310350" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:55.310102" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:55.310510" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:55.309765" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.310902" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:55.310658" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.311461" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:55.311165" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:55.310985" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:55.310624" elapsed="0.000921"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.314067" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:55.311706" elapsed="0.002389"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:55.314148" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:55.314302" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:55.309423" elapsed="0.004904"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:55.315598" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:55.315364" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:55.315773" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:55.315022" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:55.316012" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:55.315869" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:55.315850" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.316235" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.316400" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.316466" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:55.318403" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:55.314674" elapsed="0.003756"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.319833" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:55.319560" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:55.320273" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:55.320026" elapsed="0.000292"/>
</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-06-06T03:33:55.327453" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:55.327588" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:55.327703" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:55.322487" elapsed="0.005590">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:55.320384" elapsed="0.007774">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:55.328337" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:55.328191" elapsed="0.000210"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:55.320366" elapsed="0.008058">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:55.328845" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.328982" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:55.328943" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:55.328925" elapsed="0.000121"/>
</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-06-06T03:33:55.329182" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.329253" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:55.318745" elapsed="0.010611">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.329429" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:55.270536" elapsed="0.058986">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:55.329801" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:55.329613" elapsed="0.000260"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:55.329596" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:55.329930" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:55.263148" elapsed="0.066877">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.373912" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:56.373499" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:56.374716" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:56.374447" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:56.374889" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:56.374112" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.375473" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:56.375082" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:56.375824" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:56.375994" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:56.375673" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.376422" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:56.376173" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.377439" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:56.377180" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.378051" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:56.377757" elapsed="0.000328"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.378475" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.378704" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.378876" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:56.378337" elapsed="0.000598"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.378154" elapsed="0.000811"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:56.379014" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:33:56.379179" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:56.376861" elapsed="0.002343"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:56.376545" elapsed="0.002691"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.379400" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:56.379261" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:56.376522" elapsed="0.002954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.380073" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:56.379611" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:56.380152" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:56.372867" elapsed="0.007409"/>
</kw>
<msg time="2026-06-06T03:33:56.380330" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:56.371975" elapsed="0.008402"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.380887" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.383076" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.383589" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.383791" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.383961" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.384327" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:56.384187" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:56.384172" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.384583" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.384764" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.384926" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:56.384143" elapsed="0.000837"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.384042" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.385144" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.385220" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:56.385339" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:56.367678" elapsed="0.017688"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:56.386667" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:56.386404" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:56.386832" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:56.386063" elapsed="0.000793"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.387166" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:56.386927" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.387725" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:56.387413" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:56.387247" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:56.386908" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.390385" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:56.387954" elapsed="0.002458"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:56.390466" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:56.390622" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:56.385736" elapsed="0.004928"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:56.391939" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:56.391698" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:56.392096" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:56.391345" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:56.392329" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:56.392191" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:56.392172" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.392556" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.392738" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.392806" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:56.394944" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:56.390983" elapsed="0.004024"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.396394" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:56.396141" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:56.396855" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:56.396589" elapsed="0.000311"/>
</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-06-06T03:33:56.403845" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:56.403983" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:56.404086" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:56.399109" elapsed="0.005344">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:56.396968" elapsed="0.007567">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:56.404735" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:56.404568" elapsed="0.000234"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:56.396949" elapsed="0.007877">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:56.405201" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.405334" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:56.405296" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:56.405278" elapsed="0.000121"/>
</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-06-06T03:33:56.405572" elapsed="0.000028"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.405666" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:56.395314" elapsed="0.010461">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.405851" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:56.345150" elapsed="0.060798">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:56.406222" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:56.406047" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:56.406029" elapsed="0.000291"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:56.406353" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:56.338935" elapsed="0.067514">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.453414" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:57.452962" elapsed="0.000496"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:57.454249" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:57.453991" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:57.454421" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:57.453633" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.455013" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:57.454606" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:57.455347" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:57.455515" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:57.455202" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.455964" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:57.455714" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.457056" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:57.456797" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.457526" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:57.457255" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.457899" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.458097" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.458263" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:57.457768" elapsed="0.000551"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.457607" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:57.458404" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:33:57.458578" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:57.456456" elapsed="0.002147"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:57.456093" elapsed="0.002542"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.458821" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:57.458678" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:57.456068" elapsed="0.002827"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.459476" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:57.459033" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:57.459553" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:57.452318" elapsed="0.007377"/>
</kw>
<msg time="2026-06-06T03:33:57.459751" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:57.451364" elapsed="0.008435"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.460368" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.460926" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.461427" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.461608" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.461796" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.462155" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:57.462013" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:57.461998" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.462368" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.462540" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.462719" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:57.461970" elapsed="0.000803"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.461871" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.462940" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.463015" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:33:57.463136" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:57.446498" elapsed="0.016812"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:57.464823" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:57.464362" elapsed="0.000532">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:57.464990" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:57.463977" elapsed="0.001038"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.465334" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:57.465091" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.465941" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:57.465625" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:57.465451" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:57.465072" elapsed="0.000952"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.468479" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:57.466171" elapsed="0.002336"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:57.468560" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:33:57.468735" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:57.463627" elapsed="0.005133"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:57.469987" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:57.469751" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:57.470145" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:57.469405" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:57.470375" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:33:57.470239" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:57.470221" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.470599" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.470782" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.470847" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:57.472827" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:57.469085" elapsed="0.003769"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.474354" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:57.474036" elapsed="0.000377"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:57.474842" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:57.474575" elapsed="0.000311"/>
</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-06-06T03:33:57.482404" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:57.482544" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:57.482669" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:57.477158" elapsed="0.005933">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:57.474959" elapsed="0.008256">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:57.483516" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:57.483264" elapsed="0.000355"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:57.474936" elapsed="0.008745">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:57.484249" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.484556" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:57.484497" elapsed="0.000123"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:57.484467" elapsed="0.000213"/>
</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-06-06T03:33:57.484895" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.485011" elapsed="0.000028"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:57.473176" elapsed="0.012000">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.485287" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:57.423133" elapsed="0.062294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:57.485883" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:57.485565" elapsed="0.000446"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:57.485540" elapsed="0.000510"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:57.486101" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:57.416625" elapsed="0.069623">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.531396" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:58.530992" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:58.532251" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:58.531959" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:58.532426" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:58.531605" elapsed="0.000846"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.533019" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:58.532610" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:58.533350" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:58.533520" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:58.533205" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.533962" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:58.533711" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.535028" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:58.534723" elapsed="0.000351"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.535500" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:58.535231" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.535882" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.536172" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.536346" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:58.535752" elapsed="0.000654"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.535581" elapsed="0.000855"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:58.536486" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:58.536675" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:58.534389" elapsed="0.002313"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:58.534088" elapsed="0.002647"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.536902" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:58.536760" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:58.534064" elapsed="0.002915"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.537591" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:58.537116" elapsed="0.000503"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:58.537690" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:58.530349" elapsed="0.007467"/>
</kw>
<msg time="2026-06-06T03:33:58.537871" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:58.529286" elapsed="0.008633"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.538562" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.539117" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.539832" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.540019" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.540188" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.540550" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:58.540408" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:58.540393" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.540785" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.540997" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.541162" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:58.540364" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.540264" elapsed="0.000978"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.541386" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.541464" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:58.541582" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:58.524874" elapsed="0.016734"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:58.542920" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:58.542598" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:58.543083" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:58.542266" elapsed="0.000841"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.543417" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:58.543177" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.543980" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:58.543684" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:58.543498" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:58.543158" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.546422" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:58.544205" elapsed="0.002243"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:58.546500" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:33:58.546667" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:58.541941" elapsed="0.004751"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:58.547912" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:58.547663" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:58.548069" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:58.547317" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:58.548299" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:33:58.548163" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:58.548145" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.548519" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.548701" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.548768" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:33:58.550732" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:58.547001" elapsed="0.003758"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.552221" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:58.551918" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:58.552681" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:58.552418" elapsed="0.000309"/>
</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-06-06T03:33:58.560152" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:58.560343" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:58.560478" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:58.555228" elapsed="0.005770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:58.552794" elapsed="0.008320">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:58.561370" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:58.561160" elapsed="0.000301"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:58.552775" elapsed="0.008720">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:58.562024" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.562217" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:58.562164" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:58.562139" elapsed="0.000167"/>
</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-06-06T03:33:58.562497" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.562595" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:58.551100" elapsed="0.011659">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.562880" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:58.502207" elapsed="0.060808">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:58.563384" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:58.563144" elapsed="0.000340"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:58.563121" elapsed="0.000397"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:58.563564" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:58.495685" elapsed="0.068032">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.607386" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:59.606985" elapsed="0.000517"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:59.608495" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:59.608204" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:59.608684" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:59.607856" elapsed="0.000855"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.609321" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:59.608873" elapsed="0.000485"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:33:59.609685" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:33:59.609848" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:33:59.609521" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.610308" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:59.610055" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.611578" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:59.611308" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.612073" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:33:59.611801" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.612435" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.612653" elapsed="0.000027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.612827" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:33:59.612303" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.612157" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:33:59.612964" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:33:59.613184" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:33:59.610978" elapsed="0.002237"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:59.610434" elapsed="0.002819"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.613463" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:59.613285" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:59.610409" elapsed="0.003136"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.614155" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:33:59.613702" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:33:59.614232" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:33:59.606351" elapsed="0.008006"/>
</kw>
<msg time="2026-06-06T03:33:59.614412" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:33:59.605423" elapsed="0.009037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.614964" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.615513" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.616030" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.616220" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.616390" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.616795" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:59.616627" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:59.616604" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.617012" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.617218" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.617424" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:33:59.616564" elapsed="0.000923"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.616465" elapsed="0.001048"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.617674" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.617752" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:33:59.617871" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:33:59.600749" elapsed="0.017149"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:59.619201" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:59.618956" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:59.619362" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:59.618604" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.619715" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:59.619456" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.620273" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:33:59.619977" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:33:59.619805" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:59.619438" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.623128" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:33:59.620500" elapsed="0.002656"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:33:59.623244" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:33:59.623404" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:59.618262" elapsed="0.005168"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:33:59.624666" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:33:59.624412" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:33:59.624826" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:33:59.624078" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:33:59.625057" elapsed="0.000059"/>
</return>
<status status="PASS" start="2026-06-06T03:33:59.624921" elapsed="0.000236"/>
</branch>
<status status="PASS" start="2026-06-06T03:33:59.624902" elapsed="0.000280"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.625348" elapsed="0.000027"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.625526" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.625593" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:33:59.627527" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:33:59.623752" elapsed="0.003802"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.628994" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:59.628737" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:33:59.629500" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:33:59.629246" elapsed="0.000298"/>
</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-06-06T03:33:59.638323" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:33:59.638462" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:33:59.638562" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:33:59.631699" elapsed="0.007255">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:33:59.629611" elapsed="0.009426">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:33:59.639295" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:59.639073" elapsed="0.000315"/>
</branch>
<status status="FAIL" start="2026-06-06T03:33:59.629593" elapsed="0.009828">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:33:59.639970" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.640161" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:33:59.640107" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:59.640082" elapsed="0.000167"/>
</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-06-06T03:33:59.640485" elapsed="0.000036"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.640594" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:33:59.627879" elapsed="0.012892">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.640938" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:33:59.577392" elapsed="0.063687">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:33:59.641524" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:33:59.641246" elapsed="0.000385"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:33:59.641221" elapsed="0.000468"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:33:59.641737" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:33:59.569737" elapsed="0.072137">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.689237" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:00.688828" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:00.690068" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:00.689801" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:00.690250" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:00.689444" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.690852" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:00.690436" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:00.691261" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:00.691434" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:00.691041" elapsed="0.000420"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.691893" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:00.691621" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.692939" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:00.692668" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.693423" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:00.693144" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.693798" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.693999" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.694166" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:00.693666" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.693506" elapsed="0.000747"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:00.694365" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:34:00.694541" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:00.692321" elapsed="0.002245"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:00.692021" elapsed="0.002578"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.694784" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:00.694625" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:00.691996" elapsed="0.002867"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.695465" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:00.695000" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:00.695544" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:00.688193" elapsed="0.007491"/>
</kw>
<msg time="2026-06-06T03:34:00.695739" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:00.687166" elapsed="0.008621"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.696273" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.696789" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.697473" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.697673" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.697844" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.698195" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:00.698058" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:00.698043" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.698408" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.698575" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.698750" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:00.698016" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.697918" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.699002" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.699079" elapsed="0.000068"/>
</return>
<msg time="2026-06-06T03:34:00.699261" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:00.682615" elapsed="0.016672"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:00.700693" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:00.700343" elapsed="0.000441">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:00.700913" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:00.699936" elapsed="0.001011"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.701376" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:00.701045" elapsed="0.000412"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.702179" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:00.701744" elapsed="0.000472"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:00.701491" elapsed="0.000775"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:00.701019" elapsed="0.001276"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.705714" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:00.702516" elapsed="0.003236"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:00.705827" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:34:00.706048" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:00.699599" elapsed="0.006483"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:00.707877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:00.707502" elapsed="0.000469">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:00.708104" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:00.706984" elapsed="0.001147"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:00.708340" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:00.708203" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:00.708184" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.708571" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.708754" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.708822" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:00.710762" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:00.706506" elapsed="0.004283"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.712196" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:00.711935" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:00.712628" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:00.712386" elapsed="0.000302"/>
</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-06-06T03:34:00.720888" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:00.721089" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:00.721196" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:00.714988" elapsed="0.006581">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:00.712753" elapsed="0.008915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:00.721857" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:00.721704" elapsed="0.000218"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:00.712736" elapsed="0.009211">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:00.722320" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.722455" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:00.722417" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:00.722398" elapsed="0.000120"/>
</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-06-06T03:34:00.722670" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.722741" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:00.711094" elapsed="0.011751">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.722919" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:00.658530" elapsed="0.064483">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:00.723320" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:00.723107" elapsed="0.000286"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:00.723088" elapsed="0.000329"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:00.723449" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:00.652303" elapsed="0.071241">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.767702" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:01.767285" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:01.768513" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:01.768245" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:01.768699" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:01.767907" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.769445" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:01.769052" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:01.769795" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:01.769955" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:01.769628" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.771994" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:01.770132" elapsed="0.001910"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.773043" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:01.772757" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.773518" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:01.773245" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.773889" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.774088" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.774259" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:01.773759" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.773600" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:01.774393" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:01.774558" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:01.772422" elapsed="0.002161"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:01.772121" elapsed="0.002494"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.774796" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:01.774655" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:01.772097" elapsed="0.002775"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.775453" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:01.775008" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:01.775529" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:01.766677" elapsed="0.008990"/>
</kw>
<msg time="2026-06-06T03:34:01.775724" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:01.765788" elapsed="0.009984"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.776255" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.776766" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.777318" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.777499" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.777680" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.778029" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:01.777892" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:01.777877" elapsed="0.000231"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.778240" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.778438" elapsed="0.000030"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.778655" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:01.777850" elapsed="0.000864"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.777755" elapsed="0.000984"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.778879" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.778954" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:01.779070" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:01.761522" elapsed="0.017573"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:01.780314" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:01.780066" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:01.780472" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:01.779732" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.780823" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:01.780568" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.781400" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:01.781108" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:01.780904" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:01.780549" elapsed="0.000933"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.784083" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:01.781627" elapsed="0.002483"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:01.784167" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:01.784321" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:01.779400" elapsed="0.004947"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:01.785578" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:01.785342" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:01.785797" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:01.785006" elapsed="0.000816"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:01.786030" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:01.785894" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:01.785875" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.786254" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.786419" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.786484" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:01.788414" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:01.784654" elapsed="0.003787"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.789869" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:01.789596" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:01.790306" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:01.790062" elapsed="0.000288"/>
</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-06-06T03:34:01.798544" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:01.798704" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:01.798810" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:01.792512" elapsed="0.006665">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:01.790415" elapsed="0.008843">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:01.799442" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:01.799291" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:01.790397" elapsed="0.009134">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:01.799916" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.800049" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:01.800012" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:01.799994" elapsed="0.000118"/>
</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-06-06T03:34:01.800249" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.800318" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:01.788759" elapsed="0.011660">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.800492" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:01.739237" elapsed="0.061349">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:01.800906" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:01.800733" elapsed="0.000274"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:01.800714" elapsed="0.000320"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:01.801108" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:01.733001" elapsed="0.068212">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.848823" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:02.848388" elapsed="0.000483"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:02.849708" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:02.849396" elapsed="0.000396">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:02.849887" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:02.849045" elapsed="0.000867"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.850463" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:02.850074" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:02.850883" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:02.851055" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:02.850711" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.851485" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:02.851234" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.852502" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:02.852246" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.852987" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:02.852717" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.853356" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.853557" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.853743" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:02.853226" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.853072" elapsed="0.000763"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:02.853883" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:02.854051" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:02.851928" elapsed="0.002148"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:02.851611" elapsed="0.002498"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.854280" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:02.854134" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:02.851586" elapsed="0.002770"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.855006" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:02.854495" elapsed="0.000600"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:02.855147" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:02.847737" elapsed="0.007543"/>
</kw>
<msg time="2026-06-06T03:34:02.855335" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:02.846803" elapsed="0.008579"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.855891" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.856396" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.856916" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.857101" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.857274" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.857841" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:02.857696" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:02.857680" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.858060" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.858228" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.858389" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:02.857634" elapsed="0.000808"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.857351" elapsed="0.001117"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.858653" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.858750" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:34:02.858881" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:02.842250" elapsed="0.016657"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:02.860179" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:02.859943" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:02.860337" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:02.859586" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.860688" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:02.860432" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.861241" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:02.860941" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:02.860771" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:02.860414" elapsed="0.000910"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.863843" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:02.861470" elapsed="0.002401"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:02.863924" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:02.864078" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:02.859262" elapsed="0.004841"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:02.865309" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:02.865071" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:02.865465" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:02.864739" elapsed="0.000751"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:02.865714" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:02.865561" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:02.865542" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.865938" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.866109" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.866175" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:02.868187" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:02.864403" elapsed="0.003812"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.869612" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:02.869341" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:02.870091" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:02.869841" elapsed="0.000294"/>
</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-06-06T03:34:02.877367" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:02.877505" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:02.877599" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:02.872568" elapsed="0.005416">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:02.870201" elapsed="0.007899">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:02.878293" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:02.878136" elapsed="0.000223"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:02.870183" elapsed="0.008200">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:02.878817" elapsed="0.000031"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.878967" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:02.878929" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:02.878910" elapsed="0.000120"/>
</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-06-06T03:34:02.879171" elapsed="0.000025"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.879245" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:02.868518" elapsed="0.010829">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.879421" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:02.818800" elapsed="0.060713">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:02.879792" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:02.879603" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:02.879586" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:02.879921" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:02.809826" elapsed="0.070189">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.927003" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:03.926582" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:03.927819" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:03.927544" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:03.927990" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:03.927207" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.928762" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:03.928213" elapsed="0.000577"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:03.929092" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:03.929259" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:03.928947" elapsed="0.000413"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.929790" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:03.929518" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.931081" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:03.930814" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.931560" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:03.931287" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.931937" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.932153" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.932329" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:03.931805" elapsed="0.000581"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.931658" elapsed="0.000758"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:03.932463" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:03.932630" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:03.930468" elapsed="0.002203"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:03.929917" elapsed="0.002788"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.932873" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:03.932731" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:03.929893" elapsed="0.003057"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.933537" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:03.933088" elapsed="0.000477"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:03.933614" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:03.925965" elapsed="0.007792"/>
</kw>
<msg time="2026-06-06T03:34:03.933812" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:03.924982" elapsed="0.008877"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.934348" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.934865" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.935363" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.935582" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.935768" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.936157" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:03.935988" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:03.935973" elapsed="0.000267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.936378" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.936540" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.936715" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:03.935945" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.935845" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.936935" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.937011" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:03.937128" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:03.920495" elapsed="0.016659"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:03.938390" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:03.938154" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:03.938547" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:03.937821" elapsed="0.000750"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.938898" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:03.938656" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.939446" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:03.939150" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:03.938979" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:03.938622" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.942095" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:03.939686" elapsed="0.002437"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:03.942175" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:03.942334" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:03.937484" elapsed="0.004875"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:03.943568" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:03.943335" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:03.943743" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:03.943004" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:03.943974" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:03.943838" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:03.943819" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.944258" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.944427" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.944493" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:03.946411" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:03.942681" elapsed="0.003756"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.947835" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:03.947561" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:03.948310" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:03.948026" elapsed="0.000329"/>
</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-06-06T03:34:03.955510" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:03.955665" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:03.955761" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:03.950478" elapsed="0.005641">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:03.948422" elapsed="0.007812">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:03.956416" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:03.956267" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:03.948403" elapsed="0.008101">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:03.956890" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.957022" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:03.956985" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:03.956968" elapsed="0.000118"/>
</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-06-06T03:34:03.957225" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.957296" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:03.946754" elapsed="0.010644">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.957470" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:03.897926" elapsed="0.059637">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:03.957843" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:03.957670" elapsed="0.000250"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:03.957651" elapsed="0.000294"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:03.958010" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:03.889415" elapsed="0.068695">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.004055" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:05.003660" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:05.004850" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:05.004584" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:05.005021" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:05.004256" elapsed="0.000790"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.005599" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:05.005203" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:05.005946" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:05.006124" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:05.005801" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.006577" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:05.006320" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.007612" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:05.007357" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.008094" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:05.007828" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.008446" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.008668" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.008840" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:05.008316" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.008174" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:05.008974" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:05.009144" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:05.007042" elapsed="0.002128"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:05.006741" elapsed="0.002462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.009368" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:05.009227" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:05.006716" elapsed="0.002728"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.010064" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:05.009605" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:05.010141" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:05.003035" elapsed="0.007230"/>
</kw>
<msg time="2026-06-06T03:34:05.010371" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:05.002110" elapsed="0.008311"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.010929" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.011443" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.012136" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.012321" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.012491" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.012863" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:05.012723" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:05.012707" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.013078" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.013241" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.013412" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:05.012678" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.012566" elapsed="0.000925"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.013658" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.013736" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:05.013852" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:04.997858" elapsed="0.016020"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:05.015097" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:05.014856" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:05.015251" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:05.014507" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.015657" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:05.015379" elapsed="0.000338"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.016205" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:05.015913" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:05.015742" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:05.015360" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.018700" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:05.016430" elapsed="0.002299"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:05.018781" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:05.018935" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:05.014189" elapsed="0.004770"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:05.020147" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:05.019914" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:05.020306" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:05.019567" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:05.020537" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:05.020401" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:05.020383" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.020781" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.020945" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.021009" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:05.023007" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:05.019251" elapsed="0.003782"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.024395" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:05.024146" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:05.024841" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:05.024584" elapsed="0.000300"/>
</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-06-06T03:34:05.031934" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:05.032067" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:05.032169" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:05.027176" elapsed="0.005359">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:05.024958" elapsed="0.007658">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:05.032813" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:05.032664" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:05.024932" elapsed="0.007969">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:05.033339" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.033472" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:05.033435" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:05.033417" elapsed="0.000157"/>
</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-06-06T03:34:05.033732" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.033802" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:05.023327" elapsed="0.010577">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.033977" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:04.975414" elapsed="0.058655">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:05.034400" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:05.034160" elapsed="0.000356"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:05.034143" elapsed="0.000406"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:05.034594" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:04.967844" elapsed="0.066902">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.078177" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:06.077781" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:06.079052" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:06.078797" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:06.079228" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:06.078384" elapsed="0.000869"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.079824" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:06.079411" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:06.080143" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:06.080294" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:06.080003" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.080742" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:06.080478" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.081933" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:06.081674" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.082455" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:06.082188" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.082834" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.083034" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.083199" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:06.082690" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.082535" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:06.083332" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:06.083497" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:06.081339" elapsed="0.002189"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:06.080865" elapsed="0.002695"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.083740" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:06.083586" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:06.080842" elapsed="0.002974"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.084392" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:06.083949" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:06.084468" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:06.077157" elapsed="0.007433"/>
</kw>
<msg time="2026-06-06T03:34:06.084658" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:06.076303" elapsed="0.008404"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.085191" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.085705" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.086208" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.086386" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.086553" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.086960" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:06.086821" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:06.086772" elapsed="0.000301"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.087210" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.087377" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.087536" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:06.086744" elapsed="0.000846"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.086633" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.087770" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.087846" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:06.087961" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:06.072061" elapsed="0.015926"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:06.089222" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:06.088975" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:06.089410" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:06.088619" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.089759" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:06.089507" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.090299" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:06.090007" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:06.089841" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:06.089488" elapsed="0.000892"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.092926" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:06.090529" elapsed="0.002425"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:06.093005" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:06.093158" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:06.088303" elapsed="0.004880"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:06.094385" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:06.094149" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:06.094539" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:06.093811" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:06.094785" elapsed="0.000068"/>
</return>
<status status="PASS" start="2026-06-06T03:34:06.094633" elapsed="0.000254"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:06.094614" elapsed="0.000298"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.095050" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.095213" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.095279" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:06.097190" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:06.093477" elapsed="0.003777"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.098663" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:06.098398" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:06.099125" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:06.098882" elapsed="0.000287"/>
</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-06-06T03:34:06.106400" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:06.106537" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:06.106636" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:06.101564" elapsed="0.005487">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:06.099234" elapsed="0.007901">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:06.107329" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:06.107170" elapsed="0.000223"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:06.099216" elapsed="0.008200">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:06.107810" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.107944" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:06.107906" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:06.107888" elapsed="0.000121"/>
</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-06-06T03:34:06.108146" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.108215" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:06.097570" elapsed="0.010753">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.108396" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:06.049784" elapsed="0.058706">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:06.108769" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:06.108581" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:06.108564" elapsed="0.000303"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:06.108899" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:06.042185" elapsed="0.066808">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.155458" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:07.155057" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:07.156283" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:07.156020" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:07.156457" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:07.155676" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.157039" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:07.156652" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:07.157363" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:07.157532" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:07.157219" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.157970" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:07.157723" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.158980" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:07.158725" elapsed="0.000299"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.159442" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:07.159176" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.159815" elapsed="0.000034"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.160052" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.160221" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:07.159685" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.159523" elapsed="0.000786"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:07.160358" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:07.160526" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:07.158396" elapsed="0.002155"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:07.158095" elapsed="0.002489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.160766" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:07.160610" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:07.158070" elapsed="0.002773"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.161420" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:07.160978" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:07.161498" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:07.154434" elapsed="0.007188"/>
</kw>
<msg time="2026-06-06T03:34:07.161694" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:07.153534" elapsed="0.008209"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.162290" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.162811" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.163311" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.163495" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.163679" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.216248" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:07.216014" elapsed="0.000315"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:07.215993" elapsed="0.000363"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.216496" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.216679" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.216842" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:07.215944" elapsed="0.000951"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.163756" elapsed="0.053165"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.217061" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.217140" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:34:07.217304" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:07.149245" elapsed="0.068089"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:07.218722" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:07.218424" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:07.218890" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:07.218039" elapsed="0.000876"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.219247" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:07.218986" elapsed="0.000381"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.219877" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:07.219560" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:07.219395" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:07.218967" elapsed="0.000993"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.222343" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:07.220128" elapsed="0.002242"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:07.222423" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:07.222578" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:07.217687" elapsed="0.004916"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:07.223825" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:07.223573" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:07.223984" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:07.223235" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:07.224254" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:07.224115" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:07.224095" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.224479" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.224663" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.224732" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:07.226792" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:07.222914" elapsed="0.003905"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.228234" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:07.227952" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:07.228699" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:07.228430" elapsed="0.000313"/>
</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-06-06T03:34:07.235680" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:07.235818" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:07.235925" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:07.230891" elapsed="0.005417">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:07.228810" elapsed="0.007579">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:07.236571" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:07.236422" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:07.228791" elapsed="0.007886">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:07.237046" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.237224" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:07.237185" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:07.237166" elapsed="0.000124"/>
</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-06-06T03:34:07.237434" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.237505" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:07.227118" elapsed="0.010492">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.237704" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:07.126916" elapsed="0.110885">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:07.238067" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:07.237895" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:07.237877" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:07.238197" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:07.120704" elapsed="0.117588">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.286560" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:08.286155" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:08.287406" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:08.287141" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:08.287582" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:08.286801" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.288188" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:08.287786" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:08.288519" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:08.288709" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:08.288373" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.289181" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:08.288894" elapsed="0.000340"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.290236" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:08.289971" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.290734" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:08.290439" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.291100" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.291380" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.291552" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:08.290968" elapsed="0.000643"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.290818" elapsed="0.000840"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:08.291712" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:08.291884" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:08.289629" elapsed="0.002281"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:08.289316" elapsed="0.002626"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.292113" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:08.291969" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:08.289290" elapsed="0.002900"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.292806" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:08.292328" elapsed="0.000506"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:08.292884" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:08.285510" elapsed="0.007498"/>
</kw>
<msg time="2026-06-06T03:34:08.293064" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:08.284496" elapsed="0.008641"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.293654" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.294164" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.294689" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.294875" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.295045" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.295416" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:08.295272" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:08.295256" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.295634" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.295862" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.296028" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:08.295226" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.295121" elapsed="0.000987"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.296252" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.296329" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:08.296453" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:08.279973" elapsed="0.016506"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:08.297994" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:08.297737" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:08.298162" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:08.297377" elapsed="0.000811"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.298510" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:08.298265" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.299085" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:08.298783" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:08.298593" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:08.298245" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.301630" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:08.299320" elapsed="0.002351"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:08.301725" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:08.301884" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:08.296818" elapsed="0.005091"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:08.303174" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:08.302924" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:08.303338" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:08.302539" elapsed="0.000825"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:08.303578" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:34:08.303438" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:08.303418" elapsed="0.000264"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.303828" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.303997" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.304063" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:08.306061" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:08.302213" elapsed="0.003875"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.307585" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:08.307248" elapsed="0.000386"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:08.308052" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:08.307804" elapsed="0.000292"/>
</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-06-06T03:34:08.315054" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:08.315198" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:08.315309" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:08.310290" elapsed="0.005460">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:08.308165" elapsed="0.007677">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:08.316050" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:08.315880" elapsed="0.000259"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:08.308145" elapsed="0.008019">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:08.316622" elapsed="0.000045"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.316788" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:08.316746" elapsed="0.000088"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:08.316726" elapsed="0.000132"/>
</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-06-06T03:34:08.317002" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.317077" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:08.306401" elapsed="0.010830">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.317311" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:08.253150" elapsed="0.064267">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:08.317714" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:08.317515" elapsed="0.000276"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:08.317496" elapsed="0.000321"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:08.317851" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:08.244309" elapsed="0.073641">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.367300" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:09.366894" elapsed="0.000538"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:09.368229" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:09.367968" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:09.368403" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:09.367611" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.369000" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:09.368592" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:09.369333" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:09.369494" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:09.369185" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.369946" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:09.369693" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.370994" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:09.370733" elapsed="0.000307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.371465" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:09.371195" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.371850" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.372053" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.372223" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:09.371717" elapsed="0.000564"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.371550" elapsed="0.000762"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:09.372363" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:09.372534" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:09.370397" elapsed="0.002162"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:09.370075" elapsed="0.002516"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.372776" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:09.372618" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:09.370050" elapsed="0.002804"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.373448" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:09.372994" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:09.373525" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:09.366259" elapsed="0.007405"/>
</kw>
<msg time="2026-06-06T03:34:09.373721" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:09.365296" elapsed="0.008473"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.374293" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.374856" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.375562" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.375766" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.375940" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.376304" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:09.376163" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:09.376148" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.376527" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.376708" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.376873" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:09.376119" elapsed="0.000808"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.376018" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.377093" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.377170" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:09.377286" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:09.360881" elapsed="0.016430"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:09.378547" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:09.378308" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:09.378724" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:09.377958" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.379063" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:09.378822" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.379612" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:09.379315" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:09.379144" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:09.378803" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.382243" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:09.379856" elapsed="0.002413"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:09.382356" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:09.382515" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:09.377623" elapsed="0.004917"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:09.383951" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:09.383704" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:09.384114" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:09.383291" elapsed="0.000847"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:09.384356" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:09.384213" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:09.384193" elapsed="0.000248"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.384595" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.384781" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.384848" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:09.386976" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:09.382854" elapsed="0.004149"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.388407" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:09.388154" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:09.388862" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:09.388602" elapsed="0.000304"/>
</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-06-06T03:34:09.395386" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:09.395523" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:09.395618" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:09.391076" elapsed="0.004928">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:09.388972" elapsed="0.007113">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:09.396268" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:09.396118" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:09.388954" elapsed="0.007402">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:09.396751" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.396884" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:09.396847" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:09.396830" elapsed="0.000118"/>
</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-06-06T03:34:09.397087" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.397156" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:09.387317" elapsed="0.009942">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.397378" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:09.338255" elapsed="0.059222">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:09.397763" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:09.397571" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:09.397554" elapsed="0.000305"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:09.397892" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:09.328520" elapsed="0.069469">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.443248" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:10.442836" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:10.444057" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:10.443801" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:10.444227" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:10.443449" elapsed="0.000803"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.444844" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:10.444435" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:10.445171" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:10.445335" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:10.445028" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.445785" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:10.445519" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.446893" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:10.446562" elapsed="0.000378"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.447415" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:10.447133" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.447821" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.448022" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.448191" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:10.447681" elapsed="0.000567"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.447500" elapsed="0.000780"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:10.448398" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:34:10.448574" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:10.446214" elapsed="0.002385"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:10.445912" elapsed="0.002720"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.448819" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:10.448674" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:10.445889" elapsed="0.003006"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.449489" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:10.449034" elapsed="0.000483"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:10.449566" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:10.442198" elapsed="0.007510"/>
</kw>
<msg time="2026-06-06T03:34:10.449764" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:10.441235" elapsed="0.008579"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.450314" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.450841" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.451374" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.451556" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.451741" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.452099" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:10.451960" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:10.451945" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.452312" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.452475" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.452633" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:10.451917" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.451818" elapsed="0.000910"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.452905" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.452982" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:10.453102" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:10.436727" elapsed="0.016402"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:10.454578" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:10.454334" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:10.454758" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:10.453999" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.455094" elapsed="0.000059"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:10.454853" elapsed="0.000340"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.455784" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:10.455401" elapsed="0.000411"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:10.455218" elapsed="0.000631"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:10.454835" elapsed="0.001036"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.458324" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:10.456023" elapsed="0.002329"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:10.458405" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:10.458561" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:10.453466" elapsed="0.005121"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:10.459855" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:10.459597" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:10.460015" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:10.459248" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:10.460253" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:34:10.460109" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:10.460091" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.460485" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.460667" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.460736" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:10.463241" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:10.458905" elapsed="0.004375"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.464889" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:10.464606" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:10.465345" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:10.465085" elapsed="0.000306"/>
</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-06-06T03:34:10.472681" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:10.472883" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:10.472987" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:10.467623" elapsed="0.005771">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:10.465459" elapsed="0.008058">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:10.473825" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:10.473569" elapsed="0.000356"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:10.465440" elapsed="0.008523">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:10.474541" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.474767" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:10.474709" elapsed="0.000122"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:10.474681" elapsed="0.000184"/>
</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-06-06T03:34:10.475072" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.475207" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:10.463733" elapsed="0.011629">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.475473" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:10.413778" elapsed="0.061834">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:10.476028" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:10.475771" elapsed="0.000364"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:10.475745" elapsed="0.000426"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:10.476219" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:10.407500" elapsed="0.068861">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.522417" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:11.522021" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:11.523220" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:11.522966" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:11.523389" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:11.522617" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.524077" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:11.523666" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:11.524407" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:11.524566" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:11.524263" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.525016" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:11.524763" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.526040" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:11.525780" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.526508" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:11.526240" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.526879" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.527079" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.527248" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:11.526749" elapsed="0.000557"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.526589" elapsed="0.000747"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:11.527382" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:11.527552" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:11.525443" elapsed="0.002135"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:11.525143" elapsed="0.002468"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.527797" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:11.527637" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:11.525119" elapsed="0.002755"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.528489" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:11.528039" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:11.528567" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:11.521395" elapsed="0.007320"/>
</kw>
<msg time="2026-06-06T03:34:11.528771" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:11.520515" elapsed="0.008304"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.529316" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.529837" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.530563" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.530766" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.530939" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.531302" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:11.531162" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:11.531146" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.531519" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.531699" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.531864" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:11.531117" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.531016" elapsed="0.000929"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.532113" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.532201" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:34:11.532336" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:11.516223" elapsed="0.016139"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:11.533609" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:11.533369" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:11.533788" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:11.533035" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.534125" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:11.533883" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.534688" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:11.534376" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:11.534206" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:11.533865" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.537244" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:11.534919" elapsed="0.002354"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:11.537331" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:34:11.537500" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:11.532693" elapsed="0.004832"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:11.538906" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:11.538590" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:11.539257" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:11.538232" elapsed="0.001051"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:11.539526" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:34:11.539365" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:11.539343" elapsed="0.000272"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.539790" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.539962" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.540057" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:11.542278" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:11.537879" elapsed="0.004427"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.543856" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:11.543543" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:11.544344" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:11.544093" elapsed="0.000296"/>
</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-06-06T03:34:11.551776" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:11.551944" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:11.552108" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:11.546777" elapsed="0.005778">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:11.544465" elapsed="0.008245">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:11.553066" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:11.552766" elapsed="0.000422"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:11.544441" elapsed="0.008791">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:11.553882" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.554105" elapsed="0.000027"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:11.554033" elapsed="0.000150"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:11.554003" elapsed="0.000222"/>
</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-06-06T03:34:11.554500" elapsed="0.000038"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.554623" elapsed="0.000047"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:11.542673" elapsed="0.012148">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.554933" elapsed="0.000034"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:11.493739" elapsed="0.061377">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:11.555751" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:11.555383" elapsed="0.000512"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:11.555350" elapsed="0.000594"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:11.556014" elapsed="0.000060"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:11.486343" elapsed="0.069907">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.606329" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:12.605927" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:12.607147" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:12.606893" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:12.607320" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:12.606539" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.607918" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:12.607506" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:12.608248" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:12.608413" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:12.608103" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.608898" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:12.608594" elapsed="0.000354"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.609934" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:12.609664" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.610416" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:12.610138" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.610788" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.610991" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.611161" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:12.610655" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.610497" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:12.611301" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:12.611470" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:12.609323" elapsed="0.002173"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:12.609027" elapsed="0.002502"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.611715" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:12.611555" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:12.609003" elapsed="0.002791"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.612385" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:12.611934" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:12.612530" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:12.605301" elapsed="0.007375"/>
</kw>
<msg time="2026-06-06T03:34:12.612734" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:12.604397" elapsed="0.008386"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.613306" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.613830" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.614332" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.614514" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.614698" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.615059" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:12.614919" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:12.614903" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.615275" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.615436" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.615596" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:12.614875" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.614775" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.615832" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.615907" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:12.616026" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:12.600061" elapsed="0.015991"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:12.617561" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:12.617309" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:12.617743" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:12.616739" elapsed="0.001030"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.618086" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:12.617842" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.618654" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:12.618338" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:12.618169" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:12.617823" elapsed="0.000918"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.621116" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:12.618900" elapsed="0.002243"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:12.621195" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:12.621350" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:12.616403" elapsed="0.004972"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:12.622592" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:12.622355" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:12.622768" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:12.622014" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:12.623001" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:12.622864" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:12.622846" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.623227" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.623394" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.623460" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:12.625423" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:12.621687" elapsed="0.003764"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.626859" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:12.626587" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:12.627301" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:12.627056" elapsed="0.000290"/>
</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-06-06T03:34:12.634260" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:12.634395" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:12.634500" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:12.629520" elapsed="0.005370">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:12.627412" elapsed="0.007594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:12.635194" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:12.635042" elapsed="0.000218"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:12.627394" elapsed="0.007890">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:12.635667" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.635802" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:12.635763" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:12.635746" elapsed="0.000122"/>
</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-06-06T03:34:12.636007" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.636077" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:12.625769" elapsed="0.010411">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.636252" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:12.575059" elapsed="0.061285">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:12.636611" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:12.636433" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:12.636417" elapsed="0.000306"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:12.636756" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:12.565909" elapsed="0.070944">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.682370" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:13.681967" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:13.683207" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:13.682935" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:13.683387" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:13.682581" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.683975" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:13.683572" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:13.684318" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:13.684490" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:13.684158" elapsed="0.000634"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.685204" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:13.684954" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.686262" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:13.686004" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.686750" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:13.686461" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.687118" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.687317" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.687486" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:13.686986" elapsed="0.000562"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.686835" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:13.687630" elapsed="0.000049"/>
</return>
<msg time="2026-06-06T03:34:13.687818" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:13.685669" elapsed="0.002174"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:13.685333" elapsed="0.002543"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.688044" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:13.687902" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:13.685307" elapsed="0.002813"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.688733" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:13.688259" elapsed="0.000503"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:13.688812" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:13.681309" elapsed="0.007628"/>
</kw>
<msg time="2026-06-06T03:34:13.688992" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:13.680325" elapsed="0.008716"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.689532" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.690218" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.690953" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.691183" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.691355" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.691734" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:13.691579" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:13.691564" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.691951" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.692114" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.692273" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:13.691535" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.691434" elapsed="0.000919"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.692492" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.692568" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:13.692701" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:13.675873" elapsed="0.016855"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:13.694028" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:13.693760" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:13.694194" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:13.693365" elapsed="0.000854"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.694531" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:13.694290" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.695111" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:13.694815" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:13.694612" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:13.694271" elapsed="0.000922"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.697671" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:13.695338" elapsed="0.002377"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:13.697767" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:13.697923" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:13.693045" elapsed="0.004903"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:13.699160" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:13.698920" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:13.699319" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:13.698568" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:13.699553" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:13.699414" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:13.699395" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.699845" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.700013" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.700080" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:13.702063" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:13.698245" elapsed="0.003845"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.703486" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:13.703232" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:13.703942" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:13.703696" elapsed="0.000290"/>
</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-06-06T03:34:13.711192" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:13.711341" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:13.711449" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:13.706356" elapsed="0.005641">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:13.704053" elapsed="0.008069">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:13.712404" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:13.712174" elapsed="0.000327"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:13.704034" elapsed="0.008503">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:13.713136" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.713338" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:13.713281" elapsed="0.000121"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:13.713253" elapsed="0.000183"/>
</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-06-06T03:34:13.713661" elapsed="0.000034"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.713817" elapsed="0.000025"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:13.702403" elapsed="0.011573">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.714085" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:13.653268" elapsed="0.060960">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:13.714624" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:13.714365" elapsed="0.000387"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:13.714339" elapsed="0.000449"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:13.714908" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:13.646777" elapsed="0.068280">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.761555" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:14.761156" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:14.762415" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:14.762108" elapsed="0.000395">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:14.762601" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:14.761773" elapsed="0.000861"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.763208" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:14.762817" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:14.763536" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:14.763719" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:14.763392" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.764151" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:14.763900" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.765408" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:14.765139" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.765905" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:14.765618" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.766260" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.766458" elapsed="0.000060"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.766686" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:14.766130" elapsed="0.000615"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.765985" elapsed="0.000791"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:14.766824" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:34:14.767003" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:14.764810" elapsed="0.002222"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:14.764277" elapsed="0.002788"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.767236" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:14.767091" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:14.764253" elapsed="0.003060"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.767924" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:14.767452" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:14.768003" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:14.760518" elapsed="0.007612"/>
</kw>
<msg time="2026-06-06T03:34:14.768251" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:14.759655" elapsed="0.008649"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.768828" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.769337" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.769856" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.770041" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.770211" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.770597" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:14.770436" elapsed="0.000233"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:14.770420" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.770833" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.770995" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.771156" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:14.770390" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.770288" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.771376" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.771460" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:14.771578" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:14.755202" elapsed="0.016402"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:14.772871" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:14.772606" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:14.773034" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:14.772268" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.773413" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:14.773166" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.773985" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:14.773682" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:14.773496" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:14.773146" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.776729" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:14.774217" elapsed="0.002540"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:14.776809" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:14.776965" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:14.771940" elapsed="0.005051"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:14.778206" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:14.777969" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:14.778363" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:14.777616" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:14.778609" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:14.778460" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:14.778441" elapsed="0.000269"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.778853" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.779027" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.779094" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:14.781024" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:14.777290" elapsed="0.003761"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.782435" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:14.782185" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:14.782918" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:14.782669" elapsed="0.000293"/>
</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-06-06T03:34:14.789918" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:14.790053" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:14.790147" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:14.785127" elapsed="0.005418">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:14.783029" elapsed="0.007598">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:14.790823" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:14.790676" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:14.783010" elapsed="0.007900">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:14.791318" elapsed="0.000053"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.791483" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:14.791445" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:14.791427" elapsed="0.000124"/>
</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-06-06T03:34:14.791707" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.791777" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:14.781356" elapsed="0.010525">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.791955" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:14.732541" elapsed="0.059509">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:14.792313" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:14.792142" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:14.792125" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:14.792442" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:14.724671" elapsed="0.067870">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.838058" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:15.837637" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:15.838854" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:15.838588" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:15.839024" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:15.838258" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.839613" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:15.839206" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:15.839961" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:15.840124" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:15.839817" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.840558" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:15.840300" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.841585" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:15.841326" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.842144" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:15.841863" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.842506" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.842726" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.842897" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:15.842376" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.842228" elapsed="0.000758"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:15.843034" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:15.843200" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:15.841002" elapsed="0.002252"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:15.840701" elapsed="0.002588"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.843456" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:15.843314" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:15.840677" elapsed="0.002855"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.844126" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:15.843683" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:15.844203" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:15.837032" elapsed="0.007294"/>
</kw>
<msg time="2026-06-06T03:34:15.844380" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:15.836141" elapsed="0.008287"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.844951" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.845455" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.846154" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.846344" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.846516" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.846899" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:15.846756" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:15.846740" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.847160" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.847359" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.847524" elapsed="0.000028"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:15.846710" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.846591" elapsed="0.001025"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.847778" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.847857" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:15.847976" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:15.831830" elapsed="0.016174"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:15.849246" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:15.849005" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:15.849405" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:15.848666" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.849782" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:15.849507" elapsed="0.000334"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.850338" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:15.850042" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:15.849866" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:15.849486" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.852931" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:15.850569" elapsed="0.002389"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:15.853010" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:15.853164" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:15.848325" elapsed="0.004864"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:15.854407" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:15.854166" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:15.854567" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:15.853829" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:15.854821" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:15.854680" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:15.854659" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.855053" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.855222" elapsed="0.000042"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.855316" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:15.857276" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:15.853487" elapsed="0.003854"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.858762" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:15.858489" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:15.859217" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:15.858968" elapsed="0.000331"/>
</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-06-06T03:34:15.866335" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:15.866472" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:15.866571" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:15.861599" elapsed="0.005370">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:15.859370" elapsed="0.007683">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:15.867236" elapsed="0.000072"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:15.867086" elapsed="0.000275"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:15.859351" elapsed="0.008034">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:15.867849" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.868037" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:15.867984" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:15.867958" elapsed="0.000168"/>
</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-06-06T03:34:15.868316" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.868413" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:15.857667" elapsed="0.010890">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.868680" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:15.809297" elapsed="0.059525">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:15.869188" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:15.868950" elapsed="0.000337"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:15.868927" elapsed="0.000394"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:15.869366" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:15.802440" elapsed="0.067057">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.914712" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:16.914297" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:16.915500" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:16.915249" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:16.915690" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:16.914916" elapsed="0.000801"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.916280" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:16.915877" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:16.916606" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:16.916782" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:16.916464" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.917424" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:16.916971" elapsed="0.000500"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.918439" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:16.918181" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.918929" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:16.918658" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.919280" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.919479" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.919672" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:16.919150" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.919010" elapsed="0.000753"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:16.919810" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:16.920014" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:16.917859" elapsed="0.002183"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:16.917546" elapsed="0.002529"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.920254" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:16.920102" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:16.917523" elapsed="0.002808"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.920963" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:16.920472" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:16.921041" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:16.913691" elapsed="0.007474"/>
</kw>
<msg time="2026-06-06T03:34:16.921222" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:16.912814" elapsed="0.008458"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.921859" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.922371" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.922893" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.923074" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.923246" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.923618" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:16.923472" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:16.923456" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.923855" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.924034" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.924195" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:16.923427" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.923325" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.924414" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.924491" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:16.924628" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:16.908494" elapsed="0.016185"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:16.925970" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:16.925697" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:16.926137" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:16.925336" elapsed="0.000826"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.926483" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:16.926233" elapsed="0.000345"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.927093" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:16.926795" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:16.926605" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:16.926214" elapsed="0.000961"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.929824" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:16.927320" elapsed="0.002532"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:16.929906" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:16.930062" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:16.925004" elapsed="0.005083"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:16.931322" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:16.931077" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:16.931483" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:16.930739" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:16.931738" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:16.931579" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:16.931559" elapsed="0.000264"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.931978" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.932148" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.932214" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:16.934202" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:16.930394" elapsed="0.003836"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.935683" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:16.935396" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:16.936165" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:16.935882" elapsed="0.000327"/>
</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-06-06T03:34:16.942959" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:16.943101" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:16.943211" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:16.938382" elapsed="0.005219">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:16.936278" elapsed="0.007436">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:16.943925" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:16.943752" elapsed="0.000290"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:16.936259" elapsed="0.007808">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:16.944480" elapsed="0.000041"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.944778" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:16.944717" elapsed="0.000126"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:16.944688" elapsed="0.000188"/>
</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-06-06T03:34:16.945084" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.945189" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:16.934546" elapsed="0.010801">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.945459" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:16.886052" elapsed="0.059549">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:16.946015" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:16.945759" elapsed="0.000364"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:16.945733" elapsed="0.000425"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:16.946207" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:16.878889" elapsed="0.067458">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:17.993792" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:17.993369" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:17.994587" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:17.994334" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:17.994775" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:17.993996" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:17.995353" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:17.994962" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:17.995701" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:17.995866" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:17.995536" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:17.996294" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:17.996044" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:17.997356" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:17.997096" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:17.997847" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:17.997557" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:17.998203" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:17.998496" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:17.998684" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:17.998073" elapsed="0.000672"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:17.997928" elapsed="0.000847"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:17.998822" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:17.998992" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:17.996772" elapsed="0.002245"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:17.996419" elapsed="0.002631"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:17.999218" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:17.999076" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:17.996395" elapsed="0.002902"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:17.999908" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:17.999435" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:17.999986" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:17.992753" elapsed="0.007358"/>
</kw>
<msg time="2026-06-06T03:34:18.000167" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:17.991829" elapsed="0.008386"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.000744" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.001250" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.001767" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.001951" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.002121" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.002723" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:18.002553" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:18.002537" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.002945" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.003148" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.003311" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:18.002506" elapsed="0.000860"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.002198" elapsed="0.001195"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.003533" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.003611" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:18.003748" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:17.987496" elapsed="0.016279"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:18.005068" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:18.004816" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:18.005233" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:18.004422" elapsed="0.000836"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.005574" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:18.005329" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:18.006147" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:18.005851" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:18.005677" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:18.005310" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:18.008738" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:18.006377" elapsed="0.002390"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:18.008821" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:18.008979" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:18.004093" elapsed="0.004911"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:18.010240" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:18.009994" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:18.010402" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:18.009653" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:18.010653" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:34:18.010499" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:18.010480" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.010883" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.011052" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.011117" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:18.013257" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:18.009310" elapsed="0.003974"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:18.014747" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:18.014423" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:18.015193" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:18.014945" elapsed="0.000292"/>
</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-06-06T03:34:18.022789" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:18.022970" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:18.023122" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:18.017584" elapsed="0.006040">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:18.015304" elapsed="0.008462">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:18.024021" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:18.023813" elapsed="0.000297"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:18.015286" elapsed="0.008857">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:18.024672" elapsed="0.000069"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.024902" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:18.024848" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:18.024822" elapsed="0.000169"/>
</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-06-06T03:34:18.025185" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.025282" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:18.013588" elapsed="0.011840">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.025531" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:17.964790" elapsed="0.060897">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:18.026059" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:18.025821" elapsed="0.000337"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:18.025798" elapsed="0.000394"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:18.026237" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:17.958472" elapsed="0.067898">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.072726" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:19.072299" elapsed="0.000551"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:19.073689" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:19.073411" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:19.073871" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:19.073027" elapsed="0.000870"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.074459" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:19.074059" elapsed="0.000427"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:19.074810" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:19.074971" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:19.074659" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.075406" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:19.075154" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.076789" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:19.076224" elapsed="0.000615"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.077283" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:19.077002" elapsed="0.000380"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.077765" elapsed="0.000026"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.077973" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.078144" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:19.077610" elapsed="0.000590"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.077455" elapsed="0.000776"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:19.078278" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:19.078448" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:19.075895" elapsed="0.002579"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:19.075559" elapsed="0.002947"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.078689" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:19.078531" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:19.075526" elapsed="0.003245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.079362" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:19.078910" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:19.079439" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:19.071605" elapsed="0.007961"/>
</kw>
<msg time="2026-06-06T03:34:19.079621" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:19.070735" elapsed="0.008951"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.080182" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.080862" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.081408" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.081597" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.081791" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.082153" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:19.082014" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:19.081998" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.082371" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.082533" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.082711" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:19.081969" elapsed="0.000797"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.081869" elapsed="0.000924"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.082935" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.083011" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:19.083132" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:19.066363" elapsed="0.016796"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:19.084433" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:19.084160" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:19.084602" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:19.083822" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.084967" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:19.084719" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.085571" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:19.085223" elapsed="0.000376"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:19.085051" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:19.084698" elapsed="0.001013"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.090575" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:19.086045" elapsed="0.004558"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:19.090723" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:34:19.090906" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:19.083479" elapsed="0.007454"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:19.092180" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:19.091937" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:19.092343" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:19.091572" elapsed="0.000797"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:19.092584" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:19.092444" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:19.092424" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.092829" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.092999" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.093067" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:19.095068" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:19.091241" elapsed="0.003854"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.096473" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:19.096219" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:19.096931" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:19.096681" elapsed="0.000296"/>
</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-06-06T03:34:19.104405" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:19.104544" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:19.104661" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:19.099160" elapsed="0.005889">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:19.097045" elapsed="0.008089">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:19.105346" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:19.105168" elapsed="0.000247"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:19.097026" elapsed="0.008413">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:19.105841" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.105980" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:19.105941" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:19.105922" elapsed="0.000124"/>
</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-06-06T03:34:19.106187" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.106258" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:19.095396" elapsed="0.010967">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.106479" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:19.043429" elapsed="0.063150">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:19.106877" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:19.106696" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:19.106675" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:19.107011" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:19.036556" elapsed="0.070555">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.151188" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:20.150770" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:20.152016" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:20.151758" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:20.152199" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:20.151397" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.152803" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:20.152390" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:20.153137" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:20.153313" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:20.152989" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.153759" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:20.153490" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.154800" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:20.154522" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.155270" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:20.155001" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.155624" elapsed="0.000039"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.155846" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.156016" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:20.155495" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.155351" elapsed="0.000753"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:20.156217" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:20.156390" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:20.154203" elapsed="0.002213"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:20.153900" elapsed="0.002549"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.156617" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:20.156475" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:20.153877" elapsed="0.002835"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.157299" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:20.156852" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:20.157378" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:20.150130" elapsed="0.007374"/>
</kw>
<msg time="2026-06-06T03:34:20.157559" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:20.149170" elapsed="0.008437"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.158165" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.158713" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.159418" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.159607" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.159797" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.160161" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:20.160020" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:20.160005" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.160381" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.160545" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.160727" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:20.159976" elapsed="0.000806"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.159873" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.160984" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.161063" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:20.161182" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:20.144588" elapsed="0.016620"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:20.162452" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:20.162215" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:20.162611" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:20.161877" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.162972" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:20.162724" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.163518" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:20.163224" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:20.163055" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:20.162705" elapsed="0.000896"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.166010" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:20.163762" elapsed="0.002275"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:20.166090" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:20.166244" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:20.161525" elapsed="0.004744"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:20.167459" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:20.167226" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:20.167617" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:20.166897" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:20.167866" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:20.167729" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:20.167710" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.168095" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.168260" elapsed="0.000025"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.168330" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:20.170266" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:20.166563" elapsed="0.003730"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.171689" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:20.171423" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:20.172124" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:20.171884" elapsed="0.000284"/>
</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-06-06T03:34:20.179594" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:20.179794" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:20.179891" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:20.174627" elapsed="0.005659">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:20.172234" elapsed="0.008150">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:20.180570" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:20.180419" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:20.172215" elapsed="0.008463">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:20.181044" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.181178" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:20.181139" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:20.181122" elapsed="0.000121"/>
</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-06-06T03:34:20.181382" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.181454" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:20.170588" elapsed="0.011003">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.181686" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:20.120847" elapsed="0.060936">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:20.182083" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:20.181906" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:20.181858" elapsed="0.000320"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:20.182210" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:20.114438" elapsed="0.067872">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.228338" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:21.227927" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:21.229166" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:21.228906" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:21.229341" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:21.228548" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.230023" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:21.229611" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:21.230362" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:21.230553" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:21.230209" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.231001" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:21.230749" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.232260" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:21.231998" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.232752" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:21.232464" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.233113" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.233309" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.233475" elapsed="0.000026"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:21.232981" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.232836" elapsed="0.000732"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:21.233617" elapsed="0.000053"/>
</return>
<msg time="2026-06-06T03:34:21.233810" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:21.231671" elapsed="0.002164"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:21.231131" elapsed="0.002743"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.234048" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:21.233904" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:21.231105" elapsed="0.003019"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.234749" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:21.234264" elapsed="0.000514"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:21.234827" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:21.227253" elapsed="0.007700"/>
</kw>
<msg time="2026-06-06T03:34:21.235007" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:21.226355" elapsed="0.008699"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.235538" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.236051" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.236592" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.236797" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.236966" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.237321" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:21.237183" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:21.237168" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.237534" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.237708" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.237869" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:21.237140" elapsed="0.000781"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.237041" elapsed="0.000906"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.238086" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.238161" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:21.238278" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:21.221986" elapsed="0.016318"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:21.239566" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:21.239310" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:21.239747" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:21.238977" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.240080" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:21.239842" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.240678" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:21.240349" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:21.240172" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:21.239823" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.243292" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:21.240911" elapsed="0.002409"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:21.243373" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:21.243529" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:21.238656" elapsed="0.004898"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:21.244780" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:21.244523" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:21.244975" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:21.244191" elapsed="0.000809"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:21.245216" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:34:21.245073" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:21.245054" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.245445" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.245613" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.245703" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:21.247684" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:21.243868" elapsed="0.003845"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.249110" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:21.248858" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:21.249547" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:21.249304" elapsed="0.000291"/>
</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-06-06T03:34:21.261637" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:21.261899" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:21.262062" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:21.254155" elapsed="0.008514">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:21.249688" elapsed="0.013115">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:21.263078" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:21.262858" elapsed="0.000313"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:21.249667" elapsed="0.013537">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:21.263826" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.264026" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:21.263969" elapsed="0.000120"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:21.263942" elapsed="0.000178"/>
</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-06-06T03:34:21.264316" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.264414" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:21.248025" elapsed="0.016543">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.264696" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:21.199041" elapsed="0.065797">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:21.265313" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:21.265061" elapsed="0.000354"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:21.265035" elapsed="0.000415"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:21.265497" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:21.190207" elapsed="0.075434">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.311555" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:22.311160" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:22.312357" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:22.312098" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:22.312536" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:22.311771" elapsed="0.000789"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.313122" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:22.312736" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:22.313454" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:22.313614" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:22.313310" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.314051" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:22.313805" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.315063" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:22.314795" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.315532" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:22.315260" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.315904" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.316102" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.316268" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:22.315773" elapsed="0.000551"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.315613" elapsed="0.000742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:22.316403" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:22.316567" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:22.314469" elapsed="0.002122"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:22.314176" elapsed="0.002447"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.316807" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:22.316666" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:22.314152" elapsed="0.002730"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.317454" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:22.317017" elapsed="0.000522"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:22.317615" elapsed="0.000055"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:22.310505" elapsed="0.007284"/>
</kw>
<msg time="2026-06-06T03:34:22.317854" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:22.309635" elapsed="0.008275"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.318457" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.319324" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.320040" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.320256" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.320452" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.320896" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:22.320724" elapsed="0.000238"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:22.320707" elapsed="0.000281"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.321152" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.321347" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.321529" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:22.320675" elapsed="0.000917"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.320539" elapsed="0.001080"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.321810" elapsed="0.000032"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.321906" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:34:22.322055" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:22.305302" elapsed="0.016781"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:22.323552" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:22.323293" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:22.323773" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:22.322882" elapsed="0.000919"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.324177" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:22.323883" elapsed="0.000357"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.324835" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:22.324486" elapsed="0.000386"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:22.324274" elapsed="0.000638"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:22.323858" elapsed="0.001076"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.327849" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:22.325103" elapsed="0.002782"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:22.327945" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:22.328108" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:22.322479" elapsed="0.005654"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:22.329325" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:22.329093" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:22.329481" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:22.328762" elapsed="0.000743"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:22.329729" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:22.329574" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:22.329556" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.329951" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.330113" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.330177" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:22.333950" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:22.328429" elapsed="0.005548"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.335375" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:22.335122" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:22.335831" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:22.335568" elapsed="0.000307"/>
</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-06-06T03:34:22.342694" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:22.342835" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:22.342945" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:22.338009" elapsed="0.005351">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:22.335941" elapsed="0.007536">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:22.343675" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:22.343511" elapsed="0.000230"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:22.335922" elapsed="0.007843">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:22.344130" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.344263" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:22.344225" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:22.344207" elapsed="0.000118"/>
</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-06-06T03:34:22.344460" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.344529" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:22.334275" elapsed="0.010356">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.344720" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:22.282906" elapsed="0.061911">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:22.345081" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:22.344909" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:22.344892" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:22.345209" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:22.276236" elapsed="0.069067">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.392738" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:23.392306" elapsed="0.000467"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:23.393570" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:23.393307" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:23.393766" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:23.392946" elapsed="0.000847"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.394374" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:23.393957" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:23.394765" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:23.394935" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:23.394593" elapsed="0.000428"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.395475" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:23.395205" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.396610" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:23.396333" elapsed="0.000342"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.397122" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:23.396835" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.397513" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.397738" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.397912" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:23.397377" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.397217" elapsed="0.000785"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:23.398050" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:23.398230" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:23.395964" elapsed="0.002292"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:23.395637" elapsed="0.002653"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.398461" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:23.398315" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:23.395612" elapsed="0.002928"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.399162" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:23.398696" elapsed="0.000496"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:23.399243" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:23.391631" elapsed="0.007742"/>
</kw>
<msg time="2026-06-06T03:34:23.399430" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:23.390709" elapsed="0.008771"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.400016" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.400542" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.401072" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.401313" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.401522" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.401945" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:23.401776" elapsed="0.000233"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:23.401760" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.402200" elapsed="0.000030"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.402394" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.402559" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:23.401729" elapsed="0.000885"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.401606" elapsed="0.001054"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.402811" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.402890" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:23.403014" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:23.386019" elapsed="0.017021"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:23.404667" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:23.404173" elapsed="0.000565">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:23.404840" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:23.403768" elapsed="0.001099"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.405200" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:23.404940" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.405780" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:23.405462" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:23.405287" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:23.404921" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.408318" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:23.406038" elapsed="0.002309"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:23.408401" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:23.408559" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:23.403377" elapsed="0.005209"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:23.409957" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:23.409596" elapsed="0.000426">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:23.410118" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:23.409232" elapsed="0.000911"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:23.410355" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:23.410216" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:23.410197" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.410675" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.410852" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.410920" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:23.412897" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:23.408906" elapsed="0.004019"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.414341" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:23.414083" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:23.414805" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:23.414537" elapsed="0.000313"/>
</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-06-06T03:34:23.422154" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:23.422297" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:23.422395" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:23.417068" elapsed="0.005756">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:23.414917" elapsed="0.008028">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:23.423208" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:23.422992" elapsed="0.000309"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:23.414899" elapsed="0.008435">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:23.423924" elapsed="0.000046"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.424150" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:23.424095" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:23.424067" elapsed="0.000177"/>
</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-06-06T03:34:23.424442" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.424540" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:23.413234" elapsed="0.011475">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.424817" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:23.362278" elapsed="0.062677">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:23.425327" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:23.425084" elapsed="0.000345"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:23.425060" elapsed="0.000403"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:23.425559" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:23.355790" elapsed="0.069930">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.483100" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:24.482606" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:24.484074" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:24.483771" elapsed="0.000414">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:24.484296" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:24.483344" elapsed="0.000982"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.484995" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:24.484520" elapsed="0.000507"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:24.485384" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:24.485569" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:24.485216" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.486114" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:24.485813" elapsed="0.000352"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.487205" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:24.486938" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.487702" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:24.487410" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.488079" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.488338" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.488516" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:24.487943" elapsed="0.000632"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.487787" elapsed="0.000820"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:24.488674" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:24.488850" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:24.486573" elapsed="0.002311"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:24.486246" elapsed="0.002673"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.489094" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:24.488945" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:24.486222" elapsed="0.002952"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.489797" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:24.489317" elapsed="0.000509"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:24.489887" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:24.481880" elapsed="0.008139"/>
</kw>
<msg time="2026-06-06T03:34:24.490139" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:24.480751" elapsed="0.009440"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.490718" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.491251" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.492028" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.492241" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.492420" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.492812" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:24.492663" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:24.492631" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.493050" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.493216" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.493380" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:24.492601" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.492499" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.493603" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.493698" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:34:24.493822" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:24.474799" elapsed="0.019051"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:24.495124" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:24.494875" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:24.495287" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:24.494505" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.495694" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:24.495427" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.496314" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:24.495965" elapsed="0.000377"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:24.495781" elapsed="0.000599"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:24.495407" elapsed="0.000995"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.498874" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:24.496553" elapsed="0.002354"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:24.498970" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:24.499133" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:24.494179" elapsed="0.004981"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:24.500435" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:24.500189" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:24.500596" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:24.499817" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:24.500857" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:34:24.500712" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:24.500692" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.501094" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.501262" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.501330" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:24.503320" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:24.499466" elapsed="0.003881"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.504823" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:24.504543" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:24.505280" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:24.505030" elapsed="0.000294"/>
</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-06-06T03:34:24.513082" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:24.513223" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:24.513322" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:24.507684" elapsed="0.006031">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:24.505392" elapsed="0.008409">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:24.514073" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:24.513842" elapsed="0.000329"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:24.505373" elapsed="0.008833">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:24.514836" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.515035" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:24.514979" elapsed="0.000119"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:24.514953" elapsed="0.000178"/>
</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-06-06T03:34:24.515340" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.515445" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:24.503673" elapsed="0.011926">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.515731" elapsed="0.000025"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:24.443756" elapsed="0.072119">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:24.516295" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:24.516012" elapsed="0.000392"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:24.515986" elapsed="0.000454"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:24.516490" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:24.432632" elapsed="0.084001">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.562566" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:25.562165" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:25.563381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:25.563124" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:25.563553" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:25.562788" elapsed="0.000790"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.564147" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:25.563754" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:25.564475" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:25.564657" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:25.564331" elapsed="0.000367"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.565109" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:25.564855" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.566368" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:25.566103" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.566927" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:25.566635" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.567286" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.567493" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.567678" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:25.567156" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.567010" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:25.567817" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:25.567986" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:25.565772" elapsed="0.002240"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:25.565234" elapsed="0.002811"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.568215" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:25.568071" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:25.565210" elapsed="0.003082"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.568909" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:25.568430" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:25.568987" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:25.561533" elapsed="0.007580"/>
</kw>
<msg time="2026-06-06T03:34:25.569168" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:25.560623" elapsed="0.008592"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.569723" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.570229" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.570744" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.570926" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.571094" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.571455" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:25.571316" elapsed="0.000234"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:25.571301" elapsed="0.000275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.571728" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.571894" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.572057" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:25.571273" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.571168" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.572277" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.572353" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:25.572471" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:25.556370" elapsed="0.016127"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:25.573788" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:25.573517" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:25.573949" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:25.573182" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.574445" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:25.574201" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.575013" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:25.574715" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:25.574528" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:25.574181" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.577658" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:25.575243" elapsed="0.002444"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:25.577741" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:25.577898" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:25.572861" elapsed="0.005062"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:25.579130" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:25.578897" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:25.579286" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:25.578547" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:25.579516" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:25.579380" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:25.579361" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.579753" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.579918" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.579982" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:25.581944" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:25.578221" elapsed="0.003783"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.583390" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:25.583138" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:25.583844" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:25.583583" elapsed="0.000306"/>
</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-06-06T03:34:25.590440" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:25.590574" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:25.590699" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:25.586061" elapsed="0.005012">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:25.583954" elapsed="0.007201">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:25.591337" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:25.591188" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:25.583936" elapsed="0.007490">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:25.591810" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.591945" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:25.591907" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:25.591889" elapsed="0.000120"/>
</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-06-06T03:34:25.592145" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.592214" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:25.582310" elapsed="0.010005">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.592389" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:25.533954" elapsed="0.058528">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:25.592797" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:25.592573" elapsed="0.000303"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:25.592556" elapsed="0.000347"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:25.592939" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:25.526214" elapsed="0.066819">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.638166" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:26.637768" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:26.638982" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:26.638724" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:26.639157" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:26.638368" elapsed="0.000813"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.639749" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:26.639343" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:26.640080" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:26.640250" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:26.639931" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.640688" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:26.640426" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.641774" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:26.641498" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.642241" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:26.641973" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.642602" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.642820" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.642990" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:26.642471" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.642324" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:26.643129" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:26.643297" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:26.641146" elapsed="0.002176"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:26.640815" elapsed="0.002541"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.643523" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:26.643382" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:26.640791" elapsed="0.002807"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.644355" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:26.643752" elapsed="0.000631"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:26.644432" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:26.637114" elapsed="0.007441"/>
</kw>
<msg time="2026-06-06T03:34:26.644609" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:26.636242" elapsed="0.008430"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.645225" elapsed="0.000048"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.645779" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.646460" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.646662" elapsed="0.000039"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.646899" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.647269" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:26.647129" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:26.647114" elapsed="0.000263"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.647517" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.647695" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.647855" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:26.647086" elapsed="0.000821"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.646986" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.648077" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.648152" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:26.648277" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:26.631029" elapsed="0.017274"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:26.649628" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:26.649366" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:26.649812" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:26.648975" elapsed="0.000862"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.650209" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:26.649906" elapsed="0.000414"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.650837" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:26.650519" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:26.650348" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:26.649887" elapsed="0.001036"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.653393" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:26.651076" elapsed="0.002344"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:26.653472" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:26.653629" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:26.648628" elapsed="0.005041"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:26.654868" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:26.654615" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:26.655026" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:26.654285" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:26.655257" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:26.655121" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:26.655102" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.655484" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.655662" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.655730" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:26.658270" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:26.653967" elapsed="0.004331"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.660032" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:26.659701" elapsed="0.000400"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:26.660629" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:26.660316" elapsed="0.000377"/>
</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-06-06T03:34:26.668595" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:26.668781" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:26.668889" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:26.663725" elapsed="0.005579">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:26.660775" elapsed="0.008615">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:26.669591" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:26.669424" elapsed="0.000276"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:26.660749" elapsed="0.008978">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:26.670111" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.670300" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:26.670260" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:26.670241" elapsed="0.000124"/>
</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-06-06T03:34:26.670509" elapsed="0.000028"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.670607" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:26.658709" elapsed="0.012032">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.670818" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:26.608132" elapsed="0.062785">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:26.671191" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:26.671013" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:26.670995" elapsed="0.000293"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:26.671322" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:26.599909" elapsed="0.071511">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.722720" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:27.722152" elapsed="0.000614"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:27.723566" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:27.723310" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:27.723756" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:27.722980" elapsed="0.000800"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.724352" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:27.723944" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:27.724694" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:27.724948" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:27.724535" elapsed="0.000440"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.725734" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:27.725269" elapsed="0.000518"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.726791" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:27.726517" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.727254" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:27.726989" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.727608" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.727889" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.728064" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:27.727479" elapsed="0.000641"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.727334" elapsed="0.000818"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:27.728199" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:34:27.728367" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:27.726195" elapsed="0.002197"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:27.725900" elapsed="0.002523"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.728590" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:27.728450" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:27.725874" elapsed="0.002821"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.729287" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:27.728839" elapsed="0.000476"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:27.729364" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:27.721256" elapsed="0.008231"/>
</kw>
<msg time="2026-06-06T03:34:27.729541" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:27.720060" elapsed="0.009528"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.730130" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.730631" elapsed="0.000039"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.731144" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.731323" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.731490" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.731861" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:27.731722" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:27.731706" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.732075" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.732304" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.732465" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:27.731677" elapsed="0.000842"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.731563" elapsed="0.000982"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.732700" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.732778" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:27.732894" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:27.714109" elapsed="0.018811"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:27.734164" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:27.733927" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:27.734321" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:27.733552" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.734677" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:27.734417" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.735229" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:27.734930" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:27.734760" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:27.734398" elapsed="0.000914"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.739260" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:27.735456" elapsed="0.003832"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:27.739340" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:27.739494" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:27.733232" elapsed="0.006288"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:27.740740" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:27.740491" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:27.740898" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:27.740157" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:27.741130" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:27.740993" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:27.740974" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.741354" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.741520" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.741585" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:27.743535" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:27.739831" elapsed="0.003730"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.744989" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:27.744696" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:27.745432" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:27.745182" elapsed="0.000295"/>
</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-06-06T03:34:27.752734" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:27.752871" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:27.752972" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:27.747628" elapsed="0.005702">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:27.745544" elapsed="0.007867">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:27.753592" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:27.753444" elapsed="0.000229"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:27.745525" elapsed="0.008172">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:27.754103" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.754237" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:27.754199" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:27.754181" elapsed="0.000119"/>
</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-06-06T03:34:27.754436" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.754506" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:27.743874" elapsed="0.010733">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.754697" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:27.689847" elapsed="0.064944">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:27.755099" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:27.754882" elapsed="0.000318"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:27.754865" elapsed="0.000369"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:27.755279" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:27.679463" elapsed="0.075947">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.795863" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:28.795449" elapsed="0.000517"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:28.796736" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:28.796472" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:28.796906" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:28.796137" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.797484" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:28.797095" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:28.797832" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:28.797989" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:28.797689" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.798446" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:28.798167" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.799494" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:28.799234" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.799987" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:28.799713" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.800340" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.800540" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.800722" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:28.800211" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.800068" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:28.800858" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:28.801024" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:28.798910" elapsed="0.002140"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:28.798571" elapsed="0.002511"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.801248" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:28.801107" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:28.798548" elapsed="0.002777"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.801922" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:28.801463" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:28.802000" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:28.794832" elapsed="0.007292"/>
</kw>
<msg time="2026-06-06T03:34:28.802180" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:28.793904" elapsed="0.008324"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.802776" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.803323" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.803839" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.804021" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.804188" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.804750" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:28.804592" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:28.804577" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.804968" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.805133" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.805295" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:28.804548" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.804264" elapsed="0.001111"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.805515" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.805591" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:28.805724" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:28.789559" elapsed="0.016191"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:28.807005" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:28.806769" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:28.807162" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:28.806418" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.807496" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:28.807257" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.808059" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:28.807762" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:28.807578" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:28.807238" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.810538" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:28.808289" elapsed="0.002276"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:28.810668" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:28.810831" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:28.806065" elapsed="0.004792"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:28.812111" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:28.811854" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:28.812273" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:28.811495" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:28.812518" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:28.812373" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:28.812353" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.812761" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.812930" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.813003" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:28.815033" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:28.811166" elapsed="0.003896"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.816598" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:28.816307" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:28.817067" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:28.816818" elapsed="0.000294"/>
</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-06-06T03:34:28.824795" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:28.824984" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:28.825154" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:28.819589" elapsed="0.006154">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:28.817186" elapsed="0.008695">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:28.826214" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:28.825938" elapsed="0.000376"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:28.817164" elapsed="0.009186">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:28.827012" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.827222" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:28.827162" elapsed="0.000124"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:28.827132" elapsed="0.000187"/>
</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-06-06T03:34:28.827528" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.827632" elapsed="0.000044"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:28.815419" elapsed="0.012394">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.828116" elapsed="0.000025"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:28.766511" elapsed="0.061754">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:28.828706" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:28.828405" elapsed="0.000411"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:28.828380" elapsed="0.000473"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:28.828903" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:28.760247" elapsed="0.068798">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.880752" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:29.880237" elapsed="0.000557"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:29.881794" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:29.881444" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:29.882008" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:29.881014" elapsed="0.001026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.882623" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:29.882218" elapsed="0.000450"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:29.883028" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:29.883238" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:29.882829" elapsed="0.000439"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.883707" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:29.883424" elapsed="0.000353"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.885149" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:29.884852" elapsed="0.000344"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.885637" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:29.885357" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.886021" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.886430" elapsed="0.000027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.886606" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:29.885888" elapsed="0.000794"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.885739" elapsed="0.000976"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:29.886831" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:34:29.887038" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:29.884502" elapsed="0.002562"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:29.883888" elapsed="0.003209"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.887270" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:29.887124" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:29.883854" elapsed="0.003494"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.887978" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:29.887489" elapsed="0.000522"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:29.888062" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:29.879444" elapsed="0.008745"/>
</kw>
<msg time="2026-06-06T03:34:29.888245" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:29.878233" elapsed="0.010060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.888807" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.889315" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.889833" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.890054" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.890278" elapsed="0.000037"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.890771" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:29.890569" elapsed="0.000276"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:29.890549" elapsed="0.000329"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.891095" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.891309" elapsed="0.000026"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.891517" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:29.890513" elapsed="0.001071"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.890386" elapsed="0.001229"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.891870" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.891970" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:34:29.892124" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:29.873145" elapsed="0.019012"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:29.893596" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:29.893343" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:29.893785" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:29.892985" elapsed="0.000826"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.894131" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:29.893884" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.894715" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:29.894392" elapsed="0.000351"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:29.894217" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:29.893864" elapsed="0.000938"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.897527" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:29.894970" elapsed="0.002584"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:29.897609" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:34:29.897781" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:29.892554" elapsed="0.005253"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:29.899038" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:29.898780" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:29.899201" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:29.898430" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:29.899437" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:29.899298" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:29.899278" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.899679" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.899850" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.899916" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:29.902186" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:29.898106" elapsed="0.004114"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.904060" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:29.903732" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:29.904621" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:29.904311" elapsed="0.000390"/>
</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-06-06T03:34:29.911570" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:29.911872" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:29.912033" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:29.907100" elapsed="0.005646">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:29.904789" elapsed="0.008113">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:29.913231" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:29.912968" elapsed="0.000360"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:29.904764" elapsed="0.008599">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:29.913943" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.914142" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:29.914087" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:29.914059" elapsed="0.000176"/>
</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-06-06T03:34:29.914431" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.914530" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:29.902616" elapsed="0.012099">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.914823" elapsed="0.000026"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:29.847328" elapsed="0.067700">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:29.915423" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:29.915171" elapsed="0.000356"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:29.915144" elapsed="0.000419"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:29.915609" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:29.840434" elapsed="0.075336">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.959269" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:30.958872" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:30.960094" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:30.959840" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:30.960263" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:30.959469" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.960946" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:30.960531" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:30.961280" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:30.961435" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:30.961136" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.961891" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:30.961619" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.962908" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:30.962633" elapsed="0.000320"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.963375" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:30.963106" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.963755" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.963957" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.964126" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:30.963611" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.963455" elapsed="0.000760"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:30.964263" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:30.964428" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:30.962314" elapsed="0.002140"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:30.962017" elapsed="0.002470"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.964666" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:30.964512" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:30.961993" elapsed="0.002751"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.965345" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:30.964882" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:30.965421" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:30.958246" elapsed="0.007297"/>
</kw>
<msg time="2026-06-06T03:34:30.965598" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:30.957349" elapsed="0.008312"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.966147" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.966653" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.967384" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.967600" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.967789" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.968146" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:30.968008" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:30.967993" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.968360" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.968521" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.968696" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:30.967965" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.967865" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.968918" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.968993" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:30.969109" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:30.953040" elapsed="0.016095"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:30.970351" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:30.970113" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:30.970511" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:30.969781" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.970861" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:30.970606" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.971407" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:30.971108" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:30.970942" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:30.970588" elapsed="0.000915"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.973868" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:30.971662" elapsed="0.002234"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:30.973948" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:30.974100" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:30.969448" elapsed="0.004677"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:30.975315" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:30.975081" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:30.975549" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:30.974753" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:30.975801" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:34:30.975663" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:30.975629" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.976025" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.976188" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.976253" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:30.978178" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:30.974421" elapsed="0.003784"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.979605" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:30.979341" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:30.980064" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:30.979818" elapsed="0.000289"/>
</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-06-06T03:34:30.986520" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:30.986678" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:30.986779" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:30.982385" elapsed="0.004763">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:30.980172" elapsed="0.007058">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:30.987413" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:30.987263" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:30.980154" elapsed="0.007369">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:30.987913" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.988046" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:30.988008" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:30.987991" elapsed="0.000122"/>
</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-06-06T03:34:30.988253" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.988323" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:30.978513" elapsed="0.009913">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.988500" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:30.930118" elapsed="0.058477">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:30.988926" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:30.988749" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:30.988730" elapsed="0.000293"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:30.989057" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:30.922194" elapsed="0.066959">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.037252" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:32.036855" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:32.038061" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:32.037805" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:32.038231" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:32.037454" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.038809" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:32.038411" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:32.039130" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:32.039296" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:32.038989" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.039733" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:32.039470" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.040971" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:32.040712" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.041437" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:32.041171" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.041804" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.042002" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.042175" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:32.041674" elapsed="0.000557"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.041517" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:32.042306" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:32.042469" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:32.040375" elapsed="0.002120"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:32.039856" elapsed="0.002671"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.042708" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:32.042551" elapsed="0.000218"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:32.039833" elapsed="0.002957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.043368" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:32.042926" elapsed="0.000524"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:32.043501" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:32.036234" elapsed="0.007392"/>
</kw>
<msg time="2026-06-06T03:34:32.043701" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:32.035355" elapsed="0.008395"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.044248" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.044762" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.045255" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.045435" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.045599" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.045967" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:32.045829" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:32.045815" elapsed="0.000231"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.046179" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.046338" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.046500" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:32.045787" elapsed="0.000765"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.045690" elapsed="0.000888"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.046732" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.046807" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:32.046921" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:32.031054" elapsed="0.015893"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:32.048257" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:32.047974" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:32.048414" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:32.047626" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.048763" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:32.048509" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.049302" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:32.049013" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:32.048844" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:32.048490" elapsed="0.000893"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.051895" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:32.049525" elapsed="0.002397"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:32.051973" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:32.052138" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:32.047308" elapsed="0.004856"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:32.053359" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:32.053115" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:32.053514" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:32.052786" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:32.053760" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:32.053608" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:32.053589" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.053981" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.054143" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.054207" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:32.056162" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:32.052456" elapsed="0.003732"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.057570" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:32.057311" elapsed="0.000307"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:32.058047" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:32.057799" elapsed="0.000295"/>
</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-06-06T03:34:32.065871" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:32.066005" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:32.066109" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:32.060396" elapsed="0.006082">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:32.058164" elapsed="0.008438">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:32.066806" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:32.066637" elapsed="0.000235"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:32.058144" elapsed="0.008751">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:32.067274" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.067409" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:32.067370" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:32.067352" elapsed="0.000121"/>
</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-06-06T03:34:32.067611" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.067698" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:32.056486" elapsed="0.011316">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.067876" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:32.008829" elapsed="0.059140">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:32.068275" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:32.068099" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:32.068047" elapsed="0.000332"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:32.068411" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:31.999144" elapsed="0.069363">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.120435" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:33.120010" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:33.121313" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:33.121051" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:33.121487" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:33.120685" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.122122" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:33.121689" elapsed="0.000462"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:33.122459" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:33.122656" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:33.122311" elapsed="0.000432"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.123166" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:33.122901" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.124270" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:33.124003" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.124853" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:33.124473" elapsed="0.000417"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.125276" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.125491" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.125708" elapsed="0.000030"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:33.125137" elapsed="0.000653"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.124960" elapsed="0.000865"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:33.125884" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:34:33.126063" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:33.123623" elapsed="0.002467"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:33.123294" elapsed="0.002835"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.126300" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:33.126155" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:33.123270" elapsed="0.003108"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.126999" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:33.126517" elapsed="0.000510"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:33.127076" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:33.119355" elapsed="0.007851"/>
</kw>
<msg time="2026-06-06T03:34:33.127262" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:33.118390" elapsed="0.008923"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.127833" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.130300" elapsed="0.000037"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.130970" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.131245" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.131422" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.131816" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:33.131671" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:33.131637" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.132045" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.132262" elapsed="0.000029"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.132481" elapsed="0.000028"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:33.131606" elapsed="0.000948"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.131502" elapsed="0.001086"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.132848" elapsed="0.000030"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.132953" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:34:33.133118" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:33.113198" elapsed="0.019955"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:33.134777" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:33.134449" elapsed="0.000428">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:33.134994" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:33.134012" elapsed="0.001013"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.135446" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:33.135120" elapsed="0.000401"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.136183" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:33.135798" elapsed="0.000419"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:33.135555" elapsed="0.000707"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:33.135092" elapsed="0.001196"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.138813" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:33.136475" elapsed="0.002372"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:33.138903" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:33.139067" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:33.133561" elapsed="0.005533"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:33.140594" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:33.140278" elapsed="0.000509">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:33.140903" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:33.139838" elapsed="0.001094"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:33.141463" elapsed="0.000063"/>
</return>
<status status="PASS" start="2026-06-06T03:34:33.141014" elapsed="0.000595"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:33.140991" elapsed="0.000721"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.142176" elapsed="0.000058"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.142742" elapsed="0.000054"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.142907" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:34:33.147939" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:33.139399" elapsed="0.008604"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.151307" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:33.150706" elapsed="0.000709"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:33.152328" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:33.151778" elapsed="0.000648"/>
</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-06-06T03:34:33.160420" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:33.160563" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:33.160763" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:33.154990" elapsed="0.006315">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:33.152574" elapsed="0.008859">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:33.161754" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:33.161485" elapsed="0.000369"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:33.152532" elapsed="0.009358">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:33.162461" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.162684" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:33.162603" elapsed="0.000147"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:33.162576" elapsed="0.000207"/>
</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-06-06T03:34:33.162985" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.163089" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:33.148762" elapsed="0.014482">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.163354" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:33.088488" elapsed="0.075004">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:33.163896" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:33.163625" elapsed="0.000379"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:33.163600" elapsed="0.000440"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:33.164172" elapsed="0.000024"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:33.079916" elapsed="0.084403">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.207190" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:34.206798" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:34.207987" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:34.207740" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:34.208156" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:34.207390" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.208778" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:34.208372" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:34.209106" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:34.209288" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:34.208963" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.209734" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:34.209469" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.210742" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:34.210467" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.211210" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:34.210943" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.211559" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.211773" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.211942" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:34.211431" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.211290" elapsed="0.000739"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:34.212076" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:34.212240" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:34.210149" elapsed="0.002116"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:34.209858" elapsed="0.002439"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.212465" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:34.212323" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:34.209835" elapsed="0.002706"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.213136" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:34.212693" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:34.213241" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:34.206164" elapsed="0.007204"/>
</kw>
<msg time="2026-06-06T03:34:34.213488" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:34.205278" elapsed="0.008261"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.214047" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.214554" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.215075" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.215258" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.215428" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.215804" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:34.215661" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:34.215631" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.216020" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.216184" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.216346" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:34.215603" elapsed="0.000797"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.215503" elapsed="0.000923"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.216567" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.216657" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:34.216777" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:34.200319" elapsed="0.016484"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:34.218241" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:34.217813" elapsed="0.000494">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:34.218402" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:34.217458" elapsed="0.000969"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.218797" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:34.218533" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.219354" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:34.219050" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:34.218881" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:34.218513" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.221858" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:34.219585" elapsed="0.002300"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:34.221939" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:34.222096" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:34.217118" elapsed="0.005005"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:34.223334" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:34.223096" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:34.223492" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:34.222762" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:34.223741" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:34:34.223588" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:34.223569" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.223969" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.224135" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.224201" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:34.226155" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:34.222424" elapsed="0.003758"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.227564" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:34.227312" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:34.228021" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:34.227776" elapsed="0.000289"/>
</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-06-06T03:34:34.236048" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:34.236185" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:34.236278" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:34.230219" elapsed="0.006442">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:34.228131" elapsed="0.008617">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:34.236932" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:34.236784" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:34.228113" elapsed="0.008907">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:34.237459" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.237594" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:34.237555" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:34.237538" elapsed="0.000141"/>
</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-06-06T03:34:34.237822" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.237894" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:34.226482" elapsed="0.011515">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.238072" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:34.177799" elapsed="0.060398">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:34.238565" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:34.238325" elapsed="0.000362"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:34.238301" elapsed="0.000422"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:34.238769" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:34.170385" elapsed="0.068518">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.284999" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:35.284586" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:35.285801" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:35.285529" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:35.285970" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:35.285196" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.286541" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:35.286154" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:35.286887" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:35.287051" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:35.286736" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.287471" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:35.287225" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.288481" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:35.288219" elapsed="0.000307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.289032" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:35.288757" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.289392" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.289592" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.289803" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:35.289262" elapsed="0.000602"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.289115" elapsed="0.000780"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:35.289945" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:35.290113" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:35.287905" elapsed="0.002233"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:35.287594" elapsed="0.002577"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.290336" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:35.290196" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:35.287570" elapsed="0.002843"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.291012" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:35.290549" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:35.291089" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:35.283974" elapsed="0.007237"/>
</kw>
<msg time="2026-06-06T03:34:35.291265" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:35.283097" elapsed="0.008215"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.291812" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.292315" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.293015" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.293201" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.293370" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.293751" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:35.293584" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:35.293569" elapsed="0.000303"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.294011" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.294181" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.294343" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:35.293541" elapsed="0.000856"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.293444" elapsed="0.000979"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.294563" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.294653" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:35.294773" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:35.278738" elapsed="0.016060"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:35.296022" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:35.295782" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:35.296180" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:35.295426" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.296515" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:35.296275" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.297077" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:35.296782" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:35.296597" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:35.296257" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.299541" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:35.297305" elapsed="0.002263"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:35.299620" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:34:35.299790" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:35.295108" elapsed="0.004707"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:35.301009" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:35.300774" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:35.301166" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:35.300429" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:35.301398" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:35.301262" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:35.301243" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.301618" elapsed="0.000035"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.301818" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.301885" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:35.303809" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:35.300107" elapsed="0.003763"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.305253" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:35.305003" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:35.305701" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:35.305446" elapsed="0.000322"/>
</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-06-06T03:34:35.313125" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:35.313259" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:35.313353" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:35.308068" elapsed="0.005672">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:35.305837" elapsed="0.008022">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:35.314044" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:35.313893" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:35.305817" elapsed="0.008316">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:35.314661" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.314848" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:35.314796" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:35.314771" elapsed="0.000166"/>
</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-06-06T03:34:35.315126" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.315229" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:35.304176" elapsed="0.011194">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.315473" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:35.255987" elapsed="0.059617">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:35.315992" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:35.315753" elapsed="0.000339"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:35.315729" elapsed="0.000396"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:35.316171" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:35.249105" elapsed="0.067198">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.361311" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:36.360913" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:36.362121" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:36.361863" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:36.362321" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:36.361515" elapsed="0.000833"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.362908" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:36.362506" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:36.363244" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:36.363412" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:36.363088" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.363859" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:36.363593" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.365081" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:36.364823" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.365557" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:36.365290" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.365923" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.366121" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.366318" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:36.365794" elapsed="0.000583"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.365637" elapsed="0.000770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:36.366454" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:36.366617" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:36.364484" elapsed="0.002178"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:36.363987" elapsed="0.002710"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.366865" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:36.366723" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:36.363964" elapsed="0.002977"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.367516" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:36.367077" elapsed="0.000467"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:36.367593" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:36.360289" elapsed="0.007444"/>
</kw>
<msg time="2026-06-06T03:34:36.367788" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:36.359417" elapsed="0.008419"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.368374" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.368888" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.369388" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.369569" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.369751" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.370111" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:36.369967" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:36.369952" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.370336" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.370497" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.370670" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:36.369924" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.369826" elapsed="0.000925"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.370891" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.370967" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:36.371082" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:36.355035" elapsed="0.016073"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:36.372336" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:36.372092" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:36.372493" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:36.371754" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.372847" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:36.372592" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.373429" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:36.373136" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:36.372966" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:36.372569" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.376126" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:36.373689" elapsed="0.002464"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:36.376210" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:36.376374" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:36.371419" elapsed="0.004980"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:36.377601" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:36.377361" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:36.377774" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:36.377033" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:36.378001" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:36.377868" elapsed="0.000190"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:36.377849" elapsed="0.000233"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.378220" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.378410" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.378477" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:36.380434" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:36.376716" elapsed="0.003745"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.381835" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:36.381569" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:36.382283" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:36.382025" elapsed="0.000332"/>
</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-06-06T03:34:36.390790" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:36.390928" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:36.391022" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:36.384657" elapsed="0.006832">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:36.382423" elapsed="0.009190">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:36.391903" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:36.391685" elapsed="0.000310"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:36.382405" elapsed="0.009622">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:36.392521" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.392785" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:36.392732" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:36.392705" elapsed="0.000170"/>
</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-06-06T03:34:36.393066" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.393161" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:36.380773" elapsed="0.012535">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.393410" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:36.332699" elapsed="0.060839">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:36.393926" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:36.393684" elapsed="0.000343"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:36.393659" elapsed="0.000401"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:36.394105" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:36.325744" elapsed="0.068490">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.443122" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:37.442573" elapsed="0.000590"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:37.444060" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:37.443723" elapsed="0.000437">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:37.444260" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:37.443354" elapsed="0.000931"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.444868" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:37.444450" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:37.445212" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:37.445438" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:37.445055" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.446004" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:37.445683" elapsed="0.000373"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.447186" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:37.446921" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.447684" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:37.447389" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.448075" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.449892" elapsed="0.000134"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.450475" elapsed="0.000056"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:37.447939" elapsed="0.002689"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.447777" elapsed="0.002972"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:37.450927" elapsed="0.000123"/>
</return>
<msg time="2026-06-06T03:34:37.451527" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:37.446530" elapsed="0.005085"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:37.446153" elapsed="0.005583"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.452206" elapsed="0.000048"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:37.451829" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:37.446121" elapsed="0.006261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.454182" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:37.452746" elapsed="0.001501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:37.454360" elapsed="0.000069"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:37.441913" elapsed="0.012774"/>
</kw>
<msg time="2026-06-06T03:34:37.454839" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:37.440660" elapsed="0.014361"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.456246" elapsed="0.000060"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.457423" elapsed="0.000056"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.459258" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.459458" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.459660" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.460086" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:37.459942" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:37.459923" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.460300" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.460520" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.460701" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:37.459881" elapsed="0.000877"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.459755" elapsed="0.001029"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.460926" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.461004" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:37.461140" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:37.435871" elapsed="0.025295"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:37.462589" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:37.462266" elapsed="0.000448">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:37.462814" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:37.461901" elapsed="0.000937"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.463301" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:37.462938" elapsed="0.000460"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.463969" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:37.463620" elapsed="0.000377"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:37.463432" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:37.462910" elapsed="0.001144"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.466568" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:37.464203" elapsed="0.002392"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:37.466663" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:37.466827" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:37.461491" elapsed="0.005361"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:37.468161" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:37.467895" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:37.468334" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:37.467537" elapsed="0.000822"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:37.468573" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:37.468431" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:37.468412" elapsed="0.000262"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.468818" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.468984" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.469049" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:34:37.471006" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:37.467185" elapsed="0.003848"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.472534" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:37.472213" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:37.472996" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:37.472747" elapsed="0.000293"/>
</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-06-06T03:34:37.481014" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:37.481213" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:37.481355" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:37.475368" elapsed="0.006539">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:37.473107" elapsed="0.008921">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:37.482289" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:37.482075" elapsed="0.000304"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:37.473089" elapsed="0.009323">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:37.483000" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.483198" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:37.483142" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:37.483116" elapsed="0.000169"/>
</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-06-06T03:34:37.483485" elapsed="0.000033"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.483588" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:37.471364" elapsed="0.012396">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.483864" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:37.412830" elapsed="0.071164">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:37.484365" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:37.484124" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:37.484100" elapsed="0.000398"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:37.484543" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:37.405171" elapsed="0.079525">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.531310" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:38.530895" elapsed="0.000557"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:38.532271" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:38.531986" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:38.532449" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:38.531634" elapsed="0.000840"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.533040" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:38.532632" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:38.533380" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:38.533565" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:38.533227" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.535659" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:38.533759" elapsed="0.001951"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.536686" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:38.536409" elapsed="0.000324"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.537159" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:38.536887" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.537511" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.537731" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.537898" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:38.537383" elapsed="0.000571"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.537240" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:38.538033" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:38.538198" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:38.536091" elapsed="0.002132"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:38.535791" elapsed="0.002464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.538418" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:38.538281" elapsed="0.000191"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:38.535767" elapsed="0.002726"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.539082" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:38.538627" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:38.539158" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:38.530273" elapsed="0.009007"/>
</kw>
<msg time="2026-06-06T03:34:38.539334" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:38.529351" elapsed="0.010029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.539903" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.540443" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.540958" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.541139" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.541307" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.541673" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:38.541521" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:38.541506" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.541890" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.542052" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.542212" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:38.541479" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.541381" elapsed="0.000909"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.542430" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.542505" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:38.542621" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:38.524965" elapsed="0.017696"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:38.543946" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:38.543705" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:38.544105" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:38.543300" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.544526" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:38.544201" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.545324" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:38.544907" elapsed="0.000454"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:38.544662" elapsed="0.000749"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:38.544182" elapsed="0.001260"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.549130" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:38.545666" elapsed="0.003502"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:38.549293" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:34:38.549588" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:38.542971" elapsed="0.006653"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:38.551335" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:38.551005" elapsed="0.000418">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:38.551572" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:38.550512" elapsed="0.001094"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:38.551919" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:34:38.551728" elapsed="0.000273"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:38.551701" elapsed="0.000335"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.552231" elapsed="0.000033"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.552466" elapsed="0.000029"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.552558" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:34:38.555327" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:38.550061" elapsed="0.005304"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.557025" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:38.556775" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:38.557468" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:38.557219" elapsed="0.000293"/>
</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-06-06T03:34:38.565054" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:38.565231" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:38.565377" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:38.559694" elapsed="0.006217">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:38.557578" elapsed="0.008446">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:38.566278" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:38.566070" elapsed="0.000299"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:38.557560" elapsed="0.008842">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:38.566924" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.567110" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:38.567058" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:38.567033" elapsed="0.000165"/>
</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-06-06T03:34:38.567390" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.567511" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:38.555840" elapsed="0.011834">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.567829" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:38.501457" elapsed="0.066507">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:38.568346" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:38.568092" elapsed="0.000356"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:38.568069" elapsed="0.000413"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:38.568528" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:38.494113" elapsed="0.074566">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.614616" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:39.614220" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:39.615419" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:39.615164" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:39.615589" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:39.614833" elapsed="0.000781"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.616210" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:39.615791" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:39.616538" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:39.616714" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:39.616395" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.617141" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:39.616893" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.618146" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:39.617889" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.618618" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:39.618351" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.618996" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.619200" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.619370" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:39.618859" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.618716" elapsed="0.000742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:39.619561" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:39.619747" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:39.617556" elapsed="0.002217"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:39.617263" elapsed="0.002543"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.619975" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:39.619831" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:39.617240" elapsed="0.002831"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.620674" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:39.620211" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:39.620753" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:39.613596" elapsed="0.007282"/>
</kw>
<msg time="2026-06-06T03:34:39.620934" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:39.612704" elapsed="0.008278"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.621471" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.621988" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.622482" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.622677" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.622846" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.623379" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:39.623237" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:39.623222" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.623593" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.623774" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.623936" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:39.623193" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.622920" elapsed="0.001129"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.624224" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.624304" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:39.624421" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:39.608419" elapsed="0.016028"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:39.625678" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:39.625428" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:39.625837" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:39.625092" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.626170" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:39.625933" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.626737" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:39.626428" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:39.626252" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:39.625914" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.629204" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:39.626964" elapsed="0.002267"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:39.629283" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:39.629435" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:39.624776" elapsed="0.004684"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:39.630667" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:39.630418" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:39.630825" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:39.630089" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:39.631056" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:39.630920" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:39.630901" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.631277" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.631441" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.631507" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:39.633457" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:39.629769" elapsed="0.003715"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.634889" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:39.634613" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:39.635322" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:39.635082" 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-06-06T03:34:39.642787" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:39.642960" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:39.643057" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:39.637676" elapsed="0.005919">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:39.635430" elapsed="0.008263">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:39.643878" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:39.643728" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:39.635412" elapsed="0.008555">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:39.644369" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.644503" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:39.644465" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:39.644448" elapsed="0.000117"/>
</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-06-06T03:34:39.644717" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.644789" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:39.633796" elapsed="0.011095">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.644963" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:39.585814" elapsed="0.059243">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:39.645320" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:39.645148" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:39.645131" elapsed="0.000283"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:39.645447" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:39.578587" elapsed="0.066953">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.693444" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:40.693033" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:40.694265" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:40.694004" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:40.694438" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:40.693666" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.695115" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:40.694719" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:40.695445" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:40.695604" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:40.695301" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.696050" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:40.695798" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.697327" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:40.697066" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.697817" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:40.697529" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.698170" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.698371" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.698539" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:40.698040" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.697898" elapsed="0.000729"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:40.698689" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:40.698858" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:40.696737" elapsed="0.002146"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:40.696174" elapsed="0.002741"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.699082" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:40.698941" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:40.696150" elapsed="0.003008"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.699760" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:40.699296" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:40.699838" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:40.692388" elapsed="0.007575"/>
</kw>
<msg time="2026-06-06T03:34:40.700018" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:40.691481" elapsed="0.008584"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.700582" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.701100" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.701657" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.701842" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.702011" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.702365" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:40.702227" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:40.702211" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.702604" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.702797" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.702956" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:40.702183" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.702085" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.703192" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.703267" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:40.703382" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:40.687225" elapsed="0.016182"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:40.704749" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:40.704428" elapsed="0.000387">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:40.704914" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:40.704091" elapsed="0.000848"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.705248" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:40.705010" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.705823" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:40.705497" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:40.705328" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:40.704990" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.708399" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:40.706049" elapsed="0.002376"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:40.708477" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:40.708656" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:40.703774" elapsed="0.004909"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:40.709883" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:40.709628" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:40.710078" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:40.709296" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:40.710311" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:40.710175" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:40.710156" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.710534" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.710714" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.710781" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:40.712722" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:40.708976" elapsed="0.003773"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.714138" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:40.713887" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:40.714578" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:40.714333" elapsed="0.000289"/>
</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-06-06T03:34:40.721631" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:40.721790" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:40.721885" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:40.716789" elapsed="0.005455">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:40.714705" elapsed="0.007619">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:40.722566" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:40.722357" elapsed="0.000323"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:40.714686" elapsed="0.008029">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:40.723222" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.723406" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:40.723354" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:40.723330" elapsed="0.000162"/>
</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-06-06T03:34:40.723710" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.723810" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:40.713057" elapsed="0.010894">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.724053" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:40.664854" elapsed="0.059326">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:40.724625" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:40.724359" elapsed="0.000389"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:40.724334" elapsed="0.000448"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:40.724829" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:40.655284" elapsed="0.069678">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.769938" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:41.769522" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:41.770731" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:41.770468" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:41.770899" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:41.770138" elapsed="0.000786"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.771475" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:41.771081" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:41.771813" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:41.771976" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:41.771670" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.772399" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:41.772151" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.773458" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:41.773194" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.773941" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:41.773672" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.774293" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.774495" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.774678" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:41.774163" elapsed="0.000574"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.774021" elapsed="0.000746"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:41.774813" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:41.774982" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:41.772840" elapsed="0.002167"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:41.772521" elapsed="0.002518"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.775203" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:41.775063" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:41.772498" elapsed="0.002780"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.775881" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:41.775418" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:41.776013" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:41.768888" elapsed="0.007250"/>
</kw>
<msg time="2026-06-06T03:34:41.776192" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:41.768027" elapsed="0.008212"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.776757" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.777290" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.777981" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.778165" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.778332" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.778704" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:41.778551" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:41.778536" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.778920" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.779080" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.779238" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:41.778508" elapsed="0.000783"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.778409" elapsed="0.000908"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.779455" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.779530" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:41.779659" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:41.763777" elapsed="0.015909"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:41.780951" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:41.780717" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:41.781141" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:41.780372" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.781487" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:41.781243" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.782046" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:41.781754" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:41.781568" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:41.781222" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.784537" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:41.782271" elapsed="0.002292"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:41.784614" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:34:41.784783" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:41.780055" elapsed="0.004753"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:41.786024" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:41.785791" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:41.786179" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:41.785443" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:41.786407" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:41.786273" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:41.786255" elapsed="0.000234"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.786626" elapsed="0.000036"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.786807" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.786871" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:41.788797" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:41.785100" elapsed="0.003724"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.790213" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:41.789965" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:41.790756" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:41.790403" elapsed="0.000405"/>
</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-06-06T03:34:41.797007" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:41.797218" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:41.797329" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:41.793069" elapsed="0.004649">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:41.790873" elapsed="0.006969">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:41.798032" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:41.797877" elapsed="0.000220"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:41.790855" elapsed="0.007265">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:41.798493" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.798625" elapsed="0.000029"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:41.798588" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:41.798571" elapsed="0.000136"/>
</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-06-06T03:34:41.798843" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.798913" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:41.789149" elapsed="0.009865">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.799086" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:41.741534" elapsed="0.057645">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:41.799450" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:41.799269" elapsed="0.000252"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:41.799252" elapsed="0.000294"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:41.799578" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:41.732766" elapsed="0.066924">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.844931" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:42.844512" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:42.845761" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:42.845465" elapsed="0.000379">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:42.845941" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:42.845135" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.846522" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:42.846124" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:42.846864" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:42.847033" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:42.846718" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.847527" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:42.847280" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.848777" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:42.848503" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.849245" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:42.848977" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.849609" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.849857" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.850026" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:42.849479" elapsed="0.000604"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.849328" elapsed="0.000785"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:42.850162" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:42.850331" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:42.848184" elapsed="0.002182"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:42.847667" elapsed="0.002732"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.850565" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:42.850425" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:42.847627" elapsed="0.003027"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.851242" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:42.850794" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:42.851318" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:42.843897" elapsed="0.007548"/>
</kw>
<msg time="2026-06-06T03:34:42.851500" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:42.842992" elapsed="0.008557"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.852056" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.852551" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.853060" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.853285" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.853455" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.853844" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:42.853701" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:42.853684" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.854059" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.854219" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.854383" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:42.853627" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.853529" elapsed="0.000934"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.854604" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.854699" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:42.854821" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:42.838506" elapsed="0.016340"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:42.856107" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:42.855850" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:42.856271" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:42.855492" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.856606" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:42.856365" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.857170" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:42.856878" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:42.856703" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:42.856347" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.859896" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:42.857399" elapsed="0.002525"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:42.859976" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:42.860130" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:42.855161" elapsed="0.004993"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:42.861352" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:42.861117" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:42.861508" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:42.860786" elapsed="0.000746"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:42.861767" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:42.861602" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:42.861583" elapsed="0.000267"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.862036" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.862201" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.862265" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:42.864183" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:42.860451" elapsed="0.003759"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.865584" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:42.865330" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:42.866053" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:42.865807" elapsed="0.000290"/>
</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-06-06T03:34:42.872981" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:42.873127" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:42.873228" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:42.868234" elapsed="0.005380">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:42.866163" elapsed="0.007589">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:42.873944" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:42.873790" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:42.866145" elapsed="0.007887">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:42.874406" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.874537" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:42.874499" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:42.874482" elapsed="0.000119"/>
</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-06-06T03:34:42.874757" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.874827" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:42.864508" elapsed="0.010422">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.875001" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:42.816179" elapsed="0.058914">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:42.875364" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:42.875184" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:42.875167" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:42.875535" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:42.809090" elapsed="0.066542">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.922765" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:43.922330" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:43.923580" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:43.923307" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:43.923775" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:43.922972" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.924354" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:43.923964" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:43.924702" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:43.924877" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:43.924539" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.925310" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:43.925059" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.926448" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:43.926121" elapsed="0.000375"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.926959" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:43.926678" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.927324" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.927526" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.927722" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:43.927193" elapsed="0.000589"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.927044" elapsed="0.000770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:43.927864" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:34:43.928037" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:43.925795" elapsed="0.002267"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:43.925442" elapsed="0.002653"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.928269" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:43.928122" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:43.925415" elapsed="0.002931"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.928985" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:43.928492" elapsed="0.000521"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:43.929063" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:43.921497" elapsed="0.007692"/>
</kw>
<msg time="2026-06-06T03:34:43.929312" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:43.920534" elapsed="0.008831"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.929908" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.930429" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.930943" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.931125" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.931292" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.931866" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:43.931722" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:43.931707" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.932082" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.932243" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.932404" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:43.931676" elapsed="0.000783"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.931366" elapsed="0.001119"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.932623" elapsed="0.000036"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.932718" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:43.932837" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:43.916067" elapsed="0.016795"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:43.934107" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:43.933852" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:43.934320" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:43.933498" elapsed="0.000847"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.934730" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:43.934469" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.935279" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:43.934986" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:43.934813" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:43.934449" elapsed="0.000911"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.937807" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:43.935509" elapsed="0.002325"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:43.937888" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:43.938045" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:43.933175" elapsed="0.004894"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:43.939339" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:43.939086" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:43.939502" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:43.938747" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:43.939766" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:43.939599" elapsed="0.000226"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:43.939580" elapsed="0.000271"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.939993" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.940159" elapsed="0.000032"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.940237" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:43.942173" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:43.938397" elapsed="0.003802"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.943634" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:43.943367" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:43.944087" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:43.943844" elapsed="0.000286"/>
</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-06-06T03:34:43.951228" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:43.951377" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:43.951496" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:43.946477" elapsed="0.005429">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:43.944197" elapsed="0.007796">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:43.952187" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:43.952028" elapsed="0.000223"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:43.944179" elapsed="0.008096">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:43.952751" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.952889" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:43.952849" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:43.952831" elapsed="0.000123"/>
</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-06-06T03:34:43.953092" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.953162" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:43.942534" elapsed="0.010733">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.953341" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:43.892287" elapsed="0.061149">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:43.953719" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:43.953529" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:43.953512" elapsed="0.000304"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:43.953848" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:43.884910" elapsed="0.069033">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:44.998578" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:44.998179" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:44.999403" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:44.999150" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:44.999579" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:44.998813" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.000172" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:44.999782" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:45.000497" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:45.000676" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:45.000354" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.001135" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:45.000853" elapsed="0.000337"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.002503" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:45.002012" elapsed="0.000537"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.003140" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:45.002842" elapsed="0.000325"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.003502" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.003723" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.003893" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:45.003369" elapsed="0.000581"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.003225" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:45.004030" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:45.004197" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:45.001617" elapsed="0.002605"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:45.001277" elapsed="0.002977"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.004420" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:45.004279" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:45.001251" elapsed="0.003248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.005097" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:45.004635" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:45.005175" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:44.997550" elapsed="0.007772"/>
</kw>
<msg time="2026-06-06T03:34:45.005377" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:44.996676" elapsed="0.008749"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.005921" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.006414" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.006949" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.007143" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.007309" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.007672" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:45.007518" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:45.007504" elapsed="0.000282"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.007923" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.008083" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.008253" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:45.007477" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.007382" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.008471" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.008546" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:45.008689" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:44.992360" elapsed="0.016357"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:45.010050" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:45.009776" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:45.010208" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:45.009400" elapsed="0.000833"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.010540" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:45.010303" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.011167" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:45.010852" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:45.010620" elapsed="0.000609"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:45.010285" elapsed="0.000965"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.013942" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:45.011404" elapsed="0.002565"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:45.014021" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:45.014172" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:45.009036" elapsed="0.005161"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:45.015490" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:45.015239" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:45.015664" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:45.014859" elapsed="0.000832"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:45.015899" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:45.015763" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:45.015743" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.016123" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.016286" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.016361" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:45.018366" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:45.014491" elapsed="0.003940"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.019918" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:45.019630" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:45.020385" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:45.020120" elapsed="0.000310"/>
</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-06-06T03:34:45.029909" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:45.030066" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:45.030163" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:45.022655" elapsed="0.007888">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:45.020495" elapsed="0.010129">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:45.030839" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:45.030673" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:45.020477" elapsed="0.010450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:45.031291" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.031424" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:45.031387" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:45.031369" elapsed="0.000117"/>
</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-06-06T03:34:45.031658" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.031730" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:45.018751" elapsed="0.013083">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.031927" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:44.969746" elapsed="0.062274">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:45.032283" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:45.032111" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:45.032094" elapsed="0.000296"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:45.032423" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:44.963478" elapsed="0.069044">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.079279" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:46.078750" elapsed="0.000575"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:46.080370" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:46.080035" elapsed="0.000433">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:46.080602" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:46.079571" elapsed="0.001083"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.081418" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:46.080881" elapsed="0.000574"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:46.081882" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:46.082100" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:46.081690" elapsed="0.000447"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.082713" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:46.082350" elapsed="0.000428"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.084078" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:46.083721" elapsed="0.000420"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.084755" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:46.084357" elapsed="0.000431"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.085205" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.085469" elapsed="0.000033"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.085719" elapsed="0.000030"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:46.085039" elapsed="0.000762"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.084855" elapsed="0.000988"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:46.085905" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:34:46.086126" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:46.083243" elapsed="0.002916"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:46.082876" elapsed="0.003320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.086406" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:46.086222" elapsed="0.000269"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:46.082846" elapsed="0.003674"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.087330" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:46.086728" elapsed="0.000662"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:46.087457" elapsed="0.000040"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:46.077919" elapsed="0.009705"/>
</kw>
<msg time="2026-06-06T03:34:46.087719" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:46.076699" elapsed="0.011090"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.088528" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.089175" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.090127" elapsed="0.000036"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.090360" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.090549" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.091060" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:46.090864" elapsed="0.000273"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:46.090842" elapsed="0.000328"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.091402" elapsed="0.000032"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.091627" elapsed="0.000046"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.091869" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:46.090802" elapsed="0.001142"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.090665" elapsed="0.001315"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.092151" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.092242" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:34:46.092392" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:46.071121" elapsed="0.021301"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:46.093970" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:46.093669" elapsed="0.000409">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:46.094190" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:46.093231" elapsed="0.000991"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.094611" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:46.094319" elapsed="0.000420"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.095387" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:46.094994" elapsed="0.000425"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:46.094772" elapsed="0.000686"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:46.094293" elapsed="0.001193"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.098342" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:46.095688" elapsed="0.002684"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:46.098428" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:34:46.098617" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:46.092843" elapsed="0.005827"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:46.100265" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:46.099989" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:46.100443" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:46.099546" elapsed="0.000932"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:46.100748" elapsed="0.000035"/>
</return>
<status status="PASS" start="2026-06-06T03:34:46.100555" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:46.100535" elapsed="0.000330"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.101056" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.101252" elapsed="0.000029"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.101343" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:34:46.103856" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:46.099072" elapsed="0.004819"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.105610" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:46.105280" elapsed="0.000409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:46.106162" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:46.105866" elapsed="0.000355"/>
</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-06-06T03:34:46.114918" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:46.115057" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:46.115170" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:46.109159" elapsed="0.006462">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:46.106296" elapsed="0.009429">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:46.115914" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:46.115761" elapsed="0.000221"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:46.106273" elapsed="0.009732">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:46.116379" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.116608" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:46.116553" elapsed="0.000138"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:46.116525" elapsed="0.000200"/>
</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-06-06T03:34:46.116923" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.117026" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:46.104266" elapsed="0.012907">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.117278" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:46.047145" elapsed="0.070270">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:46.117821" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:46.117546" elapsed="0.000377"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:46.117522" elapsed="0.000435"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:46.118002" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:46.038915" elapsed="0.079220">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.162716" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:47.162305" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:47.163498" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:47.163249" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:47.163682" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:47.162918" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.164286" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:47.163869" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:47.164608" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:47.164785" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:47.164467" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.165212" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:47.164963" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.166433" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:47.166167" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.166916" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:47.166632" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.167265" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.167520" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.167704" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:47.167137" elapsed="0.000629"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.166997" elapsed="0.000799"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:47.167843" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:34:47.168022" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:47.165842" elapsed="0.002205"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:47.165335" elapsed="0.002745"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.168246" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:47.168106" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:47.165312" elapsed="0.003011"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.168919" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:47.168457" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:47.168995" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:47.161700" elapsed="0.007421"/>
</kw>
<msg time="2026-06-06T03:34:47.169175" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:47.160834" elapsed="0.008389"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.169722" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.170225" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.170740" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.170924" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.171097" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.171451" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:47.171312" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:47.171298" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.171680" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.171879" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.172081" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:47.171269" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.171171" elapsed="0.000991"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.172308" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.172384" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:47.172503" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:47.156582" elapsed="0.015947"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:47.173771" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:47.173515" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:47.173929" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:47.173179" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.174273" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:47.174024" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.174831" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:47.174522" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:47.174354" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:47.174005" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.177435" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:47.175063" elapsed="0.002399"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:47.177514" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:47.177682" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:47.172859" elapsed="0.004849"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:47.178900" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:47.178666" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:47.179056" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:47.178321" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:47.179286" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:47.179150" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:47.179132" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.179507" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.179687" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.179754" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:47.181692" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:47.178002" elapsed="0.003717"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.183143" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:47.182854" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:47.183587" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:47.183337" elapsed="0.000294"/>
</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-06-06T03:34:47.191179" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:47.191312" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:47.191404" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:47.185795" elapsed="0.006087">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:47.183717" elapsed="0.008305">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:47.192272" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:47.192067" elapsed="0.000295"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:47.183697" elapsed="0.008698">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:47.192916" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.193101" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:47.193050" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:47.193025" elapsed="0.000163"/>
</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-06-06T03:34:47.193376" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.193473" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:47.182017" elapsed="0.011596">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.193735" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:47.134291" elapsed="0.059575">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:47.194235" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:47.193993" elapsed="0.000342"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:47.193969" elapsed="0.000400"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:47.194413" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:47.127418" elapsed="0.067133">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.239616" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:48.239214" elapsed="0.000625"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:48.240699" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:48.240369" elapsed="0.000408">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:48.240878" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:48.240021" elapsed="0.000882"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.241453" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:48.241064" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:48.241801" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:48.241961" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:48.241655" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.242389" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:48.242139" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.243480" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:48.243222" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.243984" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:48.243695" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.244345" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.244586" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.244772" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:48.244213" elapsed="0.000618"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.244068" elapsed="0.000794"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:48.244909" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:34:48.245079" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:48.242884" elapsed="0.002220"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:48.242516" elapsed="0.002621"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.245305" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:48.245163" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:48.242493" elapsed="0.002889"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.245999" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:48.245518" elapsed="0.000509"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:48.246076" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:48.238549" elapsed="0.007653"/>
</kw>
<msg time="2026-06-06T03:34:48.246259" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:48.237558" elapsed="0.008753"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.246844" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.247629" elapsed="0.000043"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.248154" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.248346" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.248559" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.248954" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:48.248810" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:48.248794" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.249172" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.249334" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.249493" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:48.248763" elapsed="0.000782"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.248657" elapsed="0.000914"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.249869" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.249946" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:34:48.250073" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:48.233011" elapsed="0.017088"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:48.251437" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:48.251150" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:48.251606" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:48.250777" elapsed="0.000881"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.251989" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:48.251732" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.252564" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:48.252244" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:48.252072" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:48.251712" elapsed="0.001129"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.255260" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:48.252986" elapsed="0.002302"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:48.255404" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:34:48.255571" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:48.250415" elapsed="0.005181"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:48.256950" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:48.256675" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:48.257118" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:48.256276" elapsed="0.000867"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:48.257365" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:48.257217" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:48.257197" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.257591" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.257778" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.257844" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:48.261533" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:48.255930" elapsed="0.005634"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.263083" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:48.262796" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:48.263526" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:48.263280" elapsed="0.000290"/>
</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-06-06T03:34:48.271346" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:48.271525" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:48.271704" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:48.265770" elapsed="0.006350">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:48.263656" elapsed="0.008563">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:48.272468" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:48.272260" elapsed="0.000302"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:48.263620" elapsed="0.008967">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:48.273040" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.273186" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:48.273144" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:48.273123" elapsed="0.000130"/>
</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-06-06T03:34:48.273392" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.273462" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:48.261928" elapsed="0.011649">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.273734" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:48.208882" elapsed="0.064951">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:48.274110" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:48.273926" elapsed="0.000257"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:48.273908" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:48.274240" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:48.200588" elapsed="0.073746">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.320736" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:49.320236" elapsed="0.000536"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:49.321672" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:49.321388" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:49.321848" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:49.320960" elapsed="0.000913"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.322437" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:49.322035" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:49.322797" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:49.322977" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:49.322634" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.323417" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:49.323166" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.324461" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:49.324202" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.324947" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:49.324675" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.325339" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.325553" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.325763" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:49.325198" elapsed="0.000625"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.325028" elapsed="0.000826"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:49.325956" elapsed="0.000044"/>
</return>
<msg time="2026-06-06T03:34:49.326137" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:49.323879" elapsed="0.002283"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:49.323555" elapsed="0.002646"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.326368" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:49.326227" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:49.323531" elapsed="0.002912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.327042" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:49.326579" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:49.327118" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:49.319574" elapsed="0.007668"/>
</kw>
<msg time="2026-06-06T03:34:49.327296" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:49.318660" elapsed="0.008684"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.327849" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.328348" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.328865" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.329081" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.329255" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.329608" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:49.329470" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:49.329455" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.329838" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.329998" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.330157" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:49.329427" elapsed="0.000783"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.329329" elapsed="0.000906"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.330407" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.330484" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:49.330602" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:49.313820" elapsed="0.016808"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:49.332047" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:49.331611" elapsed="0.000502">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:49.332207" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:49.331278" elapsed="0.000954"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.332547" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:49.332304" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.333164" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:49.332826" elapsed="0.000367"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:49.332628" elapsed="0.000603"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:49.332285" elapsed="0.000969"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.335735" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:49.333428" elapsed="0.002335"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:49.335816" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:49.335970" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:49.330961" elapsed="0.005034"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:49.337232" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:49.336954" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:49.337390" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:49.336609" elapsed="0.000805"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:49.337631" elapsed="0.000046"/>
</return>
<status status="PASS" start="2026-06-06T03:34:49.337485" elapsed="0.000227"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:49.337466" elapsed="0.000272"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.337881" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.338047" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.338113" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:49.340074" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:49.336290" elapsed="0.003811"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.341500" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:49.341247" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:49.341958" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:49.341714" elapsed="0.000287"/>
</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-06-06T03:34:49.349717" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:49.349898" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:49.349999" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:49.344149" elapsed="0.006228">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:49.342067" elapsed="0.008397">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:49.350699" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:49.350502" elapsed="0.000264"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:49.342048" elapsed="0.008742">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:49.351184" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.351321" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:49.351281" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:49.351262" elapsed="0.000124"/>
</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-06-06T03:34:49.351524" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.351600" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:49.340405" elapsed="0.011318">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.351800" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:49.291296" elapsed="0.060600">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:49.352166" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:49.351990" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:49.351973" elapsed="0.000290"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:49.352296" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:49.284293" elapsed="0.068099">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.399779" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:50.399365" elapsed="0.000448"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:50.400569" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:50.400311" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:50.400759" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:50.399982" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.401409" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:50.401018" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:50.401770" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:50.401930" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:50.401604" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.402360" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:50.402109" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.403399" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:50.403142" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.403881" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:50.403596" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.404238" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.404436" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.404602" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:50.404109" elapsed="0.000566"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.403963" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:50.404754" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:50.404922" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:50.402816" elapsed="0.002131"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:50.402486" elapsed="0.002493"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.405144" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:50.405004" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:50.402462" elapsed="0.002757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.405850" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:50.405355" elapsed="0.000523"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:50.405927" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:50.398754" elapsed="0.007298"/>
</kw>
<msg time="2026-06-06T03:34:50.406106" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:50.397852" elapsed="0.008303"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.406662" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.407161" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.407912" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.408100" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.408269" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.408628" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:50.408487" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:50.408471" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.408860" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.409020" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.409179" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:50.408443" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.408343" elapsed="0.000913"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.409396" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.409477" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:50.409604" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:50.393491" elapsed="0.016140"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:50.410871" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:50.410610" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:50.411028" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:50.410279" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.411363" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:50.411124" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.411923" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:50.411616" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:50.411444" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:50.411105" elapsed="0.000899"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.414416" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:50.412154" elapsed="0.002289"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:50.414495" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:50.414661" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:50.409960" elapsed="0.004728"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:50.415875" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:50.415625" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:50.416076" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:50.415298" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:50.416308" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:50.416173" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:50.416154" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.416534" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.416717" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.416786" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:50.418747" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:50.414980" elapsed="0.003795"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.420157" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:50.419906" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:50.420589" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:50.420349" 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-06-06T03:34:50.428497" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:50.428636" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:50.428757" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:50.422950" elapsed="0.006171">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:50.420715" elapsed="0.008487">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:50.429384" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:50.429235" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:50.420696" elapsed="0.008777">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:50.429880" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.430016" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:50.429977" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:50.429959" elapsed="0.000121"/>
</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-06-06T03:34:50.430219" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.430290" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:50.419083" elapsed="0.011309">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.430464" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:50.370969" elapsed="0.059589">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:50.430883" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:50.430709" elapsed="0.000246"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:50.430690" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:50.431012" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:50.362447" elapsed="0.068660">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.476794" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:51.476379" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:51.477614" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:51.477331" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:51.477803" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:51.476998" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.478399" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:51.477985" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:51.478746" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:51.478915" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:51.478587" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.479341" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:51.479094" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.480597" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:51.480339" elapsed="0.000318"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.481088" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:51.480817" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.481452" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.481664" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.481834" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:51.481322" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.481173" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:51.481969" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:51.482135" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:51.480007" elapsed="0.002167"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:51.479468" elapsed="0.002739"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.482378" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:51.482233" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:51.479444" elapsed="0.003009"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.483059" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:51.482590" elapsed="0.000566"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:51.483209" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:51.475763" elapsed="0.007572"/>
</kw>
<msg time="2026-06-06T03:34:51.483391" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:51.474852" elapsed="0.008585"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.483954" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.484455" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.484976" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.485158" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.485326" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.485691" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:51.485539" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:51.485524" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.485905" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.486065" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.486251" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:51.485497" elapsed="0.000809"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.485400" elapsed="0.000932"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.486470" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.486546" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:51.486676" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:51.470509" elapsed="0.016195"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:51.487959" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:51.487724" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:51.488115" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:51.487375" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.488450" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:51.488209" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.489010" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:51.488718" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:51.488531" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:51.488191" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.491632" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:51.489236" elapsed="0.002437"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:51.491725" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:51.491878" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:51.487057" elapsed="0.004846"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:51.493092" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:51.492861" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:51.493248" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:51.492514" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:51.493478" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:34:51.493342" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:51.493323" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.493717" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.493884" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.493950" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:51.495900" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:51.492197" elapsed="0.003729"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.497303" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:51.497054" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:51.497751" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:51.497493" elapsed="0.000302"/>
</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-06-06T03:34:51.505669" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:51.505853" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:51.505979" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:51.499941" elapsed="0.006596">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:51.497861" elapsed="0.008853">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:51.506972" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:51.506764" elapsed="0.000300"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:51.497843" elapsed="0.009254">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:51.507595" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.507802" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:51.507750" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:51.507724" elapsed="0.000167"/>
</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-06-06T03:34:51.508080" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.508178" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:51.496227" elapsed="0.012091">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.508420" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:51.447973" elapsed="0.060579">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:51.508942" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:51.508704" elapsed="0.000338"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:51.508680" elapsed="0.000396"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:51.509120" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:51.440630" elapsed="0.068621">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.554307" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:52.553906" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:52.555139" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:52.554875" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:52.555322" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:52.554511" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.555918" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:52.555512" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:52.556242" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:52.556412" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:52.556098" elapsed="0.000401"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.556920" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:52.556668" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.557936" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:52.557681" elapsed="0.000299"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.558397" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:52.558132" elapsed="0.000291"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.558789" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.558990" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.559158" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:52.558630" elapsed="0.000585"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.558481" elapsed="0.000765"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:52.559294" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:52.559460" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:52.557339" elapsed="0.002145"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:52.557047" elapsed="0.002470"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.559709" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:52.559542" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:52.557021" elapsed="0.002765"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.560377" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:52.559928" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:52.560455" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:52.553278" elapsed="0.007299"/>
</kw>
<msg time="2026-06-06T03:34:52.560633" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:52.552391" elapsed="0.008306"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.561195" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.561710" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.562383" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.562610" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.562826" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.563320" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:52.563171" elapsed="0.000207"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:52.563033" elapsed="0.000370"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.563538" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.563722" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.563885" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:52.563004" elapsed="0.000934"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.562904" elapsed="0.001060"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.564105" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.564180" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:52.564294" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:52.548106" elapsed="0.016213"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:52.565531" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:52.565297" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:52.565701" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:52.564957" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.566033" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:52.565798" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.566572" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:52.566284" elapsed="0.000314"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:52.566114" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:52.565779" elapsed="0.000890"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.569058" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:52.566856" elapsed="0.002229"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:52.569136" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:34:52.569287" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:52.564627" elapsed="0.004684"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:52.570499" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:52.570269" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:52.570669" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:52.569944" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:52.570925" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:52.570789" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:52.570770" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.571185" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.571350" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.571415" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:52.573320" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:52.569608" elapsed="0.003738"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.574709" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:52.574448" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:52.575154" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:52.574914" 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-06-06T03:34:52.583612" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:52.583776" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:52.583871" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:52.577461" elapsed="0.006793">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:52.575262" elapsed="0.009074">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:52.584516" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:52.584369" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:52.575244" elapsed="0.009360">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:52.584980" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.585109" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:52.585073" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:52.585056" elapsed="0.000116"/>
</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-06-06T03:34:52.585306" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.585374" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:52.573637" elapsed="0.011839">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.585549" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:52.525791" elapsed="0.059865">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:52.585932" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:52.585760" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:52.585738" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:52.586090" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:52.519282" elapsed="0.066906">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.630313" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:53.629913" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:53.631127" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:53.630868" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:53.631327" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:53.630522" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.631914" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:53.631513" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:53.632237" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:53.632402" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:53.632096" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.633030" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:53.632582" elapsed="0.000495"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.634042" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:53.633786" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.634502" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:53.634237" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.634880" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.635078" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.635251" elapsed="0.000040"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:53.634752" elapsed="0.000576"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.634582" elapsed="0.000777"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:53.635407" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:53.635574" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:53.633445" elapsed="0.002153"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:53.633154" elapsed="0.002476"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.635812" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:53.635671" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:53.633130" elapsed="0.002757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.636482" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:53.636020" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:53.636562" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:53.629289" elapsed="0.007447"/>
</kw>
<msg time="2026-06-06T03:34:53.636857" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:53.628409" elapsed="0.008515"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.637423" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.637938" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.638433" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.638611" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.638794" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.639141" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:53.639006" elapsed="0.000191"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:53.638990" elapsed="0.000230"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.639363" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.639523" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.639699" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:53.638963" elapsed="0.000791"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.638867" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.639917" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.639999" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:53.640114" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:53.624160" elapsed="0.015979"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:53.641388" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:53.641143" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:53.641546" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:53.640809" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.641932" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:53.641691" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.642487" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:53.642187" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:53.642013" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:53.641670" elapsed="0.000898"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.646472" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:53.642726" elapsed="0.003774"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:53.646553" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:53.646745" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:53.640452" elapsed="0.006321"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:53.647998" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:53.647761" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:53.648156" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:53.647407" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:53.648387" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:53.648251" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:53.648232" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.648610" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.648790" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.648856" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:53.650820" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:53.647073" elapsed="0.003774"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.652251" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:53.652001" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:53.652709" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:53.652443" elapsed="0.000312"/>
</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-06-06T03:34:53.660535" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:53.660692" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:53.660852" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:53.654911" elapsed="0.006449">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:53.652827" elapsed="0.008658">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:53.661761" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:53.661533" elapsed="0.000318"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:53.652806" elapsed="0.009078">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:53.662527" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.662739" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:53.662682" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:53.662654" elapsed="0.000177"/>
</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-06-06T03:34:53.663024" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.663121" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:53.651148" elapsed="0.012121">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.663398" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:53.601905" elapsed="0.061624">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:53.663956" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:53.663682" elapsed="0.000376"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:53.663633" elapsed="0.000459"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:53.664137" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:53.594141" elapsed="0.070126">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.704452" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:54.704059" elapsed="0.000425"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:54.705243" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:54.704997" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:54.705413" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:54.704664" elapsed="0.000774"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.706007" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:54.705597" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:54.706334" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:54.706498" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:54.706190" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.706939" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:54.706690" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.707979" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:54.707692" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.708502" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:54.708234" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.708871" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.709072" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.709240" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:54.708742" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.708583" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:54.709375" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:54.709540" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:54.707359" elapsed="0.002206"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:54.707061" elapsed="0.002537"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.709778" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:54.709622" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:54.707038" elapsed="0.002817"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.710430" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:54.709991" elapsed="0.000467"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:54.710508" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:54.703414" elapsed="0.007219"/>
</kw>
<msg time="2026-06-06T03:34:54.710706" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:54.702549" elapsed="0.008205"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.711259" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.711779" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.712293" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.712472" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.712653" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.713193" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:54.713052" elapsed="0.000232"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:54.713036" elapsed="0.000274"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.713448" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.713612" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.713791" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:54.713007" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.712730" elapsed="0.001141"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.714011" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.714087" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:54.714203" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:54.698294" elapsed="0.015935"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:54.715437" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:54.715202" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:54.715596" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:54.714872" elapsed="0.000749"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.715973" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:54.715709" elapsed="0.000323"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.716528" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:54.716227" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:54.716056" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:54.715690" elapsed="0.000922"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.718982" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:54.716772" elapsed="0.002237"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:54.719059" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:54.719213" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:54.714538" elapsed="0.004700"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:54.720458" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:54.720222" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:54.720616" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:54.719886" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:54.720884" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:34:54.720742" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:54.720722" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.721109" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.721275" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.721341" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:54.723271" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:54.719531" elapsed="0.003799"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.724759" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:54.724493" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:54.725196" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:54.724953" elapsed="0.000287"/>
</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-06-06T03:34:54.733727" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:54.734031" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:54.734255" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:54.727549" elapsed="0.007547">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:54.725305" elapsed="0.009988">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:54.735769" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:54.735373" elapsed="0.000599"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:54.725287" elapsed="0.010746">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:54.736931" elapsed="0.000060"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.737247" elapsed="0.000034"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:54.737157" elapsed="0.000191"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:54.737114" elapsed="0.000289"/>
</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-06-06T03:34:54.737765" elapsed="0.000053"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.737938" elapsed="0.000036"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:54.723631" elapsed="0.014553">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.738362" elapsed="0.000037"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:54.675971" elapsed="0.062614">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:54.739245" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:54.738835" elapsed="0.000582"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:54.738793" elapsed="0.000682"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:54.739553" elapsed="0.000034"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:54.669578" elapsed="0.070230">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.786113" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:55.785712" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:55.786950" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:55.786686" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:55.787130" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:55.786315" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.787730" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:55.787316" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:55.788062" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:55.788224" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:55.787919" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.788729" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:55.788440" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.789989" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:55.789725" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.790461" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:55.790192" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.790832" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.791046" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.791214" elapsed="0.000030"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:55.790701" elapsed="0.000580"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.790542" elapsed="0.000769"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:55.791358" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:55.791524" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:55.789377" elapsed="0.002173"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:55.788864" elapsed="0.002718"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.791777" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:55.791619" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:55.788840" elapsed="0.003015"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.792483" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:55.791992" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:55.792562" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:55.785082" elapsed="0.007628"/>
</kw>
<msg time="2026-06-06T03:34:55.792765" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:55.784143" elapsed="0.008669"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.793359" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.793878" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.794373" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.794553" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.794736" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.795089" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:55.794951" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:55.794937" elapsed="0.000231"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.795307" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.795468" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.795626" elapsed="0.000034"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:55.794910" elapsed="0.000784"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.794812" elapsed="0.000908"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.795865" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.795941" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:55.796057" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:55.779594" elapsed="0.016489"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:55.797318" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:55.797083" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:55.797473" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:55.796750" elapsed="0.000747"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.797827" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:55.797567" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.798417" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:55.798114" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:55.797942" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:55.797548" elapsed="0.000954"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.801116" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:55.798673" elapsed="0.002471"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:55.801197" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:55.801367" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:55.796409" elapsed="0.004984"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:55.802633" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:55.802375" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:55.802867" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:55.802034" elapsed="0.000858"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:55.803101" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:55.802964" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:55.802945" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.803323" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.803488" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.803553" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:55.805496" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:55.801710" elapsed="0.003813"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.806910" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:55.806634" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:55.807353" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:55.807103" elapsed="0.000305"/>
</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-06-06T03:34:55.815812" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:55.815955" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:55.816050" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:55.809634" elapsed="0.006806">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:55.807474" elapsed="0.009052">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:55.816724" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:55.816559" elapsed="0.000254"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:55.807456" elapsed="0.009390">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:55.817350" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.817592" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:55.817538" elapsed="0.000135"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:55.817512" elapsed="0.000197"/>
</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-06-06T03:34:55.817906" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.818166" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:55.805836" elapsed="0.012474">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.818413" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:55.756890" elapsed="0.061654">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:55.818933" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:55.818692" elapsed="0.000342"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:55.818667" elapsed="0.000401"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:55.819113" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:55.747796" elapsed="0.071448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.861825" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:56.861414" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:56.862611" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:56.862357" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:56.862797" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:56.862026" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.863369" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:56.862981" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:56.863711" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:56.863876" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:56.863553" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.864311" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:56.864056" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.865355" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:56.865100" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.865839" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:56.865553" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.866194" elapsed="0.000028"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.866485" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.866671" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:56.866063" elapsed="0.000668"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.865921" elapsed="0.000841"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:56.866814" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:56.866981" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:56.864749" elapsed="0.002258"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:56.864436" elapsed="0.002604"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.867208" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:56.867065" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:56.864412" elapsed="0.002873"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.867894" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:56.867424" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:56.867972" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:56.860781" elapsed="0.007313"/>
</kw>
<msg time="2026-06-06T03:34:56.868148" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:56.859866" elapsed="0.008331"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.868702" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.869212" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.869923" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.870111" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.870282" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.870657" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:56.870502" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:56.870487" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.870877" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.871082" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.871245" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:56.870458" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.870357" elapsed="0.000968"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.871465" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.871541" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:56.871673" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:56.855476" elapsed="0.016225"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:56.872924" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:56.872683" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:56.873114" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:56.872333" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.873448" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:56.873209" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.874009" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:56.873716" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:56.873529" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:56.873190" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.876446" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:56.874234" elapsed="0.002239"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:56.876526" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:56.876695" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:56.872014" elapsed="0.004707"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:56.877943" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:56.877708" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:56.878105" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:56.877363" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:56.878334" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:56.878199" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:56.878181" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.878554" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.878734" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.878800" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:56.881010" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:56.877047" elapsed="0.003990"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.882446" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:56.882158" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:56.882925" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:56.882678" elapsed="0.000291"/>
</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-06-06T03:34:56.891042" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:56.891227" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:56.891362" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:56.885240" elapsed="0.006643">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:56.883036" elapsed="0.008964">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:56.892263" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:56.892046" elapsed="0.000308"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:56.883018" elapsed="0.009368">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:56.892931" elapsed="0.000056"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.893142" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:56.893089" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:56.893063" elapsed="0.000168"/>
</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-06-06T03:34:56.893423" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.893519" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:56.881335" elapsed="0.012347">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.893786" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:56.833059" elapsed="0.060858">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:56.894282" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:56.894045" elapsed="0.000335"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:56.894021" elapsed="0.000393"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:56.894459" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:56.825629" elapsed="0.068962">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.943103" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:57.942688" elapsed="0.000512"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:57.943974" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:57.943730" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:57.944143" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:57.943374" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.944742" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:57.944328" elapsed="0.000441"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:57.945068" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:57.945211" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:57.944926" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.945678" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:57.945388" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.946904" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:57.946621" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.947374" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:57.947106" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.947743" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.947944" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.948113" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:57.947597" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.947455" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:57.948246" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:34:57.948413" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:57.946300" elapsed="0.002139"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:57.945811" elapsed="0.002660"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.948652" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:57.948496" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:57.945786" elapsed="0.002943"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.949311" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:57.948866" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:57.949387" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:57.942059" elapsed="0.007453"/>
</kw>
<msg time="2026-06-06T03:34:57.949582" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:57.941138" elapsed="0.008492"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.950143" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.950700" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.951198" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.951380" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.951549" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.951919" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:57.951781" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:57.951765" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.952134" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.952294" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.952454" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:57.951737" elapsed="0.000769"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.951624" elapsed="0.000908"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.952687" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.952764" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:57.952880" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:57.936791" elapsed="0.016115"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:57.954326" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:57.953953" elapsed="0.000438">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:57.954484" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:57.953578" elapsed="0.000931"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.954843" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:57.954579" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.955393" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:57.955099" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:57.954930" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:57.954560" elapsed="0.000915"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.958068" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:57.955619" elapsed="0.002476"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:57.958180" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:34:57.958341" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:57.953219" elapsed="0.005148"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:57.959597" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:57.959362" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:57.959774" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:57.959025" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:57.960008" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:57.959870" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:57.959851" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.960231" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.960396" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.960460" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:57.962434" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:57.958680" elapsed="0.003781"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.963868" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:57.963598" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:57.964304" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:57.964060" elapsed="0.000288"/>
</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-06-06T03:34:57.972452" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:57.972589" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:57.972704" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:57.966618" elapsed="0.006577">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:57.964413" elapsed="0.008898">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:57.973603" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:57.973357" elapsed="0.000361"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:57.964394" elapsed="0.009358">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:57.974262" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.974444" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:57.974393" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:57.974369" elapsed="0.000164"/>
</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-06-06T03:34:57.974744" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.974845" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:57.962788" elapsed="0.012200">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.975143" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:57.910695" elapsed="0.064581">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:57.975664" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:57.975405" elapsed="0.000362"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:57.975381" elapsed="0.000420"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:57.975847" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:57.902378" elapsed="0.073601">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.021105" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:59.020709" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:59.021904" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:59.021633" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:59.022111" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:59.021303" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.022703" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:59.022298" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:34:59.023032" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:34:59.023191" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:34:59.022890" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.023611" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:59.023364" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.024760" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:59.024488" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.025227" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:34:59.024959" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.025587" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.025802" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.025970" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:34:59.025451" elapsed="0.000575"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.025308" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:34:59.026173" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:34:59.026348" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:34:59.024167" elapsed="0.002207"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:59.023749" elapsed="0.002657"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.026571" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:59.026431" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:59.023726" elapsed="0.002935"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.027242" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:34:59.026799" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:34:59.027319" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:34:59.020092" elapsed="0.007350"/>
</kw>
<msg time="2026-06-06T03:34:59.027496" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:34:59.019221" elapsed="0.008320"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.028055" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.030037" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.030569" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.030769" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.030939" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.031300" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:59.031161" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:59.031146" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.031516" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.031693" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.031856" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:34:59.031117" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.031015" elapsed="0.000920"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.032106" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.032182" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:34:59.032299" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:34:59.014986" elapsed="0.017339"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:59.033548" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:59.033309" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:59.033724" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:59.032972" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.034061" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:59.033822" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.034667" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:34:59.034355" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:34:59.034180" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:59.033803" elapsed="0.000950"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.037084" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:34:59.034899" elapsed="0.002212"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:34:59.037162" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:34:59.037316" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:59.032636" elapsed="0.004705"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:34:59.038555" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:34:59.038320" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:34:59.038728" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:34:59.037969" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:34:59.038960" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:34:59.038824" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:34:59.038805" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.039186" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.039351" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.039417" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:34:59.041471" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:34:59.037631" elapsed="0.003867"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.042927" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:59.042671" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:34:59.043371" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:34:59.043123" elapsed="0.000292"/>
</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-06-06T03:34:59.051195" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:34:59.051371" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:34:59.051473" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:34:59.045554" elapsed="0.006308">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:34:59.043481" elapsed="0.008464">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:34:59.052129" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:59.051978" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:34:59.043463" elapsed="0.008756">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:34:59.052582" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.052730" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:34:59.052693" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:59.052674" elapsed="0.000120"/>
</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-06-06T03:34:59.052935" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.053005" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:34:59.041811" elapsed="0.011296">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.053181" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:34:58.992576" elapsed="0.060698">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:34:59.053533" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:34:59.053364" elapsed="0.000241"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:34:59.053347" elapsed="0.000282"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:34:59.053677" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:34:58.985820" elapsed="0.067951">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.098026" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:00.097617" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:00.098845" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:00.098557" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:00.099022" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:00.098227" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.099699" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:00.099293" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:00.100028" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:00.100189" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:00.099885" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.100627" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:00.100377" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.101637" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:00.101378" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.102123" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:00.101854" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.102474" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.102712" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.102886" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:00.102345" elapsed="0.000599"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.102205" elapsed="0.000769"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:00.103022" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:00.103185" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:00.101059" elapsed="0.002151"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:00.100767" elapsed="0.002475"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.103407" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:00.103267" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:00.100745" elapsed="0.002736"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.104088" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:00.103618" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:00.104165" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:00.097006" elapsed="0.007283"/>
</kw>
<msg time="2026-06-06T03:35:00.104342" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:00.096147" elapsed="0.008243"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.104889" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.105485" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.106047" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.106228" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.106396" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.106777" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:00.106609" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:00.106594" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.106992" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.107153" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.107312" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:00.106566" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.106469" elapsed="0.000922"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.107530" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.107605" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:00.107736" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:00.091635" elapsed="0.016128"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:00.109157" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:00.108734" elapsed="0.000489">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:00.109317" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:00.108388" elapsed="0.000955"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.109673" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:00.109415" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.110223" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:00.109926" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:00.109757" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:00.109396" elapsed="0.000911"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.112692" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:00.110454" elapsed="0.002266"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:00.112772" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:00.112928" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:00.108071" elapsed="0.004882"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:00.114158" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:00.113924" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:00.114356" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:00.113570" elapsed="0.000811"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:00.114592" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:00.114454" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:00.114434" elapsed="0.000269"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.114846" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.115014" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.115081" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:00.117072" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:00.113250" elapsed="0.003849"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.118470" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:00.118218" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:00.118952" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:00.118701" elapsed="0.000295"/>
</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-06-06T03:35:00.127284" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:00.127419" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:00.127513" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:00.121126" elapsed="0.006773">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:00.119062" elapsed="0.008921">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:00.128163" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:00.128015" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:00.119044" elapsed="0.009207">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:00.128620" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.128769" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:00.128731" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:00.128714" elapsed="0.000118"/>
</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-06-06T03:35:00.128968" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.129038" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:00.117401" elapsed="0.011739">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.129213" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:00.069199" elapsed="0.060106">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:00.129607" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:00.129433" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:00.129416" elapsed="0.000304"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:00.129754" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:00.062996" elapsed="0.066855">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.174567" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:01.174172" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:01.175436" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:01.175135" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:01.175608" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:01.174782" elapsed="0.000850"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.176196" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:01.175808" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:01.176520" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:01.176702" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:01.176377" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.177135" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:01.176883" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.178142" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:01.177884" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.178607" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:01.178341" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.178978" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.179176" elapsed="0.000049"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.179371" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:01.178850" elapsed="0.000578"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.178706" elapsed="0.000753"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:01.179506" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:01.179686" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:01.177547" elapsed="0.002165"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:01.177256" elapsed="0.002489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.179909" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:01.179769" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:01.177234" elapsed="0.002755"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.180567" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:01.180124" elapsed="0.000541"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:01.180719" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:01.173549" elapsed="0.007295"/>
</kw>
<msg time="2026-06-06T03:35:01.180899" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:01.172694" elapsed="0.008253"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.181432" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.181946" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.182617" elapsed="0.000041"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.182820" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.182987" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.183352" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:01.183213" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:01.183186" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.183566" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.183743" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.183904" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:01.183158" elapsed="0.000799"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.183061" elapsed="0.000921"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.184121" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.184196" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:01.184310" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:01.168425" elapsed="0.015911"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:01.185598" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:01.185361" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:01.185774" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:01.185025" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.186106" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:01.185869" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.186703" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:01.186365" elapsed="0.000364"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:01.186187" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:01.185851" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.189170" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:01.186931" elapsed="0.002266"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:01.189249" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:01.189427" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:01.184700" elapsed="0.004753"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:01.190656" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:01.190410" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:01.190822" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:01.190083" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:01.191052" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:01.190916" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:01.190897" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.191289" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.191453" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.191518" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:01.193446" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:01.189761" elapsed="0.003712"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.194856" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:01.194589" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:01.195313" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:01.195046" elapsed="0.000310"/>
</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-06-06T03:35:01.203580" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:01.203740" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:01.203836" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:01.197626" elapsed="0.006677">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:01.195421" elapsed="0.009036">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:01.204737" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:01.204506" elapsed="0.000325"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:01.195403" elapsed="0.009462">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:01.205375" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.205559" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:01.205507" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:01.205483" elapsed="0.000184"/>
</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-06-06T03:35:01.205861" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.205965" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:01.193792" elapsed="0.012314">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.206208" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:01.146031" elapsed="0.060307">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:01.206723" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:01.206464" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:01.206441" elapsed="0.000417"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:01.206903" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:01.139763" elapsed="0.067272">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.251196" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:02.250801" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:02.252008" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:02.251744" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:02.252176" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:02.251395" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.252771" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:02.252366" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:02.253096" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:02.253258" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:02.252954" elapsed="0.000393"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.253767" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:02.253500" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.254982" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:02.254723" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.255497" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:02.255182" elapsed="0.000342"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.255898" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.256103" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.256271" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:02.255739" elapsed="0.000588"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.255580" elapsed="0.000779"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:02.256405" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:02.256571" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:02.254384" elapsed="0.002213"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:02.253891" elapsed="0.002738"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.256814" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:02.256671" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:02.253869" elapsed="0.003020"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.257471" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:02.257030" elapsed="0.000468"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:02.257547" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:02.250182" elapsed="0.007503"/>
</kw>
<msg time="2026-06-06T03:35:02.257740" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:02.249315" elapsed="0.008472"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.258272" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.258785" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.259289" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.259503" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.259688" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.260059" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:02.259920" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:02.259905" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.260274" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.260435" elapsed="0.000026"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.260600" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:02.259877" elapsed="0.000791"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.259777" elapsed="0.000918"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.260836" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.260912" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:02.261028" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:02.245080" elapsed="0.015974"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:02.262280" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:02.262045" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:02.262437" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:02.261705" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.262788" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:02.262533" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.263331" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:02.263038" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:02.262870" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:02.262514" elapsed="0.000900"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.265982" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:02.263557" elapsed="0.002457"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:02.266067" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:02.266220" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:02.261371" elapsed="0.004875"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:02.267440" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:02.267208" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:02.267597" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:02.266877" elapsed="0.000745"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:02.267871" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:02.267709" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:02.267690" elapsed="0.000264"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.268129" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.268296" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.268361" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:02.270275" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:02.266538" elapsed="0.003763"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.271674" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:02.271408" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:02.272146" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:02.271901" elapsed="0.000288"/>
</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-06-06T03:35:02.280313" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:02.280451" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:02.280544" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:02.274313" elapsed="0.006628">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:02.272254" elapsed="0.008769">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:02.281202" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:02.281055" elapsed="0.000210"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:02.272236" elapsed="0.009052">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:02.281656" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.281788" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:02.281751" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:02.281734" elapsed="0.000116"/>
</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-06-06T03:35:02.281989" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.282057" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:02.270594" elapsed="0.011562">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.282229" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:02.222769" elapsed="0.059550">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:02.282577" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:02.282409" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:02.282392" elapsed="0.000307"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:02.282762" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:02.214682" elapsed="0.068178">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.327684" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:03.327270" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:03.328509" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:03.328215" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:03.328697" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:03.327887" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.329272" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:03.328881" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:03.329595" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:03.329778" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:03.329450" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.330207" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:03.329958" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.331222" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:03.330966" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.331705" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:03.331421" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.332059" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.332259" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.332468" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:03.331930" elapsed="0.000596"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.331787" elapsed="0.000768"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:03.332601" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:03.332784" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:03.330623" elapsed="0.002186"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:03.330330" elapsed="0.002512"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.333013" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:03.332867" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:03.330307" elapsed="0.002783"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.333680" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:03.333225" elapsed="0.000483"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:03.333756" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:03.326668" elapsed="0.007210"/>
</kw>
<msg time="2026-06-06T03:35:03.333987" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:03.325778" elapsed="0.008259"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.334529" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.335047" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.335732" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.335917" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.336084" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.336456" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:03.336300" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:03.336285" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.336685" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.336848" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.337009" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:03.336257" elapsed="0.000806"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.336159" elapsed="0.000929"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.337227" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.337302" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:03.337417" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:03.321320" elapsed="0.016123"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:03.338673" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:03.338422" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:03.338831" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:03.338090" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.339194" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:03.338958" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.339761" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:03.339450" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:03.339275" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:03.338939" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.342218" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:03.339984" elapsed="0.002260"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:03.342296" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:03.342449" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:03.337771" elapsed="0.004702"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:03.343676" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:03.343429" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:03.343833" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:03.343102" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:03.344067" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:03.343927" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:03.343909" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.344287" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.344478" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.344544" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:03.346478" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:03.342785" elapsed="0.003720"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.347875" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:03.347612" elapsed="0.000308"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:03.348313" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:03.348069" elapsed="0.000315"/>
</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-06-06T03:35:03.356559" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:03.356728" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:03.356829" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:03.350683" elapsed="0.006519">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:03.348451" elapsed="0.008833">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:03.357467" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:03.357318" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:03.348432" elapsed="0.009122">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:03.357993" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.358131" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:03.358092" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:03.358074" elapsed="0.000122"/>
</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-06-06T03:35:03.358335" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.358405" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:03.346815" elapsed="0.011694">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.358583" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:03.299078" elapsed="0.059614">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:03.358957" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:03.358785" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:03.358768" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:03.359085" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:03.292757" elapsed="0.066423">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.403867" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:04.403455" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:04.404673" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:04.404405" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:04.404843" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:04.404068" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.405443" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:04.405057" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:04.405783" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:04.405944" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:04.405624" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.407860" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:04.406124" elapsed="0.001783"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.408894" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:04.408601" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.409418" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:04.409149" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.409783" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.409983" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.410149" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:04.409638" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.409498" elapsed="0.000739"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:04.410284" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:04.410447" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:04.408280" elapsed="0.002192"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:04.407985" elapsed="0.002520"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.410686" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:04.410530" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:04.407962" elapsed="0.002802"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.411340" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:04.410899" elapsed="0.000469"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:04.411418" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:04.402854" elapsed="0.008689"/>
</kw>
<msg time="2026-06-06T03:35:04.411597" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:04.401984" elapsed="0.009675"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.412146" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.412657" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.413183" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.413362" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.413529" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.413897" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:04.413759" elapsed="0.000226"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:04.413744" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.414145" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.414305" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.414463" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:04.413715" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.413603" elapsed="0.000938"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.414695" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.414771" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:04.414887" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:04.397746" elapsed="0.017166"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:04.416112" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:04.415879" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:04.416268" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:04.415534" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.416598" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:04.416362" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.417329" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:04.416867" elapsed="0.000488"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:04.416694" elapsed="0.000696"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:04.416343" elapsed="0.001068"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.419918" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:04.417556" elapsed="0.002389"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:04.419997" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:04.420151" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:04.415219" elapsed="0.004957"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:04.421414" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:04.421182" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:04.421571" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:04.420801" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:04.421826" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:04.421683" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:04.421662" elapsed="0.000248"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.422050" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.422214" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.422279" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:04.424200" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:04.420469" elapsed="0.003791"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.425664" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:04.425398" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:04.426106" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:04.425861" elapsed="0.000288"/>
</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-06-06T03:35:04.434243" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:04.434381" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:04.434485" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:04.428273" elapsed="0.006597">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:04.426214" elapsed="0.008737">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:04.435136" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:04.434984" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:04.426196" elapsed="0.009027">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:04.435583" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.435734" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:04.435697" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:04.435678" elapsed="0.000120"/>
</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-06-06T03:35:04.435932" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.436000" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:04.424561" elapsed="0.011545">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.436179" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:04.375483" elapsed="0.060788">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:04.436530" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:04.436361" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:04.436344" elapsed="0.000281"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:04.436674" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:04.368478" elapsed="0.068290">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.480355" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:05.479954" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:05.481171" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:05.480913" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:05.481343" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:05.480559" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.481964" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:05.481555" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:05.482299" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:05.482471" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:05.482153" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.482920" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:05.482667" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.483940" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:05.483679" elapsed="0.000307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.484411" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:05.484141" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.484783" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.484987" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.485158" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:05.484635" elapsed="0.000581"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.484492" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:05.485294" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:05.485477" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:05.483341" elapsed="0.002163"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:05.483046" elapsed="0.002491"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.485721" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:05.485563" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:05.483021" elapsed="0.002778"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.486388" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:05.485939" elapsed="0.000477"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:05.486466" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:05.479323" elapsed="0.007267"/>
</kw>
<msg time="2026-06-06T03:35:05.486661" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:05.478425" elapsed="0.008286"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.487260" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.487775" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.488271" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.488453" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.488623" elapsed="0.000035"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.489174" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:05.489032" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:05.489017" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.489391" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.489584" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.489764" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:05.488988" elapsed="0.000830"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.488715" elapsed="0.001130"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.489985" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.490060" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:05.490177" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:05.474148" elapsed="0.016055"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:05.491418" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:05.491185" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:05.491575" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:05.490851" elapsed="0.000748"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.491931" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:05.491686" elapsed="0.000333"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.492525" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:05.492221" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:05.492047" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:05.491666" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.495039" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:05.492771" elapsed="0.002295"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:05.495118" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:05.495273" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:05.490514" elapsed="0.004784"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:05.496494" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:05.496258" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:05.496666" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:05.495926" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:05.496904" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:05.496766" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:05.496747" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.497127" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.497293" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.497359" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:05.499313" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:05.495590" elapsed="0.003750"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.500737" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:05.500456" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:05.501171" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:05.500929" elapsed="0.000285"/>
</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-06-06T03:35:05.509516" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:05.509692" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:05.509791" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:05.503518" elapsed="0.006645">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:05.501281" elapsed="0.008966">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:05.510431" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:05.510281" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:05.501262" elapsed="0.009259">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:05.510910" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.511092" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:05.511049" elapsed="0.000089"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:05.511030" elapsed="0.000131"/>
</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-06-06T03:35:05.511303" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.511377" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:05.499636" elapsed="0.011848">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.511561" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:05.451444" elapsed="0.060230">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:05.511951" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:05.511772" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:05.511754" elapsed="0.000296"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:05.512087" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:05.444894" elapsed="0.067293">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.557278" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:06.556875" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:06.558114" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:06.557827" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:06.558284" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:06.557480" elapsed="0.000829"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.558873" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:06.558469" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:06.559199" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:06.559361" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:06.559056" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.559802" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:06.559536" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.561050" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:06.560788" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.561521" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:06.561251" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.561889" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.562171" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.562341" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:06.561760" elapsed="0.000639"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.561602" elapsed="0.000828"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:06.562477" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:06.562660" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:06.560448" elapsed="0.002239"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:06.559927" elapsed="0.002793"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.562889" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:06.562746" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:06.559903" elapsed="0.003062"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.563561" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:06.563105" elapsed="0.000484"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:06.563652" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:06.556256" elapsed="0.007525"/>
</kw>
<msg time="2026-06-06T03:35:06.563836" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:06.555380" elapsed="0.008504"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.564373" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.564889" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.565388" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.565568" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.565749" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.566133" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:06.565964" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:06.565948" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.566347" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.566544" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.566723" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:06.565920" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.565824" elapsed="0.000981"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.566946" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.567023" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:06.567138" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:06.551089" elapsed="0.016075"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:06.568379" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:06.568145" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:06.568533" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:06.567814" elapsed="0.000744"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.568885" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:06.568629" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.569426" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:06.569136" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:06.568966" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:06.568610" elapsed="0.000899"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.572042" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:06.569665" elapsed="0.002404"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:06.572121" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:06.572273" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:06.567480" elapsed="0.004818"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:06.573476" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:06.573247" elapsed="0.000291">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:06.573629" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:06.572920" elapsed="0.000749"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:06.573875" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:06.573741" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:06.573722" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.574126" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.574292" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.574356" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:35:06.576280" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:06.572590" elapsed="0.003716"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.577726" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:06.577424" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:06.578182" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:06.577921" elapsed="0.000305"/>
</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-06-06T03:35:06.585754" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:06.585898" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:06.586001" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:06.580358" elapsed="0.006042">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:06.578293" elapsed="0.008193">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:06.586708" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:06.586522" elapsed="0.000252"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:06.578274" elapsed="0.008524">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:06.587182" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.587318" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:06.587279" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:06.587261" elapsed="0.000122"/>
</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-06-06T03:35:06.587520" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.587589" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:06.576603" elapsed="0.011105">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.587783" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:06.528568" elapsed="0.059308">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:06.588140" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:06.587967" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:06.587950" elapsed="0.000286"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:06.588415" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:06.521484" elapsed="0.067026">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.637062" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:07.636656" elapsed="0.000524"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:07.637969" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:07.637707" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:07.638142" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:07.637358" elapsed="0.000809"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.638746" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:07.638326" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:07.639072" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:07.639233" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:07.638929" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.639669" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:07.639407" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.640701" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:07.640429" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.641167" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:07.640900" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.641528" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.641742" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.641914" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:07.641398" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.641251" elapsed="0.000751"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:07.642051" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:07.642217" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:07.640107" elapsed="0.002135"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:07.639797" elapsed="0.002477"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.642441" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:07.642300" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:07.639772" elapsed="0.002745"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.643183" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:07.642724" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:07.643260" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:07.636022" elapsed="0.007361"/>
</kw>
<msg time="2026-06-06T03:35:07.643437" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:07.635093" elapsed="0.008392"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.644005" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.644568" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.645286" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.645475" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.645660" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.646020" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:07.645881" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:07.645866" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.646235" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.646398" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.646580" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:07.645837" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.645738" elapsed="0.000946"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.646826" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.646902" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:07.647019" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:07.630744" elapsed="0.016301"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:07.648277" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:07.648024" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:07.648436" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:07.647692" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.648786" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:07.648530" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.649337" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:07.649038" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:07.648868" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:07.648511" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.651871" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:07.649565" elapsed="0.002333"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:07.651992" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:07.652150" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:07.647355" elapsed="0.004820"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:07.653411" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:07.653168" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:07.653568" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:07.652817" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:07.653819" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:07.653682" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:07.653662" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.654046" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.654211" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.654276" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:07.656221" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:07.652470" elapsed="0.003777"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.657657" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:07.657392" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:07.658090" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:07.657850" elapsed="0.000282"/>
</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-06-06T03:35:07.666555" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:07.666804" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:07.666906" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:07.660573" elapsed="0.006786">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:07.658198" elapsed="0.009280">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:07.667769" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:07.667527" elapsed="0.000339"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:07.658180" elapsed="0.009721">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:07.668437" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.668630" elapsed="0.000040"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:07.668576" elapsed="0.000136"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:07.668551" elapsed="0.000194"/>
</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-06-06T03:35:07.668946" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.669047" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:07.656551" elapsed="0.012644">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.669357" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:07.605638" elapsed="0.063860">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:07.669908" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:07.669634" elapsed="0.000379"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:07.669610" elapsed="0.000438"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:07.670096" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:07.597566" elapsed="0.072667">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.714991" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:08.714573" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:08.715853" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:08.715574" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:08.716024" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:08.715238" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.716593" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:08.716207" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:08.716932" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:08.717097" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:08.716789" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.717519" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:08.717272" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.718741" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:08.718459" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.719231" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:08.718942" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.719586" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.719801" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.719969" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:08.719457" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.719314" elapsed="0.000742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:08.720155" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:35:08.720326" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:08.718139" elapsed="0.002212"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:08.717656" elapsed="0.002727"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.720550" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:08.720408" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:08.717619" elapsed="0.003006"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.721228" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:08.720781" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:08.721305" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:08.713952" elapsed="0.007477"/>
</kw>
<msg time="2026-06-06T03:35:08.721483" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:08.713066" elapsed="0.008464"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.722037" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.722558" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.723088" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.723348" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.723519" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.723900" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:08.723760" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:08.723746" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.724124" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.724290" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.724450" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:08.723716" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.723594" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.724725" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.724803" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:08.724919" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:08.708783" elapsed="0.016162"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:08.726156" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:08.725923" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:08.726312" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:08.725569" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.726669" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:08.726416" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.727233" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:08.726921" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:08.726752" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:08.726397" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.729855" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:08.727468" elapsed="0.002414"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:08.729934" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:08.730087" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:08.725255" elapsed="0.004857"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:08.731333" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:08.731068" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:08.731490" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:08.730740" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:08.731736" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:08.731584" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:08.731566" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.731957" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.732118" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.732184" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:08.734105" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:08.730409" elapsed="0.003723"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.735509" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:08.735260" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:08.735963" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:08.735720" elapsed="0.000286"/>
</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-06-06T03:35:08.743815" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:08.743986" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:08.744081" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:08.738138" elapsed="0.006320">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:08.736072" elapsed="0.008467">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:08.744734" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:08.744571" elapsed="0.000228"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:08.736054" elapsed="0.008769">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:08.745177" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.745307" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:08.745271" elapsed="0.000076"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:08.745254" elapsed="0.000115"/>
</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-06-06T03:35:08.745503" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.745572" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:08.734425" elapsed="0.011262">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.745761" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:08.686190" elapsed="0.059662">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:08.746109" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:08.745941" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:08.745924" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:08.746240" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:08.678362" elapsed="0.067971">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.792715" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:09.792305" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:09.793489" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:09.793240" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:09.793673" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:09.792915" elapsed="0.000784"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.794316" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:09.793923" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:09.794655" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:09.794814" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:09.794498" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.795240" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:09.794993" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.796273" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:09.796012" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.796807" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:09.796511" elapsed="0.000323"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.797159" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.797355" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.797522" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:09.797031" elapsed="0.000548"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.796890" elapsed="0.000718"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:09.797670" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:09.797835" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:09.795669" elapsed="0.002191"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:09.795363" elapsed="0.002529"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.798056" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:09.797917" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:09.795339" elapsed="0.002793"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.798727" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:09.798267" elapsed="0.000488"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:09.798804" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:09.791698" elapsed="0.007228"/>
</kw>
<msg time="2026-06-06T03:35:09.798980" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:09.790820" elapsed="0.008207"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.799551" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.800155" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.800758" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.800944" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.801111" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.867168" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:09.866959" elapsed="0.000294"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:09.866932" elapsed="0.000347"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.867420" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.867584" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.867778" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:09.866882" elapsed="0.000951"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.801185" elapsed="0.066676"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.868002" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.868081" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:35:09.868255" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:09.786547" elapsed="0.081736"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:09.869723" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:09.869389" elapsed="0.000410">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:09.869896" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:09.869000" elapsed="0.000921"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.870255" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:09.869993" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.870834" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:09.870511" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:09.870337" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:09.869974" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.873331" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:09.871064" elapsed="0.002293"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:09.873540" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:09.873713" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:09.868627" elapsed="0.005111"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:09.875081" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:09.874709" elapsed="0.000436">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:09.875311" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:09.874360" elapsed="0.000976"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:09.875548" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:09.875409" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:09.875390" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.875810" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.875978" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.876045" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:09.878153" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:09.874037" elapsed="0.004145"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.879578" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:09.879320" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:09.880064" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:09.879817" elapsed="0.000291"/>
</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-06-06T03:35:09.888246" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:09.888434" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:09.888587" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:09.882267" elapsed="0.006870">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:09.880175" elapsed="0.009081">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:09.889525" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:09.889305" elapsed="0.000317"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:09.880156" elapsed="0.009525">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:09.890220" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.890416" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:09.890360" elapsed="0.000118"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:09.890334" elapsed="0.000178"/>
</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-06-06T03:35:09.890734" elapsed="0.000033"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.890841" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:09.878488" elapsed="0.012504">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.891102" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:09.763468" elapsed="0.127774">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:09.891714" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:09.891436" elapsed="0.000410"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:09.891410" elapsed="0.000473"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:09.891933" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:09.757312" elapsed="0.134763">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.936546" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:10.936140" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:10.937328" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:10.937091" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:10.937494" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:10.936757" elapsed="0.000762"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.938093" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:10.937701" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:10.938425" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:10.938584" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:10.938280" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.939029" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:10.938781" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.940037" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:10.939777" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.940544" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:10.940238" elapsed="0.000333"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.940913" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.941115" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.941283" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:10.940784" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.940626" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:10.941422" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:10.941585" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:10.939442" elapsed="0.002168"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:10.939150" elapsed="0.002506"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.941828" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:10.941683" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:10.939128" elapsed="0.002777"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.942491" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:10.942043" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:10.942624" elapsed="0.000045"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:10.935518" elapsed="0.007252"/>
</kw>
<msg time="2026-06-06T03:35:10.942825" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:10.934683" elapsed="0.008190"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.943365" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.943889" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.944414" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.944598" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.944784" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.945144" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:10.945004" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:10.944989" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.945361" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.945526" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.945703" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:10.944960" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.944860" elapsed="0.000926"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.945927" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.946005" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:10.946124" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:10.930349" elapsed="0.015801"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:10.947618" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:10.947377" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:10.947796" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:10.947037" elapsed="0.000784"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.948137" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:10.947893" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.948749" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:10.948432" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:10.948221" elapsed="0.000592"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:10.947874" elapsed="0.000961"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.951222" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:10.948984" elapsed="0.002269"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:10.951307" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:10.951478" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:10.946508" elapsed="0.004997"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:10.952781" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:10.952511" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:10.952940" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:10.952154" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:10.953174" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:10.953038" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:10.953019" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.953407" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.953575" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.953658" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:10.955604" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:10.951830" elapsed="0.003801"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.957062" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:10.956809" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:10.957501" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:10.957256" elapsed="0.000289"/>
</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-06-06T03:35:10.965920" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:10.966055" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:10.966149" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:10.959694" elapsed="0.006922">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:10.957610" elapsed="0.009201">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:10.967087" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:10.966863" elapsed="0.000320"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:10.957592" elapsed="0.009627">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:10.967782" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.967981" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:10.967924" elapsed="0.000120"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:10.967898" elapsed="0.000180"/>
</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-06-06T03:35:10.968303" elapsed="0.000034"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.968410" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:10.955950" elapsed="0.012611">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.968692" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:10.907493" elapsed="0.061341">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:10.969224" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:10.968970" elapsed="0.000364"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:10.968945" elapsed="0.000426"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:10.969420" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:10.901265" elapsed="0.068295">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.015706" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:12.015296" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:12.016484" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:12.016236" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:12.016667" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:12.015903" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.017255" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:12.016865" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:12.017578" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:12.017753" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:12.017437" elapsed="0.000406"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.018251" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:12.017998" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.019278" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:12.019012" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.019765" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:12.019480" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.020120" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.020320" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.020487" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:12.019990" elapsed="0.000555"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.019847" elapsed="0.000728"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:12.020622" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:35:12.020805" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:12.018688" elapsed="0.002166"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:12.018375" elapsed="0.002515"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.021057" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:12.020916" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:12.018353" elapsed="0.002782"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.021748" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:12.021274" elapsed="0.000503"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:12.021828" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:12.014685" elapsed="0.007269"/>
</kw>
<msg time="2026-06-06T03:35:12.022009" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:12.013818" elapsed="0.008238"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.022551" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.023078" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.023788" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.024021" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.024195" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.024557" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:12.024417" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:12.024401" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.024792" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.024969" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.025129" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:12.024372" elapsed="0.000812"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.024272" elapsed="0.000938"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.025351" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.025428" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:12.025546" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:12.009502" elapsed="0.016070"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:12.026813" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:12.026561" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:12.026970" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:12.026222" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.027308" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:12.027066" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.027871" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:12.027558" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:12.027390" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:12.027048" elapsed="0.000907"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.030319" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:12.028101" elapsed="0.002246"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:12.030399" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:12.030554" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:12.025903" elapsed="0.004676"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:12.031791" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:12.031540" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:12.031948" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:12.031210" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:12.032180" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:12.032044" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:12.032025" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.032449" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.032619" elapsed="0.000040"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.032708" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:12.034786" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:12.030889" elapsed="0.003925"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.036197" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:12.035945" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:12.036657" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:12.036398" elapsed="0.000306"/>
</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-06-06T03:35:12.045056" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:12.045191" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:12.045312" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:12.038856" elapsed="0.007003">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:12.036771" elapsed="0.009206">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:12.046245" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:12.046027" elapsed="0.000314"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:12.036753" elapsed="0.009623">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:12.046934" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.047130" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:12.047074" elapsed="0.000118"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:12.047048" elapsed="0.000176"/>
</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-06-06T03:35:12.047426" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.047528" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:12.035114" elapsed="0.012584">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.047809" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:11.986876" elapsed="0.061071">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:12.048336" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:12.048082" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:12.048057" elapsed="0.000422"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:12.048577" elapsed="0.000024"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:11.979453" elapsed="0.069291">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.091213" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:13.090818" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:13.092185" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:13.091932" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:13.092355" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:13.091414" elapsed="0.000966"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.092961" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:13.092538" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:13.093288" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:13.093468" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:13.093145" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.093914" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:13.093664" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.094926" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:13.094667" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.095399" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:13.095127" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.095764" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.095963" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.096132" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:13.095619" elapsed="0.000571"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.095479" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:13.096267" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:13.096431" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:13.094331" elapsed="0.002126"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:13.094038" elapsed="0.002451"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.096669" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:13.096514" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:13.094015" elapsed="0.002731"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.097329" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:13.096885" elapsed="0.000472"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:13.097430" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:13.090195" elapsed="0.007361"/>
</kw>
<msg time="2026-06-06T03:35:13.097683" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:13.089308" elapsed="0.008425"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.098222" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.098735" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.099232" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.099414" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.099584" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.099956" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:13.099816" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:13.099801" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.100174" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.100335" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.100493" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:13.099773" elapsed="0.000772"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.099673" elapsed="0.000898"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.100725" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.100802" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:13.100920" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:13.085048" elapsed="0.015899"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:13.102366" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:13.102127" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:13.102524" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:13.101792" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.102915" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:13.102673" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.103459" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:13.103166" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:13.102996" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:13.102652" elapsed="0.000890"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.105926" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:13.103704" elapsed="0.002249"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:13.106005" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:13.106158" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:13.101263" elapsed="0.004920"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:13.107385" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:13.107152" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:13.107541" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:13.106814" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:13.107788" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:13.107636" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:13.107617" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.108013" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.108178" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.108243" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:13.110175" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:13.106477" elapsed="0.003724"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.111577" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:13.111323" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:13.112027" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:13.111785" elapsed="0.000286"/>
</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-06-06T03:35:13.119174" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:13.119312" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:13.119406" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:13.114238" elapsed="0.005559">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:13.112136" elapsed="0.007744">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:13.120063" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:13.119913" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:13.112118" elapsed="0.008033">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:13.120604" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.120757" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:13.120719" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:13.120701" elapsed="0.000120"/>
</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-06-06T03:35:13.120962" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.121033" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:13.110500" elapsed="0.010637">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.121211" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:13.062397" elapsed="0.058909">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:13.121595" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:13.121397" elapsed="0.000286"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:13.121380" elapsed="0.000328"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:13.121741" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:13.055170" elapsed="0.066667">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.166184" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:14.165763" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:14.166998" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:14.166749" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:14.167166" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:14.166383" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.167764" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:14.167357" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:14.168091" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:14.168254" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:14.167949" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.168701" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:14.168438" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.169716" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:14.169442" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.170258" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:14.169985" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.170618" elapsed="0.000037"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.170838" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.171010" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:14.170488" elapsed="0.000580"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.170341" elapsed="0.000757"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:14.171145" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:14.171309" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:14.169118" elapsed="0.002216"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:14.168824" elapsed="0.002543"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.171535" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:14.171393" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:14.168801" elapsed="0.002811"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.172219" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:14.171766" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:14.172298" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:14.165139" elapsed="0.007432"/>
</kw>
<msg time="2026-06-06T03:35:14.172627" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:14.164274" elapsed="0.008417"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.173184" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.173705" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.174421" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.174609" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.174805" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.175163" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:14.175025" elapsed="0.000228"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:14.175009" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.175418" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.175583" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.175774" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:14.174982" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.174881" elapsed="0.000974"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.175996" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.176072" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:14.176189" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:14.159992" elapsed="0.016223"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:14.177443" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:14.177206" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:14.177602" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:14.176869" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.177965" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:14.177715" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.178510" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:14.178216" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:14.178048" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:14.177696" elapsed="0.000898"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.181048" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:14.178755" elapsed="0.002320"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:14.181126" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:14.181281" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:14.176533" elapsed="0.004773"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:14.182529" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:14.182294" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:14.182702" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:14.181939" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:14.182935" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:14.182800" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:14.182780" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.183166" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.183330" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.183397" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:14.185535" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:14.181603" elapsed="0.003993"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.186996" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:14.186744" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:14.187429" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:14.187188" elapsed="0.000284"/>
</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-06-06T03:35:14.195277" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:14.195412" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:14.195505" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:14.189595" elapsed="0.006293">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:14.187539" elapsed="0.008431">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:14.196151" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:14.196003" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:14.187520" elapsed="0.008719">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:14.196616" elapsed="0.000040"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.196766" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:14.196728" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:14.196710" elapsed="0.000120"/>
</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-06-06T03:35:14.196966" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.197035" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:14.185914" elapsed="0.011223">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.197211" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:14.137498" elapsed="0.059808">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:14.197569" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:14.197397" elapsed="0.000262"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:14.197380" elapsed="0.000305"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:14.197719" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:14.129827" elapsed="0.067988">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.244424" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:15.244014" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:15.245251" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:15.244985" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:15.245431" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:15.244632" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.246025" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:15.245618" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:15.246375" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:15.246556" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:15.246209" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.247003" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:15.246750" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.248028" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:15.247763" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.248501" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:15.248229" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.248878" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.249081" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.249249" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:15.248745" elapsed="0.000560"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.248583" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:15.249387" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:15.249555" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:15.247424" elapsed="0.002157"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:15.247130" elapsed="0.002483"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.249798" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:15.249652" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:15.247105" elapsed="0.002769"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.250465" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:15.250010" elapsed="0.000484"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:15.250567" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:15.243390" elapsed="0.007320"/>
</kw>
<msg time="2026-06-06T03:35:15.250766" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:15.242464" elapsed="0.008350"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.251362" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.251882" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.252382" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.252563" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.252746" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.253102" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:15.252964" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:15.252949" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.253316" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.253481" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.253652" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:15.252921" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.252822" elapsed="0.000910"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.253873" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.253949" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:15.254065" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:15.238129" elapsed="0.015962"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:15.255571" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:15.255314" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:15.255751" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:15.254789" elapsed="0.000987"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.256087" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:15.255847" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.256700" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:15.256378" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:15.256204" elapsed="0.000559"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:15.255828" elapsed="0.000957"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.259220" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:15.256986" elapsed="0.002261"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:15.259300" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:15.259459" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:15.254404" elapsed="0.005080"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:15.260699" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:15.260450" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:15.260856" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:15.260118" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:15.261090" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:15.260953" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:15.260933" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.261314" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.261479" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.261544" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:15.263506" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:15.259797" elapsed="0.003736"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.264945" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:15.264693" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:15.265379" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:15.265137" elapsed="0.000286"/>
</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-06-06T03:35:15.273204" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:15.273348" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:15.273457" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:15.267581" elapsed="0.006273">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:15.265489" elapsed="0.008448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:15.274116" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:15.273969" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:15.265471" elapsed="0.008733">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:15.274599" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.274787" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:15.274749" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:15.274730" elapsed="0.000122"/>
</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-06-06T03:35:15.274989" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.275059" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:15.263866" elapsed="0.011297">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.275236" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:15.213698" elapsed="0.061630">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:15.275715" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:15.275456" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:15.275433" elapsed="0.000416"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:15.275893" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:15.207446" elapsed="0.068578">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.325652" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:16.325232" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:16.326462" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:16.326209" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:16.326633" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:16.325863" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.327268" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:16.326836" elapsed="0.000460"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:16.327597" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:16.327779" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:16.327451" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.328233" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:16.327959" elapsed="0.000323"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.329270" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:16.328993" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.329761" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:16.329476" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.330131" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.330396" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.330567" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:16.329986" elapsed="0.000639"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.329842" elapsed="0.000830"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:16.330720" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:16.330897" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:16.328669" elapsed="0.002254"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:16.328359" elapsed="0.002597"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.331164" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:16.330981" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:16.328336" elapsed="0.002909"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.331849" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:16.331382" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:16.331927" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:16.324598" elapsed="0.007461"/>
</kw>
<msg time="2026-06-06T03:35:16.332117" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:16.323711" elapsed="0.008454"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.332678" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.333194" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.333905" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.334103" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.334289" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.334668" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:16.334511" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:16.334495" elapsed="0.000259"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.334892" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.335127" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.335294" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:16.334466" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.334365" elapsed="0.001010"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.335521" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.335598" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:16.335732" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:16.319322" elapsed="0.016437"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:16.337154" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:16.336900" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:16.337314" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:16.336401" elapsed="0.000938"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.337669" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:16.337412" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.338240" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:16.337925" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:16.337753" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:16.337392" elapsed="0.000931"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.340814" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:16.338474" elapsed="0.002367"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:16.340893" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:16.341057" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:16.336081" elapsed="0.005006"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:16.342323" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:16.342078" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:16.342482" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:16.341732" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:16.342736" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:16.342580" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:16.342561" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.342963" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.343178" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.343251" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:16.345388" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:16.341390" elapsed="0.004026"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.346877" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:16.346556" elapsed="0.000368"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:16.347399" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:16.347128" elapsed="0.000315"/>
</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-06-06T03:35:16.356322" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:16.356468" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:16.356566" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:16.349834" elapsed="0.007124">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:16.347512" elapsed="0.009535">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:16.357231" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:16.357082" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:16.347493" elapsed="0.009827">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:16.357703" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.357841" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:16.357802" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:16.357783" elapsed="0.000123"/>
</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-06-06T03:35:16.358051" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.358124" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:16.345737" elapsed="0.012493">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.358306" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:16.295283" elapsed="0.063119">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:16.358692" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:16.358500" elapsed="0.000267"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:16.358482" elapsed="0.000310"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:16.358827" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:16.286099" elapsed="0.072827">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.407373" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:17.406968" elapsed="0.000636"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:17.408422" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:17.408166" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:17.408596" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:17.407827" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.409192" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:17.408799" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:17.409519" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:17.409691" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:17.409375" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.410130" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:17.409872" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.411375" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:17.411114" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.411895" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:17.411579" elapsed="0.000343"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.412251" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.412452" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.412620" elapsed="0.000034"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:17.412121" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.411977" elapsed="0.000746"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:17.412770" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:17.412937" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:17.410788" elapsed="0.002175"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:17.410255" elapsed="0.002740"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.413167" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:17.413021" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:17.410232" elapsed="0.003012"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.413844" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:17.413382" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:17.413922" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:17.406345" elapsed="0.007701"/>
</kw>
<msg time="2026-06-06T03:35:17.414100" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:17.405461" elapsed="0.008686"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.414635" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.415230" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.415765" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.415948" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.416114" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.416468" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:17.416329" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:17.416313" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.416698" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.416862" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.417021" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:17.416286" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.416187" elapsed="0.000911"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.417237" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.417313" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:17.417430" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:17.401164" elapsed="0.016291"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:17.418712" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:17.418459" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:17.418869" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:17.418128" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.419204" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:17.418965" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.419791" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:17.419453" elapsed="0.000364"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:17.419284" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:17.418946" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.422426" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:17.420016" elapsed="0.002438"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:17.422543" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:17.422723" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:17.417786" elapsed="0.004963"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:17.424004" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:17.423759" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:17.424164" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:17.423387" elapsed="0.000802"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:17.424401" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:17.424262" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:17.424243" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.424623" elapsed="0.000038"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.424808" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.424875" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:17.426786" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:17.423056" elapsed="0.003757"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.428232" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:17.427977" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:17.428685" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:17.428424" elapsed="0.000306"/>
</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-06-06T03:35:17.436038" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:17.436187" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:17.436296" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:17.430857" elapsed="0.005938">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:17.428797" elapsed="0.008133">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:17.437244" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:17.436993" elapsed="0.000347"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:17.428778" elapsed="0.008596">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:17.437936" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.438124" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:17.438071" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:17.438046" elapsed="0.000168"/>
</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-06-06T03:35:17.438403" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.438499" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:17.427117" elapsed="0.011547">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.438854" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:17.377185" elapsed="0.061810">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:17.439372" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:17.439126" elapsed="0.000352"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:17.439102" elapsed="0.000409"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:17.439557" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:17.368433" elapsed="0.071338">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.485848" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:18.485423" elapsed="0.000459"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:18.486665" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:18.486389" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:18.486841" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:18.486051" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.487426" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:18.487030" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:18.487976" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:18.488151" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:18.487612" elapsed="0.000566"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.488611" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:18.488357" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.489709" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:18.489419" elapsed="0.000338"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.490193" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:18.489917" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.490557" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.490779" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.490952" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:18.490424" elapsed="0.000588"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.490278" elapsed="0.000764"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:18.491154" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:35:18.491332" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:18.489064" elapsed="0.002293"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:18.488758" elapsed="0.002633"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.491568" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:18.491418" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:18.488733" elapsed="0.002929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.492292" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:18.491804" elapsed="0.000518"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:18.492374" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:18.484793" elapsed="0.007710"/>
</kw>
<msg time="2026-06-06T03:35:18.492559" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:18.483788" elapsed="0.008822"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.493133" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.493660" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.494376" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.494565" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.494755" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.495121" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:18.494979" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:18.494963" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.495338" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.495502" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.495679" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:18.494934" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.494834" elapsed="0.000926"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.495936" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.496015" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:18.496135" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:18.479258" elapsed="0.016904"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:18.497446" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:18.497207" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:18.497615" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:18.496871" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.497986" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:18.497740" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.498563" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:18.498263" elapsed="0.000326"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:18.498067" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:18.497720" elapsed="0.000941"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.501099" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:18.498810" elapsed="0.002317"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:18.501180" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:18.501337" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:18.496529" elapsed="0.004833"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:18.502574" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:18.502336" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:18.502752" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:18.501998" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:18.502986" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:18.502848" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:18.502828" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.503216" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.503384" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.503451" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:18.505452" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:18.501676" elapsed="0.003804"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.506937" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:18.506660" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:18.507383" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:18.507135" elapsed="0.000293"/>
</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-06-06T03:35:18.515694" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:18.515891" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:18.516008" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:18.509784" elapsed="0.006638">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:18.507497" elapsed="0.009040">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:18.516836" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:18.516592" elapsed="0.000338"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:18.507478" elapsed="0.009488">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:18.517494" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.517725" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:18.517665" elapsed="0.000122"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:18.517617" elapsed="0.000202"/>
</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-06-06T03:35:18.518017" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.518118" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:18.505803" elapsed="0.012463">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.518371" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:18.456141" elapsed="0.062365">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:18.518910" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:18.518662" elapsed="0.000352"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:18.518619" elapsed="0.000429"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:18.519094" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:18.448247" elapsed="0.070994">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.566386" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:19.565989" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:19.567194" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:19.566943" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:19.567362" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:19.566590" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.568060" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:19.567652" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:19.568390" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:19.568545" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:19.568246" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.569241" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:19.568738" elapsed="0.000550"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.570268" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:19.570012" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.570756" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:19.570468" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.571111" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.571311" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.571480" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:19.570983" elapsed="0.000554"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.570840" elapsed="0.000728"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:19.571615" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:35:19.571803" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:19.569693" elapsed="0.002135"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:19.569367" elapsed="0.002493"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.572028" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:19.571886" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:19.569343" elapsed="0.002761"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.572701" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:19.572241" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:19.572801" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:19.565303" elapsed="0.007622"/>
</kw>
<msg time="2026-06-06T03:35:19.572980" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:19.564337" elapsed="0.008691"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.573529" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.574044" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.574581" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.574779" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.574946" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.575304" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:19.575165" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:19.575148" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.575523" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.575708" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.575870" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:19.575121" elapsed="0.000802"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.575021" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.576089" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.576164" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:19.576281" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:19.559946" elapsed="0.016362"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:19.577583" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:19.577339" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:19.577764" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:19.577004" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.578098" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:19.577860" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.578634" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:19.578347" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:19.578178" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:19.577841" elapsed="0.000891"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.581285" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:19.578876" elapsed="0.002436"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:19.581364" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:19.581516" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:19.576622" elapsed="0.004918"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:19.582750" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:19.582502" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:19.582945" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:19.582172" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:19.583178" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:19.583042" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:19.583023" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.583401" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.583571" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.583636" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:19.585578" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:19.581851" elapsed="0.003754"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.586995" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:19.586744" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:19.587431" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:19.587185" elapsed="0.000290"/>
</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-06-06T03:35:19.595581" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:19.595799" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:19.595939" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:19.589614" elapsed="0.006840">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:19.587540" elapsed="0.009032">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:19.596881" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:19.596621" elapsed="0.000357"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:19.587522" elapsed="0.009491">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:19.597567" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.597785" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:19.597729" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:19.597703" elapsed="0.000176"/>
</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-06-06T03:35:19.598080" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.598181" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:19.585920" elapsed="0.012411">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.598437" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:19.537433" elapsed="0.061145">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:19.599058" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:19.598802" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:19.598776" elapsed="0.000423"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:19.599247" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:19.528555" elapsed="0.070832">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.645427" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:20.645010" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:20.646224" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:20.645976" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:20.646391" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:20.645628" elapsed="0.000788"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.646981" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:20.646575" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:20.647305" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:20.647465" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:20.647163" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.647908" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:20.647658" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.648905" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:20.648634" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.649384" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:20.649105" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.649748" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.649948" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.650116" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:20.649605" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.649464" elapsed="0.000739"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:20.650249" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:20.650412" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:20.648318" elapsed="0.002120"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:20.648029" elapsed="0.002441"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.650651" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:20.650496" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:20.648006" elapsed="0.002724"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.651309" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:20.650869" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:20.651440" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:20.644383" elapsed="0.007183"/>
</kw>
<msg time="2026-06-06T03:35:20.651621" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:20.643522" elapsed="0.008161"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.652178" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.652700" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.653204" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.653413" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.653584" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.654142" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:20.653998" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:20.653982" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.654362" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.654528" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.654704" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:20.653952" elapsed="0.000808"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.653674" elapsed="0.001112"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.654928" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.655004" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:20.655122" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:20.639261" elapsed="0.015887"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:20.656407" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:20.656168" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:20.656562" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:20.655833" elapsed="0.000753"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.656917" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:20.656677" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.657486" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:20.657167" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:20.656998" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:20.656637" elapsed="0.000930"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.659909" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:20.657728" elapsed="0.002207"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:20.659985" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:20.660137" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:20.655494" elapsed="0.004667"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:20.661373" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:20.661113" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:20.661531" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:20.660785" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:20.661780" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:20.661626" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:20.661607" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.662005" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.662170" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.662236" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:20.664165" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:20.660452" elapsed="0.003739"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.665596" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:20.665314" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:20.666050" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:20.665806" elapsed="0.000288"/>
</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-06-06T03:35:20.676146" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:20.676473" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:20.676790" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:20.668380" elapsed="0.009254">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:20.666160" elapsed="0.011831">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:20.678498" elapsed="0.000054"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:20.678081" elapsed="0.000599"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:20.666141" elapsed="0.012597">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:20.679632" elapsed="0.000089"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.679978" elapsed="0.000033"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:20.679887" elapsed="0.000190"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:20.679844" elapsed="0.000284"/>
</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-06-06T03:35:20.680445" elapsed="0.000049"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.680609" elapsed="0.000062"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:20.664490" elapsed="0.016393">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.681053" elapsed="0.000036"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:20.616674" elapsed="0.064594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:20.681993" elapsed="0.000055"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:20.681568" elapsed="0.000588"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:20.681526" elapsed="0.000685"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:20.682284" elapsed="0.000031"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:20.610503" elapsed="0.071993">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.728352" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:21.727946" elapsed="0.000441"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:21.729193" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:21.728909" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:21.729368" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:21.728560" elapsed="0.000834"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.730062" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:21.729554" elapsed="0.000536"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:21.730421" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:21.730695" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:21.730259" elapsed="0.000678"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.731366" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:21.731108" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.732676" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:21.732144" elapsed="0.000579"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.733187" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:21.732881" elapsed="0.000334"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.733561" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.733784" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.734000" elapsed="0.000030"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:21.733427" elapsed="0.000649"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.733276" elapsed="0.000835"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:21.734163" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:35:21.734342" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:21.731823" elapsed="0.002546"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:21.731496" elapsed="0.002914"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.734590" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:21.734441" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:21.731470" elapsed="0.003218"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.735285" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:21.734832" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:21.735362" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:21.727249" elapsed="0.008241"/>
</kw>
<msg time="2026-06-06T03:35:21.735549" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:21.726314" elapsed="0.009286"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.736115" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.736619" elapsed="0.000041"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.737153" elapsed="0.000030"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.737423" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.737656" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.738131" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:21.737958" elapsed="0.000241"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:21.737937" elapsed="0.000291"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.738391" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.738566" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.738767" elapsed="0.000024"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:21.737868" elapsed="0.000959"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.737751" elapsed="0.001102"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.738998" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.739075" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:21.739197" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:21.721913" elapsed="0.017311"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:21.740493" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:21.740251" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:21.740676" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:21.739910" elapsed="0.000795"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.741023" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:21.740779" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.741607" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:21.741281" elapsed="0.000353"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:21.741107" elapsed="0.000590"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:21.740759" elapsed="0.000962"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.744345" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:21.741872" elapsed="0.002501"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:21.744426" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:21.744585" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:21.739544" elapsed="0.005067"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:21.745934" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:21.745629" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:21.746100" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:21.745277" elapsed="0.000850"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:21.746338" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:35:21.746199" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:21.746180" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.746608" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.746815" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.746886" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:21.748863" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:21.744943" elapsed="0.003948"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.750331" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:21.750074" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:21.750807" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:21.750526" elapsed="0.000327"/>
</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-06-06T03:35:21.758942" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:21.759083" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:21.759179" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:21.753002" elapsed="0.006577">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:21.750921" elapsed="0.008761">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:21.759864" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:21.759717" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:21.750902" elapsed="0.009049">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:21.760316" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.760447" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:21.760410" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:21.760393" elapsed="0.000116"/>
</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-06-06T03:35:21.760678" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.760752" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:21.749204" elapsed="0.011652">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.760929" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:21.699251" elapsed="0.061772">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:21.761316" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:21.761121" elapsed="0.000272"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:21.761104" elapsed="0.000314"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:21.761486" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:21.690216" elapsed="0.071372">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.808124" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:22.807720" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:22.808926" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:22.808675" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:22.809097" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:22.808324" elapsed="0.000798"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.809715" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:22.809284" elapsed="0.000460"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:22.810054" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:22.810220" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:22.809906" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.810762" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:22.810419" elapsed="0.000391"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.811808" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:22.811514" elapsed="0.000338"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.812275" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:22.812009" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.812654" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.812875" elapsed="0.000032"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.813087" elapsed="0.000024"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:22.812509" elapsed="0.000645"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.812358" elapsed="0.000832"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:22.813247" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:35:22.813438" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:22.811188" elapsed="0.002280"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:22.810891" elapsed="0.002614"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.813729" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:22.813536" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:22.810865" elapsed="0.002954"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.814535" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:22.813988" elapsed="0.000579"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:22.814623" elapsed="0.000053"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:22.807079" elapsed="0.007709"/>
</kw>
<msg time="2026-06-06T03:35:22.814924" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:22.806163" elapsed="0.008823"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.815562" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.816167" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.816996" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.817210" elapsed="0.000025"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.817408" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.817865" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:22.817696" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:22.817677" elapsed="0.000285"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.818108" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.818273" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.818435" elapsed="0.000058"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:22.817621" elapsed="0.000908"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.817502" elapsed="0.001053"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.818714" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.818793" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:35:22.818918" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:22.801780" elapsed="0.017163"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:22.820171" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:22.819929" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:22.820331" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:22.819578" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.820720" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:22.820463" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.821269" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:22.820976" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:22.820802" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:22.820443" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.823816" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:22.821496" elapsed="0.002352"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:22.823912" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:22.824104" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:22.819258" elapsed="0.004878"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:22.825590" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:22.825313" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:22.825795" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:22.824908" elapsed="0.000918"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:22.826072" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:35:22.825911" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:22.825888" elapsed="0.000285"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.826347" elapsed="0.000026"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.826573" elapsed="0.000028"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.826673" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:35:22.829116" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:22.824499" elapsed="0.004648"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.830910" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:22.830583" elapsed="0.000384"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:22.831452" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:22.831154" elapsed="0.000351"/>
</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-06-06T03:35:22.839721" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:22.839861" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:22.839956" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:22.833929" elapsed="0.006391">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:22.831585" elapsed="0.008817">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:22.840587" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:22.840435" elapsed="0.000239"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:22.831562" elapsed="0.009304">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:22.841277" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.841409" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:22.841372" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:22.841355" elapsed="0.000118"/>
</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-06-06T03:35:22.841612" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.841698" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:22.829529" elapsed="0.012274">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.841876" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:22.779029" elapsed="0.062942">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:22.842234" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:22.842063" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:22.842046" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:22.842363" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:22.770253" elapsed="0.072235">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.888433" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:23.888018" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:23.889272" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:23.889010" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:23.889447" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:23.888644" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.890065" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:23.889632" elapsed="0.000462"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:23.890411" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:23.890591" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:23.890254" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.891051" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:23.890796" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.892449" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:23.892180" elapsed="0.000315"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.893031" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:23.892747" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.893397" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.893612" elapsed="0.000034"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.893816" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:23.893263" elapsed="0.000614"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.893116" elapsed="0.000793"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:23.893957" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:23.894130" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:23.891836" elapsed="0.002320"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:23.891180" elapsed="0.003008"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.894370" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:23.894215" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:23.891155" elapsed="0.003295"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.895067" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:23.894589" elapsed="0.000507"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:23.895146" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:23.887359" elapsed="0.007922"/>
</kw>
<msg time="2026-06-06T03:35:23.895336" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:23.886313" elapsed="0.009074"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.895970" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.896486" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.897006" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.897196" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.897377" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.897760" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:23.897597" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:23.897581" elapsed="0.000303"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.898024" elapsed="0.000025"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.898204" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.898365" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:23.897553" elapsed="0.000867"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.897453" elapsed="0.000992"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.898587" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.898680" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:23.898803" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:23.881744" elapsed="0.017229"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:23.900299" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:23.900038" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:23.900467" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:23.899680" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.901048" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:23.900588" elapsed="0.000524"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.901705" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:23.901338" elapsed="0.000397"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:23.901139" elapsed="0.000632"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:23.900559" elapsed="0.001236"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.904576" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:23.901974" elapsed="0.002629"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:23.904681" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:23.904847" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:23.899301" elapsed="0.005571"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:23.906240" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:23.905971" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:23.906432" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:23.905554" elapsed="0.000903"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:23.906697" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:35:23.906531" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:23.906511" elapsed="0.000273"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.906927" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.907122" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.907190" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:23.909273" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:23.905182" elapsed="0.004192"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.910995" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:23.910605" elapsed="0.000463"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:23.911610" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:23.911276" elapsed="0.000428"/>
</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-06-06T03:35:23.919960" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:23.920167" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:23.920293" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:23.914116" elapsed="0.006673">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:23.911803" elapsed="0.009115">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:23.921227" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:23.920972" elapsed="0.000356"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:23.911773" elapsed="0.009591">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:23.921999" elapsed="0.000042"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.922211" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:23.922150" elapsed="0.000127"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:23.922123" elapsed="0.000188"/>
</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-06-06T03:35:23.922516" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.922618" elapsed="0.000028"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:23.909724" elapsed="0.013098">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.922990" elapsed="0.000033"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:23.858869" elapsed="0.064305">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:23.923620" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:23.923318" elapsed="0.000447"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:23.923292" elapsed="0.000509"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:23.923851" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:23.850942" elapsed="0.073055">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.969509" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:24.969115" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:24.970337" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:24.970084" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:24.970517" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:24.969751" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.971113" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:24.970720" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:24.971450" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:24.971648" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:24.971305" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.972087" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:24.971839" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.973112" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:24.972846" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.973578" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:24.973311" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.974011" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.974212" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.974381" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:24.973876" elapsed="0.000563"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:24.973711" elapsed="0.000758"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:24.974515" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:24.974702" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:24.972501" elapsed="0.002227"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:24.972210" elapsed="0.002551"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.974927" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:24.974786" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:24.972187" elapsed="0.002833"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.975607" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:24.975159" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:24.975705" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:24.968483" elapsed="0.007347"/>
</kw>
<msg time="2026-06-06T03:35:24.975884" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:24.967589" elapsed="0.008343"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.976482" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.977184" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.977715" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.977923" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.978097" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.978454" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:24.978316" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:24.978301" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.978694" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.978875" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.979034" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:24.978274" elapsed="0.000812"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:24.978176" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.979249" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:24.979323" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:24.979438" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:24.963259" elapsed="0.016205"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:24.980695" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:24.980445" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:24.980853" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:24.980113" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.981186" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:24.980948" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.981787" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:24.981472" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:24.981300" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:24.980930" elapsed="0.000991"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.984305" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:24.982071" elapsed="0.002261"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:24.984384" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:24.984537" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:24.979791" elapsed="0.004771"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:24.985802" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:24.985546" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:24.985987" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:24.985205" elapsed="0.000808"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:24.986234" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:24.986094" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:24.986071" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.986467" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:24.986632" elapsed="0.000045"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:24.986736" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:35:24.990303" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:24.984886" elapsed="0.005445"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.991749" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:24.991478" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:24.992205" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:24.991945" elapsed="0.000306"/>
</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-06-06T03:35:25.000437" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:25.000612" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:25.000783" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:24.994442" elapsed="0.006840">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:24.992319" elapsed="0.009075">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:25.001651" elapsed="0.000050"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:25.001440" elapsed="0.000322"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:24.992300" elapsed="0.009495">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:25.002348" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:25.002582" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:25.002529" elapsed="0.000119"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:25.002502" 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-06-06T03:35:25.002915" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:25.003013" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:24.990630" elapsed="0.012525">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:25.003258" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:24.940326" elapsed="0.063061">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:25.003803" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:25.003528" elapsed="0.000376"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:25.003504" elapsed="0.000434"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:25.003982" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:24.934038" elapsed="0.070074">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.049745" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:26.049323" elapsed="0.000457"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:26.050556" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:26.050293" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:26.050780" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:26.049958" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.051370" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:26.050975" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:26.051720" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:26.051896" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:26.051556" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.052328" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:26.052078" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.053454" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:26.053142" elapsed="0.000390"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.054078" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:26.053778" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.054442" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.054742" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.054911" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:26.054311" elapsed="0.000658"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.054164" elapsed="0.000836"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:26.055049" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:26.055219" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:26.052781" elapsed="0.002463"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:26.052455" elapsed="0.002822"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.055444" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:26.055302" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:26.052430" elapsed="0.003090"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.056290" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:26.055674" elapsed="0.000645"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:26.056368" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:26.048677" elapsed="0.007816"/>
</kw>
<msg time="2026-06-06T03:35:26.056549" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:26.047708" elapsed="0.008892"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.057244" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.057774" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.058266" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.058446" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.058812" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.059183" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:26.059042" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:26.059027" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.059396" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.059595" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.059782" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:26.058998" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.058895" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.060000" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.060074" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:26.060197" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:26.042785" elapsed="0.017437"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:26.061848" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:26.061332" elapsed="0.000593">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:26.062021" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:26.060879" elapsed="0.001167"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.062365" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:26.062118" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.063027" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:26.062621" elapsed="0.000434"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:26.062447" elapsed="0.000646"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:26.062099" elapsed="0.001016"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.065810" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:26.063265" elapsed="0.002573"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:26.065894" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:26.066058" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:26.060536" elapsed="0.005547"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:26.067412" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:26.067162" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:26.067575" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:26.066812" elapsed="0.000788"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:26.067853" elapsed="0.000032"/>
</return>
<status status="PASS" start="2026-06-06T03:35:26.067691" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:26.067669" elapsed="0.000293"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.068151" elapsed="0.000027"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.068361" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.068458" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:35:26.070748" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:26.066397" elapsed="0.004380"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.072463" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:26.072113" elapsed="0.000399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:26.072931" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:26.072681" elapsed="0.000294"/>
</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-06-06T03:35:26.085377" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:26.085524" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:26.085706" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:26.075183" elapsed="0.011064">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:26.073045" elapsed="0.013325">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:26.086682" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:26.086422" elapsed="0.000359"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:26.073024" elapsed="0.013793">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:26.087387" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.087588" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:26.087529" elapsed="0.000143"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:26.087502" elapsed="0.000206"/>
</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-06-06T03:35:26.087913" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.088015" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:26.071257" elapsed="0.016912">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.088277" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:26.019420" elapsed="0.068997">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:26.088835" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:26.088553" elapsed="0.000389"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:26.088528" elapsed="0.000450"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:26.089025" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:26.013076" elapsed="0.076091">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.138168" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:27.137601" elapsed="0.000693"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:27.139133" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:27.138857" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:27.139315" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:27.138482" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.139940" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:27.139508" elapsed="0.000460"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:27.140284" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:27.140453" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:27.140133" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.140992" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:27.140672" elapsed="0.000375"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.142148" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:27.141854" elapsed="0.000342"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.142676" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:27.142370" elapsed="0.000337"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.143056" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.143263" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.143437" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:27.142920" elapsed="0.000575"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.142768" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:27.143577" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:35:27.143787" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:27.141465" elapsed="0.002349"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:27.141133" elapsed="0.002715"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.144020" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:27.143874" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:27.141105" elapsed="0.002994"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.144756" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:27.144245" elapsed="0.000540"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:27.144836" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:27.136974" elapsed="0.007990"/>
</kw>
<msg time="2026-06-06T03:35:27.145021" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:27.135971" elapsed="0.009108"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.145611" elapsed="0.000038"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.146365" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.147309" elapsed="0.000035"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.147553" elapsed="0.000027"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.147796" elapsed="0.000030"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.148284" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:27.148091" elapsed="0.000272"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:27.148071" elapsed="0.000326"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.148586" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.148827" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.149051" elapsed="0.000029"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:27.148032" elapsed="0.001093"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.147899" elapsed="0.001262"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.149355" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.149458" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:35:27.149614" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:27.131376" elapsed="0.018292"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:27.151333" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:27.151019" elapsed="0.000402">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:27.151544" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:27.150543" elapsed="0.001035"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.151994" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:27.151690" elapsed="0.000376"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.152727" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:27.152328" elapsed="0.000434"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:27.152100" elapsed="0.000708"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:27.151649" elapsed="0.001187"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.156116" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:27.153037" elapsed="0.003113"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:27.156264" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:35:27.156473" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:27.150078" elapsed="0.006429"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:27.158122" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:27.157819" elapsed="0.000384">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:27.158348" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:27.157359" elapsed="0.001024"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:27.158654" elapsed="0.000052"/>
</return>
<status status="PASS" start="2026-06-06T03:35:27.158477" elapsed="0.000276"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:27.158452" elapsed="0.000334"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.158972" elapsed="0.000028"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.159193" elapsed="0.000029"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.159283" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:35:27.161970" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:27.156937" elapsed="0.005070"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.164134" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:27.163582" elapsed="0.000616"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:27.164756" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:27.164401" elapsed="0.000415"/>
</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-06-06T03:35:27.174806" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:27.175003" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:27.175160" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:27.168337" elapsed="0.007435">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:27.164906" elapsed="0.010985">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:27.176173" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:27.175942" elapsed="0.000323"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:27.164880" elapsed="0.011419">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:27.176880" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.177072" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:27.177018" elapsed="0.000115"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:27.176991" elapsed="0.000172"/>
</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-06-06T03:35:27.177357" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.177456" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:27.162463" elapsed="0.015142">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.177802" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:27.107487" elapsed="0.070452">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:27.178304" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:27.178060" elapsed="0.000344"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:27.178038" elapsed="0.000399"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:27.178484" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:27.097803" elapsed="0.080969">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.228744" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:28.228316" elapsed="0.000464"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:28.229593" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:28.229337" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:28.229785" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:28.228993" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.230360" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:28.229971" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:28.230704" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:28.230871" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:28.230542" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.231299" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:28.231049" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.232556" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:28.232294" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.233075" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:28.232776" elapsed="0.000326"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.233438" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.233638" elapsed="0.000040"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.233825" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:28.233305" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.233160" elapsed="0.000753"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:28.234020" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:28.234192" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:28.231968" elapsed="0.002249"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:28.231424" elapsed="0.002825"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.234416" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:28.234275" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:28.231400" elapsed="0.003093"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.235101" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:28.234629" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:28.235179" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:28.227708" elapsed="0.007596"/>
</kw>
<msg time="2026-06-06T03:35:28.235358" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:28.226824" elapsed="0.008582"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.235909" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.236408" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.236929" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.237131" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.237297" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.237647" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:28.237508" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:28.237494" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.237886" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.238047" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.238205" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:28.237467" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.237370" elapsed="0.000911"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.238455" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.238532" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:28.238665" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:28.222500" elapsed="0.016193"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:28.239915" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:28.239678" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:28.240071" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:28.239326" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.240405" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:28.240165" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.240968" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:28.240673" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:28.240486" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:28.240147" elapsed="0.000933"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.243610" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:28.241226" elapsed="0.002411"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:28.243705" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:28.243859" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:28.239009" elapsed="0.004875"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:28.245112" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:28.244852" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:28.245279" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:28.244497" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:28.245509" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:28.245373" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:28.245355" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.245754" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.245922" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.245988" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:28.247956" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:28.244179" elapsed="0.003804"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.249468" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:28.249196" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:28.249927" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:28.249680" elapsed="0.000291"/>
</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-06-06T03:35:28.258713" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:28.258959" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:28.259096" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:28.252109" elapsed="0.007540">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:28.250038" elapsed="0.009746">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:28.260038" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:28.259830" elapsed="0.000298"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:28.250020" elapsed="0.010141">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:28.260686" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.260878" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:28.260824" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:28.260799" elapsed="0.000169"/>
</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-06-06T03:35:28.261165" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.261265" elapsed="0.000057"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:28.248314" elapsed="0.013143">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.261562" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:28.194824" elapsed="0.066900">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:28.262127" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:28.261886" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:28.261857" elapsed="0.000404"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:28.262307" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:28.188427" elapsed="0.074014">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.310682" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:29.310262" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:29.311473" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:29.311221" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:29.311645" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:29.310887" elapsed="0.000797"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.312315" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:29.311919" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:29.312646" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:29.312821" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:29.312500" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.313255" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:29.313004" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.314325" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:29.314067" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.314813" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:29.314522" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.315181" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.315392" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.315563" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:29.315046" elapsed="0.000574"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.314894" elapsed="0.000773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:29.315715" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:29.315880" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:29.313695" elapsed="0.002210"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:29.313379" elapsed="0.002559"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.316103" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:29.315963" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:29.313356" elapsed="0.002824"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.316774" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:29.316316" elapsed="0.000486"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:29.316851" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:29.309614" elapsed="0.007359"/>
</kw>
<msg time="2026-06-06T03:35:29.317027" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:29.308723" elapsed="0.008351"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.317558" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.318114" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.318849" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.319035" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.319204" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.319558" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:29.319421" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:29.319405" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.319790" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.319949" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.320105" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:29.319378" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.319279" elapsed="0.000910"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.320327" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.320401" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:29.320516" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:29.304315" elapsed="0.016227"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:29.321758" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:29.321507" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:29.322002" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:29.321179" elapsed="0.000850"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.322343" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:29.322103" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.322904" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:29.322589" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:29.322423" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:29.322084" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.325323" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:29.323128" elapsed="0.002222"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:29.325401" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:29.325559" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:29.320865" elapsed="0.004719"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:29.326816" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:29.326559" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:29.327008" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:29.326234" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:29.327239" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:29.327104" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:29.327086" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.327460" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.327621" elapsed="0.000025"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.327706" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:29.329599" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:29.325894" elapsed="0.003731"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.331047" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:29.330799" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:29.331490" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:29.331246" elapsed="0.000288"/>
</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-06-06T03:35:29.339763" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:29.339953" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:29.340097" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:29.333895" elapsed="0.006702">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:29.331599" elapsed="0.009140">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:29.341009" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:29.340794" elapsed="0.000306"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:29.331581" elapsed="0.009553">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:29.341688" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.341877" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:29.341824" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:29.341799" elapsed="0.000167"/>
</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-06-06T03:35:29.342192" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.342291" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:29.329975" elapsed="0.012460">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.342539" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:29.279641" elapsed="0.063057">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:29.343148" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:29.342906" elapsed="0.000355"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:29.342881" elapsed="0.000414"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:29.343341" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:29.272566" elapsed="0.070909">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.389122" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:30.388672" elapsed="0.000483"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:30.390067" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:30.389682" elapsed="0.000494">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:30.390319" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:30.389326" elapsed="0.001030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.391216" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:30.390589" elapsed="0.000668"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:30.391714" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:30.391938" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:30.391484" elapsed="0.000493"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.392878" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:30.392198" elapsed="0.000751"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.394295" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:30.394035" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.394787" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:30.394497" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.395151" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.395350" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.395517" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:30.395022" elapsed="0.000551"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.394876" elapsed="0.000729"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:30.395670" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:35:30.395846" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:30.393615" elapsed="0.002256"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:30.393112" elapsed="0.002791"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.396070" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:30.395929" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:30.393078" elapsed="0.003067"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.396834" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:30.396301" elapsed="0.000688"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:30.397081" elapsed="0.000034"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:30.388029" elapsed="0.009188"/>
</kw>
<msg time="2026-06-06T03:35:30.397274" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:30.387095" elapsed="0.010231"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.397848" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.398350" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.398866" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.399050" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.399221" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.399579" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:30.399440" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:30.399425" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.399825" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.399988" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.400147" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:30.399396" elapsed="0.000805"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.399298" elapsed="0.000929"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.400366" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.400442" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:30.400563" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:30.382604" elapsed="0.017985"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:30.402013" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:30.401747" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:30.402180" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:30.401381" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.402528" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:30.402283" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.403103" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:30.402806" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:30.402610" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:30.402264" elapsed="0.000922"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.407302" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:30.403328" elapsed="0.004005"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:30.407394" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:35:30.407564" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:30.400990" elapsed="0.006599"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:30.408910" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:30.408630" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:30.409073" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:30.408282" elapsed="0.000816"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:30.409373" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:30.409227" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:30.409206" elapsed="0.000251"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.409598" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.409780" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.409851" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:30.411769" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:30.407939" elapsed="0.003857"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.413246" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:30.412945" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:30.413709" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:30.413445" elapsed="0.000309"/>
</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-06-06T03:35:30.421940" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:30.422091" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:30.422222" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:30.415912" elapsed="0.006707">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:30.413822" elapsed="0.008973">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:30.423023" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:30.422840" elapsed="0.000249"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:30.413803" elapsed="0.009310">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:30.423524" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.423682" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:30.423624" elapsed="0.000104"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:30.423605" elapsed="0.000145"/>
</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-06-06T03:35:30.423888" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.423960" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:30.412104" elapsed="0.011963">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.424142" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:30.360013" elapsed="0.064223">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:30.424504" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:30.424328" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:30.424311" elapsed="0.000291"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:30.424634" elapsed="0.000030"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:30.351514" elapsed="0.073234">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.470248" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:31.469836" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:31.471063" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:31.470810" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:31.471250" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:31.470450" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.471836" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:31.471431" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:31.472172" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:31.472335" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:31.472016" elapsed="0.000399"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.472845" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:31.472567" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.473862" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:31.473577" elapsed="0.000331"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.474341" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:31.474061" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.474711" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.474939" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.475110" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:31.474565" elapsed="0.000615"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.474423" elapsed="0.000787"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:31.475257" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:31.475421" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:31.473264" elapsed="0.002183"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:31.472970" elapsed="0.002510"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.475660" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:31.475505" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:31.472945" elapsed="0.002795"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.476326" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:31.475885" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:31.476417" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:31.469192" elapsed="0.007348"/>
</kw>
<msg time="2026-06-06T03:35:31.476596" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:31.468287" elapsed="0.008360"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.477170" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.477698" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.478209" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.478423" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.478606" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.479178" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:31.479036" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:31.479020" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.479395" elapsed="0.000033"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.479572" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.479750" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:31.478990" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.478698" elapsed="0.001134"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.479978" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.480064" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:31.480182" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:31.463902" elapsed="0.016307"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:31.481432" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:31.481198" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:31.481600" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:31.480865" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.481959" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:31.481722" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.482525" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:31.482224" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:31.482039" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:31.481694" elapsed="0.000912"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.485099" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:31.482778" elapsed="0.002348"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:31.485176" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:31.485327" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:31.480519" elapsed="0.004832"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:31.486573" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:31.486328" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:31.486755" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:31.485991" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:31.487013" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:31.486851" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:31.486832" elapsed="0.000264"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.487272" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.487437" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.487503" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:31.489470" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:31.485646" elapsed="0.003850"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.490892" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:31.490627" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:31.491359" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:31.491119" elapsed="0.000295"/>
</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-06-06T03:35:31.499892" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:31.500187" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:31.500414" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:31.493755" elapsed="0.007633">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:31.491480" elapsed="0.010106">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:31.502096" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:31.501723" elapsed="0.000535"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:31.491462" elapsed="0.010854">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:31.503294" elapsed="0.000062"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.503617" elapsed="0.000064"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:31.503525" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:31.503482" elapsed="0.000325"/>
</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-06-06T03:35:31.504000" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.504099" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:31.489821" elapsed="0.014421">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.504345" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:31.441026" elapsed="0.063450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:31.504870" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:31.504603" elapsed="0.000369"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:31.504580" elapsed="0.000426"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:31.505100" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:31.434747" elapsed="0.070491">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.552839" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:32.552350" elapsed="0.000540"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:32.553868" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:32.553503" elapsed="0.000468">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:32.554113" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:32.553106" elapsed="0.001039"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.554946" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:32.554380" elapsed="0.000603"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:32.555443" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:32.555686" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:32.555202" elapsed="0.000514"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.556203" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:32.555913" elapsed="0.000352"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.557659" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:32.557377" elapsed="0.000333"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.558160" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:32.557871" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.558534" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.558757" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.558935" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:32.558400" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.558247" elapsed="0.000778"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:32.559090" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:32.559262" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:32.557028" elapsed="0.002259"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:32.556371" elapsed="0.002948"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.559527" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:32.559346" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:32.556339" elapsed="0.003267"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.560241" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:32.559762" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:32.560319" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:32.551612" elapsed="0.008833"/>
</kw>
<msg time="2026-06-06T03:35:32.560576" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:32.550512" elapsed="0.010115"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.561217" elapsed="0.000033"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.561868" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.562377" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.562561" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.562749" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.563110" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:32.562970" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:32.562954" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.563325" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.563597" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.563813" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:32.562926" elapsed="0.000950"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.562828" elapsed="0.001074"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.564092" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.564197" elapsed="0.000019"/>
</return>
<msg time="2026-06-06T03:35:32.564330" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:32.545114" elapsed="0.019243"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:32.565709" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:32.565448" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:32.565871" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:32.565081" elapsed="0.000814"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.566305" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:32.566030" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.566887" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:32.566564" elapsed="0.000355"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:32.566390" elapsed="0.000564"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:32.566010" elapsed="0.000966"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.569669" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:32.567135" elapsed="0.002563"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:32.569752" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:32.569911" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:32.564715" elapsed="0.005222"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:32.571255" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:32.571003" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:32.571415" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:32.570616" elapsed="0.000824"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:32.571757" elapsed="0.000039"/>
</return>
<status status="PASS" start="2026-06-06T03:35:32.571589" elapsed="0.000243"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:32.571565" elapsed="0.000293"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.572003" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.572170" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.572236" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:32.574159" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:32.570241" elapsed="0.003947"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.575636" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:32.575340" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:32.576109" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:32.575858" elapsed="0.000295"/>
</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-06-06T03:35:32.584329" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:32.584604" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:32.584857" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:32.578371" elapsed="0.007255">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:32.576222" elapsed="0.009621">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:32.586297" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:32.585926" elapsed="0.000519"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:32.576203" elapsed="0.010294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:32.587567" elapsed="0.000150"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.587945" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:32.587884" elapsed="0.000120"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:32.587844" elapsed="0.000191"/>
</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-06-06T03:35:32.588234" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.588332" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:32.574494" elapsed="0.013986">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.588584" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:32.521751" elapsed="0.066990">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:32.589117" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:32.588872" elapsed="0.000345"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:32.588847" elapsed="0.000404"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:32.589297" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:32.514920" elapsed="0.074511">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.633602" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:33.633183" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:33.634494" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:33.634209" elapsed="0.000367">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:33.634711" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:33.633846" elapsed="0.000893"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.635371" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:33.634948" elapsed="0.000452"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:33.635730" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:33.635907" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:33.635562" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.636349" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:33.636092" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.637488" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:33.637201" elapsed="0.000335"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.638088" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:33.637796" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.638456" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.638687" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.638863" elapsed="0.000061"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:33.638324" elapsed="0.000642"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.638175" elapsed="0.000826"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:33.639061" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:35:33.639246" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:33.636856" elapsed="0.002421"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:33.636481" elapsed="0.002836"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.639497" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:33.639348" elapsed="0.000205"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:33.636456" elapsed="0.003118"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.640221" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:33.639742" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:33.640300" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:33.632504" elapsed="0.007924"/>
</kw>
<msg time="2026-06-06T03:35:33.640486" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:33.631512" elapsed="0.009031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.641105" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.641625" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.642424" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.642622" elapsed="0.000041"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.642821" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.643222" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:33.643081" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:33.643063" elapsed="0.000294"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.643494" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.643674" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.643836" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:33.643031" elapsed="0.000860"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.642903" elapsed="0.001014"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.644059" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.644135" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:33.644261" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:33.626911" elapsed="0.017376"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:33.645591" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:33.645320" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:33.645780" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:33.644964" elapsed="0.000841"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.646127" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:33.645877" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.646714" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:33.646392" elapsed="0.000349"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:33.646207" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:33.645857" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.649306" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:33.647040" elapsed="0.002294"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:33.649390" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:33.649553" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:33.644605" elapsed="0.004974"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:33.650879" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:33.650594" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:33.651094" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:33.650253" elapsed="0.000866"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:33.651342" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:33.651193" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:33.651173" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.651571" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.651755" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.651822" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:33.653841" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:33.649914" elapsed="0.004028"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.655466" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:33.655183" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:33.655929" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:33.655681" elapsed="0.000292"/>
</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-06-06T03:35:33.665454" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:33.665603" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:33.665744" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:33.659230" elapsed="0.006905">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:33.656047" elapsed="0.010178">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:33.666434" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:33.666263" elapsed="0.000237"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:33.656025" elapsed="0.010500">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:33.666953" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.667135" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:33.667053" elapsed="0.000128"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:33.667034" elapsed="0.000169"/>
</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-06-06T03:35:33.667343" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.667413" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:33.654285" elapsed="0.013236">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.667597" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:33.603493" elapsed="0.064217">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:33.668027" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:33.667805" elapsed="0.000330"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:33.667787" elapsed="0.000384"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:33.668219" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:33.596339" elapsed="0.072021">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.712805" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:34.712386" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:34.713690" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:34.713342" elapsed="0.000426">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:34.713865" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:34.713010" elapsed="0.000880"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.714438" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:34.714054" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:34.714780" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:34.715055" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:34.714618" elapsed="0.000465"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.715483" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:34.715235" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.716743" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:34.716464" elapsed="0.000325"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.717212" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:34.716943" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.717602" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.717819" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.717992" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:34.717433" elapsed="0.000616"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.717292" elapsed="0.000787"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:34.718125" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:34.718290" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:34.716144" elapsed="0.002171"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:34.715605" elapsed="0.002743"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.718514" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:34.718373" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:34.715583" elapsed="0.003006"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.719199" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:34.718757" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:34.719275" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:34.711766" elapsed="0.007631"/>
</kw>
<msg time="2026-06-06T03:35:34.719451" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:34.710840" elapsed="0.008656"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.720093" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.720595" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.721101" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.721279" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.721445" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.721838" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:34.721699" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:34.721683" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.722051" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.722210" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.722368" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:34.721641" elapsed="0.000779"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.721543" elapsed="0.000903"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.722585" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.722675" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:34.722794" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:34.706480" elapsed="0.016340"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:34.724035" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:34.723796" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:34.724191" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:34.723448" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.724529" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:34.724290" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.725126" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:34.724834" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:34.724645" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:34.724266" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.727777" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:34.725352" elapsed="0.002452"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:34.727856" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:34.728008" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:34.723130" elapsed="0.004903"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:34.729216" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:34.728986" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:34.729371" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:34.728644" elapsed="0.000751"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:34.729615" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:34.729464" elapsed="0.000224"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:34.729446" elapsed="0.000267"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.729853" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.730017" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.730082" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:34.731992" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:34.728324" elapsed="0.003695"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.733395" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:34.733142" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:34.733872" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:34.733613" elapsed="0.000303"/>
</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-06-06T03:35:34.741800" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:34.741937" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:34.742071" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:34.736057" elapsed="0.006503">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:34.733981" elapsed="0.008716">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:34.742955" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:34.742745" elapsed="0.000300"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:34.733963" elapsed="0.009115">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:34.743575" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.743829" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:34.743777" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:34.743750" elapsed="0.000169"/>
</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-06-06T03:35:34.744111" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.744209" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:34.732317" elapsed="0.012033">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.744453" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:34.684088" elapsed="0.060497">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:34.744979" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:34.744737" elapsed="0.000342"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:34.744712" elapsed="0.000401"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:34.745157" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:34.677896" elapsed="0.067392">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.792749" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:35.792310" elapsed="0.000473"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:35.793575" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:35.793300" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:35.793771" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:35.792957" elapsed="0.000839"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.794352" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:35.793960" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:35.794711" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:35.794882" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:35.794544" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.795343" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:35.795063" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.796398" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:35.796134" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.796912" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:35.796616" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.797334" elapsed="0.000026"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.797618" elapsed="0.000042"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.797812" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:35.797168" elapsed="0.000702"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.796999" elapsed="0.000901"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:35.797948" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:35.798120" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:35.795808" elapsed="0.002339"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:35.795479" elapsed="0.002701"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.798348" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:35.798206" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:35.795453" elapsed="0.002978"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.799056" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:35.798582" elapsed="0.000503"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:35.799136" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:35.791683" elapsed="0.007633"/>
</kw>
<msg time="2026-06-06T03:35:35.799375" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:35.790677" elapsed="0.008750"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.799947" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.802320" elapsed="0.000032"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.802878" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.803066" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.803234" elapsed="0.000051"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.803663" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:35.803504" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:35.803486" elapsed="0.000262"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.803885" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.804098" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.804259" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:35.803448" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.803345" elapsed="0.000993"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.804477" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.804554" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:35.804690" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:35.786106" elapsed="0.018611"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:35.805993" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:35.805739" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:35.806156" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:35.805363" elapsed="0.000819"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.806496" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:35.806253" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.807067" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:35.806772" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:35.806577" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:35.806234" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.809691" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:35.807340" elapsed="0.002382"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:35.809785" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:35:35.809964" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:35.805036" elapsed="0.004953"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:35.811219" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:35.810975" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:35.811414" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:35.810617" elapsed="0.000823"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:35.811665" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:35:35.811513" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:35.811494" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.811895" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.812060" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.812125" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:35.814191" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:35.810294" elapsed="0.003923"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.815736" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:35.815403" elapsed="0.000382"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:35.816183" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:35.815937" elapsed="0.000291"/>
</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-06-06T03:35:35.824473" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:35.824613" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:35.824743" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:35.818365" elapsed="0.006756">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:35.816295" elapsed="0.008908">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:35.825386" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:35.825236" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:35.816276" elapsed="0.009198">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:35.825865" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.825998" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:35.825961" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:35.825944" elapsed="0.000116"/>
</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-06-06T03:35:35.826197" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.826266" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:35.814520" elapsed="0.011848">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.826441" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:35.762697" elapsed="0.063836">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:35.826810" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:35.826622" elapsed="0.000260"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:35.826606" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:35.826938" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:35.754438" elapsed="0.072597">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.873895" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:36.873469" elapsed="0.000537"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:36.874854" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:36.874568" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:36.875038" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:36.874213" elapsed="0.000852"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.875661" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:36.875229" elapsed="0.000463"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:36.875998" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:36.876160" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:36.875851" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.876662" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:36.876377" elapsed="0.000335"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.878025" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:36.877736" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.878543" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:36.878243" elapsed="0.000327"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.878929" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.879133" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.879303" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:36.878794" elapsed="0.000567"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.878628" elapsed="0.000765"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:36.879453" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:36.879624" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:36.877319" elapsed="0.002349"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:36.876792" elapsed="0.002910"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.879875" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:36.879729" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:36.876767" elapsed="0.003185"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.880596" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:36.880091" elapsed="0.000534"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:36.880696" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:36.872819" elapsed="0.008006"/>
</kw>
<msg time="2026-06-06T03:35:36.880880" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:36.871866" elapsed="0.009063"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.881434" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.882012" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.882530" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.882734" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.882908" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.883269" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:36.883127" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:36.883112" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.883499" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.883685" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.883854" elapsed="0.000026"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:36.883084" elapsed="0.000833"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.882984" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.884088" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.884165" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:36.884303" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:36.867053" elapsed="0.017314"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:36.885846" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:36.885377" elapsed="0.000540">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:36.886012" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:36.885042" elapsed="0.000995"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.886352" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:36.886109" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.886969" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:36.886624" elapsed="0.000372"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:36.886444" elapsed="0.000588"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:36.886091" elapsed="0.000962"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.889732" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:36.887203" elapsed="0.002558"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:36.889853" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:36.890014" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:36.884717" elapsed="0.005323"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:36.891335" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:36.891093" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:36.891494" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:36.890744" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:36.891761" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:36.891593" elapsed="0.000229"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:36.891572" elapsed="0.000275"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.891991" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.892159" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.892226" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:36.894265" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:36.890356" elapsed="0.003936"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.895841" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:36.895532" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:36.896297" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:36.896041" elapsed="0.000312"/>
</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-06-06T03:35:36.904735" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:36.904889" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:36.905001" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:36.898693" elapsed="0.006853">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:36.896453" elapsed="0.009243">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:36.905984" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:36.905749" elapsed="0.000330"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:36.896433" elapsed="0.009680">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:36.906666" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.906864" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:36.906808" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:36.906781" elapsed="0.000174"/>
</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-06-06T03:35:36.907150" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.907249" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:36.894694" elapsed="0.012703">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.907573" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:36.843351" elapsed="0.064387">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:36.908139" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:36.907873" elapsed="0.000388"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:36.907849" elapsed="0.000448"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:36.908345" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:36.835525" elapsed="0.072998">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.953394" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:37.952994" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:37.954210" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:37.953946" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:37.954381" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:37.953594" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.954979" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:37.954564" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:37.955308" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:37.955472" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:37.955163" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.955919" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:37.955668" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.956967" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:37.956692" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.957439" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:37.957168" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.957823" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.958026" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.958196" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:37.957686" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.957520" elapsed="0.000765"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:37.958406" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:37.958579" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:37.956354" elapsed="0.002250"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:37.956045" elapsed="0.002591"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.958822" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:37.958678" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:37.956021" elapsed="0.002878"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.959485" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:37.959037" elapsed="0.000476"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:37.959563" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:37.952338" elapsed="0.007367"/>
</kw>
<msg time="2026-06-06T03:35:37.959762" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:37.951414" elapsed="0.008397"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.960312" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.960865" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.961585" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.961790" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.961959" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.962315" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:37.962176" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:37.962161" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.962528" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.962705" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.962866" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:37.962133" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.962035" elapsed="0.000909"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.963123" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.963201" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:37.963321" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:37.947040" elapsed="0.016307"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:37.964581" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:37.964338" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:37.964781" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:37.964000" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.965118" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:37.964878" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.965678" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:37.965368" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:37.965198" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:37.964859" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.968140" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:37.965907" elapsed="0.002260"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:37.968219" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:37.968373" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:37.963676" elapsed="0.004722"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:37.969627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:37.969391" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:37.969804" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:37.969062" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:37.970034" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:37.969899" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:37.969880" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.970256" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.970418" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.970483" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:37.972415" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:37.968710" elapsed="0.003732"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.973864" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:37.973594" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:37.974295" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:37.974055" 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-06-06T03:35:37.982477" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:37.982702" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:37.982816" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:37.976636" elapsed="0.006563">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:37.974403" elapsed="0.008884">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:37.983485" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:37.983323" elapsed="0.000227"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:37.974384" elapsed="0.009191">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:37.984008" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.984146" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:37.984106" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:37.984088" elapsed="0.000123"/>
</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-06-06T03:35:37.984349" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.984418" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:37.972766" elapsed="0.011757">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.984596" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:37.924343" elapsed="0.060364">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:37.985014" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:37.984802" elapsed="0.000322"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:37.984785" elapsed="0.000374"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:37.985207" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:37.916612" elapsed="0.068734">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.030682" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:39.030273" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:39.031509" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:39.031247" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:39.031700" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:39.030890" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.032357" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:39.031964" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:39.032733" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:39.032894" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:39.032541" elapsed="0.000388"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.033338" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:39.033083" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.034574" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:39.034314" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.035069" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:39.034792" elapsed="0.000309"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.035452" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.035665" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.035834" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:39.035323" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.035167" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:39.035969" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:39.036161" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:39.033987" elapsed="0.002205"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:39.033464" elapsed="0.002768"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.036403" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:39.036261" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:39.033440" elapsed="0.003037"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.037230" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:39.036613" elapsed="0.000646"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:39.037307" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:39.029663" elapsed="0.007766"/>
</kw>
<msg time="2026-06-06T03:35:39.037483" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:39.028811" elapsed="0.008719"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.038155" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.038676" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.039222" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.039402" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.039571" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.039949" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:39.039811" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:39.039796" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.040161" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.040320" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.040477" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:39.039768" elapsed="0.000761"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.039667" elapsed="0.000888"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.040746" elapsed="0.000029"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.040831" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:39.040947" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:39.024539" elapsed="0.016434"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:39.042191" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:39.041958" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:39.042347" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:39.041606" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.042694" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:39.042441" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.043232" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:39.042943" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:39.042775" elapsed="0.000517"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:39.042422" elapsed="0.000891"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.045840" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:39.043455" elapsed="0.002412"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:39.045919" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:39.046075" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:39.041290" elapsed="0.004811"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:39.047281" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:39.047051" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:39.047473" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:39.046724" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:39.047721" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:39.047567" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:39.047549" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.047942" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.048105" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.048171" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:35:39.050096" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:39.046392" elapsed="0.003731"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.051493" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:39.051246" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:39.051944" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:39.051699" elapsed="0.000288"/>
</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-06-06T03:35:39.059886" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:39.060019" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:39.060141" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:39.054188" elapsed="0.006434">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:39.052057" elapsed="0.008720">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:39.061033" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:39.060824" elapsed="0.000298"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:39.052034" elapsed="0.009121">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:39.061672" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.061867" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:39.061815" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:39.061783" elapsed="0.000172"/>
</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-06-06T03:35:39.062150" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.062247" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:39.050418" elapsed="0.011970">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.062491" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:39.002231" elapsed="0.060389">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:39.063059" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:39.062817" elapsed="0.000348"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:39.062792" elapsed="0.000407"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:39.063244" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:38.994020" elapsed="0.069355">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.109093" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:40.108695" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:40.109905" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:40.109628" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:40.110077" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:40.109299" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.110665" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:40.110265" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:40.110994" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:40.111164" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:40.110849" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.111588" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:40.111340" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.112631" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:40.112375" elapsed="0.000318"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.113123" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:40.112848" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.113476" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.113691" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.113861" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:40.113348" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.113205" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:40.113996" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:40.114160" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:40.112026" elapsed="0.002159"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:40.111730" elapsed="0.002487"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.114382" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:40.114242" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:40.111706" elapsed="0.002751"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.115052" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:40.114591" elapsed="0.000547"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:40.115191" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:40.108059" elapsed="0.007256"/>
</kw>
<msg time="2026-06-06T03:35:40.115370" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:40.107161" elapsed="0.008257"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.115925" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.116586" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.117272" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.117454" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.117621" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.117992" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:40.117854" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:40.117839" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.118203" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.118363" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.118520" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:40.117812" elapsed="0.000761"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.117714" elapsed="0.000884"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.118753" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.118835" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:40.118949" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:40.102846" elapsed="0.016128"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:40.120284" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:40.119985" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:40.120454" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:40.119634" elapsed="0.000846"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.120842" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:40.120557" elapsed="0.000343"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.121392" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:40.121097" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:40.120926" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:40.120534" elapsed="0.000950"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.123868" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:40.121635" elapsed="0.002260"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:40.123947" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:40.124098" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:40.119320" elapsed="0.004803"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:40.125331" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:40.125097" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:40.125485" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:40.124767" elapsed="0.000743"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:40.125739" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:40.125586" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:40.125562" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.125959" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.126127" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.126191" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:35:40.128100" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:40.124436" elapsed="0.003690"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.129518" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:40.129271" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:40.129966" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:40.129726" 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-06-06T03:35:40.138411" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:40.138737" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:40.138954" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:40.132289" elapsed="0.007474">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:40.130074" elapsed="0.009982">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:40.140589" elapsed="0.000051"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:40.140142" elapsed="0.000630"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:40.130055" elapsed="0.010778">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:40.141901" elapsed="0.000063"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.142217" elapsed="0.000032"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:40.142131" elapsed="0.000182"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:40.142090" elapsed="0.000272"/>
</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-06-06T03:35:40.142733" elapsed="0.000057"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.142903" elapsed="0.000033"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:40.128459" elapsed="0.014683">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.143331" elapsed="0.000048"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:40.080264" elapsed="0.063318">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:40.144331" elapsed="0.000086"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:40.143829" elapsed="0.000708"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:40.143789" elapsed="0.000804"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:40.144700" elapsed="0.000035"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:40.072601" elapsed="0.072324">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.189221" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:41.188824" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:41.190084" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:41.189772" elapsed="0.000389">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:41.190256" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:41.189423" elapsed="0.000858"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.190853" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:41.190439" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:41.191178" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:41.191372" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:41.191035" elapsed="0.000437"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.193465" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:41.191626" elapsed="0.001887"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.194537" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:41.194280" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.195027" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:41.194754" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.195423" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.195624" elapsed="0.000038"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.195808" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:41.195292" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.195111" elapsed="0.000785"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:41.195945" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:41.196115" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:41.193949" elapsed="0.002191"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:41.193593" elapsed="0.002579"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.196337" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:41.196197" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:41.193569" elapsed="0.002843"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.197022" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:41.196547" elapsed="0.000504"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:41.197100" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:41.188190" elapsed="0.009037"/>
</kw>
<msg time="2026-06-06T03:35:41.197281" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:41.187258" elapsed="0.010073"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.197843" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.198346" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.198856" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.199091" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.199293" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.199663" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:41.199513" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:41.199497" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.199879" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.200037" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.200193" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:41.199469" elapsed="0.000777"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.199369" elapsed="0.000903"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.200409" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.200483" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:41.200602" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:41.182765" elapsed="0.017863"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:41.201926" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:41.201635" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:41.202098" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:41.201290" elapsed="0.000833"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.202443" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:41.202196" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.203031" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:41.202729" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:41.202526" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:41.202175" elapsed="0.000939"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.205857" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:41.203294" elapsed="0.002593"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:41.205942" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:41.206108" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:41.200961" elapsed="0.005172"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:41.207501" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:41.207225" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:41.207693" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:41.206875" elapsed="0.000845"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:41.207933" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:41.207794" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:41.207774" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.208218" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.208385" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.208451" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:41.210493" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:41.206452" elapsed="0.004069"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.212029" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:41.211753" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:41.212476" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:41.212229" elapsed="0.000291"/>
</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-06-06T03:35:41.220628" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:41.220837" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:41.220987" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:41.214746" elapsed="0.006650">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:41.212590" elapsed="0.008907">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:41.221781" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:41.221541" elapsed="0.000310"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:41.212570" elapsed="0.009306">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:41.222310" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.222456" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:41.222413" elapsed="0.000089"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:41.222392" elapsed="0.000133"/>
</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-06-06T03:35:41.222711" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.222802" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:41.210868" elapsed="0.012080">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.223035" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:41.160049" elapsed="0.063101">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:41.223596" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:41.223325" elapsed="0.000403"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:41.223263" elapsed="0.000503"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:41.223900" elapsed="0.000024"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:41.152393" elapsed="0.071654">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.269766" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:42.269353" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:42.270581" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:42.270334" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:42.270765" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:42.269996" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.271338" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:42.270949" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:42.271679" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:42.271842" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:42.271520" elapsed="0.000349"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.272278" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:42.272019" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.273452" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:42.273165" elapsed="0.000333"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.273949" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:42.273674" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.274332" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.274533" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.274716" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:42.274201" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.274054" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:42.274852" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:42.275019" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:42.272788" elapsed="0.002256"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:42.272417" elapsed="0.002659"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.275246" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:42.275101" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:42.272390" elapsed="0.002931"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.275923" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:42.275457" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:42.276000" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:42.268745" elapsed="0.007379"/>
</kw>
<msg time="2026-06-06T03:35:42.276244" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:42.267869" elapsed="0.008425"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.276803" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.277305" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.277816" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.278034" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.278205" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.278760" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:42.278601" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:42.278585" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.278979" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.279140" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.279298" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:42.278556" elapsed="0.000795"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.278280" elapsed="0.001096"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.279515" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.279590" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:42.279722" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:42.263499" elapsed="0.016250"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:42.280974" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:42.280734" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:42.281132" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:42.280385" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.281510" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:42.281269" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.282097" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:42.281782" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:42.281590" elapsed="0.000570"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:42.281249" elapsed="0.000932"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.284540" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:42.282327" elapsed="0.002240"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:42.284618" elapsed="0.000048"/>
</return>
<msg time="2026-06-06T03:35:42.284796" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:42.280062" elapsed="0.004759"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:42.286035" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:42.285775" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:42.286195" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:42.285430" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:42.286430" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:42.286295" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:42.286277" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.286668" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.286833" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.286898" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:42.288819" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:42.285113" elapsed="0.003732"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.290226" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:42.289959" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:42.290704" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:42.290417" elapsed="0.000332"/>
</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-06-06T03:35:42.298542" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:42.298705" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:42.298802" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:42.293057" elapsed="0.006110">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:42.290815" elapsed="0.008435">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:42.299428" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:42.299282" elapsed="0.000209"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:42.290797" elapsed="0.008718">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:42.299934" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.300069" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:42.300031" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:42.300013" elapsed="0.000120"/>
</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-06-06T03:35:42.300275" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.300346" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:42.289139" elapsed="0.011311">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.300523" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:42.240599" elapsed="0.060018">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:42.300898" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:42.300726" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:42.300709" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:42.301026" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:42.232575" elapsed="0.068545">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.347166" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:43.346765" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:43.347983" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:43.347724" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:43.348155" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:43.347367" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.348758" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:43.348339" elapsed="0.000447"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:43.349083" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:43.349248" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:43.348940" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.349688" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:43.349424" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.350931" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:43.350669" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.351463" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:43.351192" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.351838" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.352039" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.352207" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:43.351707" elapsed="0.000557"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.351545" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:43.352344" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:43.352539" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:43.350334" elapsed="0.002231"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:43.349814" elapsed="0.002783"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.352780" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:43.352622" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:43.349790" elapsed="0.003066"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.353442" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:43.352991" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:43.353520" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:43.346143" elapsed="0.007517"/>
</kw>
<msg time="2026-06-06T03:35:43.353716" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:43.345269" elapsed="0.008497"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.354259" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.354779" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.355276" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.355456" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.355624" elapsed="0.000043"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.356005" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:43.355866" elapsed="0.000276"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:43.355851" elapsed="0.000317"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.356306" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.356511" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.356692" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:43.355823" elapsed="0.000924"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.355723" elapsed="0.001050"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.356915" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.356990" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:43.357108" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:43.341033" elapsed="0.016101"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:43.358399" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:43.358144" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:43.358563" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:43.357803" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.358917" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:43.358673" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.359480" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:43.359179" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:43.358998" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:43.358653" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.362128" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:43.359724" elapsed="0.002430"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:43.362206" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:43.362363" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:43.357449" elapsed="0.004938"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:43.363587" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:43.363355" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:43.363760" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:43.363028" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:43.363989" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:43.363855" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:43.363836" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.364210" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.364374" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.364438" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:35:43.366381" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:43.362706" elapsed="0.003747"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.367857" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:43.367587" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:43.368290" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:43.368048" elapsed="0.000285"/>
</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-06-06T03:35:43.376692" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:43.376831" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:43.376929" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:43.370681" elapsed="0.006629">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:43.368398" elapsed="0.008995">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:43.377578" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:43.377426" elapsed="0.000232"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:43.368379" elapsed="0.009304">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:43.378060" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.378192" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:43.378154" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:43.378136" elapsed="0.000119"/>
</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-06-06T03:35:43.378391" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.378460" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:43.366777" elapsed="0.011784">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.378634" elapsed="0.000031"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:43.318365" elapsed="0.060382">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:43.379011" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:43.378838" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:43.378821" elapsed="0.000285"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:43.379139" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:43.310636" elapsed="0.068603">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.425067" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:44.424669" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:44.425873" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:44.425606" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:44.426041" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:44.425272" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.426660" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:44.426236" elapsed="0.000453"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:44.426989" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:44.427156" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:44.426845" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.427580" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:44.427335" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.428593" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:44.428341" elapsed="0.000296"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.429077" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:44.428808" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.429427" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.429625" elapsed="0.000039"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.429813" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:44.429298" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.429157" elapsed="0.000742"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:44.429945" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:44.430111" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:44.428027" elapsed="0.002109"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:44.427722" elapsed="0.002446"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.430338" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:44.430194" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:44.427697" elapsed="0.002717"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.431075" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:44.430553" elapsed="0.000550"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:44.431154" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:44.424049" elapsed="0.007238"/>
</kw>
<msg time="2026-06-06T03:35:44.431342" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:44.423164" elapsed="0.008226"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.431955" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.432452" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.433148" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.433332" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.433500" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.433870" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:44.433731" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:44.433716" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.434083" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.434243" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.434400" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:44.433688" elapsed="0.000765"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.433575" elapsed="0.000903"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.434616" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.434722" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:44.434840" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:44.418866" elapsed="0.016000"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:44.436089" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:44.435847" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:44.436248" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:44.435497" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.436578" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:44.436343" elapsed="0.000336"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.437173" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:44.436880" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:44.436708" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:44.436323" elapsed="0.000933"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.439696" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:44.437399" elapsed="0.002328"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:44.439782" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:44.439943" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:44.435176" elapsed="0.004793"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:44.441207" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:44.440962" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:44.441367" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:44.440610" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:44.441604" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:44.441464" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:44.441444" elapsed="0.000267"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.441853" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.442022" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.442087" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:44.444026" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:44.440283" elapsed="0.003770"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.445438" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:44.445184" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:44.445890" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:44.445634" elapsed="0.000299"/>
</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-06-06T03:35:44.453699" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:44.453839" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:44.453935" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:44.448259" elapsed="0.006051">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:44.445998" elapsed="0.008395">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:44.454572" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:44.454425" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:44.445980" elapsed="0.008696">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:44.455072" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.455259" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:44.455208" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:44.455189" elapsed="0.000160"/>
</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-06-06T03:35:44.455541" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.455638" elapsed="0.000042"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:44.444357" elapsed="0.011448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.455908" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:44.396483" elapsed="0.059554">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:44.456400" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:44.456163" elapsed="0.000337"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:44.456140" elapsed="0.000393"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:44.456577" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:44.389146" elapsed="0.067585">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.503067" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:45.502610" elapsed="0.000492"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:45.503911" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:45.503632" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:45.504087" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:45.503274" elapsed="0.000839"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.504744" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:45.504282" elapsed="0.000492"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:45.505094" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:45.505261" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:45.504934" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.505785" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:45.505479" elapsed="0.000356"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.507027" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:45.506764" elapsed="0.000308"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.507499" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:45.507227" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.507876" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.508143" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.508314" elapsed="0.000027"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:45.507745" elapsed="0.000633"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.507581" elapsed="0.000829"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:45.508459" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:45.508673" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:45.506419" elapsed="0.002284"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:45.505914" elapsed="0.002822"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.508907" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:45.508761" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:45.505890" elapsed="0.003095"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.509574" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:45.509122" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:45.509670" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:45.501974" elapsed="0.007825"/>
</kw>
<msg time="2026-06-06T03:35:45.509856" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:45.501027" elapsed="0.008877"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.510395" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.510916" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.511416" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.511602" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.511792" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.512181" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:45.512038" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:45.512022" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.512401" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.512606" elapsed="0.000052"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.512811" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:45.511991" elapsed="0.000875"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.511870" elapsed="0.001022"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.513066" elapsed="0.000027"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.513152" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:45.513273" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:45.496557" elapsed="0.016743"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:45.514578" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:45.514316" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:45.514762" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:45.513971" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.515143" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:45.514877" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.515765" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:45.515416" elapsed="0.000377"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:45.515228" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:45.514855" elapsed="0.000997"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.518664" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:45.516002" elapsed="0.002692"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:45.518747" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:45.518902" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:45.513617" elapsed="0.005310"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:45.520168" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:45.519917" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:45.520331" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:45.519552" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:45.520570" elapsed="0.000030"/>
</return>
<status status="PASS" start="2026-06-06T03:35:45.520428" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:45.520409" elapsed="0.000291"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.520846" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.521012" elapsed="0.000027"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.521084" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:45.523029" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:45.519226" elapsed="0.003830"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.524524" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:45.524222" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:45.525036" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:45.524779" elapsed="0.000312"/>
</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-06-06T03:35:45.533211" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:45.533418" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:45.533571" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:45.527271" elapsed="0.006872">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:45.525175" elapsed="0.009114">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:45.534566" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:45.534342" elapsed="0.000361"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:45.525154" elapsed="0.009587">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:45.535318" elapsed="0.000048"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.535550" elapsed="0.000028"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:45.535479" elapsed="0.000151"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:45.535452" elapsed="0.000238"/>
</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-06-06T03:35:45.535902" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.536019" elapsed="0.000032"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:45.523366" elapsed="0.012830">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.536308" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:45.471103" elapsed="0.065488">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:45.537056" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:45.536803" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:45.536775" elapsed="0.000423"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:45.537245" elapsed="0.000026"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:45.462874" elapsed="0.074515">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.585245" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:46.584795" elapsed="0.000626"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:46.586222" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:46.585967" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:46.586439" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:46.585608" elapsed="0.000859"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.587059" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:46.586664" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:46.587386" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:46.587543" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:46.587242" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.587998" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:46.587746" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.589034" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:46.588774" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.589499" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:46.589233" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.589910" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.590118" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.590289" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:46.589760" elapsed="0.000588"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.589588" elapsed="0.000792"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:46.590456" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:46.590657" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:46.588427" elapsed="0.002258"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:46.588123" elapsed="0.002596"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.590891" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:46.590746" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:46.588099" elapsed="0.002881"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.591591" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:46.591119" elapsed="0.000503"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:46.591688" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:46.584125" elapsed="0.007692"/>
</kw>
<msg time="2026-06-06T03:35:46.591873" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:46.583182" elapsed="0.008738"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.592412" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.592979" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.593481" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.593711" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.593926" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.594511" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:46.594324" elapsed="0.000257"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:46.594309" elapsed="0.000299"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.594764" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.594945" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.595111" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:46.594280" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.594005" elapsed="0.001195"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.595342" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.595417" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:46.595553" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:46.578712" elapsed="0.016876"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:46.596950" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:46.596638" elapsed="0.000393">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:46.597130" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:46.596264" elapsed="0.000897"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.597549" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:46.597249" elapsed="0.000373"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.598162" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:46.597848" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:46.597670" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:46.597227" elapsed="0.001032"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.600728" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:46.598404" elapsed="0.002351"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:46.600840" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:46.600997" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:46.595925" elapsed="0.005097"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:46.602688" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:46.602408" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:46.602848" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:46.602070" elapsed="0.000803"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:46.603081" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:46.602944" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:46.602925" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.603305" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.603468" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.603535" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:46.605501" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:46.601363" elapsed="0.004165"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.607044" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:46.606755" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:46.607521" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:46.607246" elapsed="0.000327"/>
</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-06-06T03:35:46.615860" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:46.616023" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:46.616132" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:46.610020" elapsed="0.006481">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:46.607665" elapsed="0.008924">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:46.616794" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:46.616625" elapsed="0.000235"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:46.607629" elapsed="0.009255">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:46.617252" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.617391" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:46.617354" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:46.617336" elapsed="0.000119"/>
</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-06-06T03:35:46.617603" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.617693" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:46.605882" elapsed="0.011915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.617907" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:46.555900" elapsed="0.062104">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:46.618347" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:46.618122" elapsed="0.000307"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:46.618094" elapsed="0.000360"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:46.618526" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:46.548075" elapsed="0.070594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.663223" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:47.662821" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:47.664038" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:47.663774" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:47.664230" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:47.663430" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.664841" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:47.664419" elapsed="0.000449"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:47.665165" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:47.665331" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:47.665021" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.665773" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:47.665509" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.666999" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:47.666511" elapsed="0.000534"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.667471" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:47.667201" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.667843" elapsed="0.000029"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.668052" elapsed="0.000063"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.668275" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:47.667713" elapsed="0.000620"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.667554" elapsed="0.000809"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:47.668467" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:47.668652" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:47.666193" elapsed="0.002487"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:47.665900" elapsed="0.002813"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.668879" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:47.668738" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:47.665875" elapsed="0.003081"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.669536" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:47.669091" elapsed="0.000472"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:47.669612" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:47.662199" elapsed="0.007555"/>
</kw>
<msg time="2026-06-06T03:35:47.669808" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:47.661325" elapsed="0.008531"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.670341" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.670855" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.671356" elapsed="0.000023"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.671535" elapsed="0.000020"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.671716" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.672085" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:47.671933" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:47.671918" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.672309" elapsed="0.000025"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.672475" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.672633" elapsed="0.000034"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:47.671890" elapsed="0.000811"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.671791" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.672902" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.672980" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:47.673096" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:47.657048" elapsed="0.016074"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:47.674328" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:47.674095" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:47.674484" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:47.673767" elapsed="0.000742"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.674836" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:47.674581" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.675384" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:47.675087" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:47.674918" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:47.674562" elapsed="0.000905"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.678008" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:47.675610" elapsed="0.002425"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:47.678088" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:47.678243" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:47.673434" elapsed="0.004835"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:47.679474" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:47.679237" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:47.679631" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:47.678906" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:47.679880" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:47.679743" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:47.679724" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.680125" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.680292" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.680358" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:47.682295" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:47.678569" elapsed="0.003753"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.683722" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:47.683455" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:47.684187" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:47.683917" elapsed="0.000314"/>
</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-06-06T03:35:47.692071" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:47.692271" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:47.692394" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:47.686380" elapsed="0.006527">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:47.684298" elapsed="0.008722">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:47.693275" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:47.693067" elapsed="0.000299"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:47.684280" elapsed="0.009119">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:47.693926" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.694114" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:47.694061" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:47.694036" elapsed="0.000169"/>
</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-06-06T03:35:47.694399" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.694498" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:47.682630" elapsed="0.012029">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.694765" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:47.634418" elapsed="0.060480">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:47.695276" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:47.695026" elapsed="0.000351"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:47.695002" elapsed="0.000409"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:47.695590" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:47.628143" elapsed="0.067606">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.741223" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:48.740787" elapsed="0.000470"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:48.742100" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:48.741827" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:48.742271" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:48.741431" elapsed="0.000865"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.742953" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:48.742535" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:48.743281" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:48.743438" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:48.743138" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.743892" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:48.743628" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.744922" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:48.744662" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.745389" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:48.745120" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.745779" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.745979" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.746145" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:48.745634" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.745472" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:48.746282" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:48.746446" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:48.744326" elapsed="0.002146"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:48.744024" elapsed="0.002480"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.746683" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:48.746529" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:48.744000" elapsed="0.002760"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.747335" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:48.746897" elapsed="0.000466"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:48.747410" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:48.740164" elapsed="0.007369"/>
</kw>
<msg time="2026-06-06T03:35:48.747588" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:48.739277" elapsed="0.008358"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.748135" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.748688" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.749408" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.749627" elapsed="0.000037"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.749818" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.750179" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:48.750039" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:48.750023" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.750394" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.750556" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.750732" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:48.749995" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.749894" elapsed="0.000919"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.750953" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.751028" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:48.751145" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:48.734950" elapsed="0.016221"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:48.752399" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:48.752166" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:48.752555" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:48.751831" elapsed="0.000749"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.752911" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:48.752666" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.753454" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:48.753161" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:48.752993" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:48.752632" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.755945" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:48.753711" elapsed="0.002261"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:48.756024" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:48.756176" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:48.751487" elapsed="0.004714"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:48.757419" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:48.757188" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:48.757659" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:48.756858" elapsed="0.000828"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:48.757940" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:48.757800" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:48.757779" elapsed="0.000251"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.758180" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.758344" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.758409" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:48.760348" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:48.756523" elapsed="0.003852"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.761821" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:48.761521" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:48.762307" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:48.762057" elapsed="0.000294"/>
</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-06-06T03:35:48.771084" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:48.771226" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:48.771326" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:48.764685" elapsed="0.007030">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:48.762417" elapsed="0.009382">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:48.771986" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:48.771832" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:48.762399" elapsed="0.009676">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:48.772453" elapsed="0.000024"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.772586" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:48.772548" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:48.772529" elapsed="0.000136"/>
</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-06-06T03:35:48.772804" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.772874" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:48.760692" elapsed="0.012285">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.773050" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:48.712518" elapsed="0.060626">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:48.773449" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:48.773276" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:48.773258" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:48.773578" elapsed="0.000052"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:48.704492" elapsed="0.069238">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.818796" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:49.818370" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:49.819634" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:49.819370" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:49.819823" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:49.819037" elapsed="0.000811"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.820393" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:49.820006" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:49.820735" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:49.820904" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:49.820575" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.821322" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:49.821078" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.822601" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:49.822336" elapsed="0.000330"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.823126" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:49.822828" elapsed="0.000326"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.823489" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.823712" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.823892" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:49.823355" elapsed="0.000595"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.823209" elapsed="0.000771"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:49.824028" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:35:49.824199" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:49.822007" elapsed="0.002217"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:49.821450" elapsed="0.002807"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.824458" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:49.824286" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:49.821426" elapsed="0.003112"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.825180" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:49.824724" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:49.825324" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:49.817729" elapsed="0.007725"/>
</kw>
<msg time="2026-06-06T03:35:49.825510" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:49.816823" elapsed="0.008735"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.826108" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.826610" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.827186" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.827371" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.827541" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.827918" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:49.827777" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:49.827761" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.828136" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.828341" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.828503" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:49.827732" elapsed="0.000824"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.827616" elapsed="0.000966"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.828740" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.828818" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:49.828936" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:49.812500" elapsed="0.016463"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:49.830243" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:49.829996" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:49.830412" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:49.829654" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.830767" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:49.830509" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.831366" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:49.831061" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:49.830850" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:49.830489" elapsed="0.000961"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.834062" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:49.831596" elapsed="0.002494"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:49.834145" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:49.834305" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:49.829314" elapsed="0.005017"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:49.835595" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:49.835358" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:49.835773" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:49.835020" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:49.836005" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:49.835869" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:49.835850" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.836229" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.836393" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.836472" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:35:49.838430" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:49.834632" elapsed="0.003825"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.839926" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:49.839669" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:49.840362" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:49.840119" elapsed="0.000288"/>
</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-06-06T03:35:49.848358" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:49.848547" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:49.848721" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:49.842525" elapsed="0.006605">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:49.840473" elapsed="0.008813">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:49.849532" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:49.849329" elapsed="0.000273"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:49.840454" elapsed="0.009173">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:49.850058" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.850198" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:49.850159" elapsed="0.000085"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:49.850139" elapsed="0.000127"/>
</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-06-06T03:35:49.850404" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.850474" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:49.838779" elapsed="0.011803">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.850675" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:49.789876" elapsed="0.060899">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:49.851140" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:49.850869" elapsed="0.000351"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:49.850852" elapsed="0.000393"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:49.851278" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:49.783653" elapsed="0.067725">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.895266" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:50.894863" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:50.896078" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:50.895825" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:50.896292" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:50.895466" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.896887" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:50.896478" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:50.897212" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:50.897374" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:50.897070" elapsed="0.000396"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.897889" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:50.897620" elapsed="0.000317"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.898911" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:50.898634" elapsed="0.000323"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.899434" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:50.899112" elapsed="0.000350"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.899817" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.900024" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.900241" elapsed="0.000036"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:50.899681" elapsed="0.000639"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.899518" elapsed="0.000832"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:50.900398" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:50.900567" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:50.898312" elapsed="0.002281"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:50.898013" elapsed="0.002613"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.900811" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:50.900666" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:50.897990" elapsed="0.002897"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.901471" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:50.901024" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:50.901549" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:50.894228" elapsed="0.007467"/>
</kw>
<msg time="2026-06-06T03:35:50.901750" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:50.893345" elapsed="0.008454"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.902290" elapsed="0.000040"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.903022" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.903533" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.903774" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.903946" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.904362" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:50.904208" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:50.904156" elapsed="0.000288"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.904578" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.904753" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.904914" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:50.904128" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.904022" elapsed="0.000970"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.905130" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.905204" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:50.905319" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:50.889017" elapsed="0.016328"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:50.906579" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:50.906318" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:50.906763" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:50.905991" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.907093" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:50.906857" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.907657" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:50.907351" elapsed="0.000334"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:50.907173" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:50.906838" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.910124" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:50.907885" elapsed="0.002266"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:50.910202" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:35:50.910368" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:50.905668" elapsed="0.004726"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:50.911593" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:50.911344" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:50.911768" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:50.911018" elapsed="0.000774"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:50.912000" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:35:50.911864" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:50.911845" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.912351" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.912529" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.912595" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:50.916025" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:50.910701" elapsed="0.005354"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.917497" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:50.917237" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:50.917966" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:50.917710" elapsed="0.000301"/>
</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-06-06T03:35:50.924996" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:50.925130" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:50.925232" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:50.920152" elapsed="0.005448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:50.918078" elapsed="0.007625">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:50.925891" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:50.925737" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:50.918059" elapsed="0.007920">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:50.926337" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.926473" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:50.926430" elapsed="0.000085"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:50.926413" elapsed="0.000125"/>
</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-06-06T03:35:50.926689" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.926759" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:50.916394" elapsed="0.010468">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.926936" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:50.866307" elapsed="0.060721">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:50.927288" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:50.927118" elapsed="0.000241"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:50.927101" elapsed="0.000282"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:50.927456" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:50.858119" elapsed="0.069435">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.973901" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:51.973480" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:51.974766" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:51.974475" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:51.974939" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:51.974101" elapsed="0.000864"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.975515" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:51.975126" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:51.975859" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:51.976023" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:51.975715" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.976454" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:51.976202" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.977506" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:51.977216" elapsed="0.000336"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.978017" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:51.977739" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.978365" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.978565" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.978748" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:51.978236" elapsed="0.000571"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:51.978095" elapsed="0.000748"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:51.978892" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:35:51.979057" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:51.976893" elapsed="0.002189"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:51.976580" elapsed="0.002535"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.979281" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:51.979140" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:51.976557" elapsed="0.002801"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.979961" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:51.979495" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:51.980039" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:51.972817" elapsed="0.007346"/>
</kw>
<msg time="2026-06-06T03:35:51.980277" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:51.971846" elapsed="0.008483"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.980841" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.981386" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.981905" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.982088" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.982257" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.982610" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:51.982472" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:51.982456" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.982841" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.983003" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.983161" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:51.982429" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:51.982331" elapsed="0.000908"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.983376" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:51.983451" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:51.983570" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:51.967097" elapsed="0.016498"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:51.985020" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:51.984584" elapsed="0.000503">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:51.985181" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:51.984248" elapsed="0.000958"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.985579" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:51.985311" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.986189" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:51.985889" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:51.985694" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:51.985291" elapsed="0.000982"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.988635" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:51.986420" elapsed="0.002256"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:51.988729" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:51.988884" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:51.983927" elapsed="0.004982"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:51.990149" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:51.989916" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:51.990305" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:51.989561" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:51.990534" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:51.990399" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:51.990380" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.990772" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:51.990937" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:51.991002" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:51.992940" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:51.989206" elapsed="0.003761"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.994357" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:51.994107" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:51.994808" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:51.994548" elapsed="0.000304"/>
</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-06-06T03:35:52.002776" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:52.002915" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:52.003010" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:51.996991" elapsed="0.006383">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:51.994918" elapsed="0.008537">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:52.003634" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:52.003488" elapsed="0.000229"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:51.994900" elapsed="0.008840">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:52.004146" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:52.004280" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:52.004243" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:52.004225" elapsed="0.000118"/>
</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-06-06T03:35:52.004486" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:52.004556" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:51.993266" elapsed="0.011408">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:52.004750" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:51.943993" elapsed="0.060852">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:52.005111" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:52.004937" elapsed="0.000246"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:52.004920" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:52.005239" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:51.936823" elapsed="0.068510">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.051303" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:53.050902" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:53.052104" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:53.051849" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:53.052274" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:53.051504" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.052876" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:53.052470" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:53.053204" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:53.053367" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:53.053060" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.053825" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:53.053548" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.054865" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:53.054591" elapsed="0.000320"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.055396" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:53.055127" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.055775" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.055978" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.056148" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:53.055628" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.055479" elapsed="0.000757"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:53.056285" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:53.056453" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:53.054247" elapsed="0.002231"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:53.053952" elapsed="0.002558"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.056692" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:53.056535" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:53.053929" elapsed="0.002841"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.057352" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:53.056907" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:53.057429" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:53.050190" elapsed="0.007367"/>
</kw>
<msg time="2026-06-06T03:35:53.057611" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:53.049289" elapsed="0.008384"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.058163" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.058703" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.059415" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.059603" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.059790" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.060144" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:53.060006" elapsed="0.000227"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:53.059991" elapsed="0.000268"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.060410" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.060572" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.060760" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:53.059964" elapsed="0.000851"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.059865" elapsed="0.000975"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.060980" elapsed="0.000029"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.061065" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:53.061181" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:53.044978" elapsed="0.016229"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:53.062541" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:53.062234" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:53.062717" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:53.061881" elapsed="0.000861"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.063051" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:53.062813" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.063594" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:53.063303" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:53.063132" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:53.062794" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.066059" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:53.063848" elapsed="0.002238"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:53.066137" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:35:53.066290" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:53.061537" elapsed="0.004778"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:53.067577" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:53.067344" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:53.067751" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:53.067001" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:53.067994" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:53.067859" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:53.067840" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.068234" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.068398" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.068472" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:53.070514" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:53.066657" elapsed="0.003918"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.071993" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:53.071729" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:53.072427" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:53.072185" elapsed="0.000299"/>
</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-06-06T03:35:53.080878" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:53.081016" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:53.081110" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:53.074881" elapsed="0.006595">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:53.072551" elapsed="0.009009">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:53.081755" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:53.081592" elapsed="0.000229"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:53.072532" elapsed="0.009313">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:53.082213" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.082343" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:53.082307" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:53.082289" elapsed="0.000118"/>
</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-06-06T03:35:53.082566" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.082636" elapsed="0.000029"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:53.070911" elapsed="0.011844">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.082827" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:53.022210" elapsed="0.060711">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:53.083183" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:53.083012" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:53.082995" elapsed="0.000297"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:53.083325" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:53.015697" elapsed="0.067721">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.142240" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:54.141618" elapsed="0.000669"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:54.143369" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:54.143008" elapsed="0.000515">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:54.143702" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:54.142537" elapsed="0.001207"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.144591" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:54.144001" elapsed="0.000631"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:54.145013" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:54.145241" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:54.144837" elapsed="0.000443"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.145878" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:54.145500" elapsed="0.000449"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.147702" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:54.147283" elapsed="0.000487"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.148427" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:54.148008" elapsed="0.000457"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.148915" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.149175" elapsed="0.000035"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.149424" elapsed="0.000032"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:54.148773" elapsed="0.000737"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.148548" elapsed="0.001007"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:54.149629" elapsed="0.000069"/>
</return>
<msg time="2026-06-06T03:35:54.149897" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:54.146871" elapsed="0.003063"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:54.146067" elapsed="0.003914"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.150227" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:54.150021" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:54.146031" elapsed="0.004310"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.151222" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:54.150546" elapsed="0.000717"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:54.151337" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:54.140741" elapsed="0.010821"/>
</kw>
<msg time="2026-06-06T03:35:54.151665" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:54.139371" elapsed="0.012372"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.152463" elapsed="0.000031"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.153231" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.153972" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.154240" elapsed="0.000034"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.154466" elapsed="0.000023"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.155016" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:54.154804" elapsed="0.000296"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:54.154779" elapsed="0.000358"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.155338" elapsed="0.000032"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.155606" elapsed="0.000033"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.155879" elapsed="0.000033"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:54.154736" elapsed="0.001226"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.154569" elapsed="0.001432"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.156214" elapsed="0.000034"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.156320" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:35:54.156447" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:54.132998" elapsed="0.023476"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:54.158276" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:54.157922" elapsed="0.000442">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:54.158486" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:54.157398" elapsed="0.001120"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.158952" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:54.158598" elapsed="0.000481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.159888" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:54.159378" elapsed="0.000550"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:54.159124" elapsed="0.000857"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:54.158574" elapsed="0.001437"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.163589" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:54.160166" elapsed="0.003463"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:54.163724" elapsed="0.000043"/>
</return>
<msg time="2026-06-06T03:35:54.163945" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:54.156927" elapsed="0.007054"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:54.165705" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:54.165345" elapsed="0.000456">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:54.165938" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:54.164865" elapsed="0.001110"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:54.166282" elapsed="0.000036"/>
</return>
<status status="PASS" start="2026-06-06T03:35:54.166082" elapsed="0.000287"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:54.166053" elapsed="0.000356"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.166617" elapsed="0.000051"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.166882" elapsed="0.000033"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.166982" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:35:54.169378" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:54.164393" elapsed="0.005014"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.171513" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:54.171109" elapsed="0.000478"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:54.172189" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:54.171826" elapsed="0.000424"/>
</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-06-06T03:35:54.182399" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:54.182554" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:54.182691" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:54.175236" elapsed="0.007858">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:54.172341" elapsed="0.010843">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:54.183397" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:54.183220" elapsed="0.000300"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:54.172315" elapsed="0.011235">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:54.183964" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.184166" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:54.184123" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:54.184103" elapsed="0.000130"/>
</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-06-06T03:35:54.184386" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.184458" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:54.169879" elapsed="0.014712">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.184719" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:54.099492" elapsed="0.085362">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:54.185230" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:54.184985" elapsed="0.000368"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:54.184960" elapsed="0.000434"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:54.185443" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:54.089868" elapsed="0.095719">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.231427" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:55.231033" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:55.232343" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:55.232069" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:55.232542" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:55.231674" elapsed="0.000892"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.233149" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:55.232752" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:55.233476" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:55.233766" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:55.233332" elapsed="0.000462"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.234197" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:55.233946" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.235260" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:55.235004" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.235747" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:55.235456" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.236106" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.236446" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.236621" elapsed="0.000040"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:55.235975" elapsed="0.000725"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.235830" elapsed="0.000902"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:55.236780" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:55.236948" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:55.234682" elapsed="0.002291"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:55.234324" elapsed="0.002682"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.237172" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:55.237031" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:55.234296" elapsed="0.002951"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.237851" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:55.237384" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:55.237928" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:55.230416" elapsed="0.007637"/>
</kw>
<msg time="2026-06-06T03:35:55.238107" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:55.229542" elapsed="0.008613"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.238667" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.239170" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.239876" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.240066" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.240231" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.240680" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:55.240482" elapsed="0.000271"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:55.240463" elapsed="0.000318"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.240919" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.241118" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.241281" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:55.240431" elapsed="0.000903"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.240305" elapsed="0.001055"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.241498" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.241573" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:55.241712" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:55.225304" elapsed="0.016436"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:55.242989" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:55.242750" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:55.243143" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:55.242367" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.243473" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:55.243237" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.244027" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:55.243735" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:55.243553" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:55.243218" elapsed="0.000890"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.246484" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:55.244251" elapsed="0.002259"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:55.246562" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:35:55.246729" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:55.242051" elapsed="0.004703"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:55.247939" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:55.247705" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:55.248093" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:55.247359" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:55.248322" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:35:55.248188" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:55.248169" elapsed="0.000253"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.248566" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.248744" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.248810" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:55.250733" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:55.247045" elapsed="0.003714"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.252158" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:55.251870" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:55.252624" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:55.252349" elapsed="0.000335"/>
</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-06-06T03:35:55.260629" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:55.260794" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:55.260896" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:55.255093" elapsed="0.006175">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:55.252895" elapsed="0.008457">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:55.261556" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:55.261386" elapsed="0.000288"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:55.252876" elapsed="0.008834">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:55.262228" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.262413" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:55.262361" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:55.262336" elapsed="0.000166"/>
</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-06-06T03:35:55.262719" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.262819" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:55.251054" elapsed="0.011907">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.263062" elapsed="0.000067"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:55.203154" elapsed="0.060096">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:55.263620" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:55.263380" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:55.263356" elapsed="0.000419"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:55.263820" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:55.196179" elapsed="0.067772">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.309946" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:56.309530" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:56.310940" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:56.310590" elapsed="0.000435">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:56.311124" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:56.310256" elapsed="0.000894"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.311728" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:56.311318" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:56.312065" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:56.312230" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:56.311918" elapsed="0.000338"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.312874" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:56.312407" elapsed="0.000514"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.313923" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:56.313662" elapsed="0.000307"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.314392" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:56.314124" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.314760" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.314967" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.315134" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:56.314614" elapsed="0.000576"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.314472" elapsed="0.000748"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:56.315265" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:56.315428" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:56.313325" elapsed="0.002128"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:56.312999" elapsed="0.002486"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.315669" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:56.315510" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:56.312975" elapsed="0.002771"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.316332" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:56.315882" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:56.316408" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:56.308884" elapsed="0.007646"/>
</kw>
<msg time="2026-06-06T03:35:56.316584" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:56.307952" elapsed="0.008683"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.317179" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.317777" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.318274" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.318455" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.318628" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.319149" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:56.319009" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:56.318994" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.319362" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.319523" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.319699" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:56.318967" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.318720" elapsed="0.001059"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.319919" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.319993" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:56.320110" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:56.303501" elapsed="0.016634"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:56.321370" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:56.321134" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:56.321527" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:56.320787" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.321876" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:56.321621" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.322424" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:56.322133" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:56.321957" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:56.321603" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.326517" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:56.322670" elapsed="0.003875"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:56.326656" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:56.326817" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:56.320454" elapsed="0.006388"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:56.328054" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:56.327814" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:56.328211" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:56.327456" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:56.328445" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:56.328307" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:56.328289" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.328685" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.328852" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.328918" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:56.330855" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:56.327137" elapsed="0.003745"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.332253" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:56.332002" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:56.332711" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:56.332444" elapsed="0.000312"/>
</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-06-06T03:35:56.340756" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:56.340890" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:56.340994" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:56.334914" elapsed="0.006517">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:56.332822" elapsed="0.008690">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:56.341707" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:56.341545" elapsed="0.000237"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:56.332804" elapsed="0.009001">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:56.342175" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.342307" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:56.342270" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:56.342253" elapsed="0.000118"/>
</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-06-06T03:35:56.342513" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.342586" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:56.331179" elapsed="0.011526">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.342815" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:56.280136" elapsed="0.062773">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:56.343169" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:56.342999" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:56.342982" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:56.343299" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:56.273473" elapsed="0.069919">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.390117" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:57.389706" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:57.390956" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:57.390681" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:57.391137" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:57.390329" elapsed="0.000833"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.391733" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:57.391325" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:57.392113" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:57.392292" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:57.391960" elapsed="0.000358"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.392743" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:57.392473" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.393789" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:57.393494" elapsed="0.000341"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.394268" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:57.393992" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.394635" elapsed="0.000039"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.394858" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.395030" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:57.394502" elapsed="0.000587"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.394353" elapsed="0.000767"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:57.395228" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:57.395401" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:57.393176" elapsed="0.002251"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:57.392874" elapsed="0.002586"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.395631" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:57.395486" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:57.392847" elapsed="0.002879"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.396401" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:57.395865" elapsed="0.000574"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:57.396508" elapsed="0.000044"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:57.389039" elapsed="0.007681"/>
</kw>
<msg time="2026-06-06T03:35:57.396800" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:57.388050" elapsed="0.008820"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.397571" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.398228" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.398748" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.398941" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.399168" elapsed="0.000032"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.399847" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:57.399696" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:57.399678" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.400065" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.400224" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.400384" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:57.399627" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.399283" elapsed="0.001181"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.400682" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.400760" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:35:57.400882" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:57.383615" elapsed="0.017293"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:57.402219" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:57.401958" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:57.402386" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:57.401552" elapsed="0.000859"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.402751" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:57.402481" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.403296" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:57.403002" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:57.402833" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:57.402462" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.405788" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:57.403522" elapsed="0.002293"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:57.405867" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:35:57.406021" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:57.401221" elapsed="0.004825"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:57.407244" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:57.407009" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:57.407401" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:57.406676" elapsed="0.000750"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:57.407652" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:35:57.407497" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:57.407478" elapsed="0.000261"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.407880" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.408045" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.408112" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:57.410058" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:57.406340" elapsed="0.003745"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.411472" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:57.411219" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:57.411923" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:57.411680" elapsed="0.000289"/>
</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-06-06T03:35:57.420438" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:57.420711" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:57.420844" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:57.414308" elapsed="0.007024">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:57.412055" elapsed="0.009389">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:57.421735" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:57.421490" elapsed="0.000338"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:57.412031" elapsed="0.009831">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:57.422375" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.422559" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:57.422507" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:57.422483" elapsed="0.000185"/>
</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-06-06T03:35:57.422863" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.422961" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:57.410385" elapsed="0.012720">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.423207" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:57.359724" elapsed="0.063612">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:57.423728" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:57.423461" elapsed="0.000369"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:57.423438" elapsed="0.000425"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:57.423909" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:57.351109" elapsed="0.072931">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.469202" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:58.468800" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:58.470023" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:58.469759" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:58.470227" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:58.469410" elapsed="0.000844"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.470920" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:58.470505" elapsed="0.000443"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:58.471249" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:58.471408" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:58.471105" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.471860" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:58.471589" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.473177" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:58.472915" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.473669" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:58.473381" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.474026" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.474242" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.474410" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:58.473897" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.473753" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:58.474544" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:58.474729" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:58.472564" elapsed="0.002191"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:58.471989" elapsed="0.002798"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.474955" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:58.474813" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:58.471964" elapsed="0.003066"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.475617" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:58.475167" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:58.475711" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:58.468161" elapsed="0.007674"/>
</kw>
<msg time="2026-06-06T03:35:58.475890" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:58.467209" elapsed="0.008730"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.476432" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.476944" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.477498" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.477698" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.477869" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.478267" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:58.478093" elapsed="0.000232"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:58.478077" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.478484" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.478658" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.478819" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:58.478047" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.477946" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.479037" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.479113" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:58.479233" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:58.462769" elapsed="0.016490"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:58.480542" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:58.480274" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:58.480731" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:58.479924" elapsed="0.000832"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.481075" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:58.480829" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.481624" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:58.481328" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:58.481157" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:58.480809" elapsed="0.000921"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.484397" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:58.481888" elapsed="0.002537"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:58.484479" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:35:58.484655" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:58.479572" elapsed="0.005110"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:58.485937" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:58.485675" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:58.486155" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:58.485322" elapsed="0.000857"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:58.486433" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:35:58.486293" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:58.486273" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.486676" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.486846" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.486912" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:35:58.488861" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:58.484991" elapsed="0.003897"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.490312" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:58.490034" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:58.490774" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:58.490505" elapsed="0.000313"/>
</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-06-06T03:35:58.498778" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:58.498929" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:58.499045" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:58.492973" elapsed="0.006463">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:58.490885" elapsed="0.008640">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:58.499759" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:58.499562" elapsed="0.000264"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:58.490866" elapsed="0.008983">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:58.500271" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.500413" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:58.500373" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:58.500352" elapsed="0.000126"/>
</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-06-06T03:35:58.500618" elapsed="0.000037"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.500705" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:58.489198" elapsed="0.011617">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.500889" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:58.440249" elapsed="0.060733">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:58.501321" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:58.501139" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:58.501121" elapsed="0.000297"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:58.501451" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:58.433278" elapsed="0.068272">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.541881" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:59.541433" elapsed="0.000486"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:59.542726" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:59.542444" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:59.542916" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:59.542100" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.543500" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:59.543110" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:35:59.543848" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:35:59.544017" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:35:59.543700" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.544445" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:59.544194" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.545494" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:59.545234" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.545985" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:35:59.545711" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.546346" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.546546" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.546739" elapsed="0.000038"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:35:59.546215" elapsed="0.000600"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.546067" elapsed="0.000780"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:35:59.546903" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:35:59.547073" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:35:59.544908" elapsed="0.002190"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:59.544575" elapsed="0.002555"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.547297" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:59.547156" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:59.544548" elapsed="0.002825"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.547975" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:35:59.547511" elapsed="0.000551"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:35:59.548114" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:35:59.540816" elapsed="0.007425"/>
</kw>
<msg time="2026-06-06T03:35:59.548297" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:35:59.539869" elapsed="0.008476"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.548865" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.549378" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.550107" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.550294" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.550463" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.550878" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:59.550700" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:59.550684" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.551097" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.551258" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.551417" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:35:59.550654" elapsed="0.000816"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.550538" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.551634" elapsed="0.000036"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.551726" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:59.551845" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:35:59.535256" elapsed="0.016614"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:59.553221" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:59.552917" elapsed="0.000375">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:59.553384" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:59.552556" elapsed="0.000853"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.553744" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:59.553480" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.554301" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:35:59.553999" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:35:59.553827" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:59.553461" elapsed="0.000922"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.556812" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:35:59.554529" elapsed="0.002311"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:35:59.556890" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:35:59.557045" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:59.552233" elapsed="0.004837"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:35:59.558292" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:35:59.558034" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:35:59.558454" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:35:59.557703" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:35:59.558706" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:35:59.558550" elapsed="0.000252"/>
</branch>
<status status="PASS" start="2026-06-06T03:35:59.558530" elapsed="0.000304"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.558976" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.559141" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.559205" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:35:59.561148" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:35:59.557366" elapsed="0.003809"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.562572" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:59.562315" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:35:59.563039" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:35:59.562795" elapsed="0.000287"/>
</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-06-06T03:35:59.571819" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:35:59.571970" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:35:59.572081" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:35:59.565513" elapsed="0.006961">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:35:59.563148" elapsed="0.009475">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:35:59.572851" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:59.572680" elapsed="0.000238"/>
</branch>
<status status="FAIL" start="2026-06-06T03:35:59.563129" elapsed="0.009812">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:35:59.573340" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.573478" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:35:59.573437" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:59.573419" elapsed="0.000123"/>
</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-06-06T03:35:59.573697" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.573768" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:35:59.561479" elapsed="0.012394">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.573946" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:35:59.512668" elapsed="0.061372">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:35:59.574307" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:35:59.574132" elapsed="0.000246"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:35:59.574115" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:35:59.574434" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:35:59.506359" elapsed="0.068169">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.622052" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:00.621601" elapsed="0.000485"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:00.623007" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:00.622701" elapsed="0.000391">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:00.623190" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:00.622259" elapsed="0.000956"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.623921" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:00.623463" elapsed="0.000486"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:00.624268" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:00.624473" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:00.624110" elapsed="0.000456"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.625044" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:00.624781" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.626467" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:00.626163" elapsed="0.000353"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.627004" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:00.626694" elapsed="0.000339"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.627425" elapsed="0.000025"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.627634" elapsed="0.000042"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.627853" elapsed="0.000024"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:00.627274" elapsed="0.000641"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.627106" elapsed="0.000855"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:00.628012" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:36:00.628204" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:00.625803" elapsed="0.002427"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:00.625200" elapsed="0.003062"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.628465" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:00.628288" elapsed="0.000238"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:00.625173" elapsed="0.003375"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.629224" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:00.628733" elapsed="0.000533"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:00.629319" elapsed="0.000038"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:00.620908" elapsed="0.008560"/>
</kw>
<msg time="2026-06-06T03:36:00.629524" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:00.619950" elapsed="0.009623"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.630171" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.630730" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.631300" elapsed="0.000098"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.631694" elapsed="0.000032"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.631908" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.632374" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:00.632174" elapsed="0.000283"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:00.632154" elapsed="0.000339"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.632692" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.632914" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.633110" elapsed="0.000023"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:00.632118" elapsed="0.001056"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.631993" elapsed="0.001219"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.633370" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.633453" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:36:00.633631" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:00.615224" elapsed="0.018458"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:00.635227" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:00.634920" elapsed="0.000424">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:00.635450" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:00.634472" elapsed="0.001004"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.635850" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:00.635550" elapsed="0.000361"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.636495" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:00.636123" elapsed="0.000399"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:00.635936" elapsed="0.000622"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:00.635530" elapsed="0.001050"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.639309" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:00.636761" elapsed="0.002596"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:00.639414" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:36:00.639579" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:00.634083" elapsed="0.005521"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:00.640903" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:00.640634" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:00.641065" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:00.640290" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:00.641298" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:00.641161" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:00.641142" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.641598" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.641795" elapsed="0.000026"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.641873" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:36:00.643964" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:00.639946" elapsed="0.004046"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.645404" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:00.645134" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:00.645864" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:00.645599" elapsed="0.000309"/>
</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-06-06T03:36:00.653842" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:00.654024" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:00.654162" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:00.648059" elapsed="0.006658">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:00.645974" elapsed="0.008860">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:00.655105" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:00.654880" elapsed="0.000315"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:00.645956" elapsed="0.009271">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:00.655818" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.656007" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:00.655954" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:00.655929" elapsed="0.000166"/>
</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-06-06T03:36:00.656282" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.656378" elapsed="0.000035"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:00.644300" elapsed="0.012238">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.656657" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:00.590931" elapsed="0.065860">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:00.657169" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:00.656918" elapsed="0.000357"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:00.656895" elapsed="0.000414"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:00.657415" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:00.584294" elapsed="0.073258">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.703367" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:01.702950" elapsed="0.000470"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:01.704235" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:01.703976" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:01.704408" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:01.703591" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.705004" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:01.704598" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:01.705337" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:01.705505" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:01.705189" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.705966" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:01.705717" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.707013" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:01.706755" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.707500" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:01.707219" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.707893" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.708097" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.708266" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:01.707738" elapsed="0.000592"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.707581" elapsed="0.000779"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:01.708410" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:36:01.708587" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:01.706417" elapsed="0.002196"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:01.706092" elapsed="0.002571"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.708834" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:01.708690" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:01.706068" elapsed="0.002842"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.709492" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:01.709048" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:01.709572" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:01.702327" elapsed="0.007388"/>
</kw>
<msg time="2026-06-06T03:36:01.709831" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:01.701437" elapsed="0.008445"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.710380" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.712405" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.712948" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.713135" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.713305" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.713677" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:01.713523" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:01.713507" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.713902" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.714065" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.714226" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:01.713479" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.713380" elapsed="0.000926"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.714444" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.714521" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:01.714652" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:01.697131" elapsed="0.017550"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:01.715932" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:01.715659" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:01.716092" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:01.715312" elapsed="0.000806"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.716465" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:01.716222" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.717025" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:01.716731" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:01.716546" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:01.716203" elapsed="0.000907"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.719453" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:01.717255" elapsed="0.002225"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:01.719532" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:01.719704" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:01.714995" elapsed="0.004735"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:01.720937" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:01.720700" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:01.721097" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:01.720354" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:01.721330" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:01.721194" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:01.721175" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.721555" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.721744" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.721813" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:01.724056" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:01.720035" elapsed="0.004048"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.725469" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:01.725218" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:01.725926" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:01.725679" elapsed="0.000292"/>
</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-06-06T03:36:01.734551" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:01.734923" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:01.735194" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:01.728121" elapsed="0.008032">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:01.726039" elapsed="0.010300">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:01.736871" elapsed="0.000061"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:01.736413" elapsed="0.000631"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:01.726020" elapsed="0.011082">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:01.738232" elapsed="0.000066"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.738580" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:01.738484" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:01.738437" elapsed="0.000355"/>
</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-06-06T03:36:01.739173" elapsed="0.000054"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.739354" elapsed="0.000038"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:01.724383" elapsed="0.015243">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.739785" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:01.674559" elapsed="0.065354">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:01.740210" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:01.740020" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:01.740001" elapsed="0.000307"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:01.740342" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:01.667410" elapsed="0.073029">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.781572" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:02.781169" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:02.782409" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:02.782136" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:02.782581" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:02.781801" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.783184" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:02.782787" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:02.783512" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:02.783690" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:02.783369" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.784120" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:02.783871" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.785162" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:02.784902" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.785732" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:02.785440" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.786092" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.786292" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.786459" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:02.785960" elapsed="0.000556"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.785815" elapsed="0.000731"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:02.786595" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:02.786781" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:02.784565" elapsed="0.002241"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:02.784244" elapsed="0.002594"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.787004" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:02.786863" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:02.784221" elapsed="0.002859"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.787738" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:02.787216" elapsed="0.000551"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:02.787818" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:02.780280" elapsed="0.007663"/>
</kw>
<msg time="2026-06-06T03:36:02.787998" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:02.779334" elapsed="0.008712"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.788608" elapsed="0.000056"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.789160" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.789672" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.789854" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.790022" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.790376" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:02.790239" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:02.790224" elapsed="0.000270"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.790631" elapsed="0.000037"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.790812" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.790978" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:02.790196" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.790097" elapsed="0.000960"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.791210" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.791289" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:02.791408" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:02.774551" elapsed="0.016883"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:02.792925" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:02.792457" elapsed="0.000538">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:02.793090" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:02.792103" elapsed="0.001013"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.793428" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:02.793187" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.793996" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:02.793696" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:02.793510" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:02.793168" elapsed="0.000911"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.796479" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:02.794225" elapsed="0.002282"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:02.796559" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:02.796733" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:02.791778" elapsed="0.004982"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:02.798021" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:02.797779" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:02.798180" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:02.797380" elapsed="0.000824"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:02.798414" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:02.798277" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:02.798258" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.798653" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.798872" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.798952" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:02.800907" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:02.797056" elapsed="0.003913"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.802346" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:02.802093" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:02.802808" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:02.802538" elapsed="0.000315"/>
</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-06-06T03:36:02.810666" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:02.810812" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:02.810907" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:02.805023" elapsed="0.006256">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:02.802920" elapsed="0.008440">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:02.811542" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:02.811394" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:02.802901" elapsed="0.008729">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:02.812019" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.812153" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:02.812114" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:02.812096" elapsed="0.000121"/>
</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-06-06T03:36:02.812354" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.812423" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:02.801274" elapsed="0.011297">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.812659" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:02.751205" elapsed="0.061553">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:02.813133" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:02.812892" elapsed="0.000352"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:02.812868" elapsed="0.000409"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:02.813322" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:02.744962" elapsed="0.068492">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.861837" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:03.861394" elapsed="0.000478"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:03.862691" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:03.862407" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:03.862867" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:03.862058" elapsed="0.000835"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.863469" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:03.863067" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:03.863870" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:03.864042" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:03.863680" elapsed="0.000389"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.864489" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:03.864230" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.865611" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:03.865334" elapsed="0.000340"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.866112" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:03.865835" elapsed="0.000304"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.866472" elapsed="0.000025"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.866711" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.866885" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:03.866340" elapsed="0.000605"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.866194" elapsed="0.000780"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:03.867023" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:03.867192" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:03.864976" elapsed="0.002243"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:03.864665" elapsed="0.002587"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.867420" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:03.867278" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:03.864623" elapsed="0.002880"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.868125" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:03.867669" elapsed="0.000485"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:03.868203" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:03.860756" elapsed="0.007575"/>
</kw>
<msg time="2026-06-06T03:36:03.868387" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:03.859790" elapsed="0.008647"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.869035" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.869603" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.870464" elapsed="0.000034"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.870727" elapsed="0.000026"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.870912" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.871274" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:03.871134" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:03.871119" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.871492" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.871680" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.871845" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:03.871089" elapsed="0.000809"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.870989" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.872063" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.872139" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:03.872258" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:03.855288" elapsed="0.016997"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:03.873663" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:03.873378" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:03.873834" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:03.872946" elapsed="0.000912"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.874171" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:03.873930" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.874781" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:03.874460" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:03.874288" elapsed="0.000556"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:03.873910" elapsed="0.000955"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.877291" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:03.875009" elapsed="0.002309"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:03.877369" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:03.877522" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:03.872606" elapsed="0.004941"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:03.878762" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:03.878512" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:03.878919" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:03.878184" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:03.879150" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:03.879014" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:03.878995" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.879371" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.879534" elapsed="0.000027"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.879605" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:03.881564" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:03.877863" elapsed="0.003728"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.882990" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:03.882734" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:03.883419" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:03.883180" elapsed="0.000282"/>
</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-06-06T03:36:03.891306" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:03.891442" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:03.891538" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:03.885771" elapsed="0.006156">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:03.883528" elapsed="0.008481">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:03.892190" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:03.892042" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:03.883509" elapsed="0.008769">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:03.892652" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.892826" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:03.892788" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:03.892769" elapsed="0.000123"/>
</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-06-06T03:36:03.893045" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.893117" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:03.881907" elapsed="0.011313">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.893295" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:03.831315" elapsed="0.062074">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:03.893675" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:03.893481" elapsed="0.000267"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:03.893464" elapsed="0.000308"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:03.893805" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:03.823568" elapsed="0.070332">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.939319" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:04.938920" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:04.940122" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:04.939865" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:04.940293" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:04.939520" elapsed="0.000798"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.940875" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:04.940474" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:04.941196" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:04.941360" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:04.941055" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.941813" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:04.941535" elapsed="0.000325"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.943049" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:04.942783" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.943519" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:04.943250" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.943889" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.944152" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.944322" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:04.943759" elapsed="0.000622"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.943600" elapsed="0.000811"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:04.944458" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:04.944625" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:04.942442" elapsed="0.002224"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:04.941937" elapsed="0.002764"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.944869" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:04.944727" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:04.941914" elapsed="0.003033"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.945527" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:04.945082" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:04.945631" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:04.938298" elapsed="0.007475"/>
</kw>
<msg time="2026-06-06T03:36:04.945828" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:04.937358" elapsed="0.008524"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.946369" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.946882" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.947376" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.947555" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.947737" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.948090" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:04.947953" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:04.947938" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.948310" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.948514" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.948690" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:04.947910" elapsed="0.000836"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.947813" elapsed="0.000959"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.948912" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.948989" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:04.949105" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:04.933088" elapsed="0.016042"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:04.950363" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:04.950124" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:04.950522" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:04.949790" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.950874" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:04.950617" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.951416" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:04.951126" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:04.950956" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:04.950598" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.954073" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:04.951658" elapsed="0.002442"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:04.954153" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:04.954309" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:04.949442" elapsed="0.004892"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:04.955539" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:04.955304" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:04.955719" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:04.954973" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:04.955959" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:04.955816" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:04.955798" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.956181" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.956352" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.956416" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:04.958356" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:04.954635" elapsed="0.003747"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.959836" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:04.959514" elapsed="0.000370"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:04.960280" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:04.960032" elapsed="0.000293"/>
</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-06-06T03:36:04.968255" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:04.968395" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:04.968500" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:04.962489" elapsed="0.006417">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:04.960392" elapsed="0.008599">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:04.969178" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:04.969025" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:04.960373" elapsed="0.008894">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:04.969761" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.969940" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:04.969883" elapsed="0.000119"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:04.969858" elapsed="0.000177"/>
</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-06-06T03:36:04.970238" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.970341" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:04.958700" elapsed="0.011793">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.970601" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:04.910858" elapsed="0.059902">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:04.971155" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:04.970896" elapsed="0.000366"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:04.970871" elapsed="0.000426"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:04.971344" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:04.903175" elapsed="0.068307">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.018813" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:06.018387" elapsed="0.000524"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:06.019703" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:06.019428" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:06.019884" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:06.019088" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.020464" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:06.020073" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:06.020820" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:06.020981" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:06.020663" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.021420" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:06.021166" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.022506" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:06.022233" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.023021" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:06.022736" elapsed="0.000312"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.023380" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.023582" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.023770" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:06.023247" elapsed="0.000598"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.023104" elapsed="0.000773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:06.023925" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:06.024093" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:06.021861" elapsed="0.002257"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:06.021546" elapsed="0.002605"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.024319" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:06.024177" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:06.021522" elapsed="0.002876"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.025008" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:06.024541" elapsed="0.000496"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:06.025087" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:06.017696" elapsed="0.007516"/>
</kw>
<msg time="2026-06-06T03:36:06.025268" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:06.016777" elapsed="0.008539"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.025849" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.026427" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.027245" elapsed="0.000037"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.027507" elapsed="0.000030"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.027768" elapsed="0.000031"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.028270" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:06.028075" elapsed="0.000273"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:06.028052" elapsed="0.000329"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.028564" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.028818" elapsed="0.000029"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.029042" elapsed="0.000028"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:06.028013" elapsed="0.001101"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.027877" elapsed="0.001272"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.029340" elapsed="0.000027"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.029443" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:36:06.029602" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:06.012415" elapsed="0.017222"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:06.031254" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:06.031014" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:06.031413" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:06.030576" elapsed="0.000861"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.031761" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:06.031506" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.032306" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:06.032015" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:06.031843" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:06.031487" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.034926" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:06.032532" elapsed="0.002426"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:06.035057" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:06.035213" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:06.030089" elapsed="0.005148"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:06.036431" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:06.036196" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:06.036587" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:06.035867" elapsed="0.000744"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:06.036840" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:36:06.036702" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:06.036682" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.037070" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.037239" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.037307" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:06.039261" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:06.035532" elapsed="0.003756"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.040674" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:06.040403" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:06.041121" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:06.040875" elapsed="0.000289"/>
</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-06-06T03:36:06.049134" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:06.049275" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:06.049370" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:06.043468" elapsed="0.006292">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:06.041230" elapsed="0.008614">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:06.050029" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:06.049879" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:06.041211" elapsed="0.008908">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:06.050502" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.050657" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:06.050604" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:06.050584" elapsed="0.000139"/>
</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-06-06T03:36:06.050862" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.050931" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:06.039589" elapsed="0.011442">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.051138" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:05.989027" elapsed="0.062210">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:06.051505" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:06.051328" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:06.051311" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:06.051632" elapsed="0.000029"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:05.981832" elapsed="0.069913">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.098905" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:07.098309" elapsed="0.000641"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:07.100008" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:07.099664" elapsed="0.000446">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:07.100241" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:07.099178" elapsed="0.001098"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.101060" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:07.100497" elapsed="0.000601"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:07.101505" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:07.101877" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:07.101310" elapsed="0.000606"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.104297" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:07.102125" elapsed="0.002220"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.105327" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:07.105068" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.105814" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:07.105526" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.106166" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.106362" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.106529" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:07.106039" elapsed="0.000546"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.105895" elapsed="0.000721"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:07.106756" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:36:07.106937" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:07.104747" elapsed="0.002215"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:07.104430" elapsed="0.002565"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.107164" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:07.107020" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:07.104406" elapsed="0.002834"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.107868" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:07.107377" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:07.107947" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:07.097522" elapsed="0.010550"/>
</kw>
<msg time="2026-06-06T03:36:07.108125" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:07.096568" elapsed="0.011605"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.108678" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.109177" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.109691" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.109871" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.110037" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.110385" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:07.110249" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:07.110234" elapsed="0.000231"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.110597" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.110799" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.110968" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:07.110207" elapsed="0.000813"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.110111" elapsed="0.000934"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.111224" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.111301" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:07.111418" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:07.092203" elapsed="0.019241"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:07.112713" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:07.112454" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:07.112873" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:07.112125" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.113203" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:07.112967" elapsed="0.000291"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.113757" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:07.113449" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:07.113283" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:07.112949" elapsed="0.000894"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.116352" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:07.113985" elapsed="0.002394"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:07.116430" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:07.116582" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:07.111808" elapsed="0.004799"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:07.117879" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:07.117594" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:07.118047" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:07.117257" elapsed="0.000816"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:07.118282" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:07.118144" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:07.118126" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.118510" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.118724" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.118797" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:07.120813" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:07.116929" elapsed="0.003912"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.122272" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:07.122015" elapsed="0.000304"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:07.122769" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:07.122475" elapsed="0.000339"/>
</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-06-06T03:36:07.130538" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:07.130777" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:07.130897" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:07.125056" elapsed="0.006226">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:07.122883" elapsed="0.008484">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:07.131557" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:07.131401" elapsed="0.000220"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:07.122864" elapsed="0.008797">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:07.132049" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.132184" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:07.132145" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:07.132128" elapsed="0.000121"/>
</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-06-06T03:36:07.132386" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.132455" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:07.121155" elapsed="0.011405">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.132634" elapsed="0.000032"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:07.068317" elapsed="0.064430">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:07.133017" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:07.132838" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:07.132821" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:07.133146" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:07.061205" elapsed="0.072034">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.179037" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:08.178628" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:08.179911" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:08.179634" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:08.180081" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:08.179289" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.180757" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:08.180347" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:08.181090" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:08.181264" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:08.180945" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.181713" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:08.181443" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.182729" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:08.182455" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.183203" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:08.182932" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.183579" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.183803" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.183979" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:08.183449" elapsed="0.000588"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.183304" elapsed="0.000762"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:08.184112" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:08.184277" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:08.182135" elapsed="0.002168"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:08.181838" elapsed="0.002498"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.184502" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:08.184361" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:08.181815" elapsed="0.002763"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.185184" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:08.184731" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:08.185262" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:08.178024" elapsed="0.007362"/>
</kw>
<msg time="2026-06-06T03:36:08.185440" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:08.177136" elapsed="0.008352"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.186004" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.186507" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.187060" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.187275" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.187449" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.188012" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:08.187865" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:08.187849" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.188227" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.188388" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.188546" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:08.187820" elapsed="0.000779"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.187525" elapsed="0.001099"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.188783" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.188859" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:08.188976" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:08.172866" elapsed="0.016137"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:08.190241" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:08.189997" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:08.190401" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:08.189660" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.190774" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:08.190501" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.191341" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:08.191032" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:08.190856" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:08.190483" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.193851" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:08.191579" elapsed="0.002299"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:08.193930" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:08.194084" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:08.189321" elapsed="0.004788"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:08.195354" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:08.195069" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:08.195564" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:08.194740" elapsed="0.000849"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:08.195815" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:08.195677" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:08.195656" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.196040" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.196205" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.196270" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:08.198191" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:08.194406" elapsed="0.003812"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.199605" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:08.199351" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:08.200057" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:08.199814" elapsed="0.000286"/>
</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-06-06T03:36:08.208121" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:08.208261" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:08.208361" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:08.202404" elapsed="0.006371">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:08.200165" elapsed="0.008696">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:08.209047" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:08.208894" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:08.200147" elapsed="0.008995">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:08.209536" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.209688" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:08.209632" elapsed="0.000100"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:08.209614" elapsed="0.000140"/>
</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-06-06T03:36:08.209895" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.209969" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:08.198514" elapsed="0.011562">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.210165" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:08.149843" elapsed="0.060419">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:08.210603" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:08.210420" elapsed="0.000275"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:08.210399" elapsed="0.000322"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:08.210755" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:08.143025" elapsed="0.067826">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.257271" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:09.256872" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:09.258069" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:09.257819" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:09.258238" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:09.257471" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.258826" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:09.258420" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:09.259149" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:09.259307" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:09.259007" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.259744" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:09.259482" elapsed="0.000328"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.261012" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:09.260745" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.261480" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:09.261214" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.261869" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.262071" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.262237" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:09.261729" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.261561" elapsed="0.000764"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:09.262371" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:09.262536" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:09.260403" elapsed="0.002158"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:09.259888" elapsed="0.002706"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.262777" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:09.262619" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:09.259865" elapsed="0.002995"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.263440" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:09.262996" elapsed="0.000523"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:09.263571" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:09.256252" elapsed="0.007462"/>
</kw>
<msg time="2026-06-06T03:36:09.263769" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:09.255359" elapsed="0.008486"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.264349" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.264896" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.265400" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.265580" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.265762" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.266118" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:09.265980" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:09.265965" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.266334" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.266496" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.266670" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:09.265937" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.265838" elapsed="0.000914"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.266892" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.266968" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:09.267084" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:09.251107" elapsed="0.016003"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:09.268381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:09.268148" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:09.268536" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:09.267811" elapsed="0.000749"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.268887" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:09.268632" elapsed="0.000313"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.269434" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:09.269142" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:09.268970" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:09.268613" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.272063" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:09.269676" elapsed="0.002418"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:09.272154" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:09.272311" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:09.267463" elapsed="0.004873"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:09.273536" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:09.273305" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:09.273710" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:09.272971" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:09.273941" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:09.273807" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:09.273788" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.274164" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.274327" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.274393" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:09.276330" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:09.272631" elapsed="0.003725"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.277742" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:09.277478" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:09.278184" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:09.277940" elapsed="0.000288"/>
</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-06-06T03:36:09.286151" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:09.286284" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:09.286375" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:09.280408" elapsed="0.006350">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:09.278294" elapsed="0.008580">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:09.287062" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:09.286909" elapsed="0.000218"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:09.278275" elapsed="0.008876">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:09.287513" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.287660" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:09.287608" elapsed="0.000097"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:09.287590" elapsed="0.000137"/>
</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-06-06T03:36:09.287895" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.287967" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:09.276672" elapsed="0.011397">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.288142" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:09.226820" elapsed="0.061414">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:09.288497" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:09.288325" elapsed="0.000249"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:09.288308" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:09.288632" elapsed="0.000029"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:09.218680" elapsed="0.070062">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.333221" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:10.332823" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:10.334033" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:10.333770" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:10.334203" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:10.333423" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.334812" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:10.334400" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:10.335145" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:10.335409" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:10.335001" elapsed="0.000494"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.335929" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:10.335673" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.336988" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:10.336729" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.337455" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:10.337188" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.337830" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.338030" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.338199" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:10.337698" elapsed="0.000559"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.337537" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:10.338335" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:10.338499" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:10.336391" elapsed="0.002133"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:10.336055" elapsed="0.002501"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.338736" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:10.338581" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:10.336030" elapsed="0.002783"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.339393" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:10.338950" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:10.339471" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:10.332180" elapsed="0.007415"/>
</kw>
<msg time="2026-06-06T03:36:10.339666" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:10.331268" elapsed="0.008447"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.340216" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.340776" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.341467" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.341710" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.341885" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.342249" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:10.342109" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:10.342093" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.342464" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.342626" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.342803" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:10.342064" elapsed="0.000793"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.341963" elapsed="0.000920"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.343022" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.343097" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:10.343216" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:10.326865" elapsed="0.016377"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:10.344543" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:10.344244" elapsed="0.000371">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:10.344724" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:10.343892" elapsed="0.000857"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.345070" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:10.344820" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.345616" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:10.345322" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:10.345151" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:10.344801" elapsed="0.000915"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.348091" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:10.345861" elapsed="0.002257"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:10.348170" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:10.348324" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:10.343551" elapsed="0.004797"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:10.349734" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:10.349467" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:10.349894" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:10.349138" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:10.350134" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:10.349990" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:10.349971" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.350409" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.350577" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.350658" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:36:10.352587" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:10.348808" elapsed="0.003807"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.354014" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:10.353759" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:10.354444" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:10.354205" elapsed="0.000282"/>
</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-06-06T03:36:10.362222" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:10.362361" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:10.362463" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:10.356806" elapsed="0.006060">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:10.354552" elapsed="0.008399">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:10.363145" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:10.362985" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:10.354534" elapsed="0.008699">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:10.363632" elapsed="0.000042"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.363785" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:10.363746" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:10.363728" elapsed="0.000122"/>
</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-06-06T03:36:10.363987" elapsed="0.000020"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.364055" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:10.352938" elapsed="0.011221">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.364233" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:10.304397" elapsed="0.059930">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:10.364674" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:10.364481" elapsed="0.000266"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:10.364462" elapsed="0.000309"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:10.364851" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:10.296761" elapsed="0.068191">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.410550" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:11.410145" elapsed="0.000439"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:11.411372" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:11.411106" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:11.411542" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:11.410770" elapsed="0.000798"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.412135" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:11.411743" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:11.412461" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:11.412624" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:11.412318" elapsed="0.000348"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.413100" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:11.412818" elapsed="0.000331"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.414328" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:11.414067" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.414816" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:11.414528" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.415175" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.415374" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.415541" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:11.415045" elapsed="0.000553"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.414899" elapsed="0.000730"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:11.415693" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:36:11.415864" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:11.413737" elapsed="0.002152"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:11.413228" elapsed="0.002692"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.416085" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:11.415945" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:11.413204" elapsed="0.002957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.416771" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:11.416296" elapsed="0.000504"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:11.416849" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:11.409520" elapsed="0.007468"/>
</kw>
<msg time="2026-06-06T03:36:11.417198" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:11.408624" elapsed="0.008628"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.417767" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.418267" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.418780" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.418961" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.419128" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.419479" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:11.419343" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:11.419328" elapsed="0.000230"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.419711" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.419872" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.420030" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:11.419300" elapsed="0.000782"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.419203" elapsed="0.000904"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.420244" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.420320" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:11.420435" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:11.404129" elapsed="0.016331"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:11.421755" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:11.421486" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:11.421917" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:11.421148" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.422297" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:11.422055" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.422915" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:11.422550" elapsed="0.000391"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:11.422379" elapsed="0.000598"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:11.422035" elapsed="0.000963"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.425556" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:11.423145" elapsed="0.002440"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:11.425651" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:11.425808" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:11.420786" elapsed="0.005046"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:11.427027" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:11.426791" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:11.427188" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:11.426443" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:11.427419" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:11.427282" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:11.427263" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.427656" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.427822" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.427886" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:11.429873" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:11.426124" elapsed="0.003777"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.431388" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:11.431134" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:11.431882" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:11.431583" elapsed="0.000344"/>
</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-06-06T03:36:11.440356" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:11.440552" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:11.440728" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:11.434191" elapsed="0.007088">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:11.431997" elapsed="0.009398">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:11.441667" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:11.441443" elapsed="0.000314"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:11.431977" elapsed="0.009813">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:11.442437" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.442626" elapsed="0.000038"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:11.442572" elapsed="0.000133"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:11.442548" elapsed="0.000188"/>
</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-06-06T03:36:11.442928" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.443023" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:11.430222" elapsed="0.012952">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.443278" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:11.381632" elapsed="0.061775">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:11.443803" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:11.443534" elapsed="0.000372"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:11.443510" elapsed="0.000429"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:11.443984" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:11.372880" elapsed="0.071238">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.494049" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:12.493617" elapsed="0.000467"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:12.494949" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:12.494684" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:12.495121" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:12.494324" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.495730" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:12.495303" elapsed="0.000454"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:12.496076" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:12.496248" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:12.495914" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.496693" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:12.496427" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.497735" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:12.497436" elapsed="0.000347"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.498272" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:12.497997" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.498654" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.498858" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.499025" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:12.498505" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.498353" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:12.499160" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:12.499325" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:12.497117" elapsed="0.002233"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:12.496818" elapsed="0.002564"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.499567" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:12.499407" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:12.496795" elapsed="0.002869"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.500257" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:12.499805" elapsed="0.000480"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:12.500335" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:12.492974" elapsed="0.007486"/>
</kw>
<msg time="2026-06-06T03:36:12.500515" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:12.492077" elapsed="0.008486"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.501068" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.501652" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.502153" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.502331" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.502496" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.503047" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:12.502905" elapsed="0.000231"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:12.502890" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.503299" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.503461" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.503620" elapsed="0.000034"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:12.502861" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.502570" elapsed="0.001146"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.503856" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.503931" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:12.504047" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:12.487778" elapsed="0.016295"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:12.505302" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:12.505061" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:12.505457" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:12.504718" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.505830" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:12.505566" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.506392" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:12.506087" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:12.505915" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:12.505547" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.508821" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:12.506618" elapsed="0.002230"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:12.508899" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:12.509051" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:12.504385" elapsed="0.004692"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:12.510319" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:12.510084" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:12.510474" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:12.509735" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:12.510721" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:12.510569" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:12.510550" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.510942" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.511105" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.511168" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:12.513116" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:12.509373" elapsed="0.003804"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.514698" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:12.514428" elapsed="0.000318"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:12.515155" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:12.514896" elapsed="0.000304"/>
</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-06-06T03:36:12.523734" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:12.523871" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:12.523979" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:12.517724" elapsed="0.006626">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:12.515268" elapsed="0.009166">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:12.524614" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:12.524466" elapsed="0.000235"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:12.515249" elapsed="0.009476">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:12.525088" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.525223" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:12.525187" elapsed="0.000076"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:12.525167" elapsed="0.000118"/>
</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-06-06T03:36:12.525421" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.525548" elapsed="0.000031"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:12.513535" elapsed="0.012167">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.525780" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:12.464687" elapsed="0.061223">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:12.526248" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:12.526008" elapsed="0.000351"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:12.525989" elapsed="0.000417"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:12.526469" elapsed="0.000029"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:12.456104" elapsed="0.070582">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.580575" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:13.580171" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:13.581384" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:13.581122" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:13.581553" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:13.580792" elapsed="0.000786"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.582204" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:13.581754" elapsed="0.000478"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:13.582540" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:13.582724" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:13.582389" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.583148" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:13.582903" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.584400" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:13.583909" elapsed="0.000537"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.584893" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:13.584604" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.585249" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.585447" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.585614" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:13.585119" elapsed="0.000567"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.584976" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:13.585765" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:13.585932" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:13.583571" elapsed="0.002386"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:13.583271" elapsed="0.002718"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.586173" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:13.586014" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:13.583247" elapsed="0.003002"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.586846" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:13.586385" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:13.586924" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:13.579524" elapsed="0.007523"/>
</kw>
<msg time="2026-06-06T03:36:13.587102" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:13.578554" elapsed="0.008598"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.587721" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.588219" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.588739" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.588919" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.589085" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.589447" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:13.589308" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:13.589293" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.589679" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.589843" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.590004" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:13.589265" elapsed="0.000819"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.589161" elapsed="0.000950"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.590253" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.590329" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:13.590449" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:13.572511" elapsed="0.017964"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:13.591735" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:13.591467" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:13.591901" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:13.591133" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.592239" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:13.591998" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.592849" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:13.592527" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:13.592356" elapsed="0.000555"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:13.591978" elapsed="0.000955"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.595527" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:13.593078" elapsed="0.002476"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:13.595607" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:13.595780" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:13.590811" elapsed="0.004993"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:13.597007" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:13.596767" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:13.597165" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:13.596424" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:13.597396" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:13.597260" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:13.597240" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.597617" elapsed="0.000035"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.597800" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.597866" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:13.599841" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:13.596102" elapsed="0.003766"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.601261" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:13.601006" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:13.601716" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:13.601454" elapsed="0.000306"/>
</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-06-06T03:36:13.610186" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:13.610398" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:13.610562" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:13.603949" elapsed="0.007196">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:13.601827" elapsed="0.009446">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:13.611589" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:13.611327" elapsed="0.000386"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:13.601809" elapsed="0.009940">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:13.612332" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.612624" elapsed="0.000042"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:13.612564" elapsed="0.000147"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:13.612535" elapsed="0.000209"/>
</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-06-06T03:36:13.612950" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.613054" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:13.600173" elapsed="0.013040">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.613323" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:13.541312" elapsed="0.072149">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:13.613873" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:13.613595" elapsed="0.000385"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:13.613570" elapsed="0.000446"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:13.614085" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:13.532721" elapsed="0.081510">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.659311" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:14.658910" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:14.660125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:14.659862" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:14.660300" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:14.659514" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.660886" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:14.660484" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:14.661212" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:14.661382" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:14.661068" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.661832" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:14.661557" elapsed="0.000324"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.662896" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:14.662581" elapsed="0.000360"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.663363" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:14.663096" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.663732" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.664006" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.664176" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:14.663589" elapsed="0.000645"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.663444" elapsed="0.000820"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:14.664312" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:14.664480" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:14.662264" elapsed="0.002241"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:14.661957" elapsed="0.002580"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.664716" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:14.664562" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:14.661934" elapsed="0.002860"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.665372" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:14.664929" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:14.665450" elapsed="0.000027"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:14.658255" elapsed="0.007317"/>
</kw>
<msg time="2026-06-06T03:36:14.665626" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:14.657316" elapsed="0.008374"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.666194" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.666731" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.667443" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.667629" elapsed="0.000038"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.667815" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.668170" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:14.668032" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:14.668017" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.668566" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.668783" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.668944" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:14.667989" elapsed="0.001008"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.667890" elapsed="0.001133"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.669162" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.669238" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:14.669357" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:14.652855" elapsed="0.016528"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:14.670675" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:14.670372" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:14.670842" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:14.670036" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.671178" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:14.670938" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.671744" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:14.671429" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:14.671259" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:14.670918" elapsed="0.000910"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.674201" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:14.671971" elapsed="0.002257"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:14.674279" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:14.674433" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:14.669715" elapsed="0.004743"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:14.675706" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:14.675456" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:14.675863" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:14.675129" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:14.676099" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:36:14.675958" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:14.675939" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.676357" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.676522" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.676586" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:14.678504" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:14.674809" elapsed="0.003721"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.679966" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:14.679673" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:14.680400" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:14.680159" elapsed="0.000284"/>
</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-06-06T03:36:14.688413" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:14.688552" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:14.688681" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:14.682758" elapsed="0.006298">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:14.680509" elapsed="0.008637">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:14.689343" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:14.689182" elapsed="0.000227"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:14.680491" elapsed="0.008942">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:14.689840" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.689977" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:14.689939" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:14.689920" elapsed="0.000121"/>
</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-06-06T03:36:14.690178" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.690248" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:14.678862" elapsed="0.011493">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.690428" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:14.630359" elapsed="0.060165">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:14.690874" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:14.690686" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:14.690600" elapsed="0.000371"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:14.691004" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:14.622386" elapsed="0.068715">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.731239" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:15.730822" elapsed="0.000530"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:15.732131" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:15.731881" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:15.732305" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:15.731526" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.732896" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:15.732491" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:15.733221" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:15.733396" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:15.733079" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.733838" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:15.733572" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.735058" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:15.734799" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.735600" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:15.735324" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.735969" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.736172" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.736341" elapsed="0.000027"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:15.735841" elapsed="0.000564"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.735698" elapsed="0.000738"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:15.736482" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:15.736662" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:15.734457" elapsed="0.002232"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:15.733961" elapsed="0.002761"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.736887" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:15.736747" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:15.733939" elapsed="0.003023"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.737535" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:15.737099" elapsed="0.000463"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:15.737610" elapsed="0.000042"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:15.730194" elapsed="0.007556"/>
</kw>
<msg time="2026-06-06T03:36:15.737804" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:15.729271" elapsed="0.008579"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.738337" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.738936" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.739482" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.739680" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.739850" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.740202" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:15.740065" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:15.740050" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.740414" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.740573" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.740757" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:15.740022" elapsed="0.000790"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.739925" elapsed="0.000913"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.740981" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.741056" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:15.741170" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:15.724842" elapsed="0.016354"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:15.742444" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:15.742185" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:15.742603" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:15.741850" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.742954" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:15.742716" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.743523" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:15.743231" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:15.743035" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:15.742696" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.746137" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:15.743765" elapsed="0.002399"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:15.746255" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:15.746412" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:15.741512" elapsed="0.004925"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:15.747658" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:15.747403" elapsed="0.000320">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:15.747817" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:15.747062" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:15.748047" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:15.747912" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:15.747893" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.748268" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.748430" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.748495" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:15.750400" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:15.746747" elapsed="0.003679"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.751902" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:15.751606" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:15.752341" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:15.752094" elapsed="0.000291"/>
</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-06-06T03:36:15.760482" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:15.760619" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:15.760732" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:15.754667" elapsed="0.006422">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:15.752451" elapsed="0.008727">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:15.761432" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:15.761229" elapsed="0.000294"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:15.752433" elapsed="0.009123">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:15.762091" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.762276" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:15.762225" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:15.762201" elapsed="0.000162"/>
</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-06-06T03:36:15.762553" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.762670" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:15.750740" elapsed="0.012075">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.762968" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:15.702256" elapsed="0.060844">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:15.763499" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:15.763258" elapsed="0.000343"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:15.763233" elapsed="0.000402"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:15.763704" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:15.695958" elapsed="0.067878">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.809945" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:16.809534" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:16.810744" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:16.810476" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:16.810913" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:16.810145" elapsed="0.000793"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.811476" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:16.811094" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:16.811825" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:16.811996" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:16.811669" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.812419" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:16.812172" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.813429" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:16.813172" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.813907" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:16.813625" elapsed="0.000308"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.814276" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.814474" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.814653" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:16.814147" elapsed="0.000566"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.813999" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:16.814850" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:16.815021" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:16.812858" elapsed="0.002188"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:16.812541" elapsed="0.002538"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.815244" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:16.815105" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:16.812517" elapsed="0.002804"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.815951" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:16.815457" elapsed="0.000522"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:16.816029" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:16.808934" elapsed="0.007219"/>
</kw>
<msg time="2026-06-06T03:36:16.816208" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:16.808060" elapsed="0.008200"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.816793" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.817468" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.817991" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.818176" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.818342" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.818715" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:16.818562" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:16.818547" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.818929" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.819087" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.819248" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:16.818520" elapsed="0.000780"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.818423" elapsed="0.000902"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.819497" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.819573" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:16.819704" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:16.803694" elapsed="0.016053"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:16.820946" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:16.820713" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:16.821099" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:16.820369" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.821428" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:16.821193" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.821986" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:16.821696" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:16.821508" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:16.821175" elapsed="0.000892"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.824437" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:16.822208" elapsed="0.002256"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:16.824515" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:36:16.824681" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:16.820055" elapsed="0.004653"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:16.825891" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:16.825654" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:16.826051" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:16.825312" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:16.826285" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:16.826145" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:16.826127" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.826506" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.826684" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.826750" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:36:16.830132" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:16.824999" elapsed="0.005165"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.831609" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:16.831343" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:16.832108" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:16.831860" elapsed="0.000292"/>
</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-06-06T03:36:16.840604" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:16.840820" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:16.840931" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:16.834301" elapsed="0.007085">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:16.832222" elapsed="0.009283">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:16.841781" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:16.841552" elapsed="0.000321"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:16.832201" elapsed="0.009706">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:16.842408" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.842593" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:16.842540" elapsed="0.000130"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:16.842516" elapsed="0.000188"/>
</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-06-06T03:36:16.842895" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.842992" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:16.830496" elapsed="0.012637">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.843240" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:16.781347" elapsed="0.062023">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:16.843784" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:16.843498" elapsed="0.000432"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:16.843474" elapsed="0.000499"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:16.844023" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:16.773100" elapsed="0.071062">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.890686" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:17.890272" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:17.891476" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:17.891224" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:17.891661" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:17.890887" elapsed="0.000801"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.892337" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:17.891915" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:17.892682" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:17.892842" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:17.892523" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.893281" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:17.893023" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.894305" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:17.894045" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.894790" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:17.894504" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.895146" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.895347" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.895516" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:17.895016" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.894873" elapsed="0.000731"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:17.895671" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:17.895840" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:17.893722" elapsed="0.002144"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:17.893407" elapsed="0.002492"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.896068" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:17.895925" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:17.893384" elapsed="0.002760"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.896764" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:17.896300" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:17.896843" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:17.889656" elapsed="0.007311"/>
</kw>
<msg time="2026-06-06T03:36:17.897023" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:17.888758" elapsed="0.008315"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.897574" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.898098" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.898634" elapsed="0.000040"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.898836" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.899006" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.899365" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:17.899223" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:17.899206" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.899580" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.899757" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.899917" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:17.899178" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.899080" elapsed="0.000915"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.900134" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.900209" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:17.900362" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:17.884162" elapsed="0.016227"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:17.901803" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:17.901367" elapsed="0.000502">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:17.901963" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:17.901037" elapsed="0.000951"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.902305" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:17.902059" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.902875" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:17.902559" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:17.902387" elapsed="0.000551"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:17.902040" elapsed="0.000920"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.905327" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:17.903107" elapsed="0.002247"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:17.905406" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:17.905560" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:17.900719" elapsed="0.004866"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:17.906791" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:17.906541" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:17.906986" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:17.906212" elapsed="0.000799"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:17.907220" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:36:17.907082" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:17.907063" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.907445" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.907610" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.907698" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:17.909629" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:17.905893" elapsed="0.003777"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.911042" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:17.910793" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:17.911475" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:17.911234" elapsed="0.000284"/>
</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-06-06T03:36:17.919583" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:17.919745" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:17.919844" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:17.913677" elapsed="0.006533">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:17.911584" elapsed="0.008770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:17.920618" elapsed="0.000052"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:17.920402" elapsed="0.000331"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:17.911566" elapsed="0.009200">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:17.921279" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.921467" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:17.921414" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:17.921390" elapsed="0.000166"/>
</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-06-06T03:36:17.921769" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.921869" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:17.909969" elapsed="0.012044">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.922115" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:17.860890" elapsed="0.061356">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:17.922693" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:17.922428" elapsed="0.000369"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:17.922402" elapsed="0.000429"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:17.922877" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:17.852018" elapsed="0.070994">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.973016" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:18.972573" elapsed="0.000477"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:18.973834" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:18.973549" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:18.974017" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:18.973220" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.974588" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:18.974200" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:18.974931" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:18.975103" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:18.974787" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.975544" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:18.975294" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.976565" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:18.976308" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.977079" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:18.976781" elapsed="0.000324"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.977432" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.977632" elapsed="0.000039"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.977819" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:18.977303" elapsed="0.000574"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:18.977159" elapsed="0.000748"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:18.977954" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:18.978117" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:18.975986" elapsed="0.002157"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:18.975686" elapsed="0.002489"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.978342" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:18.978201" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:18.975661" elapsed="0.002757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.979013" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:18.978554" elapsed="0.000542"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:18.979148" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:18.971959" elapsed="0.007314"/>
</kw>
<msg time="2026-06-06T03:36:18.979327" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:18.970924" elapsed="0.008450"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.979881" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.980388" elapsed="0.000153"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.981225" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.981416" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.981585" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.981958" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:18.981818" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:18.981803" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.982172" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.982333" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.982491" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:18.981775" elapsed="0.000769"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:18.981675" elapsed="0.000894"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.982724" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:18.982800" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:18.982915" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:18.966577" elapsed="0.016363"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:18.984187" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:18.983954" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:18.984348" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:18.983609" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.984695" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:18.984442" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.985366" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:18.985071" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:18.984776" elapsed="0.000652"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:18.984424" elapsed="0.001025"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.987829" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:18.985594" elapsed="0.002262"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:18.987908" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:18.988061" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:18.983286" elapsed="0.004800"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:18.989302" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:18.989064" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:18.989456" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:18.988718" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:18.989707" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:18.989550" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:18.989532" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.989929" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:18.990092" elapsed="0.000019"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:18.990156" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:18.992092" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:18.988384" elapsed="0.003734"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.993504" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:18.993256" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:18.993962" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:18.993710" elapsed="0.000295"/>
</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-06-06T03:36:19.002077" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:19.002217" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:19.002311" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:18.996275" elapsed="0.006437">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:18.994070" elapsed="0.008755">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:19.003008" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:19.002860" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:18.994052" elapsed="0.009045">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:19.003470" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:19.003601" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:19.003564" elapsed="0.000095"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:19.003547" elapsed="0.000136"/>
</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-06-06T03:36:19.003820" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:19.003890" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:18.992416" elapsed="0.011574">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:19.004063" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:18.942675" elapsed="0.061481">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:19.004418" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:19.004247" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:19.004230" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:19.004546" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:18.934358" elapsed="0.070294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.049905" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:20.049475" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:20.050727" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:20.050444" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:20.050899" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:20.050106" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.051471" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:20.051083" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:20.051815" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:20.051980" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:20.051670" elapsed="0.000403"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.052477" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:20.052226" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.053760" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:20.053479" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.054234" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:20.053964" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.054606" elapsed="0.000025"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.054829" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.054998" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:20.054463" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.054320" elapsed="0.000767"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:20.055134" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:20.055312" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:20.053125" elapsed="0.002213"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:20.052601" elapsed="0.002770"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.055539" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:20.055397" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:20.052578" elapsed="0.003038"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.056211" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:20.055770" elapsed="0.000469"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:20.056288" elapsed="0.000033"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:20.048845" elapsed="0.007576"/>
</kw>
<msg time="2026-06-06T03:36:20.056475" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:20.047789" elapsed="0.008734"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.057024" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.057539" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.058045" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.058259" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.058428" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.058800" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:20.058659" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:20.058629" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.059013" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.059173" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.059331" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:20.058601" elapsed="0.000783"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.058502" elapsed="0.000908"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.059560" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.059653" elapsed="0.000023"/>
</return>
<msg time="2026-06-06T03:36:20.059779" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:20.043268" elapsed="0.016537"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:20.061042" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:20.060801" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:20.061198" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:20.060436" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.061602" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:20.061293" elapsed="0.000389"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.062187" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:20.061883" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:20.061711" elapsed="0.000538"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:20.061274" elapsed="0.001003"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.064845" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:20.062428" elapsed="0.002445"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:20.064925" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:20.065080" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:20.060116" elapsed="0.004989"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:20.066423" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:20.066182" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:20.066587" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:20.065782" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:20.066837" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:20.066701" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:20.066680" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.067131" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.067305" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.067370" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:20.069538" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:20.065398" elapsed="0.004174"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.071112" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:20.070859" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:20.071553" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:20.071305" elapsed="0.000291"/>
</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-06-06T03:36:20.080576" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:20.080802" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:20.080950" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:20.073763" elapsed="0.007735">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:20.071690" elapsed="0.009928">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:20.081927" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:20.081689" elapsed="0.000331"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:20.071668" elapsed="0.010385">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:20.082577" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.082788" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:20.082733" elapsed="0.000115"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:20.082707" elapsed="0.000172"/>
</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-06-06T03:36:20.083069" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.083165" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:20.069961" elapsed="0.013353">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.083416" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:20.020596" elapsed="0.062949">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:20.083936" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:20.083695" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:20.083670" elapsed="0.000400"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:20.084173" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:20.014280" elapsed="0.070032">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.129600" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:21.129204" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:21.130424" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:21.130157" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:21.130630" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:21.129815" elapsed="0.000857"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.131228" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:21.130834" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:21.131550" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:21.131735" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:21.131408" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.132157" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:21.131911" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.133158" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:21.132900" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.133621" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:21.133356" elapsed="0.000305"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.134018" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.134220" elapsed="0.000029"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.134397" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:21.133864" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.133715" elapsed="0.000772"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:21.134533" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:21.134711" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:21.132568" elapsed="0.002169"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:21.132277" elapsed="0.002493"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.134936" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:21.134795" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:21.132254" elapsed="0.002759"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.135593" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:21.135148" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:21.135685" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:21.128588" elapsed="0.007222"/>
</kw>
<msg time="2026-06-06T03:36:21.135926" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:21.127722" elapsed="0.008255"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.136467" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.136986" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.137664" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.137852" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.138036" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.138391" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:21.138253" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:21.138238" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.138606" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.138783" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.138945" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:21.138210" elapsed="0.000791"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.138112" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.139166" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.139240" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:21.139356" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:21.123409" elapsed="0.015973"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:21.140589" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:21.140355" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:21.140787" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:21.140024" elapsed="0.000788"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.141157" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:21.140919" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.141761" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:21.141430" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:21.141238" elapsed="0.000585"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:21.140900" elapsed="0.000944"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.144242" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:21.142022" elapsed="0.002247"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:21.144320" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:21.144474" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:21.139706" elapsed="0.004793"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:21.145727" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:21.145464" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:21.145883" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:21.145131" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:21.146134" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:21.145996" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:21.145960" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.146355" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.146516" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.146580" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:21.148514" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:21.144814" elapsed="0.003726"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.149909" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:21.149660" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:21.150367" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:21.150127" elapsed="0.000287"/>
</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-06-06T03:36:21.158436" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:21.158632" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:21.158789" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:21.152707" elapsed="0.006564">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:21.150479" elapsed="0.008909">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:21.159658" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:21.159433" elapsed="0.000318"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:21.150461" elapsed="0.009323">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:21.160326" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.160513" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:21.160460" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:21.160435" elapsed="0.000165"/>
</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-06-06T03:36:21.160821" elapsed="0.000043"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.160943" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:21.148848" elapsed="0.012241">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.161192" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:21.100583" elapsed="0.060739">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:21.161710" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:21.161449" elapsed="0.000363"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:21.161426" elapsed="0.000419"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:21.161891" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:21.094273" elapsed="0.067784">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.206407" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:22.205995" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:22.207274" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:22.207003" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:22.207453" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:22.206663" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.208062" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:22.207670" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:22.208393" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:22.208582" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:22.208244" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.209247" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:22.208775" elapsed="0.000519"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.210285" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:22.210026" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.210851" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:22.210560" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.211219" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.211419" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.211586" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:22.211087" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.210936" elapsed="0.000755"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:22.211743" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:36:22.211914" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:22.209699" elapsed="0.002240"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:22.209376" elapsed="0.002595"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.212136" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:22.211997" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:22.209350" elapsed="0.002862"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.212813" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:22.212347" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:22.212891" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:22.205372" elapsed="0.007641"/>
</kw>
<msg time="2026-06-06T03:36:22.213068" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:22.204458" elapsed="0.008657"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.213597" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.214112" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.214628" elapsed="0.000039"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.214825" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.214999" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.215359" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:22.215215" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:22.215200" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.215611" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.215788" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.215949" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:22.215173" elapsed="0.000829"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.215074" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.216165" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.216241" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:22.216356" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:22.200207" elapsed="0.016174"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:22.217594" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:22.217361" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:22.217770" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:22.217030" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.218110" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:22.217865" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.218692" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:22.218362" elapsed="0.000357"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:22.218190" elapsed="0.000565"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:22.217847" elapsed="0.000928"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.222806" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:22.218919" elapsed="0.003915"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:22.222886" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:22.223040" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:22.216708" elapsed="0.006357"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:22.224271" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:22.224038" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:22.224433" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:22.223705" elapsed="0.000752"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:22.224682" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:22.224528" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:22.224509" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.224906" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.225069" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.225133" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:22.227062" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:22.223367" elapsed="0.003755"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.228581" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:22.228332" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:22.229033" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:22.228788" elapsed="0.000289"/>
</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-06-06T03:36:22.237079" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:22.237321" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:22.237458" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:22.231219" elapsed="0.006634">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:22.229142" elapsed="0.008797">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:22.238124" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:22.237972" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:22.229124" elapsed="0.009087">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:22.238610" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.238759" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:22.238722" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:22.238705" elapsed="0.000117"/>
</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-06-06T03:36:22.238958" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.239026" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:22.227428" elapsed="0.011700">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.239200" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:22.177813" elapsed="0.061478">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:22.239630" elapsed="0.000053"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:22.239389" elapsed="0.000362"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:22.239364" elapsed="0.000420"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:22.239829" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:22.170050" elapsed="0.069908">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.369322" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:23.368918" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:23.370159" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:23.369885" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:23.370335" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:23.369528" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.370932" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:23.370523" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:23.371274" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:23.371443" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:23.371116" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.371889" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:23.371622" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.372911" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:23.372635" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.373384" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:23.373111" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.373772" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.373985" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.374156" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:23.373613" elapsed="0.000601"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.373466" elapsed="0.000778"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:23.374291" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:23.374460" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:23.372316" elapsed="0.002169"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:23.372014" elapsed="0.002504"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.374708" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:23.374545" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:23.371990" elapsed="0.002796"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.375603" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:23.374926" elapsed="0.000705"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:23.375699" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:23.368285" elapsed="0.007580"/>
</kw>
<msg time="2026-06-06T03:36:23.375927" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:23.367331" elapsed="0.008650"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.376623" elapsed="0.000053"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.377204" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.377744" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.377937" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.378122" elapsed="0.000030"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.378523" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:23.378378" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:23.378362" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.378762" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.378926" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.379090" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:23.378330" elapsed="0.000861"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.378220" elapsed="0.001000"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.379366" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.379445" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:23.379574" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:23.361153" elapsed="0.018449"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:23.380984" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:23.380700" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:23.381157" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:23.380306" elapsed="0.000878"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.381523" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:23.381259" elapsed="0.000366"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.382172" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:23.381848" elapsed="0.000354"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:23.381670" elapsed="0.000569"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:23.381237" elapsed="0.001024"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.384786" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:23.382417" elapsed="0.002397"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:23.384867" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:23.385033" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:23.379939" elapsed="0.005126"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:23.386290" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:23.386049" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:23.386450" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:23.385709" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:23.386713" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:36:23.386546" elapsed="0.000228"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:23.386527" elapsed="0.000272"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.386942" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.387110" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.387205" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:23.389534" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:23.385367" elapsed="0.004196"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.391047" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:23.390782" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:23.391521" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:23.391264" elapsed="0.000301"/>
</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-06-06T03:36:23.400025" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:23.400188" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:23.400328" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:23.393818" elapsed="0.007025">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:23.391633" elapsed="0.009314">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:23.401197" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:23.400990" elapsed="0.000275"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:23.391614" elapsed="0.009676">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:23.401745" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.401961" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:23.401918" elapsed="0.000094"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:23.401896" elapsed="0.000148"/>
</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-06-06T03:36:23.402218" elapsed="0.000025"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.402294" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:23.389890" elapsed="0.012522">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.402489" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:23.337924" elapsed="0.064661">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:23.402882" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:23.402700" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:23.402682" elapsed="0.000297"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:23.403012" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:23.330991" elapsed="0.072118">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.449996" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:24.449580" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:24.450801" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:24.450534" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:24.450970" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:24.450199" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.451545" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:24.451157" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:24.451938" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:24.452103" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:24.451765" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.452535" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:24.452285" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.453565" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:24.453308" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.454059" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:24.453786" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.454413" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.454696" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.454867" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:24.454283" elapsed="0.000642"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.454140" elapsed="0.000816"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:24.455003" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:24.455169" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:24.452987" elapsed="0.002207"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:24.452675" elapsed="0.002551"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.455394" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:24.455252" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:24.452636" elapsed="0.002835"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.456104" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:24.455608" elapsed="0.000524"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:24.456183" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:24.448974" elapsed="0.007333"/>
</kw>
<msg time="2026-06-06T03:36:24.456362" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:24.448063" elapsed="0.008347"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.456921" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.457466" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.457993" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.458176" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.458347" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.458719" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:24.458567" elapsed="0.000210"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:24.458552" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.458937" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.459134" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.459294" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:24.458523" elapsed="0.000824"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.458423" elapsed="0.000949"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.459511" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.459587" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:24.459740" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:24.443709" elapsed="0.016059"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:24.461255" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:24.460980" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:24.461423" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:24.460621" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.461788" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:24.461522" elapsed="0.000325"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.462372" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:24.462074" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:24.461877" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:24.461503" elapsed="0.000953"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.464893" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:24.462605" elapsed="0.002315"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:24.464972" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:24.465126" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:24.460089" elapsed="0.005061"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:24.466349" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:24.466115" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:24.466506" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:24.465782" elapsed="0.000748"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:24.466754" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:24.466601" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:24.466582" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.466978" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.467142" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.467207" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:24.469142" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:24.465447" elapsed="0.003722"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.470600" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:24.470303" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:24.471060" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:24.470813" elapsed="0.000292"/>
</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-06-06T03:36:24.478132" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:24.478266" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:24.478361" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:24.473294" elapsed="0.005450">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:24.471171" elapsed="0.007654">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:24.479006" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:24.478858" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:24.471152" elapsed="0.007942">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:24.479465" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.479597" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:24.479559" elapsed="0.000093"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:24.479542" elapsed="0.000135"/>
</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-06-06T03:36:24.479860" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.479931" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:24.469476" elapsed="0.010558">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.480107" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:24.419192" elapsed="0.061010">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:24.480498" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:24.480294" elapsed="0.000306"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:24.480277" elapsed="0.000357"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:24.480702" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:24.412768" elapsed="0.068069">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.528056" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:25.527652" elapsed="0.000532"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:25.529006" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:25.528748" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:25.529176" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:25.528390" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.529776" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:25.529364" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:25.530117" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:25.530276" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:25.529962" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.530730" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:25.530459" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.531765" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:25.531490" elapsed="0.000321"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.532238" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:25.531968" elapsed="0.000307"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.532607" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.532827" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.532998" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:25.532475" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.532331" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:25.533134" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:25.533304" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:25.531166" elapsed="0.002163"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:25.530856" elapsed="0.002506"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.533532" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:25.533389" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:25.530832" elapsed="0.002778"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.534228" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:25.533764" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:25.534306" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:25.527017" elapsed="0.007419"/>
</kw>
<msg time="2026-06-06T03:36:25.534491" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:25.526076" elapsed="0.008465"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.535070" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.535659" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.536413" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.536604" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.536794" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.537161" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:25.537019" elapsed="0.000199"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:25.537004" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.537380" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.537547" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.537725" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:25.536974" elapsed="0.000807"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.536872" elapsed="0.000935"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.537951" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.538028" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:25.538150" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:25.521579" elapsed="0.016597"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:25.539473" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:25.539202" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:25.539655" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:25.538851" elapsed="0.000831"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.540001" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:25.539754" elapsed="0.000305"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.540579" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:25.540279" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:25.540084" elapsed="0.000571"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:25.539735" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.543092" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:25.540825" elapsed="0.002294"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:25.543237" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:25.543400" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:25.538494" elapsed="0.004932"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:25.544731" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:25.544453" elapsed="0.000345">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:25.544892" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:25.544079" elapsed="0.000838"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:25.545129" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:25.544989" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:25.544971" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.545356" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.545522" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.545588" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:25.547694" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:25.543747" elapsed="0.003976"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.549167" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:25.548903" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:25.549628" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:25.549364" elapsed="0.000325"/>
</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-06-06T03:36:25.556672" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:25.556815" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:25.556924" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:25.551905" elapsed="0.005402">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:25.549757" elapsed="0.007637">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:25.557599" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:25.557429" elapsed="0.000251"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:25.549738" elapsed="0.007967">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:25.558115" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.558254" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:25.558213" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:25.558194" elapsed="0.000125"/>
</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-06-06T03:36:25.558458" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.558526" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:25.548040" elapsed="0.010592">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.558791" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:25.498567" elapsed="0.060324">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:25.559165" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:25.558986" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:25.558969" elapsed="0.000292"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:25.559295" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:25.490959" elapsed="0.068432">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.604797" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:26.604383" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:26.605627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:26.605373" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:26.605815" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:26.605037" elapsed="0.000804"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.606393" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:26.606002" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:26.606737" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:26.606902" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:26.606578" elapsed="0.000350"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.607347" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:26.607080" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.608365" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:26.608108" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.608873" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:26.608570" elapsed="0.000330"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.609228" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.609430" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.609599" elapsed="0.000027"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:26.609097" elapsed="0.000585"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.608954" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:26.609824" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:26.609995" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:26.607783" elapsed="0.002238"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:26.607470" elapsed="0.002584"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.610226" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:26.610080" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:26.607447" elapsed="0.002857"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.610917" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:26.610445" elapsed="0.000500"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:26.610996" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:26.603774" elapsed="0.007347"/>
</kw>
<msg time="2026-06-06T03:36:26.611176" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:26.602888" elapsed="0.008335"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.611850" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.612360" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.612898" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.613083" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.613253" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.613609" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:26.613470" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:26.613455" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.613843" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.614005" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.614165" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:26.613427" elapsed="0.000793"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.613328" elapsed="0.000917"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.614421" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.614500" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:36:26.614620" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:26.598555" elapsed="0.016106"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:26.616124" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:26.615861" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:26.616338" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:26.615499" elapsed="0.000865"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.616706" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:26.616439" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.617313" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:26.617016" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:26.616790" elapsed="0.000586"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:26.616419" elapsed="0.000978"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.619814" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:26.617562" elapsed="0.002280"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:26.619897" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:26.620059" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:26.614983" elapsed="0.005102"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:26.621392" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:26.621143" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:26.621555" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:26.620739" elapsed="0.000841"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:26.621872" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:26.621720" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:26.621633" elapsed="0.000325"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.622104" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.622281" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.622349" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:26.624323" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:26.620393" elapsed="0.003957"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.625883" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:26.625560" elapsed="0.000371"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:26.626352" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:26.626099" elapsed="0.000298"/>
</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-06-06T03:36:26.633393" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:26.633593" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:26.633759" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:26.628566" elapsed="0.005693">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:26.626464" elapsed="0.007910">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:26.634634" elapsed="0.000056"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:26.634423" elapsed="0.000331"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:26.626445" elapsed="0.008344">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:26.635334" elapsed="0.000045"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.635542" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:26.635485" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:26.635460" elapsed="0.000174"/>
</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-06-06T03:36:26.635860" elapsed="0.000033"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.635966" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:26.624705" elapsed="0.011427">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.636254" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:26.575584" elapsed="0.060809">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:26.636792" elapsed="0.000063"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:26.636522" elapsed="0.000404"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:26.636499" elapsed="0.000462"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:26.637008" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:26.569038" elapsed="0.068104">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.682058" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:27.681658" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:27.682865" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:27.682591" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:27.683036" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:27.682262" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.683724" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:27.683304" elapsed="0.000448"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:27.684055" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:27.684218" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:27.683909" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.684710" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:27.684397" elapsed="0.000362"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.685782" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:27.685498" elapsed="0.000329"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.686255" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:27.685982" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.686615" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.686831" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.687000" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:27.686485" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.686338" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:27.687136" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:27.687302" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:27.685140" elapsed="0.002187"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:27.684841" elapsed="0.002519"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.687527" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:27.687387" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:27.684817" elapsed="0.002786"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.688241" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:27.687763" elapsed="0.000506"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:27.688319" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:27.681020" elapsed="0.007422"/>
</kw>
<msg time="2026-06-06T03:36:27.688496" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:27.680130" elapsed="0.008414"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.689055" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.689608" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.690384" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.690571" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.690757" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.691115" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:27.690977" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:27.690961" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.691328" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.691488" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.691666" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:27.690933" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.690833" elapsed="0.000913"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.691886" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.691960" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:27.692075" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:27.675855" elapsed="0.016245"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:27.693322" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:27.693087" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:27.693568" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:27.692744" elapsed="0.000849"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.693929" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:27.693684" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.694475" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:27.694182" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:27.694010" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:27.693663" elapsed="0.000900"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.696941" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:27.694726" elapsed="0.002242"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:27.697019" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:27.697172" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:27.692411" elapsed="0.004785"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:27.698412" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:27.698179" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:27.698608" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:27.697851" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:27.698860" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:27.698722" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:27.698702" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.699082" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.699246" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.699321" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:27.702934" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:27.697510" elapsed="0.005452"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.704387" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:27.704129" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:27.704848" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:27.704583" elapsed="0.000309"/>
</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-06-06T03:36:27.712662" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:27.712807" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:27.712917" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:27.707089" elapsed="0.006208">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:27.704958" elapsed="0.008421">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:27.713603" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:27.713448" elapsed="0.000236"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:27.704939" elapsed="0.008770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:27.714081" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.714214" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:27.714176" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:27.714159" elapsed="0.000120"/>
</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-06-06T03:36:27.714416" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.714486" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:27.703265" elapsed="0.011327">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.714684" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:27.653181" elapsed="0.061598">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:27.715089" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:27.714914" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:27.714896" elapsed="0.000289"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:27.715217" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:27.646920" elapsed="0.068392">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.759943" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:28.759522" elapsed="0.000456"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:28.761320" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:28.760485" elapsed="0.000913">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:28.761494" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:28.760149" elapsed="0.001370"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.762092" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:28.761701" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:28.762420" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:28.762602" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:28.762275" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.763049" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:28.762799" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.764080" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:28.763821" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.764549" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:28.764281" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.764922" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.765122" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.765292" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:28.764792" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.764631" elapsed="0.000751"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:28.765429" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:28.765595" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:28.763483" elapsed="0.002137"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:28.763172" elapsed="0.002499"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.765841" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:28.765698" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:28.763149" elapsed="0.002769"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.766499" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:28.766055" elapsed="0.000543"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:28.766669" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:28.758886" elapsed="0.007912"/>
</kw>
<msg time="2026-06-06T03:36:28.766854" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:28.758000" elapsed="0.008902"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.767418" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.767940" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.768435" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.768615" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.768800" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.769156" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:28.769017" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:28.769002" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.769372" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.769535" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.769713" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:28.768974" elapsed="0.000794"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.768876" elapsed="0.000918"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.769936" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.770012" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:28.770129" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:28.753413" elapsed="0.016742"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:28.771742" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:28.771207" elapsed="0.000605">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:28.771906" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:28.770860" elapsed="0.001071"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.772245" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:28.772003" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.772821" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:28.772498" elapsed="0.000350"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:28.772327" elapsed="0.000557"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:28.771984" elapsed="0.000921"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.775516" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:28.773050" elapsed="0.002493"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:28.775596" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:28.775766" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:28.770514" elapsed="0.005277"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:28.777176" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:28.776760" elapsed="0.000481">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:28.777336" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:28.776409" elapsed="0.000951"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:28.777568" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:28.777432" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:28.777412" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.777819" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.777984" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.778049" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:28.780028" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:28.776089" elapsed="0.003965"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.781454" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:28.781199" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:28.781912" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:28.781664" elapsed="0.000293"/>
</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-06-06T03:36:28.789123" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:28.789259" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:28.789353" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:28.784126" elapsed="0.005627">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:28.782023" elapsed="0.007856">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:28.790064" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:28.789914" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:28.782004" elapsed="0.008148">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:28.790521" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.790676" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:28.790620" elapsed="0.000100"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:28.790602" elapsed="0.000140"/>
</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-06-06T03:36:28.790882" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.790951" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:28.780360" elapsed="0.010694">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.791128" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:28.730495" elapsed="0.060729">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:28.791539" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:28.791359" elapsed="0.000312"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:28.791341" elapsed="0.000368"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:28.791758" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:28.722781" elapsed="0.069120">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.838433" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:29.838036" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:29.839288" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:29.839033" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:29.839459" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:29.838696" elapsed="0.000788"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.840074" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:29.839682" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:29.840407" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:29.840570" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:29.840258" elapsed="0.000427"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.841096" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:29.840841" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.842128" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:29.841868" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.842624" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:29.842327" elapsed="0.000338"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.842997" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.843198" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.843368" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:29.842867" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.842722" elapsed="0.000733"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:29.843503" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:29.843689" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:29.841522" elapsed="0.002193"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:29.841221" elapsed="0.002526"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.843912" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:29.843772" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:29.841198" elapsed="0.002789"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.844574" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:29.844124" elapsed="0.000478"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:29.844666" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:29.837399" elapsed="0.007395"/>
</kw>
<msg time="2026-06-06T03:36:29.844848" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:29.836467" elapsed="0.008428"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.845388" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.845911" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.846664" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.846889" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.847059" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.847416" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:29.847276" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:29.847261" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.847630" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.847811" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.847970" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:29.847233" elapsed="0.000790"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.847134" elapsed="0.000914"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.848188" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.848263" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:29.848379" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:29.832064" elapsed="0.016341"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:29.849627" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:29.849390" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:29.849803" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:29.849058" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.850133" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:29.849897" elapsed="0.000292"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.850731" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:29.850393" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:29.850213" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:29.849878" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.853273" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:29.850958" elapsed="0.002343"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:29.853353" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:29.853506" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:29.848739" elapsed="0.004792"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:29.854811" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:29.854496" elapsed="0.000398">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:29.855014" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:29.854165" elapsed="0.000877"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:29.855280" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:29.855126" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:29.855100" elapsed="0.000267"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.855551" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.855748" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.855816" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:29.857829" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:29.853847" elapsed="0.004009"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.859271" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:29.859018" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:29.859725" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:29.859464" elapsed="0.000306"/>
</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-06-06T03:36:29.867544" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:29.867704" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:29.867800" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:29.862125" elapsed="0.006037">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:29.859837" elapsed="0.008407">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:29.868426" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:29.868278" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:29.859818" elapsed="0.008697">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:29.868913" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.869045" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:29.869008" elapsed="0.000107"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:29.868990" elapsed="0.000157"/>
</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-06-06T03:36:29.869292" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.869363" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:29.858162" elapsed="0.011303">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.869539" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:29.809508" elapsed="0.060130">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:29.869924" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:29.869752" elapsed="0.000243"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:29.869734" elapsed="0.000285"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:29.870096" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:29.802240" elapsed="0.067953">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.915085" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:30.914683" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:30.915921" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:30.915617" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:30.916098" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:30.915287" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.916689" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:30.916283" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:30.917016" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:30.917190" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:30.916872" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.917615" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:30.917369" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.918896" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:30.918614" elapsed="0.000327"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.919366" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:30.919096" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.919741" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.919941" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.920110" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:30.919594" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.919448" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:30.920247" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:30.920415" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:30.918286" elapsed="0.002154"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:30.917772" elapsed="0.002700"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.920638" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:30.920499" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:30.917736" elapsed="0.002995"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.921318" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:30.920870" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:30.921394" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:30.914054" elapsed="0.007464"/>
</kw>
<msg time="2026-06-06T03:36:30.921666" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:30.913148" elapsed="0.008570"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.922231" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.922747" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.923245" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.923426" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.923601" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.923972" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:30.923832" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:30.923818" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.924185" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.924344" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.924503" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:30.923791" elapsed="0.000765"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.923692" elapsed="0.000889"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.924741" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.924817" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:30.924933" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:30.908867" elapsed="0.016092"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:30.926199" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:30.925962" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:30.926357" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:30.925600" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.926744" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:30.926485" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.927289" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:30.926998" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:30.926828" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:30.926466" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.929935" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:30.927514" elapsed="0.002448"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:30.930015" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:30.930170" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:30.925282" elapsed="0.004913"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:30.931390" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:30.931158" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:30.931547" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:30.930826" elapsed="0.000745"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:30.931798" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:30.931645" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:30.931623" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.932021" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.932188" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.932253" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:30.934200" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:30.930489" elapsed="0.003738"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.935603" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:30.935353" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:30.936063" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:30.935815" elapsed="0.000292"/>
</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-06-06T03:36:30.942970" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:30.943104" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:30.943199" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:30.938314" elapsed="0.005242">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:30.936173" elapsed="0.007485">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:30.943843" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:30.943694" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:30.936155" elapsed="0.007775">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:30.944332" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.944464" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:30.944427" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:30.944409" elapsed="0.000118"/>
</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-06-06T03:36:30.944685" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.944756" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:30.934528" elapsed="0.010332">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.944933" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:30.885777" elapsed="0.059250">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:30.945291" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:30.945119" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:30.945102" elapsed="0.000285"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:30.945420" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:30.877841" elapsed="0.067674">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:31.989156" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:31.988737" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:31.989957" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:31.989703" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:31.990125" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:31.989357" elapsed="0.000793"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:31.990738" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:31.990327" elapsed="0.000438"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:31.991220" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:31.991395" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:31.991077" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:31.991842" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:31.991573" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:31.992862" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:31.992576" elapsed="0.000332"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:31.993524" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:31.993251" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.993907" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.994109" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.994278" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:31.993776" elapsed="0.000561"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:31.993605" elapsed="0.000762"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:31.994414" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:31.994580" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:31.992259" elapsed="0.002346"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:31.991967" elapsed="0.002672"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.994828" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:31.994684" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:31.991943" elapsed="0.002962"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:31.995485" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:31.995041" elapsed="0.000472"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:31.995563" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:31.988112" elapsed="0.007595"/>
</kw>
<msg time="2026-06-06T03:36:31.995763" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:31.987235" elapsed="0.008576"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.996301" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.996854" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.997548" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.997751" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.997924" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.998282" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:31.998143" elapsed="0.000237"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:31.998128" elapsed="0.000278"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.998545" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.998729" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.998893" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:31.998100" elapsed="0.000847"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:31.998001" elapsed="0.000973"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:31.999115" elapsed="0.000027"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:31.999198" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:31.999315" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:31.982973" elapsed="0.016369"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:32.000578" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:32.000335" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:32.000754" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:32.000002" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:32.001102" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:32.000864" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:32.001662" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:32.001355" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:32.001182" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:32.000844" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:32.004124" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:32.001890" elapsed="0.002260"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:32.004202" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:36:32.004353" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:31.999679" elapsed="0.004698"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:32.005612" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:32.005372" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:32.005787" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:32.005043" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:32.006018" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:32.005882" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:32.005863" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:32.006241" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:32.006404" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:32.006469" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:32.008399" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:32.004690" elapsed="0.003776"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:32.009879" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:32.009608" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:32.010312" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:32.010072" elapsed="0.000284"/>
</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-06-06T03:36:32.018427" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:32.018563" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:32.018682" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:32.012665" elapsed="0.006376">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:32.010422" elapsed="0.008700">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:32.019302" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:32.019154" elapsed="0.000213"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:32.010403" elapsed="0.008987">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:32.019772" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:32.019904" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:32.019867" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:32.019849" elapsed="0.000118"/>
</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-06-06T03:36:32.020108" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:32.020179" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:32.008788" elapsed="0.011494">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:32.020356" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:31.960644" elapsed="0.059807">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:32.020733" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:32.020541" elapsed="0.000265"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:32.020525" elapsed="0.000305"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:32.020903" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:31.953183" elapsed="0.067822">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.066527" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:33.066134" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:33.067328" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:33.067077" elapsed="0.000325">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:33.067497" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:33.066743" elapsed="0.000779"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.068123" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:33.067732" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:33.068447" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:33.068610" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:33.068305" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.069254" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:33.068810" elapsed="0.000491"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.070271" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:33.070014" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.070753" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:33.070468" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.071102" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.071300" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.071468" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:33.070973" elapsed="0.000551"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.070833" elapsed="0.000721"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:33.071601" elapsed="0.000054"/>
</return>
<msg time="2026-06-06T03:36:33.071792" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:33.069690" elapsed="0.002127"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:33.069377" elapsed="0.002473"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.072015" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:33.071875" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:33.069353" elapsed="0.002738"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.072689" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:33.072226" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:33.072767" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:33.065507" elapsed="0.007383"/>
</kw>
<msg time="2026-06-06T03:36:33.072945" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:33.064635" elapsed="0.008356"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.073528" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.074047" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.074542" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.074739" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.074910" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.075270" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:33.075126" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:33.075111" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.075487" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.075688" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.075853" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:33.075084" elapsed="0.000823"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.074986" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.076073" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.076149" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:33.076265" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:33.060372" elapsed="0.015919"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:33.077501" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:33.077268" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:33.077681" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:33.076937" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.078021" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:33.077778" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.078599" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:33.078305" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:33.078135" elapsed="0.000545"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:33.077759" elapsed="0.000946"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.082704" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:33.078851" elapsed="0.003882"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:33.082787" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:33.082943" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:33.076602" elapsed="0.006367"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:33.084220" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:33.083971" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:33.084379" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:33.083587" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:33.084619" elapsed="0.000044"/>
</return>
<status status="PASS" start="2026-06-06T03:36:33.084477" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:33.084458" elapsed="0.000266"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.084870" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.085037" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.085103" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:33.087037" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:33.083265" elapsed="0.003799"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.088671" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:33.088405" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:33.089113" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:33.088867" elapsed="0.000291"/>
</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-06-06T03:36:33.096589" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:33.096743" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:33.096847" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:33.091292" elapsed="0.005915">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:33.089225" elapsed="0.008063">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:33.097470" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:33.097321" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:33.089206" elapsed="0.008353">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:33.097942" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.098114" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:33.098075" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:33.098056" elapsed="0.000123"/>
</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-06-06T03:36:33.098316" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.098385" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:33.087382" elapsed="0.011107">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.098564" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:33.037883" elapsed="0.060793">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:33.098940" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:33.098769" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:33.098752" elapsed="0.000285"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:33.099069" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:33.029724" elapsed="0.069440">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.143258" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:34.142855" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:34.144125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:34.143819" elapsed="0.000398">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:34.144327" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:34.143466" elapsed="0.000890"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.145067" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:34.144551" elapsed="0.000552"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:34.145490" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:34.145685" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:34.145315" elapsed="0.000409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.146171" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:34.145913" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.147291" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:34.147024" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.147781" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:34.147493" elapsed="0.000314"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.148148" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.148419" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.148591" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:34.148015" elapsed="0.000652"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.147865" elapsed="0.000835"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:34.148750" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:36:34.148925" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:34.146662" elapsed="0.002289"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:34.146299" elapsed="0.002685"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.149153" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:34.149009" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:34.146274" elapsed="0.002956"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.149842" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:34.149369" elapsed="0.000501"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:34.150070" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:34.142207" elapsed="0.007988"/>
</kw>
<msg time="2026-06-06T03:36:34.150250" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:34.141211" elapsed="0.009088"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.150844" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.151354" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.151917" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.152103" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.152272" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.152847" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:34.152697" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:34.152681" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.153067" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.153268" elapsed="0.000028"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.153439" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:34.152634" elapsed="0.000859"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.152348" elapsed="0.001172"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.153680" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.153758" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:34.153877" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:34.136888" elapsed="0.017016"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:34.155213" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:34.154976" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:34.155372" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:34.154620" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.155725" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:34.155468" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.156273" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:34.155980" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:34.155808" elapsed="0.000525"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:34.155449" elapsed="0.000905"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.158787" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:34.156502" elapsed="0.002314"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:34.158873" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:34.159038" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:34.154219" elapsed="0.004844"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:34.160355" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:34.160103" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:34.160516" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:34.159752" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:34.160775" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:34.160614" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:34.160595" elapsed="0.000265"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.161003" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.161170" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.161235" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:34.163186" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:34.159388" elapsed="0.003825"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.164679" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:34.164354" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:34.165124" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:34.164879" elapsed="0.000289"/>
</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-06-06T03:36:34.172806" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:34.172949" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:34.173043" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:34.167515" elapsed="0.005900">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:34.165235" elapsed="0.008262">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:34.173699" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:34.173531" elapsed="0.000240"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:34.165216" elapsed="0.008579">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:34.174161" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.174294" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:34.174257" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:34.174239" elapsed="0.000120"/>
</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-06-06T03:36:34.174530" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.174602" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:34.163518" elapsed="0.011204">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.174801" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:34.114152" elapsed="0.060744">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:34.175159" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:34.174987" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:34.174971" elapsed="0.000282"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:34.175286" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:34.107926" elapsed="0.067454">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.222151" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:35.221722" elapsed="0.000556"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:35.223091" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:35.222815" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:35.223271" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:35.222454" elapsed="0.000842"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.223888" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:35.223458" elapsed="0.000458"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:35.224219" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:35.224382" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:35.224073" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.224841" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:35.224561" elapsed="0.000401"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.226313" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:35.226048" elapsed="0.000312"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.226822" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:35.226517" elapsed="0.000331"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.227324" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.227528" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.227713" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:35.227193" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.227044" elapsed="0.000761"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:35.227853" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:35.228024" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:35.225686" elapsed="0.002363"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:35.225046" elapsed="0.003036"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.228253" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:35.228110" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:35.225020" elapsed="0.003309"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.228990" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:35.228482" elapsed="0.000536"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:35.229069" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:35.221035" elapsed="0.008160"/>
</kw>
<msg time="2026-06-06T03:36:35.229251" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:35.220012" elapsed="0.009289"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.229824" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.230410" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.230932" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.231116" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.231287" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.231670" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:35.231512" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:35.231497" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.231891" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.232055" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.232217" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:35.231467" elapsed="0.000804"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.231365" elapsed="0.000932"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.232440" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.232517" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:35.232659" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:35.215404" elapsed="0.017284"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:35.234109" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:35.233809" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:35.234280" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:35.233429" elapsed="0.000876"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.234632" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:35.234379" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.235203" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:35.234905" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:35.234732" elapsed="0.000532"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:35.234358" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.238036" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:35.235431" elapsed="0.002633"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:35.238186" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:35.238352" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:35.233075" elapsed="0.005302"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:35.239685" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:35.239403" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:35.239851" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:35.239064" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:35.240088" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:35.239949" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:35.239929" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.240314" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.240482" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.240547" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:35.242762" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:35.238726" elapsed="0.004066"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.244282" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:35.244014" elapsed="0.000315"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:35.244866" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:35.244488" elapsed="0.000444"/>
</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-06-06T03:36:35.252784" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:35.252929" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:35.253067" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:35.247316" elapsed="0.006171">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:35.245004" elapsed="0.008568">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:35.253782" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:35.253607" elapsed="0.000245"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:35.244984" elapsed="0.008892">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:35.254271" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.254425" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:35.254374" elapsed="0.000102"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:35.254354" elapsed="0.000146"/>
</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-06-06T03:36:35.254672" elapsed="0.000026"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.254751" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:35.243111" elapsed="0.011749">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.254992" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:35.192200" elapsed="0.062896">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:35.255378" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:35.255194" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:35.255176" elapsed="0.000301"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:35.255512" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:35.183834" elapsed="0.071776">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.301151" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:36.300740" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:36.301972" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:36.301709" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:36.302146" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:36.301358" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.302762" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:36.302351" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:36.303096" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:36.303265" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:36.302950" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.304398" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:36.303800" elapsed="0.000707"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.306715" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:36.306112" elapsed="0.000707"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.307819" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:36.307163" elapsed="0.000714"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.308587" elapsed="0.000048"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.309062" elapsed="0.000052"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.309427" elapsed="0.000045"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:36.308303" elapsed="0.001250"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.307994" elapsed="0.001626"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:36.309873" elapsed="0.000072"/>
</return>
<msg time="2026-06-06T03:36:36.310244" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:36.305369" elapsed="0.004930"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:36.304704" elapsed="0.005667"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.310773" elapsed="0.000049"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:36.310427" elapsed="0.000474"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:36.304627" elapsed="0.006320"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.312049" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:36.311252" elapsed="0.000825"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:36.312128" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:36.300074" elapsed="0.012179"/>
</kw>
<msg time="2026-06-06T03:36:36.312310" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:36.299037" elapsed="0.013320"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.312879" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.313385" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.314089" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.314278" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.314448" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.314826" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:36.314684" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:36.314667" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.315162" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.315346" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.315510" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:36.314623" elapsed="0.000939"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.314524" elapsed="0.001064"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.315790" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.315869" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:36:36.315988" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:36.294484" elapsed="0.021530"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:36.317243" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:36.317005" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:36.317401" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:36.316665" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.317755" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:36.317497" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.318299" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:36.318007" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:36.317837" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:36.317478" elapsed="0.000904"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.320823" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:36.318526" elapsed="0.002324"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:36.320903" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:36.321057" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:36.316328" elapsed="0.004754"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:36.322303" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:36.322067" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:36.322461" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:36.321731" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:36.322714" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:36.322555" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:36.322536" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.322940" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.323103" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.323168" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:36.325131" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:36.321378" elapsed="0.003780"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.326538" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:36.326288" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:36.327143" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:36.326750" elapsed="0.000436"/>
</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-06-06T03:36:36.335226" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:36.335449" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:36.335551" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:36.329506" elapsed="0.006441">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:36.327252" elapsed="0.008780">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:36.336213" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:36.336065" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:36.327233" elapsed="0.009068">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:36.336686" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.336827" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:36.336788" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:36.336767" elapsed="0.000123"/>
</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-06-06T03:36:36.337028" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.337098" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:36.325459" elapsed="0.011742">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.337274" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:36.271218" elapsed="0.066150">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:36.337630" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:36.337459" elapsed="0.000258"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:36.337442" elapsed="0.000300"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:36.337777" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:36.264756" elapsed="0.073118">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.382317" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:37.381912" elapsed="0.000441"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:37.383142" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:37.382877" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:37.383318" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:37.382523" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.384008" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:37.383591" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:37.384338" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:37.384500" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:37.384193" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.384948" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:37.384694" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.386286" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:37.386022" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.386794" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:37.386490" elapsed="0.000345"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.387191" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.387392" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.387561" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:37.387057" elapsed="0.000560"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.386899" elapsed="0.000766"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:37.387720" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:36:37.387892" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:37.385635" elapsed="0.002283"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:37.385081" elapsed="0.002868"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.388116" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:37.387975" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:37.385054" elapsed="0.003136"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.388799" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:37.388329" elapsed="0.000498"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:37.388876" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:37.381233" elapsed="0.007768"/>
</kw>
<msg time="2026-06-06T03:36:37.389056" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:37.380346" elapsed="0.008758"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.389588" elapsed="0.000070"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.390185" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.390750" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.390936" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.391104" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.391460" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:37.391321" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:37.391305" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.391689" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.391851" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.392010" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:37.391278" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.391179" elapsed="0.000909"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.392227" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.392302" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:37.392419" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:37.375961" elapsed="0.016483"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:37.393715" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:37.393427" elapsed="0.000366">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:37.393905" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:37.393094" elapsed="0.000837"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.394248" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:37.394004" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.394817" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:37.394503" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:37.394329" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:37.393984" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.397438" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:37.395046" elapsed="0.002419"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:37.397518" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:37.397723" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:37.392774" elapsed="0.004979"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:37.398993" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:37.398757" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:37.399188" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:37.398408" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:37.399420" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:37.399284" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:37.399265" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.399656" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.399829" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.399896" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:37.401893" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:37.398087" elapsed="0.003834"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.403304" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:37.403052" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:37.403764" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:37.403500" elapsed="0.000307"/>
</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-06-06T03:36:37.410719" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:37.410879" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:37.411016" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:37.406017" elapsed="0.005483">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:37.403873" elapsed="0.007742">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:37.411889" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:37.411682" elapsed="0.000297"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:37.403855" elapsed="0.008156">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:37.412520" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.412726" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:37.412672" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:37.412627" elapsed="0.000187"/>
</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-06-06T03:36:37.413002" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.413098" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:37.402221" elapsed="0.011018">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.413340" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:37.352839" elapsed="0.060629">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:37.413998" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:37.413686" elapsed="0.000416"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:37.413624" elapsed="0.000513"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:37.414183" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:37.346569" elapsed="0.067747">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.464136" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:38.463701" elapsed="0.000469"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:38.464948" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:38.464688" elapsed="0.000336">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:38.465119" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:38.464340" elapsed="0.000803"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.465768" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:38.465302" elapsed="0.000500"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:38.466180" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:38.466350" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:38.466023" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.466809" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:38.466535" elapsed="0.000322"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.467890" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:38.467573" elapsed="0.000362"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.468366" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:38.468093" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.468747" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.468970" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.469153" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:38.468597" elapsed="0.000616"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.468450" elapsed="0.000794"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:38.469292" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:36:38.469464" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:38.467247" elapsed="0.002242"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:38.466936" elapsed="0.002586"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.469707" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:38.469548" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:38.466911" elapsed="0.002875"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.470444" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:38.469951" elapsed="0.000584"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:38.470589" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:38.463075" elapsed="0.007661"/>
</kw>
<msg time="2026-06-06T03:36:38.470792" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:38.462114" elapsed="0.008727"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.471382" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.474065" elapsed="0.000044"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.474638" elapsed="0.000043"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.474858" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.475031" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.475451" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:38.475294" elapsed="0.000216"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:38.475272" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.475692" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.475947" elapsed="0.000024"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.476171" elapsed="0.000033"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:38.475228" elapsed="0.001023"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.475114" elapsed="0.001174"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.476474" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.476558" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:36:38.476718" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:38.456542" elapsed="0.020204"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:38.478220" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:38.477933" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:38.478405" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:38.477512" elapsed="0.000932"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.478811" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:38.478534" elapsed="0.000335"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.479372" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:38.479069" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:38.478895" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:38.478513" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.481901" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:38.479602" elapsed="0.002327"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:38.481981" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:38.482138" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:38.477129" elapsed="0.005034"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:38.483373" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:38.483133" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:38.483530" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:38.482799" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:38.483786" elapsed="0.000059"/>
</return>
<status status="PASS" start="2026-06-06T03:36:38.483628" elapsed="0.000255"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:38.483608" elapsed="0.000300"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.484052" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.484218" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.484284" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:38.486443" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:38.482459" elapsed="0.004012"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.487972" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:38.487624" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:38.488439" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:38.488182" elapsed="0.000302"/>
</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-06-06T03:36:38.496204" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:38.496356" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:38.496466" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:38.490633" elapsed="0.006241">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:38.488550" elapsed="0.008447">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:38.497187" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:38.497034" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:38.488532" elapsed="0.008745">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:38.497668" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.497805" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:38.497767" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:38.497748" elapsed="0.000127"/>
</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-06-06T03:36:38.498014" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.498083" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:38.486799" elapsed="0.011388">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.498261" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:38.431373" elapsed="0.066983">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:38.498621" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:38.498448" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:38.498431" elapsed="0.000305"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:38.498768" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:38.424855" elapsed="0.074011">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.543863" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:39.543415" elapsed="0.000483"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:39.544685" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:39.544406" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:39.544861" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:39.544069" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.545446" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:39.545050" elapsed="0.000423"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:39.545797" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:39.546040" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:39.545631" elapsed="0.000504"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.546555" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:39.546299" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.547610" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:39.547347" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.548101" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:39.547831" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.548507" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.548731" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.548906" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:39.548372" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.548208" elapsed="0.000788"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:39.549044" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:36:39.549213" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:39.547023" elapsed="0.002216"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:39.546698" elapsed="0.002575"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.549444" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:39.549299" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:39.546673" elapsed="0.002848"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.550165" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:39.549679" elapsed="0.000515"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:39.550246" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:39.542797" elapsed="0.007577"/>
</kw>
<msg time="2026-06-06T03:36:39.550430" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:39.541857" elapsed="0.008622"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.551060" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.551576" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.552174" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.552402" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.552575" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.552982" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:39.552822" elapsed="0.000220"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:39.552802" elapsed="0.000264"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.553200" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.553363" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.553580" elapsed="0.000028"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:39.552772" elapsed="0.000898"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.552668" elapsed="0.001037"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.553898" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.553987" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:36:39.554119" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:39.537110" elapsed="0.017035"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:39.555564" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:39.555135" elapsed="0.000494">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:39.555741" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:39.554798" elapsed="0.000968"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.556095" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:39.555837" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.556662" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:39.556351" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:39.556180" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:39.555818" elapsed="0.000929"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.559194" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:39.556896" elapsed="0.002326"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:39.559275" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:39.559430" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:39.554464" elapsed="0.004991"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:39.560725" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:39.560457" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:39.560886" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:39.560123" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:39.561119" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:39.560982" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:39.560963" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.561382" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.561552" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.561618" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:39.563675" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:39.559800" elapsed="0.003904"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.565191" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:39.564922" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:39.565638" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:39.565390" elapsed="0.000311"/>
</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-06-06T03:36:39.573117" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:39.573257" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:39.573352" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:39.567919" elapsed="0.005873">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:39.565769" elapsed="0.008154">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:39.574147" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:39.573978" elapsed="0.000263"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:39.565751" elapsed="0.008516">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:39.574699" elapsed="0.000029"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.574840" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:39.574801" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:39.574782" elapsed="0.000126"/>
</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-06-06T03:36:39.575074" elapsed="0.000025"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.575151" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:39.564065" elapsed="0.011190">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.575329" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:39.513957" elapsed="0.061469">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:39.575713" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:39.575519" elapsed="0.000269"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:39.575501" elapsed="0.000311"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:39.575882" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:39.507555" elapsed="0.068430">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.622558" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:40.622005" elapsed="0.000598"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:40.623779" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:40.623401" elapsed="0.000554">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:40.624338" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:40.622859" elapsed="0.001519"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.625109" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:40.624610" elapsed="0.000527"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:40.625440" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:40.625611" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:40.625295" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.626081" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:40.625807" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.627188" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:40.626916" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.627726" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:40.627427" elapsed="0.000326"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.628189" elapsed="0.000028"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.628411" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.628585" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:40.628027" elapsed="0.000633"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.627810" elapsed="0.000884"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:40.628758" elapsed="0.000040"/>
</return>
<msg time="2026-06-06T03:36:40.628952" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:40.626551" elapsed="0.002427"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:40.626209" elapsed="0.002803"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.629182" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:40.629038" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:40.626184" elapsed="0.003074"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.629954" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:40.629429" elapsed="0.000553"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:40.630034" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:40.621082" elapsed="0.009083"/>
</kw>
<msg time="2026-06-06T03:36:40.630296" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:40.620091" elapsed="0.010261"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.630888" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.631393" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.632277" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.632477" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.632666" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.633055" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:40.632910" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:40.632891" elapsed="0.000245"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.633271" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.633431" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.633589" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:40.632857" elapsed="0.000798"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.632750" elapsed="0.000934"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.633827" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.633948" elapsed="0.000025"/>
</return>
<msg time="2026-06-06T03:36:40.634100" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:40.615539" elapsed="0.018588"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:40.635530" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:40.635223" elapsed="0.000385">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:40.635722" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:40.634842" elapsed="0.000906"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.636327" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:40.636028" elapsed="0.000361"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.636957" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:40.636619" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:40.636423" elapsed="0.000597"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:40.636002" elapsed="0.001040"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.639542" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:40.637192" elapsed="0.002378"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:40.639630" elapsed="0.000051"/>
</return>
<msg time="2026-06-06T03:36:40.639822" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:40.634453" elapsed="0.005449"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:40.641253" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:40.640971" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:40.641426" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:40.640604" elapsed="0.000847"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:40.641692" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:36:40.641526" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:40.641506" elapsed="0.000281"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.641930" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.642097" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.642163" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:40.644237" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:40.640246" elapsed="0.004023"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.645808" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:40.645504" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:40.646296" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:40.646041" elapsed="0.000301"/>
</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-06-06T03:36:40.653673" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:40.653890" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:40.654023" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:40.648857" elapsed="0.005582">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:40.646415" elapsed="0.008122">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:40.654805" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:40.654582" elapsed="0.000293"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:40.646394" elapsed="0.008510">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:40.655628" elapsed="0.000044"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.655795" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:40.655751" elapsed="0.000092"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:40.655730" elapsed="0.000137"/>
</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-06-06T03:36:40.656100" elapsed="0.000026"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.656184" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:40.644618" elapsed="0.011700">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.656397" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:40.592498" elapsed="0.063999">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:40.656796" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:40.656592" elapsed="0.000278"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:40.656575" elapsed="0.000328"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:40.656952" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:40.584604" elapsed="0.072494">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.703522" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:41.703124" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:41.704347" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:41.704089" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:41.704518" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:41.703741" elapsed="0.000803"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.705112" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:41.704727" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:41.705440" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:41.705619" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:41.705297" elapsed="0.000364"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.706144" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:41.705877" elapsed="0.000314"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.707426" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:41.707166" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.707979" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:41.707704" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.708338" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.708541" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.708726" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:41.708206" elapsed="0.000580"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.708061" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:41.708865" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:41.709032" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:41.706839" elapsed="0.002219"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:41.706287" elapsed="0.002803"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.709258" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:41.709117" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:41.706262" elapsed="0.003073"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.709949" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:41.709470" elapsed="0.000508"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:41.710030" elapsed="0.000209"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:41.702495" elapsed="0.007838"/>
</kw>
<msg time="2026-06-06T03:36:41.710386" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:41.701594" elapsed="0.008839"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.710942" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.711439" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.711951" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.712130" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.712296" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.712666" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:41.712512" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:41.712496" elapsed="0.000289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.712924" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.713088" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.713248" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:41.712469" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.712371" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.713468" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.713544" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:41.713675" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:41.697341" elapsed="0.016361"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:41.714964" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:41.714725" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:41.715124" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:41.714371" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.715461" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:41.715221" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.716021" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:41.715728" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:41.715541" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:41.715201" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.718633" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:41.716246" elapsed="0.002432"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:41.718731" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:41.718884" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:41.714051" elapsed="0.004858"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:41.720103" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:41.719865" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:41.720257" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:41.719517" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:41.720486" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:41.720351" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:41.720332" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.720722" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.720888" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.720953" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:41.722913" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:41.719201" elapsed="0.003776"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.724362" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:41.724112" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:41.724818" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:41.724556" elapsed="0.000306"/>
</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-06-06T03:36:41.731766" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:41.731904" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:41.732034" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:41.726991" elapsed="0.005527">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:41.724928" elapsed="0.007703">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:41.732909" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:41.732699" elapsed="0.000304"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:41.724910" elapsed="0.008125">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:41.733538" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.733758" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:41.733690" elapsed="0.000128"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:41.733664" elapsed="0.000184"/>
</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-06-06T03:36:41.734041" elapsed="0.000036"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.734144" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:41.723291" elapsed="0.010996">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.734390" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:41.672416" elapsed="0.062103">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:41.734907" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:41.734665" elapsed="0.000343"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:41.734622" elapsed="0.000420"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:41.735087" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:41.666208" elapsed="0.069010">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.777424" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:42.777029" elapsed="0.000429"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:42.778234" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:42.777978" elapsed="0.000332">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:42.778405" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:42.777626" elapsed="0.000803"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.778990" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:42.778587" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:42.779315" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:42.779527" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:42.779172" elapsed="0.000382"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.779969" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:42.779721" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.780983" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:42.780729" elapsed="0.000299"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.781455" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:42.781181" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.781831" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.782031" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.782200" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:42.781699" elapsed="0.000558"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.781537" elapsed="0.000751"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:42.782336" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:42.782502" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:42.780394" elapsed="0.002133"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:42.780093" elapsed="0.002467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.782740" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:42.782585" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:42.780070" elapsed="0.002745"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.783391" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:42.782952" elapsed="0.000466"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:42.783467" elapsed="0.000047"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:42.776400" elapsed="0.007209"/>
</kw>
<msg time="2026-06-06T03:36:42.783678" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:42.775435" elapsed="0.008292"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.784329" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.784851" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.785533" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.785733" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.785903" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.786257" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:42.786118" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:42.786103" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.786472" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.786634" elapsed="0.000035"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.786811" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:42.786076" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.785978" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.787028" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.787103" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:42.787219" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:42.771150" elapsed="0.016095"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:42.788483" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:42.788250" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:42.788638" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:42.787923" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.788996" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:42.788756" elapsed="0.000331"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.789576" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:42.789286" elapsed="0.000315"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:42.789114" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:42.788738" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.792020" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:42.789820" elapsed="0.002226"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:42.792097" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:42.792249" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:42.787589" elapsed="0.004684"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:42.793460" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:42.793229" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:42.793615" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:42.792903" elapsed="0.000750"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:42.793861" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:42.793726" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:42.793707" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.794081" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.794243" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.794307" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:42.796282" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:42.792566" elapsed="0.003742"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.797697" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:42.797434" elapsed="0.000309"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:42.798128" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:42.797889" elapsed="0.000282"/>
</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-06-06T03:36:42.806468" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:42.806612" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:42.806726" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:42.800452" elapsed="0.006644">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:42.798236" elapsed="0.008942">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:42.807356" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:42.807210" elapsed="0.000210"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:42.798218" elapsed="0.009225">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:42.807834" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.808005" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:42.807963" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:42.807944" elapsed="0.000124"/>
</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-06-06T03:36:42.808206" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.808276" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:42.796612" elapsed="0.011767">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.808453" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:42.748589" elapsed="0.059957">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:42.808825" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:42.808651" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:42.808621" elapsed="0.000299"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:42.808953" elapsed="0.000017"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:42.741616" elapsed="0.067435">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.856981" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:43.856562" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:43.857943" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:43.857610" elapsed="0.000424">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:43.858145" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:43.857208" elapsed="0.000967"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.858860" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:43.858372" elapsed="0.000521"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:43.859257" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:43.859461" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:43.859086" elapsed="0.000407"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.862342" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:43.859697" elapsed="0.002694"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.863402" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:43.863138" elapsed="0.000310"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.863896" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:43.863605" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.864251" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.864524" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.864708" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:43.864121" elapsed="0.000645"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.863976" elapsed="0.000820"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:43.864846" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:43.865015" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:43.862805" elapsed="0.002235"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:43.862472" elapsed="0.002600"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.865270" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:43.865097" elapsed="0.000239"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:43.862446" elapsed="0.002914"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.866017" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:43.865528" elapsed="0.000517"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:43.866094" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:43.855954" elapsed="0.010264"/>
</kw>
<msg time="2026-06-06T03:36:43.866273" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:43.855039" elapsed="0.011282"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.866828" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.867325" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.867838" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.868028" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.868197" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.868548" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:43.868410" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:43.868395" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.868780" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.868996" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.869158" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:43.868368" elapsed="0.000883"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.868272" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.869459" elapsed="0.000025"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.869543" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:43.869678" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:43.850604" elapsed="0.019101"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:43.870965" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:43.870709" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:43.871130" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:43.870355" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.871469" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:43.871225" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.872062" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:43.871764" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:43.871552" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:43.871206" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.874799" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:43.872294" elapsed="0.002532"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:43.874879" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:43.875034" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:43.870021" elapsed="0.005038"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:43.876274" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:43.876036" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:43.876432" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:43.875699" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:43.876684" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:36:43.876528" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:43.876509" elapsed="0.000261"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.876912" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.877079" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.877145" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:43.879288" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:43.875359" elapsed="0.003958"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.880786" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:43.880468" elapsed="0.000369"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:43.881323" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:43.881021" elapsed="0.000355"/>
</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-06-06T03:36:43.888804" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:43.888957" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:43.889073" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:43.883705" elapsed="0.005860">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:43.881457" elapsed="0.008235">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:43.889910" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:43.889729" elapsed="0.000267"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:43.881435" elapsed="0.008588">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:43.890440" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.890582" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:43.890544" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:43.890525" elapsed="0.000138"/>
</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-06-06T03:36:43.890806" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.890878" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:43.879621" elapsed="0.011364">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.891064" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:43.827443" elapsed="0.063716">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:43.891431" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:43.891250" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:43.891233" elapsed="0.000296"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:43.891563" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:43.818899" elapsed="0.072775">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.935883" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:44.935466" elapsed="0.000533"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:44.936810" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:44.936527" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:44.936983" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:44.936189" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.937562" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:44.937171" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:44.937911" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:44.938073" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:44.937765" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.938504" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:44.938255" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.939557" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:44.939297" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.940066" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:44.939776" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.940447" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.940665" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.940838" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:44.940304" elapsed="0.000592"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.940160" elapsed="0.000767"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:44.940974" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:44.941139" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:44.938975" elapsed="0.002190"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:44.938630" elapsed="0.002568"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.941377" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:44.941223" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:44.938607" elapsed="0.002848"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.942085" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:44.941623" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:44.942163" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:44.934795" elapsed="0.007493"/>
</kw>
<msg time="2026-06-06T03:36:44.942344" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:44.933817" elapsed="0.008574"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.942924" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.943467" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.943990" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.944181" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.944352" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.944937" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:44.944793" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:44.944777" elapsed="0.000244"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.945159" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.945325" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.945488" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:44.944747" elapsed="0.000802"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.944429" elapsed="0.001147"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.945733" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.945811" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:44.945929" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:44.929290" elapsed="0.016665"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:44.947192" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:44.946955" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:44.947349" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:44.946589" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.947702" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:44.947445" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.948249" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:44.947955" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:44.947785" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:44.947426" elapsed="0.000907"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.950739" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:44.948477" elapsed="0.002289"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:44.950888" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:44.951055" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:44.946270" elapsed="0.004811"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:44.952291" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:44.952054" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:44.952448" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:44.951720" elapsed="0.000753"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:44.952698" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:44.952545" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:44.952526" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.952923" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.953089" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.953155" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:44.955111" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:44.951380" elapsed="0.003759"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.956528" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:44.956278" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:44.956983" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:44.956739" elapsed="0.000289"/>
</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-06-06T03:36:44.965266" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:44.965402" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:44.965496" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:44.959375" elapsed="0.006507">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:44.957095" elapsed="0.008870">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:44.966151" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:44.965998" elapsed="0.000219"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:44.957076" elapsed="0.009165">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:44.966611" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.966764" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:44.966726" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:44.966707" elapsed="0.000120"/>
</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-06-06T03:36:44.966998" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.967070" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:44.955442" elapsed="0.011731">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.967282" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:44.906334" elapsed="0.061061">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:44.967686" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:44.967490" elapsed="0.000270"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:44.967473" elapsed="0.000312"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:44.967818" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:44.897910" elapsed="0.070005">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.012545" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:46.012107" elapsed="0.000473"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:46.013362" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:46.013098" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:46.013534" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:46.012765" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.014116" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:46.013732" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:46.014441" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:46.014606" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:46.014298" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.015053" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:46.014803" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.016317" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:46.016057" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.016822" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:46.016533" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.017179" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.017378" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.017548" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:46.017047" elapsed="0.000559"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.016904" elapsed="0.000732"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:46.017763" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:46.017934" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:46.015731" elapsed="0.002229"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:46.015181" elapsed="0.002811"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.018161" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:46.018017" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:46.015156" elapsed="0.003083"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.018844" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:46.018378" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:46.018923" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:46.011472" elapsed="0.007576"/>
</kw>
<msg time="2026-06-06T03:36:46.019103" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:46.010575" elapsed="0.008576"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.019654" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.020161" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.020704" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.020887" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.021055" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.021414" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:46.021274" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:46.021259" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.021636" elapsed="0.000036"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.021816" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.021978" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:46.021231" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.021132" elapsed="0.000926"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.022234" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.022312" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:46.022430" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:46.006278" elapsed="0.016178"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:46.023708" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:46.023456" elapsed="0.000318">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:46.023867" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:46.023121" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.024211" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:46.023970" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.024791" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:46.024479" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:46.024293" elapsed="0.000561"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:46.023951" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.027419" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:46.025023" elapsed="0.002424"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:46.027500" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:46.027671" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:46.022787" elapsed="0.004911"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:46.028927" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:46.028691" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:46.029084" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:46.028317" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:46.029315" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:46.029180" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:46.029161" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.029537" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.029719" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.029786" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:46.031709" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:46.027995" elapsed="0.003741"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.033113" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:46.032864" elapsed="0.000294"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:46.033550" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:46.033303" elapsed="0.000290"/>
</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-06-06T03:36:46.041486" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:46.041678" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:46.041775" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:46.035737" elapsed="0.006400">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:46.033674" elapsed="0.008546">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:46.042400" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:46.042252" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:46.033654" elapsed="0.008833">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:46.042864" elapsed="0.000031"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.043003" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:46.042966" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:46.042948" elapsed="0.000121"/>
</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-06-06T03:36:46.043209" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.043278" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:46.032034" elapsed="0.011345">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.043452" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:45.983529" elapsed="0.060015">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:46.043823" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:46.043634" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:46.043617" elapsed="0.000303"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:46.043952" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:45.975797" elapsed="0.068249">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.088993" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:47.088575" elapsed="0.000452"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:47.089789" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:47.089526" elapsed="0.000361">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:47.089983" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:47.089198" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.090630" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:47.090237" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:47.090976" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:47.091132" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:47.090832" elapsed="0.000326"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.091556" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:47.091308" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.092570" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:47.092314" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.093053" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:47.092788" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.093403" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.093604" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.093788" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:47.093274" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.093134" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:47.093936" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:47.094100" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:47.091992" elapsed="0.002133"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:47.091696" elapsed="0.002462"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.094323" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:47.094183" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:47.091672" elapsed="0.002728"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.094992" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:47.094536" elapsed="0.000485"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:47.095070" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:47.087967" elapsed="0.007232"/>
</kw>
<msg time="2026-06-06T03:36:47.095253" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:47.087096" elapsed="0.008205"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.095819" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.096318" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.097047" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.097235" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.097406" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.097788" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:47.097631" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:47.097616" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.098032" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.098198" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.098360" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:47.097587" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.097482" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.098578" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.098670" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:47.098788" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:47.082833" elapsed="0.015981"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:47.100044" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:47.099799" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:47.100200" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:47.099450" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.100533" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:47.100296" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.101092" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:47.100800" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:47.100614" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:47.100277" elapsed="0.000897"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.103541" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:47.101318" elapsed="0.002250"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:47.103619" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:36:47.103797" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:47.099127" elapsed="0.004696"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:47.105018" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:47.104776" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:47.105219" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:47.104432" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:47.105453" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:47.105316" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:47.105297" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.105693" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.105858" elapsed="0.000048"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.105953" elapsed="0.000021"/>
</return>
<msg time="2026-06-06T03:36:47.107892" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:47.104115" elapsed="0.003804"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.109298" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:47.109041" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:47.109753" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:47.109492" elapsed="0.000305"/>
</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-06-06T03:36:47.117291" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:47.117425" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:47.117517" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:47.112223" elapsed="0.005696">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:47.109863" elapsed="0.008138">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:47.118186" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:47.118033" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:47.109845" elapsed="0.008429">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:47.118630" elapsed="0.000041"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.118779" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:47.118742" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:47.118724" elapsed="0.000117"/>
</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-06-06T03:36:47.118983" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.119053" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:47.108219" elapsed="0.010943">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.119235" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:47.060303" elapsed="0.059025">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:47.119626" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:47.119454" elapsed="0.000259"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:47.119436" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:47.119772" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:47.052475" elapsed="0.067393">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.167145" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:48.166745" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:48.167980" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:48.167718" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:48.168155" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:48.167367" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.168738" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:48.168336" elapsed="0.000429"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:48.169063" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:48.169231" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:48.168920" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.169672" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:48.169410" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.170889" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:48.170615" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.171387" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:48.171087" elapsed="0.000326"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.171755" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.171952" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.172120" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:48.171611" elapsed="0.000567"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.171468" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:48.172255" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:48.172420" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:48.170298" elapsed="0.002146"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:48.169797" elapsed="0.002679"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.172665" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:48.172501" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:48.169773" elapsed="0.002968"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.173327" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:48.172877" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:48.173457" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:48.166127" elapsed="0.007453"/>
</kw>
<msg time="2026-06-06T03:36:48.173635" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:48.165210" elapsed="0.008491"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.174183" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.174694" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.175186" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.175389" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.175556" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.175924" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:48.175786" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:48.175772" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.176143" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.176306" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.176464" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:48.175744" elapsed="0.000772"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.175630" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.176695" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.176772" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:36:48.176897" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:48.160880" elapsed="0.016042"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:48.178479" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:48.178194" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:48.178667" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:48.177838" elapsed="0.000855"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.179012" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:48.178766" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.179600" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:48.179272" elapsed="0.000354"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:48.179093" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:48.178747" elapsed="0.000951"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.182255" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:48.179844" elapsed="0.002438"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:48.182334" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:36:48.182488" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:48.177482" elapsed="0.005031"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:48.183835" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:48.183486" elapsed="0.000412">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:48.183990" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:48.183144" elapsed="0.000871"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:48.184221" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:48.184085" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:48.184067" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.184442" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.184605" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.184689" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:48.186604" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:48.182825" elapsed="0.003805"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.188064" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:48.187810" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:48.188504" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:48.188260" elapsed="0.000288"/>
</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-06-06T03:36:48.196699" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:48.196842" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:48.196937" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:48.190693" elapsed="0.006624">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:48.188613" elapsed="0.008830">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:48.197625" elapsed="0.000039"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:48.197477" elapsed="0.000231"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:48.188595" elapsed="0.009137">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:48.198095" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.198231" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:48.198193" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:48.198173" elapsed="0.000121"/>
</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-06-06T03:36:48.198430" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.198500" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:48.186948" elapsed="0.011653">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.198692" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:48.134905" elapsed="0.063882">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:48.199049" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:48.198879" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:48.198862" elapsed="0.000288"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:48.199182" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:48.126059" elapsed="0.073217">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.246417" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:49.246007" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:49.247255" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:49.246979" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:49.247430" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:49.246623" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.248029" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:49.247616" elapsed="0.000440"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:49.248360" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:49.248529" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:49.248214" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.249104" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:49.248820" elapsed="0.000344"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.250199" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:49.249929" elapsed="0.000317"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.250698" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:49.250403" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.251068" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.251271" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.251440" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:49.250934" elapsed="0.000566"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.250783" elapsed="0.000748"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:49.251580" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:49.251770" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:49.249565" elapsed="0.002231"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:49.249252" elapsed="0.002577"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.251997" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:49.251855" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:49.249225" elapsed="0.002851"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.252719" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:49.252214" elapsed="0.000536"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:49.252802" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:49.245322" elapsed="0.007608"/>
</kw>
<msg time="2026-06-06T03:36:49.253011" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:49.244383" elapsed="0.008688"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.253570" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.254112" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.254614" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.254849" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.255023" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.255559" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:49.255416" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:49.255400" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.255798" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.255960" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.256124" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:49.255371" elapsed="0.000813"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.255099" elapsed="0.001110"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.256349" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.256426" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:49.256545" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:49.240087" elapsed="0.016483"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:49.257877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:49.257621" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:49.258033" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:49.257282" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.258372" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:49.258129" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.258952" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:49.258638" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:49.258454" elapsed="0.000558"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:49.258109" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.261448" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:49.259179" elapsed="0.002297"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:49.261528" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:49.261703" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:49.256955" elapsed="0.004773"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:49.262953" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:49.262710" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:49.263112" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:49.262349" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:49.263349" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:49.263211" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:49.263191" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.263611" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.263805" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.263873" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:49.265925" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:49.262027" elapsed="0.003926"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.267552" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:49.267223" elapsed="0.000383"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:49.268026" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:49.267778" elapsed="0.000292"/>
</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-06-06T03:36:49.275758" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:49.275912" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:49.276029" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:49.270570" elapsed="0.005863">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:49.268142" elapsed="0.008374">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:49.276828" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:49.276551" elapsed="0.000360"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:49.268122" elapsed="0.008819">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:49.277468" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.277679" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:49.277602" elapsed="0.000139"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:49.277577" elapsed="0.000211"/>
</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-06-06T03:36:49.277980" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.278076" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:49.266332" elapsed="0.011891">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.278327" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:49.217232" elapsed="0.061227">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:49.278845" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:49.278586" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:49.278562" elapsed="0.000418"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:49.279112" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:49.209615" elapsed="0.069642">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.326632" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:50.326240" elapsed="0.000441"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:50.327488" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:50.327185" elapsed="0.000377">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:50.327677" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:50.326852" elapsed="0.000851"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.328261" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:50.327871" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:50.328585" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:50.328761" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:50.328444" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.329190" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:50.328940" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.330450" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:50.329953" elapsed="0.000543"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.330943" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:50.330671" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.331339" elapsed="0.000026"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.331560" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.331750" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:50.331167" elapsed="0.000642"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.331024" elapsed="0.000815"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:50.331886" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:50.332053" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:50.329609" elapsed="0.002470"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:50.329315" elapsed="0.002796"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.332280" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:50.332136" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:50.329292" elapsed="0.003066"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.332957" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:50.332496" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:50.333035" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:50.325583" elapsed="0.007578"/>
</kw>
<msg time="2026-06-06T03:36:50.333279" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:50.324728" elapsed="0.008601"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.333832" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.334357" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.334867" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.335050" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.335217" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.335570" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:50.335432" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:50.335416" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.335808" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.335971" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.336130" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:50.335389" elapsed="0.000794"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.335292" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.336346" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.336421" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:50.336536" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:50.320458" elapsed="0.016103"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:50.337789" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:50.337535" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:50.337949" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:50.337201" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.338333" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:50.338091" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.338896" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:50.338585" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:50.338414" elapsed="0.000543"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:50.338071" elapsed="0.000907"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.341510" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:50.339123" elapsed="0.002414"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:50.341591" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:36:50.341763" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:50.336887" elapsed="0.004901"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:50.343032" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:50.342797" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:50.343190" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:50.342446" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:50.343423" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:50.343286" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:50.343267" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.343664" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.343833" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.343900" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:50.345835" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:50.342121" elapsed="0.003742"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.347256" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:50.347005" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:50.347713" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:50.347450" elapsed="0.000308"/>
</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-06-06T03:36:50.354616" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:50.354775" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:50.354878" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:50.349928" elapsed="0.005307">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:50.347825" elapsed="0.007491">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:50.355497" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:50.355349" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:50.347807" elapsed="0.007778">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:50.356012" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.356147" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:50.356109" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:50.356091" elapsed="0.000121"/>
</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-06-06T03:36:50.356354" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.356424" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:50.346180" elapsed="0.010347">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.356601" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:50.297956" elapsed="0.058756">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:50.356977" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:50.356805" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:50.356787" elapsed="0.000286"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:50.357107" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:50.288628" elapsed="0.068574">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.403872" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:51.403453" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:51.404691" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:51.404415" elapsed="0.000356">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:51.404870" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:51.404077" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.405465" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:51.405072" elapsed="0.000420"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:51.405811" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:51.405977" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:51.405663" elapsed="0.000347"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.406416" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:51.406162" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.407462" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:51.407180" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.408019" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:51.407745" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.408382" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.408584" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.408769" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:51.408250" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.408103" elapsed="0.000757"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:51.408909" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:51.409078" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:51.406858" elapsed="0.002245"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:51.406541" elapsed="0.002595"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.409306" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:51.409161" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:51.406518" elapsed="0.002864"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.410034" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:51.409549" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:51.410112" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:51.402809" elapsed="0.007428"/>
</kw>
<msg time="2026-06-06T03:36:51.410292" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:51.401889" elapsed="0.008450"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.410849" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.411391" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.412102" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.412288" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.412456" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.412830" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:51.412690" elapsed="0.000233"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:51.412673" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.413085" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.413247" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.413407" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:51.412629" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.412529" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.413625" elapsed="0.000035"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.413717" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:51.413834" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:51.396997" elapsed="0.016862"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:51.415082" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:51.414841" elapsed="0.000308">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:51.415254" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:51.414492" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.415616" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:51.415351" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.416189" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:51.415894" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:51.415720" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:51.415332" elapsed="0.000939"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.418671" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:51.416423" elapsed="0.002276"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:51.418750" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:51.418904" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:51.414173" elapsed="0.004757"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:51.420160" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:51.419927" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:51.420316" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:51.419581" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:51.420544" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:51.420410" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:51.420391" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.420788" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.420950" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.421014" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:51.422937" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:51.419224" elapsed="0.003774"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.424400" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:51.424143" elapsed="0.000303"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:51.424852" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:51.424592" elapsed="0.000304"/>
</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-06-06T03:36:51.432163" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:51.432331" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:51.432432" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:51.427176" elapsed="0.005693">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:51.424962" elapsed="0.007992">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:51.433135" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:51.432987" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:51.424943" elapsed="0.008282">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:51.433622" elapsed="0.000043"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.433774" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:51.433738" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:51.433719" elapsed="0.000118"/>
</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-06-06T03:36:51.433975" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.434044" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:51.423317" elapsed="0.010829">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.434238" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:51.374211" elapsed="0.060135">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:51.434618" elapsed="0.000041"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:51.434441" elapsed="0.000269"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:51.434423" elapsed="0.000312"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:51.434768" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:51.367547" elapsed="0.067319">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.480637" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:52.480223" elapsed="0.000462"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:52.481437" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:52.481183" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:52.481607" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:52.480854" elapsed="0.000778"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.482195" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:52.481807" elapsed="0.000415"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:52.482694" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:52.482862" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:52.482533" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.483281" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:52.483037" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.484533" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:52.484244" elapsed="0.000337"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.485022" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:52.484750" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.485382" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.485580" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.485766" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:52.485250" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.485104" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:52.485900" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:52.486065" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:52.483926" elapsed="0.002164"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:52.483405" elapsed="0.002717"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.486295" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:52.486149" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:52.483381" elapsed="0.002989"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.486970" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:52.486507" elapsed="0.000491"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:52.487047" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:52.479599" elapsed="0.007576"/>
</kw>
<msg time="2026-06-06T03:36:52.487230" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:52.478717" elapsed="0.008566"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.487837" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.488338" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.488889" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.489072" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.489249" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.489601" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:52.489462" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:52.489447" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.489840" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.490001" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.490160" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:52.489420" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.489323" elapsed="0.000915"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.490373" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.490447" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:52.490562" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:52.474350" elapsed="0.016237"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:52.491831" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:52.491567" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:52.491990" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:52.491239" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.492320" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:52.492083" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.492950" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:52.492655" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:52.492433" elapsed="0.000578"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:52.492065" elapsed="0.000967"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.495540" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:52.493176" elapsed="0.002391"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:52.495619" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:36:52.495788" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:52.490921" elapsed="0.004891"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:52.497010" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:52.496780" elapsed="0.000292">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:52.497165" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:52.496426" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:52.497392" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:52.497258" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:52.497240" elapsed="0.000234"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.497610" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.497790" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.497856" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:36:52.499788" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:52.496105" elapsed="0.003709"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.501224" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:52.500973" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:52.501676" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:52.501417" elapsed="0.000304"/>
</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-06-06T03:36:52.508660" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:52.508803" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:52.508899" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:52.503873" elapsed="0.005410">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:52.501789" elapsed="0.007608">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:52.509666" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:52.509442" elapsed="0.000317"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:52.501770" elapsed="0.008022">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:52.510289" elapsed="0.000034"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.510520" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:52.510468" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:52.510442" elapsed="0.000167"/>
</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-06-06T03:36:52.510820" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.510917" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:52.500117" elapsed="0.010942">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.511161" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:52.450982" elapsed="0.060311">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:52.511682" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:52.511425" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:52.511395" elapsed="0.000422"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:52.511862" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:52.444323" elapsed="0.067671">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.557633" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:53.557201" elapsed="0.000481"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:53.558472" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:53.558194" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:53.558665" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:53.557856" elapsed="0.000836"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.559253" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:53.558862" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:53.559606" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:53.559792" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:53.559457" elapsed="0.000362"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.560227" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:53.559973" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.561288" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:53.561024" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.561874" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:53.561495" elapsed="0.000406"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.562237" elapsed="0.000029"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.562512" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.562702" elapsed="0.000023"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:53.562105" elapsed="0.000657"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.561959" elapsed="0.000835"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:53.562842" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:36:53.563010" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:53.560674" elapsed="0.002361"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:53.560352" elapsed="0.002715"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.563234" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:53.563093" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:53.560328" elapsed="0.002982"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.563908" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:53.563443" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:53.563986" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:53.556575" elapsed="0.007532"/>
</kw>
<msg time="2026-06-06T03:36:53.564162" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:53.555680" elapsed="0.008529"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.564716" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.565373" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.565922" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.566104" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.566270" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.566618" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:53.566481" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:53.566466" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.566853" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.567048" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.567210" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:53.566439" elapsed="0.000823"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.566344" elapsed="0.000944"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.567432" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.567506" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:53.567620" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:53.551335" elapsed="0.016326"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:53.568866" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:53.568616" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:53.569022" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:53.568286" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.569359" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:53.569116" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.569958" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:53.569608" elapsed="0.000376"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:53.569440" elapsed="0.000579"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:53.569098" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.572457" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:53.570184" elapsed="0.002308"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:53.572556" elapsed="0.000037"/>
</return>
<msg time="2026-06-06T03:36:53.572738" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:53.567971" elapsed="0.004792"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:53.573970" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:53.573733" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:53.574126" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:53.573374" elapsed="0.000776"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:53.574361" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:53.574219" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:53.574201" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.574582" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.574763" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.574828" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:53.578439" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:53.573059" elapsed="0.005409"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.579926" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:53.579615" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:53.580440" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:53.580150" elapsed="0.000338"/>
</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-06-06T03:36:53.587334" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:53.587520" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:53.587696" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:53.582743" elapsed="0.005448">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:53.580559" elapsed="0.007747">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:53.588626" elapsed="0.000064"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:53.588380" elapsed="0.000377"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:53.580540" elapsed="0.008254">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:53.589313" elapsed="0.000046"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.589520" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:53.589465" elapsed="0.000113"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:53.589439" elapsed="0.000172"/>
</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-06-06T03:36:53.589867" elapsed="0.000034"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.589974" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:53.578794" elapsed="0.011328">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.590245" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:53.528572" elapsed="0.061810">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:53.590815" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:53.590517" elapsed="0.000405"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:53.590487" elapsed="0.000469"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:53.591001" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:53.522378" elapsed="0.068756">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.635309" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:54.634911" elapsed="0.000505"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:54.636202" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:54.635938" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:54.636371" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:54.635588" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.636963" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:54.636554" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:54.637288" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:54.637448" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:54.637145" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.637892" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:54.637626" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.638919" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:54.638627" elapsed="0.000338"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.639386" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:54.639119" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.639753" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.639952" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.640120" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:54.639609" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.639467" elapsed="0.000740"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:54.640253" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:54.640420" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:54.638306" elapsed="0.002139"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:54.638013" elapsed="0.002464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.640658" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:54.640504" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:54.637991" elapsed="0.002745"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.641318" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:54.640874" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:54.641396" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:54.634259" elapsed="0.007261"/>
</kw>
<msg time="2026-06-06T03:36:54.641575" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:54.633378" elapsed="0.008244"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.642131" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.642696" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.643225" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.643406" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.643575" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.643951" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:54.643810" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:54.643795" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.644171" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.644334" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.644496" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:54.643767" elapsed="0.000783"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.643666" elapsed="0.000910"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.644731" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.644808" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:54.644924" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:54.628899" elapsed="0.016051"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:54.646379" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:54.645945" elapsed="0.000500">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:54.646540" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:54.645584" elapsed="0.000981"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.646916" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:54.646636" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.647467" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:54.647169" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:54.646999" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:54.646618" elapsed="0.000934"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.649927" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:54.647720" elapsed="0.002235"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:54.650048" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:36:54.650210" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:54.645266" elapsed="0.004969"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:54.651493" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:54.651249" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:54.651667" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:54.650917" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:54.651902" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:54.651766" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:54.651746" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.652128" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.652295" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.652361" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:54.654283" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:54.650536" elapsed="0.003774"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.655708" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:54.655444" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:54.656147" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:54.655902" elapsed="0.000290"/>
</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-06-06T03:36:54.663104" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:54.663238" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:54.663335" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:54.658454" elapsed="0.005264">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:54.656258" elapsed="0.007543">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:54.663982" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:54.663833" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:54.656240" elapsed="0.007831">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:54.664439" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.664574" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:54.664536" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:54.664518" elapsed="0.000135"/>
</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-06-06T03:36:54.664796" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.664866" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:54.654609" elapsed="0.010359">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.665078" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:54.606182" elapsed="0.058992">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:54.665447" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:54.665267" elapsed="0.000253"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:54.665250" elapsed="0.000294"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:54.665578" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:54.598552" elapsed="0.067137">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.710995" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:55.710574" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:55.711806" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:55.711534" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:55.711994" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:55.711200" elapsed="0.000819"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.712570" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:55.712185" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:55.712911" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:55.713077" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:55.712766" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.713501" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:55.713254" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.714688" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:55.714260" elapsed="0.000475"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.715160" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:55.714890" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.715512" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.715727" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.715930" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:55.715382" elapsed="0.000607"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.715241" elapsed="0.000779"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:55.716127" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:55.716296" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:55.713945" elapsed="0.002377"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:55.713632" elapsed="0.002723"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.716527" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:55.716380" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:55.713608" elapsed="0.002996"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.717202" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:55.716757" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:55.717280" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:55.709965" elapsed="0.007440"/>
</kw>
<msg time="2026-06-06T03:36:55.717461" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:55.709071" elapsed="0.008438"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.718018" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.718522" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.719216" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.719407" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.719575" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.719979" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:55.719807" elapsed="0.000232"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:55.719792" elapsed="0.000272"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.720198" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.720359" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.720517" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:55.719764" elapsed="0.000806"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.719664" elapsed="0.000931"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.720804" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.720881" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:55.720997" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:55.704776" elapsed="0.016247"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:55.722232" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:55.721993" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:55.722397" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:55.721663" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.722744" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:55.722492" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.723287" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:55.722996" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:55.722826" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:55.722473" elapsed="0.000896"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.725799" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:55.723514" elapsed="0.002313"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:55.725878" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:55.726031" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:55.721333" elapsed="0.004723"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:55.727249" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:55.727008" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:55.727407" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:55.726677" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:55.727636" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:36:55.727502" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:55.727483" elapsed="0.000254"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.727887" elapsed="0.000025"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.728058" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.728123" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:55.730050" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:55.726348" elapsed="0.003728"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.731439" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:55.731191" elapsed="0.000293"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:55.731910" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:55.731629" elapsed="0.000325"/>
</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-06-06T03:36:55.738951" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:55.739125" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:55.739220" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:55.734318" elapsed="0.005267">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:55.732020" elapsed="0.007663">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:55.739899" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:55.739718" elapsed="0.000249"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:55.732002" elapsed="0.007989">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:55.740376" elapsed="0.000043"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.740588" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:55.740535" elapsed="0.000131"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:55.740509" elapsed="0.000190"/>
</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-06-06T03:36:55.740892" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.740990" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:55.730373" elapsed="0.010760">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.741234" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:55.682267" elapsed="0.059096">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:55.741746" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:55.741489" elapsed="0.000357"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:55.741466" elapsed="0.000412"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:55.741923" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:55.675695" elapsed="0.066357">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.787565" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:56.787158" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:56.788394" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:56.788124" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:56.788572" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:56.787791" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.789283" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:56.788861" elapsed="0.000450"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:56.789619" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:56.789799" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:56.789473" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.790230" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:56.789979" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.791475" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:56.791217" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.791960" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:56.791691" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.792324" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.792521" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.792705" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:56.792194" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.792044" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:56.792842" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:36:56.793035" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:56.790897" elapsed="0.002164"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:56.790358" elapsed="0.002735"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.793259" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:56.793119" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:56.790334" elapsed="0.003000"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.793932" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:56.793470" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:56.794008" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:56.786534" elapsed="0.007598"/>
</kw>
<msg time="2026-06-06T03:36:56.794187" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:56.785659" elapsed="0.008575"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.794736" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.795237" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.795793" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.795976" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.796142" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.796496" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:56.796357" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:56.796342" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.796723" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.796885" elapsed="0.000033"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.797059" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:56.796315" elapsed="0.000798"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.796216" elapsed="0.000922"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.797278" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.797353" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:56.797470" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:56.781388" elapsed="0.016108"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:56.798731" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:56.798474" elapsed="0.000322">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:56.798888" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:56.798143" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.799221" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:56.798982" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.799774" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:56.799469" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:56.799300" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:56.798964" elapsed="0.000892"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.802376" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:56.799998" elapsed="0.002405"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:56.802455" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:36:56.802612" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:56.797826" elapsed="0.004825"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:56.803845" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:56.803597" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:56.804041" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:56.803268" elapsed="0.000797"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:56.804273" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:56.804136" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:56.804117" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.804500" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.804681" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.804750" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:56.806709" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:56.802949" elapsed="0.003787"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.808100" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:56.807851" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:56.808539" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:56.808291" elapsed="0.000291"/>
</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-06-06T03:36:56.815038" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:56.815173" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:56.815267" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:56.810748" elapsed="0.004881">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:56.808662" elapsed="0.007071">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:56.815913" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:56.815766" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:56.808629" elapsed="0.007372">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:56.816358" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.816489" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:56.816452" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:56.816434" elapsed="0.000116"/>
</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-06-06T03:36:56.816698" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.816768" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:56.807033" elapsed="0.009836">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.816983" elapsed="0.000018"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:56.758749" elapsed="0.058332">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:56.817389" elapsed="0.000038"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:56.817208" elapsed="0.000290"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:56.817190" elapsed="0.000343"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:56.817581" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:56.751474" elapsed="0.066270">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.862513" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:57.862109" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:57.863500" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:57.863152" elapsed="0.000430">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:57.863706" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:57.862731" elapsed="0.001001"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.864299" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:57.863906" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:57.864625" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:57.864820" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:57.864482" elapsed="0.000365"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.865246" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:57.864998" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.866335" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:57.866081" elapsed="0.000298"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.866817" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:57.866532" elapsed="0.000311"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.867169" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.867367" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.867541" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:57.867041" elapsed="0.000559"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.866899" elapsed="0.000731"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:57.867693" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:57.867858" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:57.865725" elapsed="0.002158"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:57.865374" elapsed="0.002541"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.868080" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:57.867941" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:57.865348" elapsed="0.002808"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.868760" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:57.868291" elapsed="0.000591"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:57.868946" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:57.861455" elapsed="0.007618"/>
</kw>
<msg time="2026-06-06T03:36:57.869129" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:57.860548" elapsed="0.008628"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.869689" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.870225" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.870925" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.871110" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.871277" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.871627" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:57.871490" elapsed="0.000209"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:57.871475" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.871858" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.872017" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.872175" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:57.871448" elapsed="0.000780"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.871350" elapsed="0.000903"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.872391" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.872465" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:57.872581" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:57.856198" elapsed="0.016408"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:57.873875" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:57.873623" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:57.874051" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:57.873286" elapsed="0.000789"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.874382" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:57.874145" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.874942" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:57.874637" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:57.874468" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:57.874127" elapsed="0.000896"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.877382" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:57.875165" elapsed="0.002244"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:57.877460" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:36:57.877612" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:57.872965" elapsed="0.004671"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:57.878877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:57.878628" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:57.879031" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:57.878300" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:57.879259" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:36:57.879125" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:57.879107" elapsed="0.000234"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.879479" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.879655" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.879722" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:57.881634" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:57.877982" elapsed="0.003696"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.883087" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:57.882827" elapsed="0.000305"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:57.883516" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:57.883277" elapsed="0.000282"/>
</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-06-06T03:36:57.890464" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:57.890601" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:57.890720" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:57.885840" elapsed="0.005250">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:57.883623" elapsed="0.007587">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:57.891397" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:57.891245" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:57.883605" elapsed="0.007889">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:57.891877" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.892015" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:57.891976" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:57.891958" elapsed="0.000120"/>
</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-06-06T03:36:57.892231" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.892302" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:57.882007" elapsed="0.010398">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.892478" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:57.833573" elapsed="0.058999">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:57.892869" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:57.892678" elapsed="0.000264"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:57.892660" elapsed="0.000314"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:57.893007" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:57.825780" elapsed="0.067331">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.938211" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:58.937813" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:58.939038" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:58.938765" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:58.939209" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:58.938412" elapsed="0.000822"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.939796" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:58.939392" elapsed="0.000432"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:36:58.940126" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:36:58.940291" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:36:58.939978" elapsed="0.000402"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.941001" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:58.940533" elapsed="0.000515"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.942022" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:58.941762" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.942487" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:36:58.942220" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.942852" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.943083" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.943252" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:36:58.942724" elapsed="0.000585"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.942567" elapsed="0.000772"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:36:58.943385" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:36:58.943549" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:36:58.941426" elapsed="0.002148"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:58.941125" elapsed="0.002481"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.943787" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:58.943630" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:58.941102" elapsed="0.002761"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.944442" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:36:58.943997" elapsed="0.000473"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:36:58.944517" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:36:58.937185" elapsed="0.007468"/>
</kw>
<msg time="2026-06-06T03:36:58.944710" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:36:58.936278" elapsed="0.008479"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.945239" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.945751" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.946247" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.946470" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.946653" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.947023" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:58.946869" elapsed="0.000211"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:58.946855" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.947238" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.947400" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.947561" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:36:58.946827" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.946730" elapsed="0.000922"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.947794" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.947869" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:36:58.947984" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:36:58.931942" elapsed="0.016067"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:58.949226" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:58.948984" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:58.949382" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:58.948652" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.949733" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:58.949475" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.950276" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:36:58.949987" elapsed="0.000314"/>
</kw>
<status status="PASS" start="2026-06-06T03:36:58.949816" elapsed="0.000520"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:58.949457" elapsed="0.000900"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.954350" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:36:58.950500" elapsed="0.003880"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:36:58.954433" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:36:58.954594" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:58.948320" elapsed="0.006299"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:36:58.955984" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:36:58.955746" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:36:58.956140" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:36:58.955282" elapsed="0.000882"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:36:58.956370" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:36:58.956235" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:36:58.956216" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.956626" elapsed="0.000039"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.956812" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.956878" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:36:58.958795" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:36:58.954957" elapsed="0.003864"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.960215" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:58.959964" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:36:58.960672" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:36:58.960408" elapsed="0.000311"/>
</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-06-06T03:36:58.967534" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:36:58.967737" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:36:58.967878" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:36:58.962845" elapsed="0.005518">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:36:58.960786" elapsed="0.007689">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:36:58.968749" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:58.968520" elapsed="0.000322"/>
</branch>
<status status="FAIL" start="2026-06-06T03:36:58.960768" elapsed="0.008106">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:36:58.969372" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.969556" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:36:58.969504" elapsed="0.000110"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:58.969480" elapsed="0.000185"/>
</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-06-06T03:36:58.969858" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.969957" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:36:58.959147" elapsed="0.010953">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.970204" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:58.909630" elapsed="0.060702">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:36:58.970717" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:36:58.970459" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:36:58.970436" elapsed="0.000416"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:36:58.971065" elapsed="0.000025"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:58.903215" elapsed="0.067995">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.015687" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:00.015277" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:00.016504" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:00.016235" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:00.016690" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:00.015901" elapsed="0.000816"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.017271" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:00.016878" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:00.017603" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:00.017780" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:00.017455" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.018209" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:00.017958" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.019219" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:00.018961" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.019701" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:00.019418" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.020086" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.020287" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.020455" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:00.019955" elapsed="0.000557"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.019782" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:00.020588" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:00.020768" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:00.018627" elapsed="0.002167"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:00.018333" elapsed="0.002494"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.020992" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:00.020852" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:00.018309" elapsed="0.002759"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.021662" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:00.021205" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:00.021741" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:00.014668" elapsed="0.007198"/>
</kw>
<msg time="2026-06-06T03:37:00.021973" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:00.013791" elapsed="0.008232"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.022513" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.023031" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.023533" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.023730" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.023914" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.024451" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:00.024308" elapsed="0.000206"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:00.024292" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.024692" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.024857" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.025019" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:00.024263" elapsed="0.000809"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.023993" elapsed="0.001105"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.025237" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.025312" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:00.025429" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:00.009445" elapsed="0.016010"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:00.026693" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:00.026439" elapsed="0.000319">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:00.026850" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:00.026104" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.027219" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:00.026979" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.027782" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:00.027471" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:00.027301" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:00.026959" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.030259" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:00.028039" elapsed="0.002247"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:00.030337" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:00.030492" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:00.025784" elapsed="0.004733"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:00.031734" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:00.031483" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:00.031907" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:00.031151" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:00.032141" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:00.032005" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:00.031986" elapsed="0.000241"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.032369" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.032535" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.032601" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:00.034530" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:00.030828" elapsed="0.003729"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.035985" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:00.035702" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:00.036429" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:00.036183" elapsed="0.000292"/>
</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-06-06T03:37:00.043450" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:00.043583" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:00.043696" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:00.038837" elapsed="0.005252">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:00.036545" elapsed="0.007626">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:00.044351" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:00.044204" elapsed="0.000211"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:00.036527" elapsed="0.007911">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:00.045003" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.045191" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:00.045137" elapsed="0.000112"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:00.045112" elapsed="0.000169"/>
</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-06-06T03:37:00.045475" elapsed="0.000035"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.045578" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:00.034872" elapsed="0.010869">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.045847" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:36:59.986938" elapsed="0.059040">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:00.046343" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:00.046106" elapsed="0.000338"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:00.046082" elapsed="0.000396"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:00.046524" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:36:59.980779" elapsed="0.065897">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.092187" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:01.091788" elapsed="0.000433"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:01.093021" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:01.092744" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:01.093191" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:01.092388" elapsed="0.000828"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.093795" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:01.093384" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:01.094125" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:01.094273" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:01.093980" elapsed="0.000320"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.094726" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:01.094456" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.095982" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:01.095717" elapsed="0.000311"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.096509" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:01.096233" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.096903" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.097106" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.097276" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:01.096752" elapsed="0.000582"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.096592" elapsed="0.000773"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:01.097412" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:01.097579" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:01.095372" elapsed="0.002233"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:01.094852" elapsed="0.002800"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.097824" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:01.097680" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:01.094829" elapsed="0.003071"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.098487" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:01.098037" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:01.098566" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:01.091165" elapsed="0.007543"/>
</kw>
<msg time="2026-06-06T03:37:01.098763" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:01.090264" elapsed="0.008548"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.099303" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.099824" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.100326" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.100508" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.100692" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.101110" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:01.100959" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:01.100943" elapsed="0.000289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.101369" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.101533" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.101710" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:01.100913" elapsed="0.000853"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.100768" elapsed="0.001024"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.101935" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.102012" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:01.102131" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:01.085926" elapsed="0.016232"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:01.103384" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:01.103146" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:01.103543" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:01.102811" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.103900" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:01.103655" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.104451" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:01.104156" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:01.103983" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:01.103623" elapsed="0.000912"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.107105" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:01.104696" elapsed="0.002436"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:01.107186" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:01.107341" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:01.102472" elapsed="0.004895"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:01.108584" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:01.108348" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:01.108757" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:01.108013" elapsed="0.000769"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:01.109019" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:01.108881" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:01.108861" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.109242" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.109408" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.109475" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:01.111438" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:01.107688" elapsed="0.003811"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.112966" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:01.112654" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:01.113500" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:01.113218" elapsed="0.000330"/>
</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-06-06T03:37:01.120536" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:01.120695" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:01.120791" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:01.115696" elapsed="0.005500">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:01.113616" elapsed="0.007663">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:01.121463" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:01.121312" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:01.113597" elapsed="0.007956">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:01.121932" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.122066" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:01.122028" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:01.122011" elapsed="0.000120"/>
</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-06-06T03:37:01.122269" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.122338" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:01.111824" elapsed="0.010616">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.122514" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:01.063118" elapsed="0.059495">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:01.122896" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:01.122722" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:01.122705" elapsed="0.000288"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:01.123027" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:01.053615" elapsed="0.069507">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.170759" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:02.170348" elapsed="0.000444"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:02.171565" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:02.171290" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:02.171759" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:02.170960" elapsed="0.000824"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.172349" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:02.171946" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:02.172696" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:02.172882" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:02.172536" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.173308" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:02.173060" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.174398" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:02.174141" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.174887" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:02.174598" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.175251" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.175449" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.175616" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:02.175121" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.174971" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:02.175769" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:02.175937" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:02.173815" elapsed="0.002147"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:02.173435" elapsed="0.002560"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.176160" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:02.176020" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:02.173410" elapsed="0.002825"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.176838" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:02.176371" elapsed="0.000496"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:02.176917" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:02.169732" elapsed="0.007319"/>
</kw>
<msg time="2026-06-06T03:37:02.177106" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:02.168792" elapsed="0.008363"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.177762" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.178266" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.178986" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.179172" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.179340" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.179717" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:02.179562" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:02.179546" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.179934" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.180094" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.180253" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:02.179517" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.179416" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.180471" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.180547" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:02.180687" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:02.164340" elapsed="0.016374"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:02.182002" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:02.181711" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:02.182166" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:02.181351" elapsed="0.000840"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.182509" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:02.182261" elapsed="0.000351"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.183126" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:02.182831" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:02.182654" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:02.182242" elapsed="0.000968"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.185590" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:02.183354" elapsed="0.002263"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:02.185683" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:02.185868" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:02.181028" elapsed="0.004864"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:02.187103" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:02.186860" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:02.187259" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:02.186502" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:02.187487" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:02.187353" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:02.187334" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.187728" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.187892" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.187956" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:02.189920" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:02.186186" elapsed="0.003761"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.191335" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:02.191082" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:02.191782" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:02.191524" elapsed="0.000301"/>
</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-06-06T03:37:02.198840" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:02.198974" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:02.199068" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:02.194217" elapsed="0.005212">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:02.191890" elapsed="0.007619">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:02.199780" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:02.199548" elapsed="0.000323"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:02.191872" elapsed="0.008033">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:02.200413" elapsed="0.000034"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.200670" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:02.200595" elapsed="0.000139"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:02.200569" elapsed="0.000198"/>
</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-06-06T03:37:02.200959" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.201057" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:02.190251" elapsed="0.010951">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.201305" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:02.141271" elapsed="0.060166">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:02.201870" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:02.201569" elapsed="0.000405"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:02.201541" elapsed="0.000466"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:02.202054" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:02.132520" elapsed="0.069667">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.245607" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:03.245202" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:03.246435" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:03.246177" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:03.246632" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:03.245831" elapsed="0.000847"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.247248" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:03.246845" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:03.247598" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:03.247842" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:03.247434" elapsed="0.000445"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.248456" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:03.248092" elapsed="0.000430"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.250208" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:03.249832" elapsed="0.000443"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.250965" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:03.250495" elapsed="0.000509"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.251462" elapsed="0.000032"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.251785" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.251958" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:03.251278" elapsed="0.000737"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.251079" elapsed="0.000966"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:03.252093" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:03.252264" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:03.249350" elapsed="0.002939"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:03.248634" elapsed="0.003688"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.252492" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:03.252348" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:03.248601" elapsed="0.003968"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.253176" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:03.252721" elapsed="0.000483"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:03.253254" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:03.244569" elapsed="0.008809"/>
</kw>
<msg time="2026-06-06T03:37:03.253433" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:03.243679" elapsed="0.009802"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.253992" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.254492" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.255035" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.255217" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.255383" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.255758" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:03.255605" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:03.255590" elapsed="0.000254"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.255976" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.256171" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.256332" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:03.255562" elapsed="0.000823"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.255455" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.256550" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.256626" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:03.256759" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:03.239307" elapsed="0.017477"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:03.257990" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:03.257754" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:03.258146" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:03.257409" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.258479" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:03.258241" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.259106" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:03.258801" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:03.258559" elapsed="0.000608"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:03.258222" elapsed="0.000966"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.261723" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:03.259332" elapsed="0.002418"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:03.261803" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:03.261957" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:03.257093" elapsed="0.004889"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:03.263210" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:03.262970" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:03.263369" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:03.262593" elapsed="0.000801"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:03.263608" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:03.263465" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:03.263447" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.263851" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.264017" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.264083" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:03.266012" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:03.262277" elapsed="0.003762"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.267532" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:03.267242" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:03.267989" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:03.267742" elapsed="0.000291"/>
</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-06-06T03:37:03.275407" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:03.275564" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:03.275709" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:03.270155" elapsed="0.005955">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:03.268100" elapsed="0.008101">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:03.276422" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:03.276238" elapsed="0.000252"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:03.268081" elapsed="0.008433">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:03.276930" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.277068" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:03.277029" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:03.277010" elapsed="0.000124"/>
</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-06-06T03:37:03.277272" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.277343" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:03.266342" elapsed="0.011109">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.277525" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:03.215556" elapsed="0.062069">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:03.277909" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:03.277733" elapsed="0.000248"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:03.277715" elapsed="0.000290"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:03.278037" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:03.208625" elapsed="0.069507">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.325857" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:04.325440" elapsed="0.000521"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:04.326752" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:04.326468" elapsed="0.000363">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:04.326926" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:04.326136" elapsed="0.000815"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.327515" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:04.327109" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:04.327859" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:04.328016" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:04.327714" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.328440" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:04.328192" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.329456" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:04.329200" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.329943" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:04.329669" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.330293" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.330491" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.330672" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:04.330166" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.330024" elapsed="0.000737"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:04.330808" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:04.330974" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:04.328883" elapsed="0.002116"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:04.328564" elapsed="0.002467"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.331194" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:04.331055" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:04.328541" elapsed="0.002728"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.331894" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:04.331403" elapsed="0.000518"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:04.331970" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:04.324840" elapsed="0.007252"/>
</kw>
<msg time="2026-06-06T03:37:04.332147" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:04.323932" elapsed="0.008261"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.332693" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.334791" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.335305" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.335502" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.335691" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.336054" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:04.335915" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:04.335899" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.336267" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.336426" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.336583" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:04.335870" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.335769" elapsed="0.000913"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.336822" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.336897" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:04.337015" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:04.319583" elapsed="0.017458"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:04.338270" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:04.338028" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:04.338431" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:04.337693" elapsed="0.000763"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.338786" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:04.338527" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.339342" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:04.339040" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:04.338868" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:04.338508" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.341962" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:04.339703" elapsed="0.002286"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:04.342079" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:04.342238" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:04.337354" elapsed="0.004909"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:04.343466" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:04.343229" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:04.343636" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:04.342898" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:04.343887" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:04.343750" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:04.343730" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.344113" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.344279" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.344345" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:04.346421" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:04.342558" elapsed="0.003889"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.347868" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:04.347598" elapsed="0.000316"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:04.348306" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:04.348061" elapsed="0.000289"/>
</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-06-06T03:37:04.355379" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:04.355577" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:04.355713" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:04.350493" elapsed="0.005597">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:04.348417" elapsed="0.007757">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:04.356357" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:04.356207" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:04.348398" elapsed="0.008048">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:04.356942" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.357139" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:04.357082" elapsed="0.000117"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:04.357056" elapsed="0.000175"/>
</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-06-06T03:37:04.357432" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.357533" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:04.346765" elapsed="0.010939">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.357876" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:04.296832" elapsed="0.061186">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:04.358406" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:04.358154" elapsed="0.000359"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:04.358130" elapsed="0.000419"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:04.358597" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:04.287988" elapsed="0.070777">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.403116" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:05.402713" elapsed="0.000437"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:05.403940" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:05.403676" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:05.404142" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:05.403322" elapsed="0.000849"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.404889" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:05.404410" elapsed="0.000509"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:05.405240" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:05.405408" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:05.405077" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.405905" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:05.405605" elapsed="0.000348"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.406946" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:05.406683" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.407419" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:05.407148" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.407793" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.407997" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.408166" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:05.407659" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.407501" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:05.408434" elapsed="0.000041"/>
</return>
<msg time="2026-06-06T03:37:05.408621" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:05.406343" elapsed="0.002332"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:05.406032" elapsed="0.002683"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.408893" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:05.408743" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:05.406008" elapsed="0.002965"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.409599" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:05.409116" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:05.409698" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:05.402082" elapsed="0.007747"/>
</kw>
<msg time="2026-06-06T03:37:05.409887" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:05.401121" elapsed="0.008820"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.410478" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.411014" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.411523" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.411724" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.411898" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.412275" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:05.412131" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:05.412115" elapsed="0.000291"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.412560" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.412743" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.412907" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:05.412084" elapsed="0.000878"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.411976" elapsed="0.001011"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.413241" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.413326" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:05.413454" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:05.396426" elapsed="0.017056"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:05.415026" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:05.414528" elapsed="0.000575">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:05.415200" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:05.414179" elapsed="0.001046"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.415548" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:05.415298" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.416131" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:05.415828" elapsed="0.000330"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:05.415632" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:05.415279" elapsed="0.000937"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.418696" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:05.416403" elapsed="0.002321"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:05.418779" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:05.418938" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:05.413841" elapsed="0.005123"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:05.420193" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:05.419951" elapsed="0.000307">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:05.420402" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:05.419591" elapsed="0.000838"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:05.420658" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:37:05.420504" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:05.420484" elapsed="0.000261"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.420888" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.421058" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.421125" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:05.423092" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:05.419268" elapsed="0.003851"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.424525" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:05.424250" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:05.424985" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:05.424740" elapsed="0.000289"/>
</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-06-06T03:37:05.431859" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:05.432062" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:05.432167" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:05.427157" elapsed="0.005420">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:05.425095" elapsed="0.007587">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:05.432896" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:05.432724" elapsed="0.000239"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:05.425077" elapsed="0.007910">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:05.433384" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.433523" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:05.433482" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:05.433464" elapsed="0.000123"/>
</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-06-06T03:37:05.433741" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.433814" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:05.423424" elapsed="0.010497">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.433994" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:05.373926" elapsed="0.060163">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:05.434357" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:05.434182" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:05.434165" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:05.434485" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:05.367128" elapsed="0.067453">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.480561" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:06.480158" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:06.481415" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:06.481119" elapsed="0.000374">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:06.481589" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:06.480782" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.482280" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:06.481878" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:06.482617" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:06.482797" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:06.482470" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.483228" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:06.482977" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.484269" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:06.484010" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.484760" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:06.484469" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.485122" elapsed="0.000036"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.485342" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.485514" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:06.484991" elapsed="0.000581"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.484844" elapsed="0.000758"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:06.485665" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:06.485836" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:06.483686" elapsed="0.002175"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:06.483353" elapsed="0.002540"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.486061" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:06.485919" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:06.483330" elapsed="0.002806"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.486741" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:06.486275" elapsed="0.000495"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:06.486820" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:06.479517" elapsed="0.007428"/>
</kw>
<msg time="2026-06-06T03:37:06.487001" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:06.478569" elapsed="0.008481"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.487547" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.488213" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.488986" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.489212" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.489387" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.489769" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:06.489611" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:06.489595" elapsed="0.000257"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.489989" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.490152" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.490313" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:06.489566" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.489464" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.490533" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.490609" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:06.490749" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:06.474102" elapsed="0.016674"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:06.492053" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:06.491794" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:06.492218" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:06.491423" elapsed="0.000820"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.492560" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:06.492314" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.493122" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:06.492827" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:06.492655" elapsed="0.000554"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:06.492295" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.495616" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:06.493376" elapsed="0.002282"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:06.495713" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:06.496022" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:06.491092" elapsed="0.004956"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:06.497303" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:06.497031" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:06.497523" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:06.496695" elapsed="0.000854"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:06.497777" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:06.497620" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:06.497601" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.498001" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.498167" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.498233" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:06.500163" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:06.496355" elapsed="0.003836"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.501614" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:06.501351" elapsed="0.000325"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:06.502067" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:06.501825" elapsed="0.000286"/>
</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-06-06T03:37:06.508595" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:06.508752" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:06.508860" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:06.504417" elapsed="0.004842">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:06.502177" elapsed="0.007166">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:06.509539" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:06.509378" elapsed="0.000227"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:06.502158" elapsed="0.007471">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:06.510033" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.510172" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:06.510132" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:06.510113" elapsed="0.000125"/>
</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-06-06T03:37:06.510376" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.510446" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:06.500499" elapsed="0.010052">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.510625" elapsed="0.000030"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:06.451510" elapsed="0.059232">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:06.511121" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:06.510944" elapsed="0.000250"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:06.510925" elapsed="0.000293"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:06.511251" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:06.444534" elapsed="0.066815">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.557111" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:07.556716" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:07.557915" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:07.557654" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:07.558098" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:07.557311" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.558684" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:07.558282" elapsed="0.000430"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:07.559009" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:07.559169" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:07.558867" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.559598" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:07.559344" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.560826" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:07.560546" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.561296" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:07.561028" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.561662" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.561864" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.562058" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:07.561519" elapsed="0.000597"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.561376" elapsed="0.000770"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:07.562193" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:07.562358" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:07.560223" elapsed="0.002160"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:07.559737" elapsed="0.002678"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.562582" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:07.562440" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:07.559713" elapsed="0.002960"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.563257" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:07.562814" elapsed="0.000515"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:07.563381" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:07.556099" elapsed="0.007407"/>
</kw>
<msg time="2026-06-06T03:37:07.563561" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:07.555237" elapsed="0.008372"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.564111" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.564612" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.565128" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.565308" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.565475" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.565844" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:07.565705" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:07.565690" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.566079" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.566242" elapsed="0.000026"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.566408" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:07.565660" elapsed="0.000806"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.565548" elapsed="0.000944"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.566630" elapsed="0.000035"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.566721" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:07.566842" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:07.550989" elapsed="0.015880"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:07.568125" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:07.567891" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:07.568283" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:07.567541" elapsed="0.000767"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.568617" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:07.568379" elapsed="0.000311"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.569176" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:07.568884" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:07.568715" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:07.568360" elapsed="0.000899"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.571841" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:07.569402" elapsed="0.002466"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:07.571920" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:07.572074" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:07.567217" elapsed="0.004883"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:07.573290" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:07.573060" elapsed="0.000293">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:07.573446" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:07.572726" elapsed="0.000746"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:07.573695" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:07.573543" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:07.573524" elapsed="0.000255"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.573918" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.574096" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.574162" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:07.576083" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:07.572393" elapsed="0.003716"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.577482" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:07.577232" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:07.577948" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:07.577700" elapsed="0.000319"/>
</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-06-06T03:37:07.585525" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:07.585765" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:07.585860" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:07.580173" elapsed="0.006084">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:07.578085" elapsed="0.008290">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:07.586558" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:07.586410" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:07.578067" elapsed="0.008594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:07.587136" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.587318" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:07.587267" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:07.587243" elapsed="0.000163"/>
</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-06-06T03:37:07.587594" elapsed="0.000038"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.587721" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:07.576408" elapsed="0.011455">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.587965" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:07.528323" elapsed="0.059770">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:07.588453" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:07.588218" elapsed="0.000334"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:07.588195" elapsed="0.000391"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:07.588630" elapsed="0.000040"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:07.521488" elapsed="0.067294">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.634876" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:08.634445" elapsed="0.000466"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:08.635686" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:08.635416" elapsed="0.000347">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:08.635858" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:08.635082" elapsed="0.000801"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.636431" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:08.636046" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:08.636774" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:08.636937" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:08.636610" elapsed="0.000409"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.637427" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:08.637177" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.638433" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:08.638177" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.638947" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:08.638630" elapsed="0.000344"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.639300" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.639499" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.639682" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:08.639170" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.639028" elapsed="0.000743"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:08.639818" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:08.639982" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:08.637859" elapsed="0.002149"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:08.637550" elapsed="0.002491"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.640208" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:08.640066" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:08.637527" elapsed="0.002757"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.640890" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:08.640421" elapsed="0.000497"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:08.640967" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:08.633813" elapsed="0.007283"/>
</kw>
<msg time="2026-06-06T03:37:08.641151" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:08.632926" elapsed="0.008272"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.641713" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.642214" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.642954" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.643172" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.643344" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.643721" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:08.643567" elapsed="0.000218"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:08.643551" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.643945" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.644106" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.644266" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:08.643523" elapsed="0.000797"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.643424" elapsed="0.000921"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.644484" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.644561" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:08.644691" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:08.628586" elapsed="0.016132"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:08.645941" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:08.645703" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:08.646098" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:08.645348" elapsed="0.000775"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.646432" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:08.646194" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.647032" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:08.646701" elapsed="0.000358"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:08.646512" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:08.646175" elapsed="0.000940"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.649477" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:08.647260" elapsed="0.002244"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:08.649555" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:08.649728" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:08.645029" elapsed="0.004725"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:08.650982" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:08.650717" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:08.651158" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:08.650372" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:08.651400" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:37:08.651256" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:08.651237" elapsed="0.000248"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.651679" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.651849" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.651915" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:08.653860" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:08.650048" elapsed="0.003838"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.655286" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:08.655037" elapsed="0.000295"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:08.655740" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:08.655477" elapsed="0.000314"/>
</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-06-06T03:37:08.662862" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:08.662997" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:08.663091" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:08.658097" elapsed="0.005351">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:08.655856" elapsed="0.007673">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:08.663731" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:08.663561" elapsed="0.000263"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:08.655838" elapsed="0.008027">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:08.664365" elapsed="0.000043"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.664556" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:08.664506" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:08.664481" elapsed="0.000184"/>
</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-06-06T03:37:08.664864" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.664960" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:08.654183" elapsed="0.010917">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.665203" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:08.605719" elapsed="0.059613">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:08.665722" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:08.665459" elapsed="0.000366"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:08.665436" elapsed="0.000423"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:08.665948" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:08.599213" elapsed="0.066874">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.711020" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:09.710604" elapsed="0.000450"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:09.711844" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:09.711575" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:09.712016" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:09.711220" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.712589" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:09.712204" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:09.712957" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:09.713126" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:09.712809" elapsed="0.000344"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.715101" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:09.713304" elapsed="0.001847"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.716418" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:09.716139" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.716912" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:09.716620" elapsed="0.000319"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.717262" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.717460" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.717628" elapsed="0.000035"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:09.717133" elapsed="0.000568"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.716992" elapsed="0.000739"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:09.717777" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:09.717944" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:09.715738" elapsed="0.002232"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:09.715230" elapsed="0.002772"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.718170" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:09.718027" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:09.715205" elapsed="0.003041"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.718847" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:09.718382" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:09.718924" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:09.710001" elapsed="0.009049"/>
</kw>
<msg time="2026-06-06T03:37:09.719165" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:09.709082" elapsed="0.010135"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.719797" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.720302" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.720834" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.721022" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.721194" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.721572" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:09.721420" elapsed="0.000233"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:09.721403" elapsed="0.000284"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.721834" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.721996" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.722155" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:09.721373" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.721272" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.722371" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.722447" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:09.722568" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:09.704724" elapsed="0.017870"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:09.723917" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:09.723625" elapsed="0.000376">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:09.724095" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:09.723255" elapsed="0.000865"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.724475" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:09.724227" elapsed="0.000306"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.725042" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:09.724746" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:09.724557" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:09.724208" elapsed="0.000918"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.727701" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:09.725272" elapsed="0.002457"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:09.727782" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:09.727952" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:09.722924" elapsed="0.005054"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:09.729182" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:09.728942" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:09.729340" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:09.728595" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:09.729598" elapsed="0.000065"/>
</return>
<status status="PASS" start="2026-06-06T03:37:09.729447" elapsed="0.000259"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:09.729426" elapsed="0.000307"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.729877" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.730042" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.730106" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:09.732070" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:09.728274" elapsed="0.003823"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.733469" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:09.733217" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:09.733926" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:09.733678" elapsed="0.000298"/>
</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-06-06T03:37:09.741221" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:09.741386" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:09.741517" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:09.736354" elapsed="0.005582">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:09.734051" elapsed="0.007984">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:09.742230" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:09.742071" elapsed="0.000225"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:09.734032" elapsed="0.008288">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:09.742800" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.742940" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:09.742900" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:09.742882" elapsed="0.000124"/>
</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-06-06T03:37:09.743145" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.743215" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:09.732399" elapsed="0.010923">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.743399" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:09.681911" elapsed="0.061581">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:09.743858" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:09.743658" elapsed="0.000314"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:09.743623" elapsed="0.000387"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:09.744058" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:09.675384" elapsed="0.068810">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.789753" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:10.789333" elapsed="0.000455"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:10.790551" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:10.790295" elapsed="0.000331">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:10.790740" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:10.789961" elapsed="0.000805"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.791319" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:10.790928" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:10.791663" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:10.791831" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:10.791504" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.792261" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:10.792011" elapsed="0.000334"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.793330" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:10.793069" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.793893" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:10.793603" elapsed="0.000317"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.794253" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.794455" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.794625" elapsed="0.000035"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:10.794122" elapsed="0.000577"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.793977" elapsed="0.000753"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:10.794780" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:10.794954" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:10.792747" elapsed="0.002232"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:10.792424" elapsed="0.002588"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.795179" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:10.795038" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:10.792401" elapsed="0.002853"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.795852" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:10.795391" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:10.795930" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:10.788713" elapsed="0.007342"/>
</kw>
<msg time="2026-06-06T03:37:10.796109" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:10.787749" elapsed="0.008407"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.796671" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.797187" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.797695" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.797883" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.798051" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.798617" elapsed="0.000045"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:10.798456" elapsed="0.000302"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:10.798440" elapsed="0.000356"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.798999" elapsed="0.000028"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.799230" elapsed="0.000029"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.799466" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:10.798412" elapsed="0.001132"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.798125" elapsed="0.001458"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.799779" elapsed="0.000023"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.799861" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:10.799997" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:10.783339" elapsed="0.016685"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:10.801369" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:10.801103" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:10.801541" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:10.800749" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.801903" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:10.801652" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.802453" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:10.802160" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:10.801985" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:10.801619" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.804994" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:10.802697" elapsed="0.002324"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:10.805073" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:10.805228" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:10.800395" elapsed="0.004858"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:10.806455" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:10.806222" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:10.806613" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:10.805891" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:10.806861" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:37:10.806725" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:10.806705" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.807084" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.807247" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.807312" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:10.809299" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:10.805548" elapsed="0.003831"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.810827" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:10.810542" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:10.811274" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:10.811024" elapsed="0.000294"/>
</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-06-06T03:37:10.818180" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:10.818321" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:10.818423" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:10.813879" elapsed="0.004948">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:10.811389" elapsed="0.007522">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:10.819096" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:10.818946" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:10.811367" elapsed="0.007819">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:10.819561" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.819710" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:10.819672" elapsed="0.000082"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:10.819652" elapsed="0.000124"/>
</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-06-06T03:37:10.819948" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.820054" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:10.809709" elapsed="0.010484">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.820318" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:10.760436" elapsed="0.060017">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:10.820758" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:10.820564" elapsed="0.000268"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:10.820546" elapsed="0.000311"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:10.820890" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:10.752162" elapsed="0.068826">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.867569" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:11.867169" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:11.868388" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:11.868126" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:11.868564" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:11.867790" elapsed="0.000799"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.869305" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:11.868766" elapsed="0.000566"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:11.869630" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:11.869816" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:11.869488" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.870244" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:11.869998" elapsed="0.000292"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.871574" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:11.871317" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.872060" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:11.871791" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.872418" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.872619" elapsed="0.000039"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.872805" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:11.872287" elapsed="0.000575"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.872143" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:11.872939" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:11.873118" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:11.870906" elapsed="0.002237"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:11.870369" elapsed="0.002806"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.873340" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:11.873201" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:11.870343" elapsed="0.003079"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.874019" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:11.873559" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:11.874095" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:11.866538" elapsed="0.007680"/>
</kw>
<msg time="2026-06-06T03:37:11.874272" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:11.865665" elapsed="0.008654"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.874887" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.875388" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.875914" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.876097" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.876263" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.876613" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:11.876475" elapsed="0.000214"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:11.876460" elapsed="0.000253"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.876849" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.877016" elapsed="0.000045"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.877204" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:11.876433" elapsed="0.000825"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.876336" elapsed="0.000947"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.877422" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.877497" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:11.877612" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:11.861363" elapsed="0.016275"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:11.878883" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:11.878624" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:11.879042" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:11.878286" elapsed="0.000781"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.879376" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:11.879139" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.879971" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:11.879678" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:11.879490" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:11.879119" elapsed="0.000935"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.882570" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:11.880200" elapsed="0.002397"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:11.882662" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:11.882820" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:11.877968" elapsed="0.004880"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:11.884036" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:11.883804" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:11.884191" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:11.883457" elapsed="0.000759"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:11.884421" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:11.884286" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:11.884267" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.884654" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.884822" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.884887" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:11.886831" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:11.883141" elapsed="0.003716"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.888226" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:11.887975" elapsed="0.000297"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:11.888675" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:11.888418" elapsed="0.000302"/>
</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-06-06T03:37:11.897078" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:11.897220" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:11.897319" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:11.890896" elapsed="0.006819">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:11.888786" elapsed="0.009013">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:11.898052" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:11.897833" elapsed="0.000308"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:11.888767" elapsed="0.009407">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:11.898707" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.898948" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:11.898893" elapsed="0.000114"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:11.898866" elapsed="0.000172"/>
</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-06-06T03:37:11.899233" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.899331" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:11.887151" elapsed="0.012325">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.899579" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:11.838685" elapsed="0.061045">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:11.900096" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:11.899858" elapsed="0.000338"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:11.899834" elapsed="0.000396"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:11.900275" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:11.830254" elapsed="0.070150">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.945384" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:12.944991" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:12.946228" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:12.945954" elapsed="0.000348">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:12.946398" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:12.945586" elapsed="0.000837"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.946989" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:12.946583" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:12.947311" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:12.947573" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:12.947170" elapsed="0.000431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.948031" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:12.947781" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.949043" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:12.948785" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.949514" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:12.949248" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.949918" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.950184" elapsed="0.000030"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.950362" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:12.949780" elapsed="0.000641"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.949595" elapsed="0.000856"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:12.950498" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:12.950685" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:12.948445" elapsed="0.002267"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:12.948152" elapsed="0.002593"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.950923" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:12.950771" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:12.948130" elapsed="0.002875"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.951656" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:12.951147" elapsed="0.000540"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:12.951738" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:12.944371" elapsed="0.007493"/>
</kw>
<msg time="2026-06-06T03:37:12.951919" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:12.943508" elapsed="0.008459"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.952460" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.952983" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.953668" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.953868" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.954037" elapsed="0.000019"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.954386" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:12.954249" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:12.954234" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.954599" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.954824" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.954987" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:12.954206" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.954109" elapsed="0.000957"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.955207" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.955284" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:12.955399" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:12.939229" elapsed="0.016196"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:12.956654" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:12.956399" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:12.956831" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:12.956069" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.957163" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:12.956925" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.957795" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:12.957415" elapsed="0.000415"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:12.957243" elapsed="0.000622"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:12.956907" elapsed="0.000980"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.960272" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:12.958032" elapsed="0.002266"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:12.960350" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:12.960503" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:12.955751" elapsed="0.004777"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:12.961740" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:12.961478" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:12.961920" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:12.961150" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:12.962149" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:12.962014" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:12.961996" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.962375" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.962538" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.962602" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:12.964552" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:12.960835" elapsed="0.003743"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.966032" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:12.965706" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:12.966469" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:12.966226" elapsed="0.000286"/>
</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-06-06T03:37:12.973672" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:12.973844" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:12.973941" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:12.968797" elapsed="0.005510">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:12.966578" elapsed="0.007811">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:12.974589" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:12.974423" elapsed="0.000265"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:12.966560" elapsed="0.008167">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:12.975222" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.975408" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:12.975356" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:12.975332" elapsed="0.000164"/>
</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-06-06T03:37:12.975709" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.975808" elapsed="0.000026"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:12.964887" elapsed="0.011083">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.976074" elapsed="0.000029"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:12.916862" elapsed="0.059389">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:12.976677" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:12.976396" elapsed="0.000386"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:12.976371" elapsed="0.000444"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:12.976861" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:12.910380" elapsed="0.066612">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.023179" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:14.022741" elapsed="0.000553"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:14.024112" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:14.023838" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:14.024286" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:14.023471" elapsed="0.000841"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.024914" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:14.024486" elapsed="0.000456"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:14.025256" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:14.025433" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:14.025102" elapsed="0.000361"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.025899" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:14.025622" elapsed="0.000338"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.027189" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:14.026916" elapsed="0.000322"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.027696" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:14.027406" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.028080" elapsed="0.000024"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.028286" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.028456" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:14.027941" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.027785" elapsed="0.000760"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:14.028593" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:14.028792" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:14.026565" elapsed="0.002254"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:14.026041" elapsed="0.002814"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.029032" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:14.028887" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:14.026017" elapsed="0.003092"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.029747" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:14.029247" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:14.029825" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:14.022029" elapsed="0.007922"/>
</kw>
<msg time="2026-06-06T03:37:14.030005" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:14.021110" elapsed="0.008942"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.030597" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.031187" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.031714" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.031903" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.032087" elapsed="0.000026"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.032462" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:14.032318" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:14.032302" elapsed="0.000250"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.032714" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.032890" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.033054" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:14.032274" elapsed="0.000834"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.032173" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.033277" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.033353" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:14.033471" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:14.016678" elapsed="0.016819"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:14.034848" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:14.034576" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:14.035011" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:14.034194" elapsed="0.000842"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.035388" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:14.035117" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.035980" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:14.035669" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:14.035471" elapsed="0.000572"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:14.035095" elapsed="0.000969"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.038718" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:14.036211" elapsed="0.002535"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:14.038831" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:14.039001" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:14.033854" elapsed="0.005174"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:14.040283" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:14.040037" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:14.040441" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:14.039681" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:14.040718" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:14.040547" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:14.040527" elapsed="0.000277"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.040951" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.041119" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.041186" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:14.043194" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:14.039340" elapsed="0.003885"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.044665" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:14.044388" elapsed="0.000329"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:14.045130" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:14.044877" elapsed="0.000298"/>
</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-06-06T03:37:14.053421" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:14.053556" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:14.053672" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:14.047420" elapsed="0.006620">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:14.045251" elapsed="0.008870">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:14.054318" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:14.054154" elapsed="0.000241"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:14.045225" elapsed="0.009194">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:14.054873" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.055074" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:14.055017" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:14.054992" elapsed="0.000173"/>
</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-06-06T03:37:14.055379" elapsed="0.000033"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.055484" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:14.043534" elapsed="0.012095">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.055816" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:13.993418" elapsed="0.062535">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:14.056362" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:14.056085" elapsed="0.000385"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:14.056061" elapsed="0.000443"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:14.056551" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:13.987080" elapsed="0.069636">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.106445" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:15.105889" elapsed="0.000590"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:15.107324" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:15.107017" elapsed="0.000389">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:15.107504" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:15.106675" elapsed="0.000853"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.108092" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:15.107707" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:15.108422" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:15.108601" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:15.108275" elapsed="0.000352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.109047" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:15.108795" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.110073" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:15.109812" elapsed="0.000305"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.110542" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:15.110273" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.110925" elapsed="0.000026"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.111237" elapsed="0.000027"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.111411" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:15.110794" elapsed="0.000674"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.110628" elapsed="0.000871"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:15.111625" elapsed="0.000054"/>
</return>
<msg time="2026-06-06T03:37:15.111819" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:15.109476" elapsed="0.002369"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:15.109172" elapsed="0.002706"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.112048" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:15.111905" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:15.109147" elapsed="0.002979"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.112805" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:15.112268" elapsed="0.000567"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:15.112886" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:15.105257" elapsed="0.007757"/>
</kw>
<msg time="2026-06-06T03:37:15.113070" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:15.104188" elapsed="0.008931"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.113621" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.114154" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.114664" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.114847" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.115017" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.115615" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:15.115469" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:15.115453" elapsed="0.000260"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.115849" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.116010" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.116170" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:15.115423" elapsed="0.000799"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.115092" elapsed="0.001156"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.116426" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.116503" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:15.116621" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:15.099807" elapsed="0.016854"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:15.117909" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:15.117662" elapsed="0.000316">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:15.118070" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:15.117308" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.118405" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:15.118165" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.118964" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:15.118669" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:15.118487" elapsed="0.000539"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:15.118146" elapsed="0.000901"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.121442" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:15.119191" elapsed="0.002278"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:15.121521" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:15.121693" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:15.116982" elapsed="0.004737"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:15.122975" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:15.122726" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:15.123136" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:15.122335" elapsed="0.000826"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:15.123410" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:15.123268" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:15.123246" elapsed="0.000250"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.123654" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.123826" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.123908" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:15.125855" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:15.122017" elapsed="0.003865"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.127324" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:15.127036" elapsed="0.000340"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:15.127832" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:15.127568" elapsed="0.000307"/>
</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-06-06T03:37:15.135400" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:15.135612" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:15.135764" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:15.130225" elapsed="0.005925">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:15.127945" elapsed="0.008293">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:15.136444" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:15.136275" elapsed="0.000235"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:15.127924" elapsed="0.008610">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:15.136955" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.137097" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:15.137055" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:15.137036" elapsed="0.000126"/>
</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-06-06T03:37:15.137301" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.137372" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:15.126198" elapsed="0.011281">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.137553" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:15.076850" elapsed="0.060812">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:15.137937" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:15.137758" elapsed="0.000251"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:15.137740" elapsed="0.000294"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:15.138067" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:15.068901" elapsed="0.069262">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.185818" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:16.185387" elapsed="0.000465"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:16.186618" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:16.186356" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:16.186806" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:16.186021" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.187474" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:16.187080" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:16.187823" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:16.188003" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:16.187676" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.188437" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:16.188186" elapsed="0.000299"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.189701" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:16.189203" elapsed="0.000544"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.190176" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:16.189904" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.190536" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.190754" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.190924" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:16.190405" elapsed="0.000576"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.190260" elapsed="0.000752"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:16.191061" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:16.191227" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:16.188886" elapsed="0.002367"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:16.188564" elapsed="0.002721"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.191455" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:16.191312" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:16.188540" elapsed="0.002992"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.192150" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:16.191686" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:16.192229" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:16.184774" elapsed="0.007580"/>
</kw>
<msg time="2026-06-06T03:37:16.192409" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:16.183833" elapsed="0.008624"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.192967" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.193548" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.194121" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.194306" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.194477" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.194855" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:16.194715" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:16.194698" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.195076" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.195237" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.195399" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:16.194668" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.194552" elapsed="0.000927"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.195620" elapsed="0.000035"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.195713" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:16.195832" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:16.179483" elapsed="0.016376"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:16.197138" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:16.196891" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:16.197297" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:16.196535" elapsed="0.000794"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.197657" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:16.197400" elapsed="0.000317"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.198209" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:16.197913" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:16.197742" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:16.197381" elapsed="0.000912"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.200878" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:16.198439" elapsed="0.002467"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:16.200960" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:16.201115" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:16.196213" elapsed="0.004928"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:16.202356" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:16.202119" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:16.202554" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:16.201783" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:16.202805" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:16.202666" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:16.202632" elapsed="0.000258"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.203032" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.203200" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.203267" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:16.205254" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:16.201440" elapsed="0.003842"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.206701" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:16.206431" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:16.207142" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:16.206896" elapsed="0.000290"/>
</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-06-06T03:37:16.215145" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:16.215333" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:16.215479" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:16.209344" elapsed="0.006730">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:16.207252" elapsed="0.008952">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:16.216493" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:16.216254" elapsed="0.000336"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:16.207233" elapsed="0.009392">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:16.217234" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.217434" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:16.217377" elapsed="0.000119"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:16.217350" elapsed="0.000179"/>
</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-06-06T03:37:16.217753" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.217857" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:16.205590" elapsed="0.012423">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.218123" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:16.156792" elapsed="0.061471">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:16.218752" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:16.218471" elapsed="0.000391"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:16.218444" elapsed="0.000455"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:16.218949" elapsed="0.000022"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:16.147489" elapsed="0.071603">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.264921" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:17.264477" elapsed="0.000477"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:17.265844" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:17.265466" elapsed="0.000455">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:17.266025" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:17.265128" elapsed="0.000923"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.266616" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:17.266213" elapsed="0.000451"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:17.266971" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:17.267136" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:17.266825" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.267567" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:17.267313" elapsed="0.000302"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.268662" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:17.268351" elapsed="0.000360"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.269143" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:17.268868" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.269504" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.269730" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.269902" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:17.269373" elapsed="0.000587"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.269226" elapsed="0.000765"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:17.270039" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:37:17.270210" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:17.268027" elapsed="0.002209"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:17.267710" elapsed="0.002559"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.270439" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:17.270296" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:17.267685" elapsed="0.002832"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.271161" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:17.270671" elapsed="0.000590"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:17.271313" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:17.263858" elapsed="0.007587"/>
</kw>
<msg time="2026-06-06T03:37:17.271505" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:17.262963" elapsed="0.008596"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.272111" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.272709" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.273490" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.273703" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.273881" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.274270" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:17.274125" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:17.274107" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.274489" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.274667" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.274831" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:17.274073" elapsed="0.000813"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.273962" elapsed="0.000951"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.275060" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.275138" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:17.275275" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:17.258621" elapsed="0.016682"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:17.276841" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:17.276469" elapsed="0.000450">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:17.277017" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:17.276069" elapsed="0.000973"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.277383" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:17.277120" elapsed="0.000320"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.277975" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:17.277661" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:17.277466" elapsed="0.000577"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:17.277098" elapsed="0.000966"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.280560" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:17.278214" elapsed="0.002379"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:17.280702" elapsed="0.000045"/>
</return>
<msg time="2026-06-06T03:37:17.280890" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:17.275713" elapsed="0.005203"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:17.282326" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:17.282040" elapsed="0.000359">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:17.282495" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:17.281637" elapsed="0.000883"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:17.282772" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:37:17.282597" elapsed="0.000244"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:17.282576" elapsed="0.000292"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.283011" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.283176" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.283243" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:17.285272" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:17.281272" elapsed="0.004027"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.286806" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:17.286504" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:17.287250" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:17.287004" elapsed="0.000290"/>
</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-06-06T03:37:17.294630" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:17.294815" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:17.294940" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:17.289764" elapsed="0.005619">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:17.287366" elapsed="0.008240">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:17.295873" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:17.295671" elapsed="0.000271"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:17.287344" elapsed="0.008622">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:17.296400" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.296543" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:17.296501" elapsed="0.000087"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:17.296481" elapsed="0.000151"/>
</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-06-06T03:37:17.296792" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.296862" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:17.285663" elapsed="0.011310">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.297055" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:17.235179" elapsed="0.061974">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:17.297427" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:17.297247" elapsed="0.000263"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:17.297229" elapsed="0.000306"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:17.297569" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:17.224491" elapsed="0.073191">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.343887" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:18.343360" elapsed="0.000569"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:18.344926" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:18.344581" elapsed="0.000444">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:18.345146" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:18.344144" elapsed="0.001033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.345935" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:18.345403" elapsed="0.000568"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:18.346368" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:18.346575" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:18.346182" elapsed="0.000516"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.347242" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:18.346908" elapsed="0.000404"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.348906" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:18.348548" elapsed="0.000417"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.349585" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:18.349176" elapsed="0.000443"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.350081" elapsed="0.000029"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.350352" elapsed="0.000034"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.350605" elapsed="0.000031"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:18.349903" elapsed="0.000808"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.349712" elapsed="0.001046"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:18.350830" elapsed="0.000052"/>
</return>
<msg time="2026-06-06T03:37:18.351077" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:18.348118" elapsed="0.002996"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:18.347416" elapsed="0.003744"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.351404" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:18.351199" elapsed="0.000286"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:18.347383" elapsed="0.004135"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.352386" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:18.351742" elapsed="0.000683"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:18.352494" elapsed="0.000041"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:18.342752" elapsed="0.009941"/>
</kw>
<msg time="2026-06-06T03:37:18.352775" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:18.341870" elapsed="0.010977"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.353564" elapsed="0.000036"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.354297" elapsed="0.000035"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.355018" elapsed="0.000036"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.355343" elapsed="0.000033"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.355600" elapsed="0.000032"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.356172" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:18.355954" elapsed="0.000304"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:18.355930" elapsed="0.000366"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.356502" elapsed="0.000031"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.356768" elapsed="0.000033"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.357010" elapsed="0.000030"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:18.355885" elapsed="0.001204"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.355733" elapsed="0.001396"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.357393" elapsed="0.000033"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.357514" elapsed="0.000024"/>
</return>
<msg time="2026-06-06T03:37:18.357705" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:18.337516" elapsed="0.020227"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:18.359429" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:18.359151" elapsed="0.000352">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:18.359597" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:18.358677" elapsed="0.000945"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.359980" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:18.359713" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.360531" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:18.360235" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:18.360062" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:18.359693" elapsed="0.000921"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.363254" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:18.360780" elapsed="0.002502"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:18.363335" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:18.363495" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:18.358190" elapsed="0.005330"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:18.364763" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:18.364504" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:18.364924" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:18.364167" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:18.365156" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:18.365020" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:18.365001" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.365482" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.365667" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.365737" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:18.367655" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:18.363840" elapsed="0.003843"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.369103" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:18.368838" elapsed="0.000313"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:18.369572" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:18.369315" elapsed="0.000302"/>
</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-06-06T03:37:18.376395" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:18.376539" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:18.376672" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:18.371806" elapsed="0.005267">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:18.369702" elapsed="0.007465">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:18.377440" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:18.377205" elapsed="0.000305"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:18.369682" elapsed="0.007852">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:18.377961" elapsed="0.000027"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.378100" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:18.378060" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:18.378042" elapsed="0.000124"/>
</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-06-06T03:37:18.378305" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.378374" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:18.367987" elapsed="0.010492">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.378553" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:18.315073" elapsed="0.063588">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:18.378937" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:18.378755" elapsed="0.000254"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:18.378738" elapsed="0.000295"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:18.379125" elapsed="0.000016"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:18.307304" elapsed="0.071921">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.426140" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:19.425703" elapsed="0.000471"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:19.426960" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:19.426698" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:19.427133" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:19.426347" elapsed="0.000812"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.427770" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:19.427352" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:19.428107" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:19.428274" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:19.427958" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.428757" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:19.428461" elapsed="0.000346"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.429822" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:19.429538" elapsed="0.000330"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.430351" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:19.430056" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.430734" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.430938" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.431108" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:19.430583" elapsed="0.000583"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.430436" elapsed="0.000760"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:19.431245" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:19.431416" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:19.429202" elapsed="0.002239"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:19.428887" elapsed="0.002586"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.431656" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:19.431499" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:19.428863" elapsed="0.002872"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.432334" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:19.431873" elapsed="0.000489"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:19.432411" elapsed="0.000036"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:19.425023" elapsed="0.007532"/>
</kw>
<msg time="2026-06-06T03:37:19.432681" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:19.424116" elapsed="0.008630"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.433250" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.433934" elapsed="0.000053"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.434527" elapsed="0.000028"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.434732" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.434902" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.435283" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:19.435141" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:19.435123" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.435521" elapsed="0.000024"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.435707" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.435876" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:19.435085" elapsed="0.000845"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.434976" elapsed="0.000980"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.436096" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.436171" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:19.436288" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:19.419764" elapsed="0.016550"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:19.437542" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:19.437303" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:19.437720" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:19.436965" elapsed="0.000780"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.438128" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:19.437850" elapsed="0.000337"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.438750" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:19.438413" elapsed="0.000363"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:19.438212" elapsed="0.000600"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:19.437830" elapsed="0.001004"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.441234" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:19.438980" elapsed="0.002281"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:19.441313" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:19.441467" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:19.436627" elapsed="0.004864"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:19.442752" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:19.442486" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:19.442915" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:19.442155" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:19.443157" elapsed="0.000029"/>
</return>
<status status="PASS" start="2026-06-06T03:37:19.443011" elapsed="0.000208"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:19.442992" elapsed="0.000252"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.443384" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.443571" elapsed="0.000025"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.443660" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:37:19.447196" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:19.441806" elapsed="0.005418"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.448629" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:19.448370" elapsed="0.000323"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:19.449098" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:19.448845" elapsed="0.000299"/>
</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-06-06T03:37:19.456046" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:19.456185" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:19.456290" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:19.451420" elapsed="0.005273">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:19.449213" elapsed="0.007574">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:19.456977" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:19.456822" elapsed="0.000220"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:19.449194" elapsed="0.007873">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:19.457546" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.457704" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:19.457662" elapsed="0.000086"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:19.457628" elapsed="0.000142"/>
</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-06-06T03:37:19.457910" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.458035" elapsed="0.000026"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:19.447533" elapsed="0.010664">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.458299" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:19.396520" elapsed="0.061901">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:19.458734" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:19.458518" elapsed="0.000291"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:19.458500" elapsed="0.000334"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:19.458868" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:19.388983" elapsed="0.069981">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.504679" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:20.504267" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:20.505479" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:20.505214" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:20.505667" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:20.504883" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.506236" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:20.505852" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:20.506558" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:20.506774" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:20.506417" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.507215" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:20.506956" elapsed="0.000306"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.508230" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:20.507972" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.508824" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:20.508530" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.509183" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.509382" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.509551" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:20.509054" elapsed="0.000555"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.508908" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:20.509702" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:20.509873" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:20.507637" elapsed="0.002261"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:20.507340" elapsed="0.002591"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.510099" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:20.509957" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:20.507315" elapsed="0.002866"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.510802" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:20.510318" elapsed="0.000514"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:20.510882" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:20.503627" elapsed="0.007379"/>
</kw>
<msg time="2026-06-06T03:37:20.511062" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:20.502700" elapsed="0.008412"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.511604" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.512118" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.512611" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.512808" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.512976" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.513335" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:20.513196" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:20.513181" elapsed="0.000283"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.513600" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.513779" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.513940" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:20.513153" elapsed="0.000841"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.513051" elapsed="0.000969"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.514160" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.514235" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:20.514354" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:20.498110" elapsed="0.016269"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:20.515867" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:20.515398" elapsed="0.000541">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:20.516034" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:20.515067" elapsed="0.000993"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.516375" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:20.516132" elapsed="0.000300"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.516944" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:20.516627" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:20.516456" elapsed="0.000552"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:20.516112" elapsed="0.000918"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.519416" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:20.517177" elapsed="0.002266"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:20.519496" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:20.519667" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:20.514741" elapsed="0.004952"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:20.520910" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:20.520664" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:20.521069" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:20.520317" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:20.521302" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:20.521166" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:20.521147" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.521529" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.521711" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.521780" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:20.523754" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:20.519995" elapsed="0.003826"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.525210" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:20.524957" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:20.525666" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:20.525405" elapsed="0.000307"/>
</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-06-06T03:37:20.534075" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:20.534262" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:20.534393" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:20.527863" elapsed="0.007090">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:20.525779" elapsed="0.009292">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:20.535336" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:20.535118" elapsed="0.000351"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:20.525760" elapsed="0.009747">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:20.536066" elapsed="0.000036"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.536254" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:20.536202" elapsed="0.000111"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:20.536176" elapsed="0.000169"/>
</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-06-06T03:37:20.536539" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.536657" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:20.524128" elapsed="0.012680">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.536910" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:20.475454" elapsed="0.061588">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:20.537412" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:20.537171" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:20.537147" elapsed="0.000398"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:20.537591" elapsed="0.000019"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:20.466332" elapsed="0.071411">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.585896" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:21.585482" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:21.586707" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:21.586431" elapsed="0.000353">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:21.586882" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:21.586101" elapsed="0.000806"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.587490" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:21.587069" elapsed="0.000449"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:21.587885" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:21.588127" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:21.587697" elapsed="0.000458"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.588570" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:21.588313" elapsed="0.000307"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.589652" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:21.589374" elapsed="0.000328"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.590140" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:21.589861" elapsed="0.000306"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.590502" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.590722" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.590896" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:21.590369" elapsed="0.000585"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.590223" elapsed="0.000763"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:21.591035" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:21.591205" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:21.589033" elapsed="0.002199"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:21.588721" elapsed="0.002545"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.591488" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:21.591328" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:21.588696" elapsed="0.002873"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.592179" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:21.591726" elapsed="0.000483"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:21.592260" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:21.584871" elapsed="0.007518"/>
</kw>
<msg time="2026-06-06T03:37:21.592445" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:21.583950" elapsed="0.008544"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.593068" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.593583" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.594308" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.594498" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.594686" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.595054" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:21.594912" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:21.594897" elapsed="0.000240"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.595274" elapsed="0.000044"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.595470" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.595635" elapsed="0.000036"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:21.594868" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.594766" elapsed="0.000968"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.595879" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.595957" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:37:21.596111" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:21.579524" elapsed="0.016616"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:21.597379" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:21.597144" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:21.597537" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:21.596807" elapsed="0.000755"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.597888" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:21.597632" elapsed="0.000347"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.598474" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:21.598179" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:21.598006" elapsed="0.000528"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:21.597613" elapsed="0.000943"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.600974" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:21.598718" elapsed="0.002282"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:21.601052" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:21.601206" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:21.596460" elapsed="0.004771"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:21.602485" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:21.602224" elapsed="0.000330">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:21.602665" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:21.601892" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:21.602904" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:21.602766" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:21.602746" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.603134" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.603321" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.603388" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:21.605382" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:21.601521" elapsed="0.003888"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.606817" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:21.606544" elapsed="0.000319"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:21.607256" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:21.607011" elapsed="0.000348"/>
</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-06-06T03:37:21.614337" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:21.614470" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:21.614563" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:21.609689" elapsed="0.005253">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:21.607443" elapsed="0.007581">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:21.615207" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:21.615057" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:21.607422" elapsed="0.007899">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:21.615717" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.615894" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:21.615852" elapsed="0.000085"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:21.615828" elapsed="0.000132"/>
</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-06-06T03:37:21.616100" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.616198" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:21.605731" elapsed="0.010611">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.616447" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:21.556704" elapsed="0.059876">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:21.616972" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:21.616732" elapsed="0.000340"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:21.616707" elapsed="0.000400"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:21.617153" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:21.547910" elapsed="0.069376">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.662530" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:22.662136" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:22.663326" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:22.663074" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:22.663494" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:22.662743" elapsed="0.000776"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.664100" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:22.663691" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:22.664434" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:22.664594" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:22.664289" elapsed="0.000332"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.665038" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:22.664788" elapsed="0.000303"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.666265" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:22.666001" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.666751" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:22.666465" elapsed="0.000313"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.667105" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.667362" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.667534" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:22.666974" elapsed="0.000618"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.666833" elapsed="0.000791"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:22.667687" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:22.667858" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:22.665679" elapsed="0.002205"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:22.665166" elapsed="0.002751"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.668132" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:22.667976" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:22.665143" elapsed="0.003066"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.668808" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:22.668346" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:22.668886" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:22.661511" elapsed="0.007507"/>
</kw>
<msg time="2026-06-06T03:37:22.669073" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:22.660656" elapsed="0.008465"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.669610" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.670132" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.670627" elapsed="0.000038"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.670825" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.670993" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.671355" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:22.671215" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:22.671200" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.671569" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.671783" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.671967" elapsed="0.000025"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:22.671165" elapsed="0.000865"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.671067" elapsed="0.000997"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.672225" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.672303" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:22.672421" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:22.656357" elapsed="0.016090"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:22.673681" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:22.673432" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:22.673840" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:22.673099" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.674180" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:22.673935" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.674741" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:22.674433" elapsed="0.000335"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:22.674262" elapsed="0.000541"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:22.673916" elapsed="0.000909"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.677380" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:22.674970" elapsed="0.002437"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:22.677460" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:22.677614" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:22.672779" elapsed="0.004873"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:22.678858" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:22.678609" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:22.679015" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:22.678278" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:22.679246" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:22.679111" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:22.679093" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.679471" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.679637" elapsed="0.000036"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.679719" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:22.681686" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:22.677951" elapsed="0.003763"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.683139" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:22.682848" elapsed="0.000339"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:22.683582" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:22.683336" elapsed="0.000291"/>
</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-06-06T03:37:22.691323" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:22.691459" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:22.691553" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:22.685823" elapsed="0.006186">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:22.683712" elapsed="0.008388">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:22.692292" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:22.692134" elapsed="0.000224"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:22.683692" elapsed="0.008689">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:22.692774" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.692911" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:22.692874" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:22.692855" elapsed="0.000120"/>
</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-06-06T03:37:22.693115" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.693188" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:22.682012" elapsed="0.011329">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.693446" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:22.633767" elapsed="0.059821">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:22.693989" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:22.693744" elapsed="0.000346"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:22.693719" elapsed="0.000406"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:22.694172" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:22.626812" elapsed="0.067493">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.743784" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:23.743331" elapsed="0.000621"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:23.744807" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:23.744503" elapsed="0.000381">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:23.744984" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:23.744146" elapsed="0.000864"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.745570" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:23.745172" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:23.745948" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:23.746107" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:23.745799" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.746535" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:23.746284" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.747560" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:23.747302" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.748050" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:23.747777" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.748414" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.748670" elapsed="0.000028"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.748847" elapsed="0.000027"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:23.748282" elapsed="0.000631"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.748132" elapsed="0.000812"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:23.748992" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:23.749164" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:23.746983" elapsed="0.002207"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:23.746677" elapsed="0.002546"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.749403" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:23.749249" elapsed="0.000231"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:23.746636" elapsed="0.002866"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.750144" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:23.749660" elapsed="0.000513"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:23.750223" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:23.742688" elapsed="0.007659"/>
</kw>
<msg time="2026-06-06T03:37:23.750402" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:23.741741" elapsed="0.008708"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.750995" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.751554" elapsed="0.000034"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.752317" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.752509" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.752744" elapsed="0.000025"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.753108" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:23.752968" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:23.752953" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.753322" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.753484" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.753659" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:23.752925" elapsed="0.000790"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.752826" elapsed="0.000915"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.753881" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.753957" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:23.754073" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:23.737073" elapsed="0.017025"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:23.755413" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:23.755173" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:23.755571" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:23.754797" elapsed="0.000798"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.755928" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:23.755684" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.756478" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:23.756185" elapsed="0.000319"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:23.756010" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:23.755663" elapsed="0.000898"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.759147" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:23.756767" elapsed="0.002409"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:23.759262" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:23.759421" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:23.754437" elapsed="0.005009"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:23.760789" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:23.760510" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:23.760949" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:23.760167" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:23.761189" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:23.761045" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:23.761027" elapsed="0.000246"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.761415" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.761582" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.761663" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:23.763609" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:23.759767" elapsed="0.003868"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.765059" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:23.764806" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:23.765492" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:23.765251" elapsed="0.000285"/>
</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-06-06T03:37:23.772695" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:23.772836" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:23.772932" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:23.767870" elapsed="0.005445">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:23.765602" elapsed="0.007827">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:23.773702" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:23.773474" elapsed="0.000320"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:23.765584" elapsed="0.008243">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:23.774338" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.774522" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:23.774470" elapsed="0.000109"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:23.774445" elapsed="0.000166"/>
</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-06-06T03:37:23.774824" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.774922" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:23.763952" elapsed="0.011111">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.775211" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:23.712871" elapsed="0.062476">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:23.775779" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:23.775476" elapsed="0.000409"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:23.775453" elapsed="0.000466"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:23.775966" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:23.705883" elapsed="0.070216">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.823308" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:24.822907" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:24.824116" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:24.823859" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:24.824287" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:24.823513" elapsed="0.000798"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.824867" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:24.824470" elapsed="0.000424"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:24.825189" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:24.825406" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:24.825048" elapsed="0.000385"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.826039" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:24.825584" elapsed="0.000501"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.827057" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:24.826800" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.827527" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:24.827261" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.827893" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.828091" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.828259" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:24.827763" elapsed="0.000553"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.827607" elapsed="0.000740"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:24.828455" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:24.828625" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:24.826466" elapsed="0.002199"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:24.826162" elapsed="0.002537"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.828866" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:24.828725" elapsed="0.000212"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:24.826138" elapsed="0.002825"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.829593" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:24.829104" elapsed="0.000520"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:24.829698" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:24.822287" elapsed="0.007538"/>
</kw>
<msg time="2026-06-06T03:37:24.829879" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:24.821408" elapsed="0.008518"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.830411" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.830922" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.831414" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.831595" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.831784" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.832135" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:24.831998" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:24.831983" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.832348" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.832507" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.832685" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:24.831955" elapsed="0.000784"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.831859" elapsed="0.000906"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.832947" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.833024" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:24.833139" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:24.817065" elapsed="0.016099"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:24.834436" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:24.834195" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:24.834598" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:24.833865" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.834959" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:24.834713" elapsed="0.000303"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.835513" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:24.835208" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:24.835040" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:24.834694" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.839548" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:24.835765" elapsed="0.003813"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:24.839633" elapsed="0.000050"/>
</return>
<msg time="2026-06-06T03:37:24.839816" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:24.833527" elapsed="0.006322"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:24.841080" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:24.840841" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:24.841283" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:24.840485" elapsed="0.000830"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:24.841528" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:24.841389" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:24.841370" elapsed="0.000243"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.841771" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.841938" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.842004" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:24.843931" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:24.840154" elapsed="0.003804"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.845355" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:24.845074" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:24.845814" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:24.845549" elapsed="0.000310"/>
</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-06-06T03:37:24.853963" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:24.854135" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:24.854235" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:24.848005" elapsed="0.006588">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:24.845925" elapsed="0.008766">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:24.854875" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:24.854725" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:24.845907" elapsed="0.009057">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:24.855328" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.855459" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:24.855422" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:24.855404" elapsed="0.000119"/>
</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-06-06T03:37:24.855674" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.855747" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:24.844255" elapsed="0.011594">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.855922" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:24.794550" elapsed="0.061464">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:24.856277" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:24.856104" elapsed="0.000245"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:24.856087" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:24.856407" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:24.785533" elapsed="0.070968">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.901751" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:25.901337" elapsed="0.000447"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:25.902573" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:25.902303" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:25.902763" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:25.901967" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.903508" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:25.903111" elapsed="0.000425"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:25.903876" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:25.904034" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:25.903718" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.904466" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:25.904214" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.905509" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:25.905250" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.906041" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:25.905724" elapsed="0.000343"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.906400" elapsed="0.000034"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.906616" elapsed="0.000038"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.906805" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:25.906270" elapsed="0.000593"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.906125" elapsed="0.000769"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:25.906943" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:25.907111" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:25.904926" elapsed="0.002210"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:25.904593" elapsed="0.002577"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.907337" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:25.907195" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:25.904569" elapsed="0.002843"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.908026" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:25.907550" elapsed="0.000505"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:25.908104" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:25.900724" elapsed="0.007505"/>
</kw>
<msg time="2026-06-06T03:37:25.908285" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:25.899825" elapsed="0.008511"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.908858" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.909361" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.909954" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.910139" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.910309" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.910920" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:25.910776" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:25.910759" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.911135" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.911298" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.911458" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:25.910727" elapsed="0.000784"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.910386" elapsed="0.001151"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.911695" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.911772" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:25.911894" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:25.895452" elapsed="0.016467"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:25.913216" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:25.912940" elapsed="0.000355">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:25.913387" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:25.912568" elapsed="0.000844"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.913745" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:25.913482" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.914367" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:25.914070" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:25.913827" elapsed="0.000601"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:25.913463" elapsed="0.000986"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.916945" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:25.914594" elapsed="0.002378"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:25.917027" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:25.917188" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:25.912232" elapsed="0.004981"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:25.918506" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:25.918241" elapsed="0.000337">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:25.918765" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:25.917898" elapsed="0.000891"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:25.919004" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:25.918863" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:25.918843" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.919230" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.919397" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.919463" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:25.921430" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:25.917530" elapsed="0.003927"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.922913" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:25.922632" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:25.923350" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:25.923107" elapsed="0.000286"/>
</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-06-06T03:37:25.930492" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:25.930711" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:25.930860" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:25.925745" elapsed="0.005657">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:25.923458" elapsed="0.008065">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:25.931825" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:25.931574" elapsed="0.000349"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:25.923440" elapsed="0.008519">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:25.932510" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.932730" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:25.932670" elapsed="0.000122"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:25.932624" elapsed="0.000201"/>
</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-06-06T03:37:25.933030" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.933131" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:25.921778" elapsed="0.011505">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.933392" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:25.872741" elapsed="0.060789">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:25.934052" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:25.933764" elapsed="0.000397"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:25.933736" elapsed="0.000461"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:25.934248" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:25.866467" elapsed="0.067923">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.981331" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:26.980922" elapsed="0.000443"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:26.982163" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:26.981901" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:26.982341" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:26.981539" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.982944" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:26.982537" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:26.983273" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:26.983494" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:26.983128" elapsed="0.000394"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.983964" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:26.983709" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.985334" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:26.985067" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.985830" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:26.985539" elapsed="0.000318"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.986186" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.986385" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.986593" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:26.986056" elapsed="0.000611"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:26.985913" elapsed="0.000785"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:26.986747" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:37:26.986918" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:26.984730" elapsed="0.002213"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:26.984093" elapsed="0.002882"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.987141" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:26.987001" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:26.984069" elapsed="0.003147"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.987822" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:26.987359" elapsed="0.000550"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:26.987962" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:26.980238" elapsed="0.007850"/>
</kw>
<msg time="2026-06-06T03:37:26.988143" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:26.979292" elapsed="0.008902"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.988858" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.989371" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.989890" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.990073" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.990241" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.990622" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:26.990460" elapsed="0.000235"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:26.990444" elapsed="0.000276"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.990855" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.991018" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.991178" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:26.990415" elapsed="0.000820"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:26.990315" elapsed="0.000946"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.991400" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:26.991475" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:26.991594" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:26.974833" elapsed="0.016788"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:26.993072" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:26.992820" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:26.993237" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:26.992324" elapsed="0.000939"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.993569" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:26.993333" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.994139" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:26.993845" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:26.993673" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:26.993314" elapsed="0.000907"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:26.996850" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:26.994371" elapsed="0.002507"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:26.996931" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:26.997085" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:26.991999" elapsed="0.005112"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:26.998337" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:26.998086" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:26.998498" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:26.997746" elapsed="0.000790"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:26.998769" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:26.998610" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:26.998590" elapsed="0.000265"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.998997" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:26.999165" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:26.999231" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:27.001238" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:26.997408" elapsed="0.003857"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:27.002738" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:27.002426" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:27.003178" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:27.002932" elapsed="0.000290"/>
</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-06-06T03:37:27.010162" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:27.010297" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:27.010400" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:27.005380" elapsed="0.005457">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:27.003290" elapsed="0.007686">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:27.011163" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:27.011012" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:27.003271" elapsed="0.007984">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:27.011824" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:27.012023" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:27.011965" elapsed="0.000120"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:27.011939" elapsed="0.000179"/>
</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-06-06T03:37:27.012324" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:27.012429" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:27.001579" elapsed="0.011001">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:27.012713" elapsed="0.000024"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:26.952031" elapsed="0.060823">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:27.013243" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:27.012990" elapsed="0.000363"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:27.012965" elapsed="0.000424"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:27.013436" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:26.943739" elapsed="0.069835">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.062201" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:28.061805" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:28.063016" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:28.062747" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:28.063214" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:28.062400" elapsed="0.000839"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.063823" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:28.063406" elapsed="0.000444"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:28.064149" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:28.064320" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:28.064007" elapsed="0.000398"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.064829" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:28.064560" elapsed="0.000316"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.065839" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:28.065565" elapsed="0.000318"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.066305" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:28.066038" elapsed="0.000293"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.066673" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.066881" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.067050" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:28.066529" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.066387" elapsed="0.000778"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:28.067213" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:28.067379" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:28.065247" elapsed="0.002158"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:28.064954" elapsed="0.002484"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.067610" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:28.067467" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:28.064931" elapsed="0.002771"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.068294" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:28.067845" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:28.068377" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:28.061173" elapsed="0.007328"/>
</kw>
<msg time="2026-06-06T03:37:28.068557" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:28.060302" elapsed="0.008302"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.069114" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.069711" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.070398" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.070622" elapsed="0.000037"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.070816" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.071201" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:28.071041" elapsed="0.000221"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:28.071026" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.071423" elapsed="0.000029"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.071595" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.071778" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:28.070997" elapsed="0.000835"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.070894" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.071999" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.072075" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:28.072192" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:28.055989" elapsed="0.016229"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:28.073454" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:28.073214" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:28.073617" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:28.072877" elapsed="0.000779"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.073969" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:28.073730" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.074519" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:28.074225" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:28.074057" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:28.073711" elapsed="0.000891"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.077111" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:28.074763" elapsed="0.002376"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:28.077191" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:28.077345" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:28.072535" elapsed="0.004836"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:28.078605" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:28.078341" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:28.078779" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:28.077996" elapsed="0.000807"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:28.079011" elapsed="0.000031"/>
</return>
<status status="PASS" start="2026-06-06T03:37:28.078874" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:28.078856" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.079289" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.079458" elapsed="0.000027"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.079531" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:28.081465" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:28.077678" elapsed="0.003814"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.082878" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:28.082613" elapsed="0.000312"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:28.083341" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:28.083071" elapsed="0.000315"/>
</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-06-06T03:37:28.090079" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:28.090216" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:28.090312" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:28.085700" elapsed="0.004999">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:28.083452" elapsed="0.007328">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:28.090959" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:28.090812" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:28.083433" elapsed="0.007615">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:28.091443" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.091574" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:28.091537" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:28.091520" elapsed="0.000117"/>
</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-06-06T03:37:28.091791" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.091861" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:28.081804" elapsed="0.010159">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.092037" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:28.032595" elapsed="0.059536">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:28.092435" elapsed="0.000042"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:28.092222" elapsed="0.000322"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:28.092206" elapsed="0.000372"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:28.092688" elapsed="0.000024"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:28.023910" elapsed="0.068920">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.138796" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:29.138384" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:29.139580" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:29.139327" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:29.139799" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:29.138997" elapsed="0.000830"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.140377" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:29.139987" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:29.140724" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:29.140889" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:29.140560" elapsed="0.000356"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.141314" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:29.141065" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.142530" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:29.142273" elapsed="0.000302"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.143017" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:29.142746" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.143371" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.143570" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.143764" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:29.143242" elapsed="0.000580"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.143099" elapsed="0.000754"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:29.143899" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:29.144065" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:29.141952" elapsed="0.002138"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:29.141442" elapsed="0.002679"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.144286" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:29.144146" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:29.141419" elapsed="0.002942"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.144951" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:29.144496" elapsed="0.000483"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:29.145027" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:29.137782" elapsed="0.007368"/>
</kw>
<msg time="2026-06-06T03:37:29.145260" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:29.136884" elapsed="0.008425"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.145812" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.146308" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.146819" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.146999" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.147165" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.147511" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:29.147376" elapsed="0.000191"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:29.147361" elapsed="0.000229"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.147738" elapsed="0.000052"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.147933" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.148093" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:29.147333" elapsed="0.000812"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.147239" elapsed="0.000932"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.148315" elapsed="0.000029"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.148399" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:29.148513" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:29.132565" elapsed="0.015973"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:29.149769" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:29.149517" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:29.149932" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:29.149185" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.150304" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:29.150066" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.150872" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:29.150554" elapsed="0.000344"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:29.150385" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:29.150046" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.153489" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:29.151098" elapsed="0.002418"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:29.153568" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:29.153737" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:29.148864" elapsed="0.004898"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:29.154953" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:29.154719" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:29.155107" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:29.154375" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:29.155336" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:29.155200" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:29.155182" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.155558" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.155739" elapsed="0.000055"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.155841" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:29.157830" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:29.154056" elapsed="0.003802"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.159351" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:29.159066" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:29.159827" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:29.159549" elapsed="0.000323"/>
</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-06-06T03:37:29.166356" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:29.166494" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:29.166596" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:29.162046" elapsed="0.004945">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:29.159940" elapsed="0.007133">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:29.167251" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:29.167106" elapsed="0.000209"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:29.159921" elapsed="0.007417">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:29.167811" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.167946" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:29.167908" elapsed="0.000079"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:29.167890" elapsed="0.000119"/>
</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-06-06T03:37:29.168145" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.168215" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:29.158201" elapsed="0.010116">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.168389" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:29.110082" elapsed="0.058400">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:29.168769" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:29.168574" elapsed="0.000268"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:29.168557" elapsed="0.000309"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:29.168898" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:29.102834" elapsed="0.066159">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.215223" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:30.214830" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:30.216020" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:30.215768" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:30.216194" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:30.215424" elapsed="0.000795"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.216818" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:30.216412" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:30.217142" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:30.217310" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:30.217001" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.217759" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:30.217495" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.218773" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:30.218499" elapsed="0.000319"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.219308" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:30.219037" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.219677" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.219879" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.220047" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:30.219531" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.219389" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:30.220181" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:30.220346" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:30.218183" elapsed="0.002201"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:30.217882" elapsed="0.002539"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.220587" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:30.220446" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:30.217859" elapsed="0.002819"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.221252" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:30.220814" elapsed="0.000465"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:30.221328" elapsed="0.000027"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:30.214208" elapsed="0.007246"/>
</kw>
<msg time="2026-06-06T03:37:30.221508" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:30.213317" elapsed="0.008237"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.222058" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.224083" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.224757" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.224943" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.225112" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.225467" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:30.225328" elapsed="0.000229"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:30.225313" elapsed="0.000269"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.225735" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.225900" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.226062" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:30.225284" elapsed="0.000832"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.225186" elapsed="0.000956"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.226281" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.226363" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:30.226479" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:30.209018" elapsed="0.017487"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:30.227913" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:30.227675" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:30.228072" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:30.227325" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.228497" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:30.228169" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.229094" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:30.228798" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:30.228590" elapsed="0.000566"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:30.228150" elapsed="0.001027"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.231536" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:30.229321" elapsed="0.002242"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:30.231614" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:37:30.231784" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:30.227006" elapsed="0.004804"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:30.233035" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:30.232801" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:30.233190" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:30.232450" elapsed="0.000765"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:30.233421" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:30.233285" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:30.233266" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.233658" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.233826" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.233891" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:30.235964" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:30.232103" elapsed="0.003933"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.237457" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:30.237206" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:30.237916" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:30.237668" elapsed="0.000293"/>
</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-06-06T03:37:30.244043" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:30.244177" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:30.244279" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:30.240122" elapsed="0.004579">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:30.238027" elapsed="0.006758">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:30.244968" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:30.244818" elapsed="0.000216"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:30.238008" elapsed="0.007050">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:30.245449" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.245665" elapsed="0.000022"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:30.245589" elapsed="0.000140"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:30.245562" elapsed="0.000201"/>
</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-06-06T03:37:30.245969" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.246072" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:30.236344" elapsed="0.009878">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.246331" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:30.186422" elapsed="0.060051">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:30.246882" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:30.246608" elapsed="0.000381"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:30.246583" elapsed="0.000442"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:30.247073" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:30.178748" elapsed="0.068464">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.293034" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:31.292579" elapsed="0.000489"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:31.293836" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:31.293571" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:31.294005" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:31.293238" elapsed="0.000792"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.294576" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:31.294190" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:31.294917" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:31.295080" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:31.294774" elapsed="0.000333"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.295506" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:31.295259" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.296516" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:31.296258" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.297014" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:31.296731" elapsed="0.000310"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.297366" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.297565" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.297749" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:31.297237" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.297096" elapsed="0.000741"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:31.297885" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:31.298048" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:31.295939" elapsed="0.002134"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:31.295628" elapsed="0.002477"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.298270" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:31.298131" elapsed="0.000193"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:31.295606" elapsed="0.002739"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.298953" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:31.298489" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:31.299029" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:31.291963" elapsed="0.007189"/>
</kw>
<msg time="2026-06-06T03:37:31.299207" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:31.291042" elapsed="0.008212"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.299813" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.300314" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.300829" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.301045" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.301216" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.301570" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:31.301430" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:31.301415" elapsed="0.000249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.301803" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.301966" elapsed="0.000025"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.302134" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:31.301388" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.301290" elapsed="0.000924"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.302356" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.302431" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:31.302549" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:31.286190" elapsed="0.016385"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:31.304003" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:31.303570" elapsed="0.000499">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:31.304163" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:31.303235" elapsed="0.000953"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.304500" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:31.304258" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.305128" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:31.304806" elapsed="0.000348"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:31.304615" elapsed="0.000575"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:31.304239" elapsed="0.000973"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.307588" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:31.305360" elapsed="0.002255"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:31.307683" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:31.307840" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:31.302911" elapsed="0.004954"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:31.309086" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:31.308829" elapsed="0.000321">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:31.309245" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:31.308476" elapsed="0.000793"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:31.309476" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:31.309341" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:31.309321" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.309715" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.309883" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.309949" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:31.311892" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:31.308158" elapsed="0.003761"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.313310" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:31.313058" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:31.313763" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:31.313503" elapsed="0.000304"/>
</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-06-06T03:37:31.320673" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:31.320809" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:31.320904" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:31.315962" elapsed="0.005336">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:31.313874" elapsed="0.007507">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:31.321562" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:31.321414" elapsed="0.000214"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:31.313855" elapsed="0.007811">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:31.322038" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.322211" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:31.322171" elapsed="0.000083"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:31.322152" elapsed="0.000125"/>
</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-06-06T03:37:31.322419" elapsed="0.000030"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.322498" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:31.312216" elapsed="0.010387">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.322696" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:31.263526" elapsed="0.059268">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:31.323061" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:31.322887" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:31.322870" elapsed="0.000288"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:31.323191" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:31.256885" elapsed="0.066401">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.369507" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:32.369100" elapsed="0.000442"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:32.370426" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:32.370124" elapsed="0.000406">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:32.370669" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:32.369770" elapsed="0.000926"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.371281" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:32.370864" elapsed="0.000445"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:32.371620" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:32.371813" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:32.371468" elapsed="0.000374"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.372266" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:32.372006" elapsed="0.000310"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.373324" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:32.373055" elapsed="0.000316"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.373863" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:32.373530" elapsed="0.000360"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.374229" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.374526" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.374718" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:32.374095" elapsed="0.000684"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.373948" elapsed="0.000861"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:32.374857" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:32.375032" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:32.372719" elapsed="0.002339"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:32.372396" elapsed="0.002695"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.375264" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:32.375116" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:32.372372" elapsed="0.002969"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.375962" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:32.375480" elapsed="0.000510"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:32.376043" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:32.368461" elapsed="0.007708"/>
</kw>
<msg time="2026-06-06T03:37:32.376227" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:32.367541" elapsed="0.008734"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.376792" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.377330" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.378236" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.378446" elapsed="0.000032"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.378685" elapsed="0.000028"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.379085" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:32.378940" elapsed="0.000203"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:32.378924" elapsed="0.000243"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.379304" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.379522" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.379703" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:32.378894" elapsed="0.000880"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.378780" elapsed="0.001021"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.379947" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.380025" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:32.380146" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:32.363187" elapsed="0.016986"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:32.381508" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:32.381237" elapsed="0.000373">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:32.381729" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:32.380874" elapsed="0.000881"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.382085" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:32.381828" elapsed="0.000314"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.382664" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:32.382348" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:32.382169" elapsed="0.000560"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:32.381808" elapsed="0.000942"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.385175" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:32.382900" elapsed="0.002302"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:32.385255" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:32.385414" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:32.380500" elapsed="0.004939"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:32.386699" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:32.386439" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:32.386857" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:32.386103" elapsed="0.000785"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:32.387096" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:32.386959" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:32.386940" elapsed="0.000239"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.387320" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.387484" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.387549" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:32.389493" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:32.385781" elapsed="0.003739"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.391965" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:32.390690" elapsed="0.001352"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:32.392510" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:32.392238" elapsed="0.000317"/>
</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-06-06T03:37:32.399851" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:32.400002" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:32.400100" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:32.394928" elapsed="0.005589">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:32.392622" elapsed="0.007979">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:32.400804" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:32.400635" elapsed="0.000234"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:32.392603" elapsed="0.008289">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:32.401278" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.401412" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:32.401373" elapsed="0.000081"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:32.401356" elapsed="0.000120"/>
</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-06-06T03:37:32.401656" elapsed="0.000024"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.401731" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:32.389871" elapsed="0.011965">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.401910" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:32.340335" elapsed="0.061671">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:32.402274" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:32.402099" elapsed="0.000247"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:32.402082" elapsed="0.000288"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:32.402404" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:32.333375" elapsed="0.069126">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.448718" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:33.448306" elapsed="0.000548"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:33.449654" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:33.449374" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:33.449828" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:33.449033" elapsed="0.000821"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.450434" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:33.450016" elapsed="0.000446"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:33.450782" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:33.450952" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:33.450620" elapsed="0.000359"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.451382" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:33.451131" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.452618" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:33.452354" elapsed="0.000326"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.453110" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:33.452837" elapsed="0.000300"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.453468" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.453683" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.453852" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:33.453339" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.453193" elapsed="0.000746"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:33.453987" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:33.454185" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:33.452026" elapsed="0.002186"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:33.451507" elapsed="0.002738"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.454415" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:33.454271" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:33.451483" elapsed="0.003008"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.455095" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:33.454629" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:33.455171" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:33.447701" elapsed="0.007593"/>
</kw>
<msg time="2026-06-06T03:37:33.455348" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:33.446799" elapsed="0.008596"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.455898" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.456471" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.456998" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.457182" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.457356" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.457740" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:33.457581" elapsed="0.000217"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:33.457567" elapsed="0.000255"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.457959" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.458120" elapsed="0.000051"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.458316" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:33.457538" elapsed="0.000831"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.457433" elapsed="0.000961"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.458535" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.458610" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:33.458749" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:33.442502" elapsed="0.016274"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:33.459995" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:33.459756" elapsed="0.000304">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:33.460153" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:33.459405" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.460491" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:33.460247" elapsed="0.000302"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.461062" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:33.460768" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:33.460573" elapsed="0.000550"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:33.460228" elapsed="0.000916"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.463727" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:33.461289" elapsed="0.002465"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:33.463837" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:33.463995" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:33.459088" elapsed="0.004932"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:33.465211" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:33.464979" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:33.465388" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:33.464631" elapsed="0.000783"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:33.465633" elapsed="0.000049"/>
</return>
<status status="PASS" start="2026-06-06T03:37:33.465488" elapsed="0.000230"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:33.465468" elapsed="0.000275"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.465888" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.466057" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.466125" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:33.468097" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:33.464314" elapsed="0.003809"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.469514" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:33.469244" elapsed="0.000331"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:33.470015" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:33.469746" elapsed="0.000314"/>
</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-06-06T03:37:33.477154" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:33.477290" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:33.477386" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:33.472223" elapsed="0.005552">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:33.470127" elapsed="0.007758">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:33.478079" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:33.477925" elapsed="0.000221"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:33.470109" elapsed="0.008105">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:33.478679" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.478872" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:33.478819" elapsed="0.000113"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:33.478793" elapsed="0.000169"/>
</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-06-06T03:37:33.479157" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.479256" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:33.468420" elapsed="0.010983">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.479558" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:33.419825" elapsed="0.059890">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:33.480093" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:33.479847" elapsed="0.000348"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:33.479823" elapsed="0.000406"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:33.480276" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:33.411985" elapsed="0.068423">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.537442" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:34.537043" elapsed="0.000432"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:34.538253" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:34.537998" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:34.538422" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:34.537660" elapsed="0.000787"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.539037" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:34.538607" elapsed="0.000457"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:34.539370" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:34.539533" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:34.539227" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.540019" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:34.539761" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.541037" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:34.540781" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.541502" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:34.541235" elapsed="0.000292"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.541879" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.542076" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.542243" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:34.541749" elapsed="0.000551"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.541585" elapsed="0.000745"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:34.542449" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:34.542619" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:34.540445" elapsed="0.002213"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:34.540144" elapsed="0.002549"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.542871" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:34.542729" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:34.540121" elapsed="0.002832"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.543531" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:34.543088" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:34.543607" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:34.536418" elapsed="0.007335"/>
</kw>
<msg time="2026-06-06T03:37:34.543808" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:34.535455" elapsed="0.008400"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.544340" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.544852" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.545615" elapsed="0.000049"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.545835" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.546005" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.546367" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:34.546222" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:34.546207" elapsed="0.000271"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.546634" elapsed="0.000038"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.546857" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.547020" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:34.546180" elapsed="0.000894"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.546081" elapsed="0.001019"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.547289" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.547368" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:34.547486" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:34.530607" elapsed="0.016905"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:34.548765" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:34.548499" elapsed="0.000333">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:34.548925" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:34.548163" elapsed="0.000787"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.549298" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:34.549021" elapsed="0.000339"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.549904" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:34.549586" elapsed="0.000345"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:34.549385" elapsed="0.000582"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:34.549002" elapsed="0.000986"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.552385" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:34.550134" elapsed="0.002279"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:34.552465" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:34.552624" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:34.547844" elapsed="0.004822"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:34.553934" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:34.553617" elapsed="0.000382">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:34.554141" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:34.553284" elapsed="0.000885"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:34.554382" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:34.554244" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:34.554224" elapsed="0.000244"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.554616" elapsed="0.000045"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.554842" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.554910" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:34.556876" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:34.552966" elapsed="0.003938"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.558278" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:34.558028" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:34.558767" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:34.558481" elapsed="0.000334"/>
</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-06-06T03:37:34.566054" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:34.566315" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:34.566458" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:34.561137" elapsed="0.005874">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:34.558886" elapsed="0.008234">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:34.567400" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:34.567164" elapsed="0.000309"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:34.558866" elapsed="0.008634">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:34.568007" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.568193" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:34.568147" elapsed="0.000093"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:34.568120" elapsed="0.000143"/>
</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-06-06T03:37:34.568408" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.568480" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:34.557214" elapsed="0.011377">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.568687" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:34.495851" elapsed="0.072934">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:34.569061" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:34.568879" elapsed="0.000256"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:34.568862" elapsed="0.000297"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:34.569192" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:34.486967" elapsed="0.082322">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.614293" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:35.613893" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:35.615128" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:35.614864" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:35.616173" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:35.614501" elapsed="0.001701"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.616862" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:35.616456" elapsed="0.000433"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:35.617189" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:35.617352" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:35.617044" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.619484" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:35.617531" elapsed="0.002001"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.620519" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:35.620260" elapsed="0.000303"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.621008" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:35.620733" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.621368" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.621565" elapsed="0.000023"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.621749" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:35.621238" elapsed="0.000569"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.621091" elapsed="0.000747"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:35.621888" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:35.622058" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:35.619938" elapsed="0.002144"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:35.619612" elapsed="0.002502"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.622280" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:35.622140" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:35.619587" elapsed="0.002774"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.622962" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:35.622498" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:35.623039" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:35.613246" elapsed="0.009917"/>
</kw>
<msg time="2026-06-06T03:37:35.623219" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:35.612199" elapsed="0.011107"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.623817" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.624312" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.624870" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.625051" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.625216" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.625568" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:35.625431" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:35.625416" elapsed="0.000247"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.625800" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.625962" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.626122" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:35.625388" elapsed="0.000786"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.625289" elapsed="0.000911"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.626339" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.626413" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:35.626534" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:35.607788" elapsed="0.018774"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:35.627863" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:35.627581" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:35.628034" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:35.627219" elapsed="0.000839"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.628376" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:35.628134" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.628940" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:35.628628" elapsed="0.000338"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:35.628455" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:35.628113" elapsed="0.000910"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.631706" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:35.629169" elapsed="0.002566"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:35.631789" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:35.631950" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:35.626889" elapsed="0.005086"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:35.633237" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:35.632975" elapsed="0.000335">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:35.633470" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:35.632611" elapsed="0.000883"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:35.633726" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:35.633567" elapsed="0.000219"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:35.633548" elapsed="0.000263"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.633954" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.634119" elapsed="0.000029"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.634193" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:35.636174" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:35.632280" elapsed="0.003921"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.637627" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:35.637361" elapsed="0.000341"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:35.638098" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:35.637850" elapsed="0.000292"/>
</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-06-06T03:37:35.647014" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:35.647236" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:35.647473" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:35.640384" elapsed="0.007694">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:35.638210" elapsed="0.010006">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:35.648548" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:35.648273" elapsed="0.000396"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:35.638191" elapsed="0.010515">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:35.649316" elapsed="0.000039"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.649524" elapsed="0.000023"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:35.649465" elapsed="0.000125"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:35.649436" elapsed="0.000187"/>
</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-06-06T03:37:35.649852" elapsed="0.000032"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.649956" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:35.636518" elapsed="0.013598">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.650225" elapsed="0.000025"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:35.585348" elapsed="0.065019">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:35.650886" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:35.650602" elapsed="0.000392"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:35.650576" elapsed="0.000455"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:35.651078" elapsed="0.000021"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:35.578733" elapsed="0.072486">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.696360" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:36.695962" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:36.697160" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:36.696911" elapsed="0.000323">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:36.697330" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:36.696563" elapsed="0.000791"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.697921" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:36.697515" elapsed="0.000434"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:36.698244" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:36.698412" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:36.698103" elapsed="0.000335"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.698862" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:36.698591" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.699906" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:36.699600" elapsed="0.000352"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.700378" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:36.700108" elapsed="0.000296"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.700750" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.700953" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.701122" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:36.700604" elapsed="0.000576"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.700461" elapsed="0.000749"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:36.701258" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:36.701423" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:36.699281" elapsed="0.002168"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:36.698986" elapsed="0.002496"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.701667" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:36.701507" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:36.698963" elapsed="0.002782"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.702329" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:36.701884" elapsed="0.000529"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:36.702464" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:36.695312" elapsed="0.007277"/>
</kw>
<msg time="2026-06-06T03:37:36.702658" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:36.694427" elapsed="0.008281"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.703199" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.703719" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.704232" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.704416" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.704586" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.705141" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:36.704997" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:36.704982" elapsed="0.000241"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.705373" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.705541" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.705724" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:36.704953" elapsed="0.000826"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.704678" elapsed="0.001127"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.705946" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.706021" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:36.706136" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:36.690110" elapsed="0.016051"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:36.707450" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:36.707215" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:36.707611" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:36.706880" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.707996" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:36.707725" elapsed="0.000328"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.708541" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:36.708250" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:36.708078" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:36.707706" elapsed="0.000917"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.711011" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:36.708787" elapsed="0.002251"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:36.711089" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:36.711242" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:36.706517" elapsed="0.004750"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:36.712472" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:36.712240" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:36.712627" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:36.711911" elapsed="0.000756"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:36.712875" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:36.712739" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:36.712720" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.713097" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.713262" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.713328" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:36.715290" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:36.711562" elapsed="0.003755"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.716733" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:36.716469" elapsed="0.000310"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:36.717166" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:36.716925" elapsed="0.000284"/>
</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-06-06T03:37:36.724372" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:36.724513" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:36.724613" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:36.719515" elapsed="0.005486">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:36.717274" elapsed="0.007843">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:36.725303" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:36.725152" elapsed="0.000217"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:36.717256" elapsed="0.008137">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:36.725783" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.725916" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:36.725878" elapsed="0.000080"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:36.725861" elapsed="0.000120"/>
</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-06-06T03:37:36.726118" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.726188" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:36.715618" elapsed="0.010672">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.726365" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:36.667343" elapsed="0.059115">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:36.726737" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:36.726549" elapsed="0.000261"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:36.726532" elapsed="0.000302"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:36.726868" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:36.660924" elapsed="0.066038">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.771616" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:37.771214" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.772452" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.772175" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:37.772626" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:37.771839" elapsed="0.000826"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.773223" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:37.772834" elapsed="0.000416"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.773547" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:37.773729" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:37.773405" elapsed="0.000416"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.774231" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.773978" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.775477" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.775210" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.775977" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:37.775702" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.776335" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.776567" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.776752" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:37.776205" elapsed="0.000606"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.776060" elapsed="0.000782"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:37.776889" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:37.777056" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:37.774882" elapsed="0.002200"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:37.774355" elapsed="0.002760"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.777283" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.777140" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.774332" elapsed="0.003028"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.777962" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:37.777497" elapsed="0.000494"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:37.778041" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:37.770434" elapsed="0.007733"/>
</kw>
<msg time="2026-06-06T03:37:37.778221" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:37.769559" elapsed="0.008711"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.778784" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.779289" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.779806" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.780023" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.780193" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.780567" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.780426" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:37.780410" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.780800" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.780960" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.781120" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:37.780367" elapsed="0.000806"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.780268" elapsed="0.000930"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.781337" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.781413" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:37.781529" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:37.765287" elapsed="0.016268"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.782784" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.782533" elapsed="0.000315">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:37.782940" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:37.782200" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.783273" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.783035" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.783833" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:37.783523" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:37.783353" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.783016" elapsed="0.000898"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.786444" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:37.784058" elapsed="0.002413"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:37.786524" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:37.786692" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:37.781882" elapsed="0.004836"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.787914" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.787675" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:37.788070" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:37.787330" elapsed="0.000764"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:37.788299" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:37.788164" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.788145" elapsed="0.000237"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.788580" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.788771" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.788838" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:37.790759" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:37.787012" elapsed="0.003773"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.792149" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.791896" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.792614" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.792342" elapsed="0.000337"/>
</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-06-06T03:37:37.800194" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:37.800329" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:37.800456" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:37.794819" elapsed="0.006135">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.792747" elapsed="0.008326">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:37.801336" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.801121" elapsed="0.000310"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.792729" elapsed="0.008737">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:37.802028" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.802224" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:37.802168" elapsed="0.000118"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:37.802142" elapsed="0.000178"/>
</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-06-06T03:37:37.802520" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.802625" elapsed="0.000043"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:37.791080" elapsed="0.011719">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.802908" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.742788" elapsed="0.060259">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.803436" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.803181" elapsed="0.000361"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:37.803157" elapsed="0.000421"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.803693" elapsed="0.000024"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.736469" elapsed="0.067372">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<msg time="2026-06-06T03:37:37.803989" level="FAIL">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 5 minutes. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>300s</arg>
<arg>1s</arg>
<arg>TemplatedRequests.Get_As_Json_Templated</arg>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:32:37.265793" elapsed="300.538335">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 5 minutes. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.806161" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.805680" elapsed="0.000545"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.805117" elapsed="0.001187"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.804665" elapsed="0.001722"/>
</kw>
<doc>Compare current pcep-topology to empty one.
Timeout is long enough to see that pcep is ready, with no PCC connected.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:32:37.264027" elapsed="300.542419">Keyword 'TemplatedRequests.Get_As_Json_Templated' failed after retrying for 5 minutes. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</test>
<test id="s1-s21-t2" name="Start_Secure_Pcc_Mock" line="61">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.809776" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.809051" elapsed="0.000789">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.808734" elapsed="0.001169">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.808706" elapsed="0.001229">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.808392" elapsed="0.001626">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.811545" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.811234" elapsed="0.000355"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.810872" elapsed="0.000789"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.810475" elapsed="0.001247"/>
</kw>
<doc>Execute pcc-mock on Mininet with password set, fail if pcc-mock promptly exits. Keep pcc-mock running for next test cases.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.807316" elapsed="0.004444">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t3" name="Topology_Unauthorized_1" line="65">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.814091" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.813818" elapsed="0.000334">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.813502" elapsed="0.000712">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.813483" elapsed="0.000763">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.813311" elapsed="0.001018">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.815555" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.815248" elapsed="0.000349"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.814900" elapsed="0.000764"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.814588" elapsed="0.001134"/>
</kw>
<doc>Try to catch a glimpse of pcc-mock in pcep-topology. Pass if no change from Precondition is detected over 10 seconds.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:37:37.812288" elapsed="0.003473">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t4" name="Set_Wrong_Password" line="70">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.817812" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.817498" elapsed="0.000419">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.817104" elapsed="0.000877">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.817085" elapsed="0.000928">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.816907" elapsed="0.001190">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.819334" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.819029" elapsed="0.000347"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.818679" elapsed="0.000748"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.818361" elapsed="0.001123"/>
</kw>
<doc>Configure password in pcep dispatcher for client with Mininet IP address.
This password does not match what pcc-mock uses.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.816138" elapsed="0.003383">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t5" name="Topology_Unauthorized_2" line="75">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.821518" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.821247" elapsed="0.000330">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.821031" elapsed="0.000624">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.821008" elapsed="0.000682">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.820828" elapsed="0.000951">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.823240" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.822929" elapsed="0.000355"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.822546" elapsed="0.000791"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.822039" elapsed="0.001354"/>
</kw>
<doc>The same logic as Topology_Unauthorized_1 as incorrect password was provided to ODL.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:37:37.820018" elapsed="0.003414">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t6" name="Set_Correct_Password" line="80">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.826976" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.826189" elapsed="0.000947">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.825568" elapsed="0.001723">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.825513" elapsed="0.001855">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.824903" elapsed="0.002656">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.830530" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.829835" elapsed="0.000796"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.829002" elapsed="0.001787"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.828227" elapsed="0.002686"/>
</kw>
<doc>Configure password in pcep dispatcher for client with Mininet IP address.
This password finally matches what pcc-mock uses.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.823877" elapsed="0.007120">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t7" name="Topology_Intercondition" line="85">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.834828" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.834193" elapsed="0.000767">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.833724" elapsed="0.001374">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.833679" elapsed="0.001489">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.833267" elapsed="0.002085">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.838327" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.837599" elapsed="0.000821"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.836827" elapsed="0.001706"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:37.835996" elapsed="0.002698"/>
</kw>
<doc>Compare pcep-topology/path-computation-client to filled one, which includes a tunnel from pcc-mock.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.831617" elapsed="0.007163">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t8" name="Stop_Pcc_Mock_1" line="102">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast" type="SETUP">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:37:37.841030" elapsed="0.000453"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:37:37.840369" elapsed="0.001231"/>
</kw>
<kw name="Stop_Pcc_Mock_Tool">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.842710" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:37.842359" elapsed="0.000379"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:37:37.842884" elapsed="0.000380"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:37:37.842086" elapsed="0.001252"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:37:37.846075" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:37:37.846171" level="INFO">${output} =  ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:37:37.843484" elapsed="0.002721"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.846622" level="INFO"> ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.846366" elapsed="0.000324"/>
</kw>
<doc>Send ctrl+c to pcc-mock, fails if no prompt is seen
after 3 seconds (the default for SSHLibrary)</doc>
<status status="PASS" start="2026-06-06T03:37:37.841768" elapsed="0.004977"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.847511" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.847199" elapsed="0.000353"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:37:37.846927" elapsed="0.000683"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:37:37.848163" elapsed="0.000509"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:37:37.847866" elapsed="0.000863"/>
</kw>
<doc>Stops First instance of pcc-mock.</doc>
<status status="PASS" start="2026-06-06T03:37:37.839395" elapsed="0.009372"/>
</test>
<test id="s1-s21-t9" name="Topology_Unauthorized_3" line="110">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.849990" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.849772" elapsed="0.000274"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.849752" elapsed="0.000319"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:37:37.849520" elapsed="0.000598"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.889220" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:37.888846" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.889988" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.889749" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:37.890144" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:37.889405" elapsed="0.000763"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.890729" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:37.890325" elapsed="0.000431"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.891045" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:37.891237" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:37.890909" elapsed="0.000354"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.891673" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.891411" elapsed="0.000309"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.892899" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.892404" elapsed="0.000541"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.893386" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:37.893110" elapsed="0.000302"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.893792" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.893994" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.894168" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:37.893628" elapsed="0.000597"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.893471" elapsed="0.000786"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:37.894308" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:37.894513" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:37.892091" elapsed="0.002448"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:37.891787" elapsed="0.002784"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.894763" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.894596" elapsed="0.000249"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.891768" elapsed="0.003102"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.895483" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:37.895023" elapsed="0.000488"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:37.895559" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:37.888209" elapsed="0.007505"/>
</kw>
<msg time="2026-06-06T03:37:37.895772" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:37.887421" elapsed="0.008398"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.896304" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.896843" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.897332" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.897546" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.897729" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.898087" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.897943" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:37.897928" elapsed="0.000238"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.898298" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.898458" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.898615" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:37.897901" elapsed="0.000789"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.897805" elapsed="0.000911"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.898857" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.898932" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:37.899052" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:37.883159" elapsed="0.015919"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.900296" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.900063" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:37.900475" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:37.899731" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.900826" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.900572" elapsed="0.000312"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.901371" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:37.901081" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:37.900908" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.900553" elapsed="0.000899"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.903955" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:37.901594" elapsed="0.002387"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:37.904032" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:37.904183" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:37.899393" elapsed="0.004813"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:37.905430" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.905196" elapsed="0.000296">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:37.905586" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:37.904863" elapsed="0.000748"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:37.905839" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:37.905698" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:37.905678" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.906101" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.906268" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.906332" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:37.908256" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:37.904531" elapsed="0.003752"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.909700" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.909428" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:37.910133" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:37.909891" elapsed="0.000284"/>
</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-06-06T03:37:37.916248" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:37.916388" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:37.916517" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:37.912312" elapsed="0.004603">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:37.910241" elapsed="0.006754">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:37.917175" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.917028" elapsed="0.000212"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:37.910222" elapsed="0.007042">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:37.917670" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.917854" elapsed="0.000019"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:37.917803" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:37.917779" elapsed="0.000163"/>
</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-06-06T03:37:37.918133" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.918230" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:37.908613" elapsed="0.009757">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.918473" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.860858" elapsed="0.057744">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:37.918992" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:37.918753" elapsed="0.000339"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:37.918729" elapsed="0.000396"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:37.919214" elapsed="0.000023"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.854738" elapsed="0.064614">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:37.850720" elapsed="0.068764">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.965049" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:38.964605" elapsed="0.000481"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:38.965880" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:38.965601" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:38.966057" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:38.965262" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.966672" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:38.966244" elapsed="0.000459"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:38.967010" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:38.967173" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:38.966863" elapsed="0.000337"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.967604" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:38.967353" elapsed="0.000321"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.968717" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:38.968373" elapsed="0.000392"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.969262" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:38.968939" elapsed="0.000350"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.969634" elapsed="0.000040"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.969857" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.970062" elapsed="0.000025"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:38.969500" elapsed="0.000626"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.969348" elapsed="0.000809"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:38.970206" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:38.970377" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:38.968052" elapsed="0.002351"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:38.967753" elapsed="0.002682"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.970602" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:38.970460" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:38.967729" elapsed="0.002976"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.971333" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:38.970846" elapsed="0.000519"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:38.971416" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:38.963992" elapsed="0.007554"/>
</kw>
<msg time="2026-06-06T03:37:38.971678" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:38.963004" elapsed="0.008727"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.972271" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.972803" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.973316" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.973497" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.973687" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.974232" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:38.974090" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:38.974075" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.974445" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.974605" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.974786" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:38.974045" elapsed="0.000795"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.973764" elapsed="0.001101"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.975004" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.975079" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:38.975195" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:38.958600" elapsed="0.016621"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:38.976437" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:38.976199" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:38.976594" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:38.975865" elapsed="0.000753"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.976977" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:38.976739" elapsed="0.000332"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.977571" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:38.977275" elapsed="0.000323"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:38.977098" elapsed="0.000537"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:38.976719" elapsed="0.000958"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.980198" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:38.977824" elapsed="0.002401"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:38.980278" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:38.980433" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:38.975531" elapsed="0.004927"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:38.981746" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:38.981479" elapsed="0.000338">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:38.981912" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:38.981125" elapsed="0.000812"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:38.982149" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:38.982009" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:38.981990" elapsed="0.000245"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.982376" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.982542" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.982608" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:38.984552" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:38.980782" elapsed="0.003798"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.986036" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:38.985782" elapsed="0.000301"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:38.986503" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:38.986231" elapsed="0.000320"/>
</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-06-06T03:37:38.994003" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:38.994143" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:38.994252" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:38.988870" elapsed="0.005753">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:38.986620" elapsed="0.008111">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:38.994920" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:38.994770" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:38.986601" elapsed="0.008407">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:38.995409" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.995543" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:38.995506" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:38.995488" elapsed="0.000118"/>
</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-06-06T03:37:38.995764" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.995835" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:38.984901" elapsed="0.011040">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.996016" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:38.935487" elapsed="0.060622">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:38.996376" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:38.996202" elapsed="0.000246"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:38.996185" elapsed="0.000287"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:38.996504" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:38.929052" elapsed="0.067547">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:38.920124" elapsed="0.076589">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.041851" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:40.041402" elapsed="0.000484"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:40.042670" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:40.042393" elapsed="0.000357">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:40.042846" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:40.042061" elapsed="0.000810"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.043414" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:40.043030" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:40.043754" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:40.043922" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:40.043595" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.044349" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:40.044099" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.045743" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:40.045400" elapsed="0.000389"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.046218" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:40.045946" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.046572" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.046790" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.046959" elapsed="0.000020"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:40.046444" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.046299" elapsed="0.000747"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:40.047094" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:40.047260" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:40.045081" elapsed="0.002204"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:40.044776" elapsed="0.002542"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.047483" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:40.047343" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:40.044449" elapsed="0.003110"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.048174" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:40.047720" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:40.048250" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:40.040797" elapsed="0.007576"/>
</kw>
<msg time="2026-06-06T03:37:40.048427" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:40.039909" elapsed="0.008566"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.048988" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.049483" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.050026" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.050208" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.050379" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.050793" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:40.050630" elapsed="0.000219"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:40.050615" elapsed="0.000258"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.051006" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.051172" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.051334" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:40.050587" elapsed="0.000801"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.050488" elapsed="0.000925"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.051553" elapsed="0.000028"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.051637" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:40.051769" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:40.035467" elapsed="0.016328"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:40.053019" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:40.052783" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:40.053176" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:40.052429" elapsed="0.000772"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.053509" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:40.053271" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.054093" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:40.053801" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:40.053607" elapsed="0.000547"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:40.053252" elapsed="0.000923"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.056722" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:40.054319" elapsed="0.002430"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:40.056800" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:40.056953" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:40.052110" elapsed="0.004868"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:40.058228" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:40.057985" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:40.058384" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:40.057623" elapsed="0.000786"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:40.058614" elapsed="0.000042"/>
</return>
<status status="PASS" start="2026-06-06T03:37:40.058479" elapsed="0.000213"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:40.058460" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.058857" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.059021" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.059131" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:40.061064" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:40.057275" elapsed="0.003816"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.062485" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:40.062229" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:40.062942" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:40.062697" elapsed="0.000288"/>
</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-06-06T03:37:40.069857" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:40.069995" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:40.070090" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:40.065280" elapsed="0.005182">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:40.063051" elapsed="0.007495">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:40.070745" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:40.070579" elapsed="0.000233"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:40.063032" elapsed="0.007803">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:40.071213" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.071344" elapsed="0.000013"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:40.071307" elapsed="0.000077"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:40.071290" elapsed="0.000117"/>
</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-06-06T03:37:40.071544" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.071615" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:40.061392" elapsed="0.010348">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.071815" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:40.012832" elapsed="0.059077">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:40.072173" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:40.072000" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:40.071984" elapsed="0.000283"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:40.072300" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:40.006690" elapsed="0.065704">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:39.997362" elapsed="0.075166">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.116544" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:41.116146" elapsed="0.000431"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:41.117347" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:41.117093" elapsed="0.000326">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:41.117516" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:41.116760" elapsed="0.000781"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.118106" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:41.117716" elapsed="0.000450"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:41.118469" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:41.118631" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:41.118324" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.119081" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:41.118832" elapsed="0.000296"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.120144" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:41.119833" elapsed="0.000356"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.120611" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:41.120344" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.121017" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.121217" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.121395" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:41.120880" elapsed="0.000573"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.120737" elapsed="0.000746"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:41.121529" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:41.121717" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:41.119498" elapsed="0.002245"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:41.119203" elapsed="0.002572"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.121941" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:41.121801" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:41.119180" elapsed="0.002837"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.122609" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:41.122166" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:41.122703" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:41.115512" elapsed="0.007316"/>
</kw>
<msg time="2026-06-06T03:37:41.122934" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:41.114638" elapsed="0.008346"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.123477" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.124001" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.124686" elapsed="0.000029"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.124876" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.125045" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.125400" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:41.125262" elapsed="0.000200"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:41.125246" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.125619" elapsed="0.000040"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.125802" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.125962" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:41.125218" elapsed="0.000798"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.125120" elapsed="0.000921"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.126209" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.126287" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:41.126403" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:41.110364" elapsed="0.016065"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:41.127694" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:41.127433" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:41.127851" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:41.127086" elapsed="0.000790"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.128220" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:41.127983" elapsed="0.000293"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.128806" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:41.128468" elapsed="0.000365"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:41.128301" elapsed="0.000567"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:41.127963" elapsed="0.000926"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.131264" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:41.129032" elapsed="0.002259"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:41.131342" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:41.131493" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:41.126765" elapsed="0.004753"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:41.132721" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:41.132475" elapsed="0.000309">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:41.132882" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:41.132147" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:41.133111" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:41.132977" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:41.132958" elapsed="0.000235"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.133333" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.133494" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.133559" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:37:41.135513" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:41.131827" elapsed="0.003712"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.136931" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:41.136681" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:41.137363" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:41.137121" elapsed="0.000286"/>
</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-06-06T03:37:41.145146" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:41.145279" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:41.145372" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:41.139700" elapsed="0.006059">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:41.137472" elapsed="0.008369">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:41.146019" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:41.145874" elapsed="0.000209"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:41.137454" elapsed="0.008653">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:41.146517" elapsed="0.000035"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.146674" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:41.146622" elapsed="0.000099"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:41.146604" elapsed="0.000139"/>
</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-06-06T03:37:41.146878" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.146947" elapsed="0.000014"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:41.135862" elapsed="0.011188">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.147124" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:41.087782" elapsed="0.059435">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:41.147477" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:41.147308" elapsed="0.000240"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:41.147292" elapsed="0.000279"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:41.147603" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:41.080680" elapsed="0.067033">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:41.073044" elapsed="0.074764">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.196564" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:42.196170" elapsed="0.000428"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:42.197378" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:42.197112" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:42.197547" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:42.196779" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.198139" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:42.197746" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:42.198472" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:42.198674" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:42.198323" elapsed="0.000404"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.199141" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:42.198885" elapsed="0.000304"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.200283" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:42.199970" elapsed="0.000364"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.200784" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:42.200489" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.201140" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.201352" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.201522" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:42.201010" elapsed="0.000570"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.200866" elapsed="0.000744"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:42.201673" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:42.201840" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:42.199635" elapsed="0.002231"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:42.199332" elapsed="0.002566"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.202063" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:42.201924" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:42.199242" elapsed="0.002898"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.202761" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:42.202277" elapsed="0.000512"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:42.202839" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:42.195538" elapsed="0.007426"/>
</kw>
<msg time="2026-06-06T03:37:42.203019" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:42.194626" elapsed="0.008440"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.203577" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.204099" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.204598" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.204799" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.204967" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.205361" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:42.205217" elapsed="0.000201"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:42.205202" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.205575" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.205765" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.205929" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:42.205173" elapsed="0.000811"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.205073" elapsed="0.000936"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.206149" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.206225" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:42.206340" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:42.190130" elapsed="0.016236"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:42.207825" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:42.207573" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:42.207983" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:42.207065" elapsed="0.000943"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.208317" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:42.208079" elapsed="0.000296"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.208900" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:42.208567" elapsed="0.000360"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:42.208399" elapsed="0.000563"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:42.208060" elapsed="0.000924"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.211352" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:42.209127" elapsed="0.002253"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:42.211431" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:42.211585" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:42.206737" elapsed="0.004873"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:42.212828" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:42.212579" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:42.212983" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:42.212250" elapsed="0.000757"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:42.213211" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:42.213077" elapsed="0.000192"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:42.213058" elapsed="0.000236"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.213432" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.213596" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.213711" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:42.215670" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:42.211933" elapsed="0.003765"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.217069" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:42.216818" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:42.217499" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:42.217258" elapsed="0.000284"/>
</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-06-06T03:37:42.224258" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:42.224391" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:42.224486" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:42.219693" elapsed="0.005244">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:42.217608" elapsed="0.007443">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:42.225301" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:42.225096" elapsed="0.000296"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:42.217589" elapsed="0.007835">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:42.225946" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.226131" elapsed="0.000018"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:42.226079" elapsed="0.000108"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:42.226055" elapsed="0.000163"/>
</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-06-06T03:37:42.226409" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.226508" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:42.216001" elapsed="0.010667">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.226794" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:42.167444" elapsed="0.059483">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:42.227294" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:42.227055" elapsed="0.000341"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:42.227032" elapsed="0.000397"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:42.227474" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:42.158104" elapsed="0.069503">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:42.148524" elapsed="0.079287">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.276866" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:43.276445" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:43.277708" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:43.277416" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:43.277906" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:43.277074" elapsed="0.000859"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.278498" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:43.278104" elapsed="0.000422"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:43.278854" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:43.279087" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:43.278700" elapsed="0.000415"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.279547" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:43.279290" elapsed="0.000305"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.280680" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:43.280354" elapsed="0.000374"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.281163" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:43.280892" elapsed="0.000303"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.281540" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.281789" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.281964" elapsed="0.000027"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:43.281404" elapsed="0.000624"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.281254" elapsed="0.000806"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:43.282110" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:43.282281" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:43.280032" elapsed="0.002274"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:43.279698" elapsed="0.002640"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.282506" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:43.282364" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:43.279671" elapsed="0.002912"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.283204" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:43.282739" elapsed="0.000493"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:43.283315" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:43.275833" elapsed="0.007608"/>
</kw>
<msg time="2026-06-06T03:37:43.283549" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:43.274845" elapsed="0.008754"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.284108" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.284806" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.285307" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.285487" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.285673" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.286030" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:43.285892" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:43.285877" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.286242" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.286400" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.286558" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:43.285849" elapsed="0.000762"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.285750" elapsed="0.000886"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.286796" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.286872" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:43.286987" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:43.270440" elapsed="0.016572"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:43.288253" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:43.288008" elapsed="0.000312">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:43.288412" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:43.287675" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.288802" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:43.288545" elapsed="0.000315"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.289346" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:43.289054" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:43.288884" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:43.288526" elapsed="0.000902"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.291940" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:43.289577" elapsed="0.002390"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:43.292018" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:43.292172" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:43.287343" elapsed="0.004853"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:43.293396" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:43.293158" elapsed="0.000300">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:43.293552" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:43.292827" elapsed="0.000749"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:43.293805" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:43.293662" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:43.293628" elapsed="0.000260"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.294028" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.294190" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.294255" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:43.297804" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:43.292492" elapsed="0.005339"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.299210" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:43.298958" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:43.299698" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:43.299437" elapsed="0.000305"/>
</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-06-06T03:37:43.306476" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:43.306611" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:43.306738" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:43.301909" elapsed="0.005199">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:43.299809" elapsed="0.007382">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:43.307421" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:43.307224" elapsed="0.000266"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:43.299791" elapsed="0.007722">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:43.308040" elapsed="0.000037"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.308237" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:43.308182" elapsed="0.000116"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:43.308155" elapsed="0.000175"/>
</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-06-06T03:37:43.308531" elapsed="0.000031"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.308634" elapsed="0.000041"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:43.298136" elapsed="0.010673">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.308919" elapsed="0.000023"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:43.245514" elapsed="0.063544">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:43.309443" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:43.309191" elapsed="0.000358"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:43.309167" elapsed="0.000416"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:43.309630" elapsed="0.000041"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:43.238600" elapsed="0.071196">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:43.228492" elapsed="0.081442">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.355959" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:44.355515" elapsed="0.000477"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:44.356777" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:44.356498" elapsed="0.000362">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:44.356960" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:44.356164" elapsed="0.000820"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.357529" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:44.357144" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:44.357873" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:44.358111" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:44.357728" elapsed="0.000410"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.358543" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:44.358293" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.359902" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:44.359536" elapsed="0.000413"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.360380" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:44.360107" elapsed="0.000299"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.360770" elapsed="0.000031"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.360982" elapsed="0.000029"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.361158" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:44.360615" elapsed="0.000600"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.360465" elapsed="0.000781"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:44.361296" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:37:44.361467" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:44.359108" elapsed="0.002388"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:44.358754" elapsed="0.002775"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.361711" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:44.361554" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:44.358664" elapsed="0.003125"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.362376" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:44.361928" elapsed="0.000476"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:44.362452" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:44.354895" elapsed="0.007681"/>
</kw>
<msg time="2026-06-06T03:37:44.362632" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:44.353989" elapsed="0.008711"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.363200" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.363716" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.364247" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.364428" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.364598" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.365022" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:44.364883" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:44.364867" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.365234" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.365394" elapsed="0.000019"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.365553" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:44.364838" elapsed="0.000770"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.364727" elapsed="0.000906"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.365793" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.365868" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:44.365986" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:44.349547" elapsed="0.016466"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:44.367491" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:44.367229" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:44.367675" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:44.366665" elapsed="0.001036"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.368031" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:44.367774" elapsed="0.000316"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.368580" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:44.368288" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:44.368114" elapsed="0.000542"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:44.367755" elapsed="0.000925"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.371081" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:44.368828" elapsed="0.002279"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:44.371159" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:44.371312" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:44.366330" elapsed="0.005007"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:44.372572" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:44.372330" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:44.372747" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:44.371999" elapsed="0.000773"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:44.372977" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:44.372842" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:44.372823" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.373203" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.373367" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.373469" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:44.375405" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:44.371633" elapsed="0.003798"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.376876" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:44.376579" elapsed="0.000355"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:44.377336" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:44.377093" elapsed="0.000286"/>
</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-06-06T03:37:44.384166" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:44.384314" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:44.384430" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:44.379604" elapsed="0.005240">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:44.377446" elapsed="0.007494">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:44.385146" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:44.384977" elapsed="0.000233"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:44.377426" elapsed="0.007808">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:44.385654" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.385799" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:44.385758" elapsed="0.000084"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:44.385738" elapsed="0.000127"/>
</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-06-06T03:37:44.386004" elapsed="0.000021"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.386075" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:44.375751" elapsed="0.010433">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.386260" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:44.326620" elapsed="0.059736">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:44.386628" elapsed="0.000040"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:44.386451" elapsed="0.000267"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:44.386433" elapsed="0.000309"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:44.386775" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:44.319949" elapsed="0.066924">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:44.310604" elapsed="0.076427">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.431795" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:45.431383" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:45.432602" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:45.432326" elapsed="0.000368">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:45.432790" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:45.431997" elapsed="0.000817"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.433358" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:45.432973" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:45.433697" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:45.433880" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:45.433539" elapsed="0.000373"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.434326" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:45.434078" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.435388" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:45.435076" elapsed="0.000358"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.435883" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:45.435588" elapsed="0.000322"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.436237" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.436464" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.436633" elapsed="0.000038"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:45.436108" elapsed="0.000601"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.435965" elapsed="0.000774"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:45.436785" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:45.436952" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:45.434760" elapsed="0.002217"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:45.434449" elapsed="0.002561"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.437181" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:45.437037" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:45.434424" elapsed="0.002835"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.437885" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:45.437401" elapsed="0.000512"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:45.437961" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:45.430780" elapsed="0.007306"/>
</kw>
<msg time="2026-06-06T03:37:45.438204" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:45.429893" elapsed="0.008362"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.438781" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.439289" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.440019" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.440205" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.440390" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.440786" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:45.440618" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:45.440602" elapsed="0.000265"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.441001" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.441161" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.441320" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:45.440573" elapsed="0.000800"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.440471" elapsed="0.000927"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.441537" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.441613" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:45.441746" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:45.425548" elapsed="0.016224"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:45.443024" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:45.442769" elapsed="0.000327">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:45.443188" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:45.442421" elapsed="0.000792"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.443559" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:45.443317" elapsed="0.000299"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.444127" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:45.443833" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:45.443655" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:45.443297" elapsed="0.000912"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.446675" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:45.444353" elapsed="0.002349"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:45.446755" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:45.446909" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:45.442096" elapsed="0.004838"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:45.448126" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:45.447894" elapsed="0.000294">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:45.448282" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:45.447548" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:45.448528" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:45.448390" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:45.448358" elapsed="0.000261"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.448776" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.448940" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.449005" elapsed="0.000014"/>
</return>
<msg time="2026-06-06T03:37:45.450946" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:45.447231" elapsed="0.003741"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.452407" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:45.452123" elapsed="0.000343"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:45.452876" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:45.452614" elapsed="0.000305"/>
</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-06-06T03:37:45.459801" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:45.459938" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:45.460035" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:45.455232" elapsed="0.005307">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:45.452987" elapsed="0.007638">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:45.460834" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:45.460680" elapsed="0.000249"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:45.452968" elapsed="0.007996">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:45.461582" elapsed="0.000038"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.461805" elapsed="0.000021"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:45.461749" elapsed="0.000124"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:45.461722" elapsed="0.000187"/>
</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-06-06T03:37:45.462102" elapsed="0.000029"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.462199" elapsed="0.000022"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:45.451272" elapsed="0.011074">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.462450" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:45.402210" elapsed="0.060373">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:45.462976" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:45.462734" elapsed="0.000343"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:45.462710" elapsed="0.000401"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:45.463156" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:45.393116" elapsed="0.070173">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:45.387629" elapsed="0.075798">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.511080" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:46.510683" elapsed="0.000430"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:46.511877" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:46.511609" elapsed="0.000346">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:46.512049" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:46.511279" elapsed="0.000796"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.512869" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:46.512243" elapsed="0.000659"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:46.513242" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:46.513406" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:46.513096" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.513854" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:46.513585" elapsed="0.000320"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.514974" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:46.514675" elapsed="0.000355"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.515454" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:46.515184" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.515834" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.516037" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.516206" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:46.515704" elapsed="0.000559"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.515535" elapsed="0.000759"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:46.516341" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:46.516507" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:46.514336" elapsed="0.002196"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:46.514033" elapsed="0.002532"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.516748" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:46.516591" elapsed="0.000215"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:46.513958" elapsed="0.002869"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.517427" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:46.516985" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:46.517503" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:46.510057" elapsed="0.007569"/>
</kw>
<msg time="2026-06-06T03:37:46.517698" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:46.509180" elapsed="0.008567"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.518235" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.518751" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.519248" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.519428" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.519594" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.520054" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:46.519873" elapsed="0.000242"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:46.519850" elapsed="0.000289"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.520276" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.520436" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.520597" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:46.519817" elapsed="0.000855"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.519715" elapsed="0.000983"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.520840" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.520916" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:37:46.521071" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:46.504859" elapsed="0.016237"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:46.522323" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:46.522088" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:46.522479" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:46.521750" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.522835" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:46.522574" elapsed="0.000319"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.523379" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:46.523088" elapsed="0.000317"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:46.522917" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:46.522555" elapsed="0.000906"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.526041" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:46.523603" elapsed="0.002465"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:46.526119" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:46.526273" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:46.521414" elapsed="0.004884"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:46.527493" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:46.527260" elapsed="0.000295">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:46.527663" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:46.526931" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:46.527904" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:37:46.527760" elapsed="0.000204"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:46.527742" elapsed="0.000247"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.528128" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.528293" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.528391" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:46.530376" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:46.526592" elapsed="0.003810"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.531791" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:46.531525" elapsed="0.000311"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:46.532226" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:46.531986" 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-06-06T03:37:46.538954" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:46.539092" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:46.539185" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:46.534434" elapsed="0.005109">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:46.532334" elapsed="0.007290">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:46.539833" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:46.539674" elapsed="0.000229"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:46.532316" elapsed="0.007612">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:46.540315" elapsed="0.000025"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.540465" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:46.540421" elapsed="0.000086"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:46.540403" elapsed="0.000127"/>
</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-06-06T03:37:46.540689" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.540773" elapsed="0.000016"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:46.530721" elapsed="0.010165">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.540995" elapsed="0.000017"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:46.482161" elapsed="0.058931">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:46.541358" elapsed="0.000030"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:46.541185" elapsed="0.000252"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:46.541168" elapsed="0.000293"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:46.541493" elapsed="0.000014"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:46.473490" elapsed="0.068097">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:46.464089" elapsed="0.077655">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.586089" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:47.585686" elapsed="0.000436"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:47.586903" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:47.586620" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:47.587074" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:47.586292" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.587656" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:47.587257" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:47.588006" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:47.588176" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:47.587842" elapsed="0.000360"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.588604" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:47.588357" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.589706" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:47.589358" elapsed="0.000394"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.590174" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:47.589907" elapsed="0.000294"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.590527" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.590749" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.590918" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:47.590397" elapsed="0.000579"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.590256" elapsed="0.000750"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:47.591052" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:47.591216" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:47.589044" elapsed="0.002197"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:47.588747" elapsed="0.002526"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.591438" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:47.591299" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:47.588722" elapsed="0.002792"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.592128" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:47.591677" elapsed="0.000479"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:47.592205" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:47.585021" elapsed="0.007309"/>
</kw>
<msg time="2026-06-06T03:37:47.592434" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:47.584150" elapsed="0.008335"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.592989" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.593520" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.594198" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.594381" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.594550" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.594928" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:47.594788" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:47.594772" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.595143" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.595305" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.595466" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:47.594744" elapsed="0.000776"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.594624" elapsed="0.000921"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.595699" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.595776" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:47.595891" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:47.579859" elapsed="0.016058"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:47.597143" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:47.596897" elapsed="0.000310">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:47.597299" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:47.596546" elapsed="0.000778"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.597706" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:47.597435" elapsed="0.000330"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.598260" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:47.597966" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:47.597790" elapsed="0.000531"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:47.597416" elapsed="0.000927"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.600724" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:47.598486" elapsed="0.002265"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:47.600802" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:47.600953" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:47.596231" elapsed="0.004746"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:47.602202" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:47.601960" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:47.602358" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:47.601612" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:47.602586" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:47.602452" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:47.602433" elapsed="0.000257"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.602830" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.602993" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.603059" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:47.605126" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:47.601269" elapsed="0.003883"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.606543" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:47.606293" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:47.606994" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:47.606750" elapsed="0.000287"/>
</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-06-06T03:37:47.613996" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:47.614128" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:47.614221" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:47.609287" elapsed="0.005290">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:47.607103" elapsed="0.007578">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:47.614867" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:47.614716" elapsed="0.000215"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:47.607084" elapsed="0.007871">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:47.615345" elapsed="0.000026"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.615478" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:47.615441" elapsed="0.000078"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:47.615423" elapsed="0.000119"/>
</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-06-06T03:37:47.615695" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.615767" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:47.605450" elapsed="0.010423">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.615953" elapsed="0.000015"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:47.557135" elapsed="0.058916">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:47.616315" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:47.616143" elapsed="0.000244"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:47.616126" elapsed="0.000284"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:47.616443" elapsed="0.000015"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:47.549837" elapsed="0.066701">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:47.542386" elapsed="0.074267">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.666138" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:48.665709" elapsed="0.000463"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.666953" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.666689" elapsed="0.000339">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:48.667123" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:48.666340" elapsed="0.000808"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.667728" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:48.667320" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.668054" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:48.668226" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:48.667911" elapsed="0.000342"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.668669" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.668405" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.669839" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.669516" elapsed="0.000368"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.670341" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:48.670038" elapsed="0.000329"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.670733" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.670935" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.671238" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:48.670570" elapsed="0.000725"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.670423" elapsed="0.000903"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:48.671373" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:48.671540" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:48.669190" elapsed="0.002375"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.668859" elapsed="0.002739"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.671783" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.671623" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.668772" elapsed="0.003088"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.672456" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:48.671998" elapsed="0.000485"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:48.672533" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:48.665077" elapsed="0.007598"/>
</kw>
<msg time="2026-06-06T03:37:48.672732" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:48.664137" elapsed="0.008646"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.673289" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.673807" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.675882" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.676075" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.676248" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.676706" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.676548" elapsed="0.000215"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:48.676532" elapsed="0.000256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.676924" elapsed="0.000026"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.677093" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.677254" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:48.676502" elapsed="0.000807"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.676394" elapsed="0.000941"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.677476" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.677552" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:48.677695" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:48.659653" elapsed="0.018069"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.679091" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.678807" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:48.679259" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:48.678421" elapsed="0.000863"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.679608" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.679355" elapsed="0.000329"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.680317" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:48.679883" elapsed="0.000460"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.679709" elapsed="0.000669"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.679336" elapsed="0.001063"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.682822" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:48.680545" elapsed="0.002304"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:48.682902" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:48.683062" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:48.678046" elapsed="0.005042"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.684371" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.684071" elapsed="0.000369">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:48.684535" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:48.683737" elapsed="0.000823"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:48.684794" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:48.684631" elapsed="0.000223"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.684612" elapsed="0.000268"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.685026" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.685193" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.685315" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:48.687306" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:48.683392" elapsed="0.003941"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.688766" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.688486" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.689208" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.688961" elapsed="0.000291"/>
</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-06-06T03:37:48.865046" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:48.865193" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=409, reason=Conflict 
 headers={'Content-Type': 'application/yang-data+json', 'Content-Length': '242'} 
 body={
  "errors": {
    "error": [
      {
        "error-tag": "data-missing",
        "error-message": "Request could not be completed because the relevant data model content does not exist",
        "error-type": "protocol"
      }
    ]
  }
} 
 </msg>
<msg time="2026-06-06T03:37:48.865322" level="FAIL">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</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="FAIL" start="2026-06-06T03:37:48.860219" elapsed="0.005524">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.689319" elapsed="0.176517">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</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-06-06T03:37:48.866033" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.865874" elapsed="0.000226"/>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.689300" elapsed="0.176824">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</if>
<kw name="Check_Status_Code" owner="TemplatedRequests">
<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="NOT RUN" start="2026-06-06T03:37:48.866599" elapsed="0.000028"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.866762" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:48.866722" elapsed="0.000086"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:48.866702" elapsed="0.000128"/>
</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-06-06T03:37:48.866970" elapsed="0.000023"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.867068" elapsed="0.000020"/>
</return>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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="FAIL" start="2026-06-06T03:37:48.687663" elapsed="0.179558">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.867325" elapsed="0.000021"/>
</return>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.636270" elapsed="0.231186">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.867850" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.867583" elapsed="0.000368"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:48.867560" elapsed="0.000425"/>
</if>
<return>
<value>${response_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.868031" elapsed="0.000020"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.626667" elapsed="0.241498">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="FAIL" start="2026-06-06T03:37:48.617312" elapsed="0.251064">HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<msg time="2026-06-06T03:37:48.868498" level="FAIL">Keyword 'Test_Unauthorized' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>10s</arg>
<arg>1s</arg>
<arg>Test_Unauthorized</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:37:37.850271" elapsed="11.018357">Keyword 'Test_Unauthorized' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.870555" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.870093" elapsed="0.000524"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.869522" elapsed="0.001191"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.869081" elapsed="0.001714"/>
</kw>
<doc>The same logic as Topology_Unauthorized_1, with no pcc-mock running.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:37:37.849003" elapsed="11.021847">Keyword 'Test_Unauthorized' failed after retrying for 10 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</status>
</test>
<test id="s1-s21-t10" name="Start_Secure_Pcc_Mock_2" line="115">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.873254" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.872863" elapsed="0.000475">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.872535" elapsed="0.000891">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.872509" elapsed="0.000961">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.872269" elapsed="0.001317">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.875253" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.874945" elapsed="0.000351"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.874435" elapsed="0.000913"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.873974" elapsed="0.001430"/>
</kw>
<doc>Execute pcc-mock on Mininet with new password set, fail if pcc-mock promptly exits. Keep pcc-mock running for next test cases.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.871354" elapsed="0.004087">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t11" name="Topology_Unauthorized_4" line="119">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.877079" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.876792" elapsed="0.000351">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.876557" elapsed="0.000650">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.876538" elapsed="0.000916">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.876360" elapsed="0.001183">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.878821" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.878494" elapsed="0.000371"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.878128" elapsed="0.000788"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.877833" elapsed="0.001139"/>
</kw>
<doc>The same logic as Topology_Unauthorized_1, but ODL password became incorrect with new pcc-mock running.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:37:48.875741" elapsed="0.003274">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t12" name="Set_Correct_Password_2" line="124">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.880938" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.880638" elapsed="0.000360">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.880421" elapsed="0.000640">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.880402" elapsed="0.000749">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.880228" elapsed="0.001012">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.882524" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.882210" elapsed="0.000357"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.881822" elapsed="0.000798"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.881505" elapsed="0.001191"/>
</kw>
<doc>Configure password in pcep dispatcher for client with Mininet IP address.
This password again matches what second pcc-mock instance uses.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.879339" elapsed="0.003395">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t13" name="Topology_Intercondition_2" line="129">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.884283" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.884012" elapsed="0.000331">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.883804" elapsed="0.000604">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.883784" elapsed="0.000656">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.883595" elapsed="0.000928">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.885781" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.885457" elapsed="0.000366"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.885111" elapsed="0.000765"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.884802" elapsed="0.001129"/>
</kw>
<doc>Compare pcep-topology/path-computation-client to filled one, which includes a tunnel from pcc-mock.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.883015" elapsed="0.002953">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t14" name="Update_Delegated" line="146">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.887466" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.887197" elapsed="0.000330">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.886986" elapsed="0.000604">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.886968" elapsed="0.000657">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.886798" elapsed="0.000931">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.889172" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.888860" elapsed="0.000355"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.888283" elapsed="0.000985"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.887988" elapsed="0.001336"/>
</kw>
<doc>Perform update-lsp on the mocked tunnel, check response is success.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.886263" elapsed="0.003098">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t15" name="Topology_Updated" line="156">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.891008" level="FAIL">SKIPPED due to a failure in a previous fundamental test case.</msg>
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.890731" elapsed="0.000336">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<status status="FAIL" start="2026-06-06T03:37:48.890501" elapsed="0.000627">SKIPPED due to a failure in a previous fundamental test case.</status>
</branch>
<status status="FAIL" start="2026-06-06T03:37:48.890483" elapsed="0.000676">SKIPPED due to a failure in a previous fundamental test case.</status>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.890312" elapsed="0.000931">SKIPPED due to a failure in a previous fundamental test case.</status>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.892609" level="INFO">${SuiteFastFail} = True</msg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:48.892305" elapsed="0.000361"/>
</kw>
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.891959" elapsed="0.000760"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:48.891638" elapsed="0.001172"/>
</kw>
<doc>Compare pcep-topology/path-computation-client to default_on_updated, which includes the updated tunnel.</doc>
<tag>critical</tag>
<status status="FAIL" start="2026-06-06T03:37:48.889701" elapsed="0.003147">Setup failed:
SKIPPED due to a failure in a previous fundamental test case.</status>
</test>
<test id="s1-s21-t16" name="Unset_Password" line="174">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast" type="SETUP">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:37:48.893904" elapsed="0.000205"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:37:48.893627" elapsed="0.000551"/>
</kw>
<kw name="Unset_Password_On_Pcep_Node">
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.895104" level="INFO">&amp;{mapping} = { IP=10.30.171.194 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:48.894614" elapsed="0.000519"/>
</kw>
<kw name="Put_As_Xml_Templated" owner="TemplatedRequests">
<kw name="Put_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.917952" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:48.917538" elapsed="0.000445"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.918861" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.918541" elapsed="0.000394">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:48.919063" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:48.918150" elapsed="0.000946"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.919888" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:48.919319" elapsed="0.000607"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.920341" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:48.920575" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology/node=$IP
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:48.920143" elapsed="0.000490"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.921302" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology/node=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.920910" elapsed="0.000460"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.922831" level="INFO">mapping: {'IP': '10.30.171.194'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.922444" elapsed="0.000450"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.923842" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:48.923218" elapsed="0.000683"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.925402" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:48.924730" elapsed="0.000730"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:37:48.927905" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:37:48.926817" elapsed="0.001150"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:37:48.928092" elapsed="0.000070"/>
</return>
<msg time="2026-06-06T03:37:48.928436" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:37:48.925897" elapsed="0.002593"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:37:48.928938" elapsed="0.000689"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:37:48.924411" elapsed="0.005376"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:37:48.924028" elapsed="0.005862"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:48.930019" elapsed="0.000079"/>
</return>
<msg time="2026-06-06T03:37:48.930530" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:48.921963" elapsed="0.008640"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.921489" elapsed="0.009246"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.931235" elapsed="0.000063"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.930813" elapsed="0.000676"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.921452" elapsed="0.010100"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.933625" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:48.931996" elapsed="0.001750"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:48.933888" elapsed="0.000082"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:48.916921" elapsed="0.017347"/>
</kw>
<msg time="2026-06-06T03:37:48.934431" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:48.916062" elapsed="0.018508"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.936065" elapsed="0.000073"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.937555" elapsed="0.000070"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.939239" elapsed="0.000033"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.939482" elapsed="0.000028"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.939724" elapsed="0.000027"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.940191" elapsed="0.000028"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.940009" elapsed="0.000255"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:48.939986" elapsed="0.000309"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.940473" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.940702" elapsed="0.000027"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.940915" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:48.939947" elapsed="0.001038"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.939821" elapsed="0.001197"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.941201" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.941300" elapsed="0.000020"/>
</return>
<msg time="2026-06-06T03:37:48.941491" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:48.911714" elapsed="0.029811"/>
</kw>
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.956654" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/data.xml</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:48.956266" elapsed="0.000419"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.957381" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/data.xml' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.957170" elapsed="0.000277">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/data.xml' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:48.957542" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:48.956842" elapsed="0.000725"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.958125" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/data.xml</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:48.957739" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.958491" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty/data.xml"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty/data.xml&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:48.958627" level="INFO">${template} = &lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;$IP&lt;/node-id&gt;
&lt;/node&gt;
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:48.958351" elapsed="0.000321"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.959072" level="INFO">&lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;$IP&lt;/node-id&gt;
&lt;/node&gt;
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.958827" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:48.959470" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.959188" elapsed="0.000342"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.960006" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:48.959711" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.959554" elapsed="0.000516"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.959168" elapsed="0.000923"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.960771" level="INFO">${final_text} = &lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.171.194&lt;/node-id&gt;
&lt;/node&gt;</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:48.960227" elapsed="0.000574"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:48.960850" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:48.955666" elapsed="0.005311"/>
</kw>
<msg time="2026-06-06T03:37:48.961035" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:48.954874" elapsed="0.006209"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.961571" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.962136" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.962694" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.962874" elapsed="0.000020"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.963038" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.963387" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.963251" elapsed="0.000190"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:48.963237" elapsed="0.000228"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.963597" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.963779" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.963936" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:48.963209" elapsed="0.000779"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.963111" elapsed="0.000902"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.964150" elapsed="0.000019"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:48.964223" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:48.964336" level="INFO">${data} = &lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.171.194&lt;/node-id&gt;
&lt;/node&gt;</msg>
<var>${data}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:48.952206" elapsed="0.012156"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:48.965776" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:48.965511" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node_empty/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:48.965933" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:48.965181" elapsed="0.000777"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:48.966295" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.966029" elapsed="0.000324"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.966864" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:48.966550" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.966377" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.966010" elapsed="0.000936"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.969301" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:48.967091" elapsed="0.002276"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:48.969423" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:48.969576" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node_empty/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:48.964700" elapsed="0.004901"/>
</kw>
<kw name="Put_To_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.970983" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.970735" elapsed="0.000298"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.971415" level="INFO">&lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.171.194&lt;/node-id&gt;
&lt;/node&gt;</msg>
<arg>${data}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.971178" elapsed="0.000283"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.971862" level="INFO">{'Content-Type': 'application/xml'}</msg>
<arg>${content_type}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.971604" elapsed="0.000302"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.972286" level="INFO">{'Accept': 'application/xml'}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.972048" elapsed="0.000281"/>
</kw>
<kw name="Join_Two_Headers" owner="TemplatedRequests">
<kw name="Copy Dictionary" owner="Collections">
<msg time="2026-06-06T03:37:48.973122" level="INFO">${accumulator} = {'Content-Type': 'application/xml'}</msg>
<var>${accumulator}</var>
<arg>${first}</arg>
<doc>Returns a copy of the given dictionary.</doc>
<status status="PASS" start="2026-06-06T03:37:48.972930" elapsed="0.000218"/>
</kw>
<kw name="Get Dictionary Items" owner="Collections">
<msg time="2026-06-06T03:37:48.973466" level="INFO">${items_to_add} = ['Accept', 'application/xml']</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-06-06T03:37:48.973293" elapsed="0.000198"/>
</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-06-06T03:37:48.973632" elapsed="0.000214"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:48.974266" level="INFO">{'Content-Type': 'application/xml', 'Accept': 'application/xml'}</msg>
<arg>${accumulator}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.973994" elapsed="0.000317"/>
</kw>
<return>
<value>${accumulator}</value>
<status status="PASS" start="2026-06-06T03:37:48.974354" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:48.974586" level="INFO">${headers} = {'Content-Type': 'application/xml', 'Accept': 'application/xml'}</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-06-06T03:37:48.972519" elapsed="0.002096"/>
</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-06-06T03:37:48.989760" level="INFO">PUT Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/xml', 'Connection': 'keep-alive', 'Content-Type': 'application/xml', 'Content-Length': '103', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=&lt;node xmlns="urn:TBD:params:xml:ns:yang:network-topology"&gt;
    &lt;node-id&gt;10.30.171.194&lt;/node-id&gt;
&lt;/node&gt; 
 </msg>
<msg time="2026-06-06T03:37:48.989887" level="INFO">PUT Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194 
 status=201, reason=Created 
 headers={'Set-Cookie': 'JSESSIONID=node01dvrpaqtsq5w5p93uzk1wvcoh31.node0; Path=/rests; HttpOnly, rememberMe=deleteMe; Path=/rests; Max-Age=0; Expires=Fri, 05-Jun-2026 03:37:48 GMT; SameSite=lax', 'Expires': 'Thu, 01 Jan 1970 00:00:00 GMT', 'Content-Length': '0'} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:48.990102" 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-06-06T03:37:48.976778" elapsed="0.013382"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.974711" elapsed="0.015592"/>
</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-06-06T03:37:48.991012" elapsed="0.000058"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:48.990367" elapsed="0.000813"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.974692" elapsed="0.016536"/>
</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-06-06T03:37:48.999164" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.993469" elapsed="0.005738"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.992984" elapsed="0.006260"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.992940" elapsed="0.006330"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.002025" level="INFO">201</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:48.999542" elapsed="0.002531"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:48.999326" elapsed="0.002781"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:48.999309" elapsed="0.002823"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.002719" 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-06-06T03:37:49.002314" elapsed="0.000432"/>
</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-06-06T03:37:49.003047" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.002817" elapsed="0.000326"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.003626" 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-06-06T03:37:49.003326" elapsed="0.000341"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.003169" elapsed="0.000536"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.002799" elapsed="0.000927"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.004241" 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-06-06T03:37:49.003878" elapsed="0.000390"/>
</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-06-06T03:37:49.004561" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.004338" elapsed="0.000280"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.005106" 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-06-06T03:37:49.004812" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.004659" elapsed="0.000508"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.004319" elapsed="0.000870"/>
</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-06-06T03:37:49.005333" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:49.006158" 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-06-06T03:37:49.005861" elapsed="0.000324"/>
</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-06-06T03:37:49.006362" elapsed="0.002330"/>
</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-06-06T03:37:48.992089" elapsed="0.016667"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:37:49.008933" elapsed="0.000033"/>
</return>
<status status="PASS" start="2026-06-06T03:37:49.008824" elapsed="0.000175"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.008805" elapsed="0.000219"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<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="NOT RUN" start="2026-06-06T03:37:49.009165" elapsed="0.000022"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.009233" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:49.011529" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>data=${data}</arg>
<arg>content_type=${content_type}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</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-06-06T03:37:48.969936" elapsed="0.041620"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.011621" elapsed="0.000046"/>
</return>
<msg time="2026-06-06T03:37:49.011797" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>extension=xml</arg>
<arg>accept=${ACCEPT_XML}</arg>
<arg>content_type=${HEADERS_XML}</arg>
<arg>mapping=${mapping}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=False</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve URI and data from folder, call Put_To_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:48.899801" elapsed="0.112021"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Xml_Templated" owner="TemplatedRequests">
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=response</arg>
<arg>mapping=${mapping}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected XML data, should be equal to provided ${response}.
Endline set to empty, as this Resource does not support indented XML comparison.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.012156" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.011920" elapsed="0.000304"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.011903" elapsed="0.000344"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.012280" elapsed="0.000025"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}pcep_topology_node_empty</arg>
<arg>mapping=${mapping}</arg>
<doc>Add arguments sensible for XML data, return Put_Templated response text.
Optionally, verification against response.xml (no iteration) is called.</doc>
<status status="PASS" start="2026-06-06T03:37:48.895410" elapsed="0.116990"/>
</kw>
<doc>Send restconf PUT to unset the config module.</doc>
<status status="PASS" start="2026-06-06T03:37:48.894319" elapsed="0.118139"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.013256" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:49.012930" elapsed="0.000367"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:37:49.012658" elapsed="0.000696"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:37:49.013913" elapsed="0.000205"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:37:49.013611" elapsed="0.000561"/>
</kw>
<doc>De-configure password for pcep dispatcher for client with Mininet IP address.</doc>
<status status="PASS" start="2026-06-06T03:37:48.893129" elapsed="0.121082"/>
</test>
<test id="s1-s21-t17" name="Topology_Unauthorized_5" line="182">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.015419" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.015209" elapsed="0.000265"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.015191" elapsed="0.000308"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:37:49.015024" elapsed="0.000521"/>
</kw>
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.054824" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.054434" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.055570" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.055335" elapsed="0.000324">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.055755" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.055008" elapsed="0.000772"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.056318" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:49.055935" elapsed="0.000409"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.056631" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:49.056792" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:49.056496" elapsed="0.000322"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.057209" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.056967" elapsed="0.000286"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.058240" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.057937" elapsed="0.000394"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.058782" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:49.058487" elapsed="0.000321"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.059280" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.059478" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.059659" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:49.059011" elapsed="0.000707"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.058864" elapsed="0.000884"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:49.059794" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:49.059950" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:49.057605" elapsed="0.002369"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.057322" elapsed="0.002684"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.060171" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.060031" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.057302" elapsed="0.002945"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.060829" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:49.060382" elapsed="0.000474"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.060905" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:49.053809" elapsed="0.007218"/>
</kw>
<msg time="2026-06-06T03:37:49.061116" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.053026" elapsed="0.008139"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.061669" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.062172" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.062868" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.063050" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.063216" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.063569" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.063433" elapsed="0.000191"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:49.063417" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.063806" elapsed="0.000020"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.063966" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.064124" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:49.063389" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.063290" elapsed="0.000912"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.064341" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.064416" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:49.064529" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:49.048764" elapsed="0.015791"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.065780" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.065530" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.065934" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.065200" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.066312" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.066063" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.066859" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.066549" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.066395" elapsed="0.000526"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.066043" elapsed="0.000899"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.069280" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:49.067085" elapsed="0.002221"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:49.069357" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:49.069509" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:49.064885" elapsed="0.004649"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.070822" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.070547" elapsed="0.000340">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.070983" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.070179" elapsed="0.000829"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:49.071230" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:49.071079" elapsed="0.000211"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.071060" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.071459" elapsed="0.000021"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.071625" elapsed="0.000038"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.071711" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:49.073669" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:49.069843" elapsed="0.003853"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.075131" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.074878" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.075568" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.075324" elapsed="0.000287"/>
</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-06-06T03:37:49.082501" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:49.082774" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:49.082872" 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-06-06T03:37:49.077919" elapsed="0.004980"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.075696" elapsed="0.007247"/>
</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-06-06T03:37:49.083128" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.082971" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.075677" elapsed="0.007537"/>
</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-06-06T03:37:49.086714" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.084242" elapsed="0.002522"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.084021" elapsed="0.002778"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.084002" elapsed="0.002857"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.090636" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.087218" elapsed="0.003512"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.086922" elapsed="0.003857"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.086904" elapsed="0.003911"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.091559" 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-06-06T03:37:49.091033" elapsed="0.000564"/>
</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-06-06T03:37:49.092043" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.091720" elapsed="0.000405"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.092825" 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-06-06T03:37:49.092382" elapsed="0.000480"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.092166" elapsed="0.000746"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.091693" elapsed="0.001249"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.093674" 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-06-06T03:37:49.093153" elapsed="0.000561"/>
</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-06-06T03:37:49.094130" elapsed="0.000029"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.093813" elapsed="0.000396"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.094938" 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-06-06T03:37:49.094500" elapsed="0.000474"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.094242" elapsed="0.000782"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.093788" elapsed="0.001265"/>
</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-06-06T03:37:49.095250" elapsed="0.000500"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:49.096353" 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-06-06T03:37:49.095973" elapsed="0.000415"/>
</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-06-06T03:37:49.096594" elapsed="0.003272"/>
</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-06-06T03:37:49.083564" elapsed="0.016392"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.100205" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:49.100057" elapsed="0.000209"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.100031" elapsed="0.000266"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:49.103889" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:49.100489" elapsed="0.003429"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:49.103970" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:49.104123" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:49.074001" elapsed="0.030148"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.104211" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:37:49.104358" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:49.026335" elapsed="0.078049"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.126179" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.125725" elapsed="0.000521"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.127046" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.126777" elapsed="0.000392">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.127356" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.126423" elapsed="0.000959"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.128011" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:49.127539" elapsed="0.000499"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.128352" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:49.128491" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:49.128194" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.128953" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.128683" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:49.129470" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.129067" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.130243" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.129709" elapsed="0.000560"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.129556" elapsed="0.000776"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.129047" elapsed="0.001308"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.130978" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:49.130496" elapsed="0.000512"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.131057" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:49.125110" elapsed="0.006072"/>
</kw>
<msg time="2026-06-06T03:37:49.131235" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.124315" elapsed="0.006968"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.131790" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.132295" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.132838" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.133018" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.133184" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.133539" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.133403" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:49.133388" elapsed="0.000231"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.133768" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.133932" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.134091" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:49.133360" elapsed="0.000785"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.133259" elapsed="0.000911"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.134320" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.134396" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:49.134512" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:49.121014" elapsed="0.013524"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.134723" elapsed="0.002393"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:49.138132" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:49.137848" elapsed="0.000313"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:49.138600" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:49.138329" elapsed="0.000297"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:49.138795" elapsed="0.000323"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:49.137429" elapsed="0.001747"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.137197" elapsed="0.002011"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.139373" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.139233" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.137177" elapsed="0.002272"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:49.105492" elapsed="0.034004"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:49.104707" elapsed="0.034864"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.104464" elapsed="0.035249"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.104447" elapsed="0.035294"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.139775" elapsed="0.000028"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:49.020242" elapsed="0.119660"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:49.016145" elapsed="0.123818"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Test_Unauthorized</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="PASS" start="2026-06-06T03:37:49.015717" elapsed="0.124288"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:49.140558" elapsed="0.000260"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:49.140262" elapsed="0.000619"/>
</kw>
<doc>Wait for pcep-topology to become empty again.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:37:49.014458" elapsed="0.126461"/>
</test>
<test id="s1-s21-t18" name="Stop_Pcc_Mock_2" line="187">
<kw name="Run_Even_When_Failing_Fast" owner="FailFast" type="SETUP">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:37:49.141886" elapsed="0.000206"/>
</kw>
<doc>This is just a more readable 'None' to override [Setup].</doc>
<status status="PASS" start="2026-06-06T03:37:49.141517" elapsed="0.000629"/>
</kw>
<kw name="Stop_Pcc_Mock_Tool">
<kw name="Write_Bare_Ctrl_C" owner="RemoteBash">
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.143180" level="INFO">${ctrl_c} = </msg>
<var>${ctrl_c}</var>
<arg>chr(int(3))</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:49.142873" elapsed="0.000334"/>
</kw>
<kw name="Write Bare" owner="SSHLibrary">
<arg>${ctrl_c}</arg>
<doc>Writes the given ``text`` on the remote machine without appending a newline.</doc>
<status status="PASS" start="2026-06-06T03:37:49.143352" elapsed="0.000274"/>
</kw>
<doc>Construct ctrl+c character and SSH-write it (without endline) to the current SSH connection.
Do not read anything yet.</doc>
<status status="PASS" start="2026-06-06T03:37:49.142597" elapsed="0.001105"/>
</kw>
<kw name="Read Until Prompt" owner="SSHLibrary">
<msg time="2026-06-06T03:37:49.148478" level="INFO">^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<msg time="2026-06-06T03:37:49.148717" level="INFO">${output} =  ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<var>${output}</var>
<doc>Consumes and returns the server output until the prompt is found.</doc>
<status status="PASS" start="2026-06-06T03:37:49.143853" elapsed="0.004929"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.149741" level="INFO"> ^C[?2004l[?2004h[?2004l
[?2004h[jenkins@releng-26932-288-1-mininet-ovs-217-0 ~]&gt;</msg>
<arg>${output}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.149125" elapsed="0.000728"/>
</kw>
<doc>Send ctrl+c to pcc-mock, fails if no prompt is seen
after 3 seconds (the default for SSHLibrary)</doc>
<status status="PASS" start="2026-06-06T03:37:49.142282" elapsed="0.007694"/>
</kw>
<kw name="Do_Not_Fail_Fast_From_Now_On" owner="FailFast">
<kw name="Set Suite Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.151863" level="INFO">${SuiteFastFail} = False</msg>
<arg>${SuiteFastFail}</arg>
<arg>False</arg>
<doc>Makes a variable available everywhere within the scope of the current suite.</doc>
<status status="PASS" start="2026-06-06T03:37:49.151121" elapsed="0.000837"/>
</kw>
<doc>Set suite to not fail fast.</doc>
<status status="PASS" start="2026-06-06T03:37:49.150423" elapsed="0.001662"/>
</kw>
<kw name="Do_Not_Start_Failing_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="No Operation" owner="BuiltIn">
<doc>Does absolutely nothing.</doc>
<status status="PASS" start="2026-06-06T03:37:49.153296" elapsed="0.000482"/>
</kw>
<doc>This is just a more readable 'None' to override [Teardown].</doc>
<status status="PASS" start="2026-06-06T03:37:49.152618" elapsed="0.001301"/>
</kw>
<doc>Stops second instance of pcc-mock</doc>
<status status="PASS" start="2026-06-06T03:37:49.141120" elapsed="0.012887"/>
</test>
<test id="s1-s21-t19" name="Topology_Postcondition" line="195">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.155764" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.155533" elapsed="0.000288"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.155514" elapsed="0.000332"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:37:49.155345" elapsed="0.000546"/>
</kw>
<kw name="Verify_Keyword_Does_Not_Fail_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Confirm_Keyword_Fails_Within_Timeout" owner="WaitForFailure">
<kw name="Run Keyword And Return" owner="BuiltIn">
<kw name="Wait Until Keyword Succeeds" owner="BuiltIn">
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.209021" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.208624" elapsed="0.000426"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.209873" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.209530" elapsed="0.000412">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.210080" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.209206" elapsed="0.000900"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.210683" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:49.210263" elapsed="0.000449"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.211002" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:49.211133" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:49.210867" elapsed="0.000292"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.211692" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.211309" elapsed="0.000428"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.212679" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.212410" elapsed="0.000314"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.213140" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:49.212875" elapsed="0.000290"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.213475" elapsed="0.000021"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.213686" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.213855" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:49.213349" elapsed="0.000562"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.213213" elapsed="0.000730"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:49.213989" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:49.214147" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:49.212095" elapsed="0.002076"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.211807" elapsed="0.002395"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.214392" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.214226" elapsed="0.000222"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.211786" elapsed="0.002683"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.215048" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:49.214606" elapsed="0.000470"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.215124" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:49.208024" elapsed="0.007222"/>
</kw>
<msg time="2026-06-06T03:37:49.215298" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.207226" elapsed="0.008123"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.215853" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.216352" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.216902" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.217084" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.217249" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.217599" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.217464" elapsed="0.000208"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:49.217449" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.217831" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.217991" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.218148" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:49.217422" elapsed="0.000778"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.217323" elapsed="0.000902"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.218408" elapsed="0.000024"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.218490" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:49.218606" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:49.202971" elapsed="0.015660"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.219849" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.219596" elapsed="0.000317">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.220004" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.219268" elapsed="0.000761"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.220339" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.220100" elapsed="0.000294"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.220888" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.220578" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.220418" elapsed="0.000530"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.220080" elapsed="0.000889"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.223469" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:49.221113" elapsed="0.002383"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:49.223547" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:49.223715" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:49.218954" elapsed="0.004786"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.224960" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.224725" elapsed="0.000297">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.225115" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.224381" elapsed="0.000758"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:49.225345" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:49.225209" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.225190" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.225567" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.225747" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.225814" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:49.227738" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:49.224066" elapsed="0.003698"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.229121" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.228875" elapsed="0.000291"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.229553" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.229311" elapsed="0.000286"/>
</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-06-06T03:37:49.235994" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:49.236110" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:49.236213" 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-06-06T03:37:49.231778" elapsed="0.004461"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.229679" elapsed="0.006602"/>
</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-06-06T03:37:49.236454" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.236307" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.229659" elapsed="0.006880"/>
</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-06-06T03:37:49.240400" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.237539" elapsed="0.002926"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.237326" elapsed="0.003187"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.237307" elapsed="0.003241"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.244398" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.240953" elapsed="0.003509"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.240627" elapsed="0.003882"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.240602" elapsed="0.003941"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.245303" 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-06-06T03:37:49.244780" elapsed="0.000561"/>
</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-06-06T03:37:49.245784" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.245442" elapsed="0.000423"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.246619" 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-06-06T03:37:49.246115" elapsed="0.000566"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.245899" elapsed="0.000880"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.245415" elapsed="0.001399"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.247404" 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-06-06T03:37:49.247032" elapsed="0.000398"/>
</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-06-06T03:37:49.247750" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.247501" elapsed="0.000309"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.248289" 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-06-06T03:37:49.247988" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.247833" elapsed="0.000518"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.247482" elapsed="0.000890"/>
</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-06-06T03:37:49.248516" elapsed="0.000368"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:49.249353" 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-06-06T03:37:49.249066" elapsed="0.000314"/>
</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-06-06T03:37:49.249531" elapsed="0.002411"/>
</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-06-06T03:37:49.236904" elapsed="0.015104"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.252268" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:49.252159" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.252138" elapsed="0.000198"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:49.255166" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:49.252474" elapsed="0.002720"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:49.255246" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:49.255402" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:49.228063" elapsed="0.027365"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.255490" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:49.255837" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:49.180159" elapsed="0.075716"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.272511" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.272136" elapsed="0.000404"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.273256" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.273042" elapsed="0.000279">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:49.273414" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:49.272714" elapsed="0.000725"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.273997" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:49.273596" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:49.274353" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:49.274509" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:49.274213" elapsed="0.000324"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.274962" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:49.274711" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:49.275501" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.275077" elapsed="0.000484"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.276086" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:49.275784" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.275587" elapsed="0.000562"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.275056" elapsed="0.001114"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.276753" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:49.276312" elapsed="0.000471"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.276833" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:49.271519" elapsed="0.005442"/>
</kw>
<msg time="2026-06-06T03:37:49.277014" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.270729" elapsed="0.006336"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.277553" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.278076" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.278621" elapsed="0.000045"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.278827" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.279012" elapsed="0.000024"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.279373" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.279237" elapsed="0.000225"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:49.279221" elapsed="0.000266"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.279624" elapsed="0.000037"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.279807" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.279979" elapsed="0.000027"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:49.279193" elapsed="0.000854"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.279092" elapsed="0.000989"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.280228" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.280306" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:49.280424" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:49.268019" elapsed="0.012433"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.280621" elapsed="0.002244"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:49.283874" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:49.283577" elapsed="0.000325"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:49.284323" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:49.284054" elapsed="0.000296"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:49.284497" elapsed="0.000339"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:49.283176" elapsed="0.001720"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.282947" elapsed="0.001981"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:49.285094" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:49.284953" elapsed="0.000207"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.282927" elapsed="0.002255"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:49.257193" elapsed="0.028037"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:49.256381" elapsed="0.028923"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:49.256007" elapsed="0.029359"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.255973" elapsed="0.029439"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:49.285477" elapsed="0.000079"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:49.171813" elapsed="0.113977"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:49.161148" elapsed="0.124806"/>
</kw>
<msg time="2026-06-06T03:37:49.286044" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:49.286089" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:49.160798" elapsed="0.125319"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:49.286300" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:49.286189" elapsed="0.000234"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:49.286170" elapsed="0.000285"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.286932" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:49.286599" elapsed="0.000359"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:49.287410" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.287107" elapsed="0.000363">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.160458" elapsed="0.127126">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.344929" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:50.344511" elapsed="0.000453"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:50.345773" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:50.345472" elapsed="0.000380">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:50.345947" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:50.345141" elapsed="0.000832"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.346518" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:50.346134" elapsed="0.000412"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:50.346861" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:50.347118" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:50.346717" elapsed="0.000431"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.347559" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.347306" elapsed="0.000298"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.348583" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.348327" elapsed="0.000301"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.349068" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:50.348797" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.349428" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.349626" elapsed="0.000039"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.349811" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:50.349298" elapsed="0.000572"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.349150" elapsed="0.000751"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:50.349952" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:50.350121" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:50.348007" elapsed="0.002140"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.347703" elapsed="0.002475"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.350345" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.350204" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.347675" elapsed="0.002747"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.351034" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:50.350557" elapsed="0.000506"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:50.351117" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:50.343902" elapsed="0.007340"/>
</kw>
<msg time="2026-06-06T03:37:50.351352" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:50.342953" elapsed="0.008453"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.351916" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.352418" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.352934" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.353115" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.353284" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.353860" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.353716" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:50.353700" elapsed="0.000242"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.354077" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.354240" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.354400" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:50.353667" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.353359" elapsed="0.001121"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.354617" elapsed="0.000037"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.354712" elapsed="0.000017"/>
</return>
<msg time="2026-06-06T03:37:50.354837" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:50.338496" elapsed="0.016367"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:50.356245" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:50.355963" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:50.356412" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:50.355595" elapsed="0.000841"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.356772" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.356508" elapsed="0.000321"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.357323" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:50.357025" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.356854" elapsed="0.000535"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.356488" elapsed="0.000922"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.359838" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:50.357554" elapsed="0.002311"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:50.359916" elapsed="0.000032"/>
</return>
<msg time="2026-06-06T03:37:50.360073" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:50.355198" elapsed="0.004900"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:50.361320" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:50.361073" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:50.361478" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:50.360742" elapsed="0.000760"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:50.361729" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:50.361573" elapsed="0.000216"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.361554" elapsed="0.000259"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.361954" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.362121" elapsed="0.000020"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.362186" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:50.364171" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:50.360398" elapsed="0.003799"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.365582" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.365327" elapsed="0.000300"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.366034" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.365790" elapsed="0.000287"/>
</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-06-06T03:37:50.373092" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:50.373231" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:50.373333" 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-06-06T03:37:50.368473" elapsed="0.004886"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.366144" elapsed="0.007260"/>
</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-06-06T03:37:50.373588" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.373431" elapsed="0.000246"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.366124" elapsed="0.007625"/>
</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-06-06T03:37:50.378049" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.374812" elapsed="0.003311"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.374565" elapsed="0.003611"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.374545" elapsed="0.003670"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.382196" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.378633" elapsed="0.003631"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.378303" elapsed="0.004012"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.378276" elapsed="0.004075"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.383263" 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-06-06T03:37:50.382612" elapsed="0.000691"/>
</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-06-06T03:37:50.383774" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.383408" elapsed="0.000454"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.384385" 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-06-06T03:37:50.384084" elapsed="0.000327"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.383898" elapsed="0.000549"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.383380" elapsed="0.001088"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.384999" 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-06-06T03:37:50.384620" elapsed="0.000406"/>
</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-06-06T03:37:50.385324" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.385097" elapsed="0.000284"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.385874" 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-06-06T03:37:50.385560" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.385406" elapsed="0.000529"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.385078" elapsed="0.000878"/>
</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-06-06T03:37:50.386110" elapsed="0.000351"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:50.386957" 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-06-06T03:37:50.386623" elapsed="0.000361"/>
</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-06-06T03:37:50.387136" elapsed="0.002352"/>
</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-06-06T03:37:50.374122" elapsed="0.015435"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.389761" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:50.389630" elapsed="0.000180"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.389610" elapsed="0.000223"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:50.392706" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:50.389974" elapsed="0.002761"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:50.392788" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:37:50.392956" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:50.364504" elapsed="0.028478"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:50.393047" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:50.393416" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:50.315427" elapsed="0.078027"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.410465" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:50.410092" elapsed="0.000401"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:50.411319" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:50.411047" elapsed="0.000349">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:50.411491" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:50.410668" elapsed="0.000848"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.412084" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:50.411692" elapsed="0.000419"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:50.412407" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:50.412567" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:50.412267" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.413004" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:50.412758" elapsed="0.000291"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:50.413403" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.413117" elapsed="0.000345"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.413930" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:50.413624" elapsed="0.000332"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.413487" elapsed="0.000505"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.413098" elapsed="0.000915"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.414578" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:50.414149" elapsed="0.000457"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:50.414672" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:50.409471" elapsed="0.005326"/>
</kw>
<msg time="2026-06-06T03:37:50.414851" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:50.408685" elapsed="0.006219"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.415414" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.415924" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.416463" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.416659" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.416831" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.417203" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.417065" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:50.417050" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.417415" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.417575" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.417752" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:50.417019" elapsed="0.000788"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.416913" elapsed="0.000921"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.417976" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.418055" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:37:50.418172" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:50.405995" elapsed="0.012203"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:50.418366" elapsed="0.002383"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:50.421898" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:50.421596" elapsed="0.000329"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:50.422341" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:50.422071" elapsed="0.000297"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:50.422515" elapsed="0.000341"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:50.421068" elapsed="0.001848"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.420832" elapsed="0.002116"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:50.423264" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:50.423000" elapsed="0.000320"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.420812" elapsed="0.002529"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:50.394912" elapsed="0.028476"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:50.394071" elapsed="0.029427"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:50.393674" elapsed="0.029887"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.393612" elapsed="0.029992"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:50.423693" elapsed="0.000078"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:50.306873" elapsed="0.117105"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:50.290369" elapsed="0.133777"/>
</kw>
<msg time="2026-06-06T03:37:50.424237" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:50.424282" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:50.289471" elapsed="0.134835"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:50.424485" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:50.424377" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:50.424359" elapsed="0.000191"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.425015" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:50.424705" elapsed="0.000335"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:50.425480" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:50.425185" elapsed="0.000356">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:50.288525" elapsed="0.137142">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.480999" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:51.480592" elapsed="0.000440"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:51.481808" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:51.481531" elapsed="0.000351">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:51.481978" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:51.481201" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.482552" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:51.482165" elapsed="0.000414"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:51.482890" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:51.483051" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:51.482748" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.483474" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.483227" elapsed="0.000336"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.484551" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.484287" elapsed="0.000313"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.485042" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:51.484773" elapsed="0.000295"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.485388" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.485584" elapsed="0.000098"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.485835" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:51.485260" elapsed="0.000633"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.485120" elapsed="0.000804"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:51.485971" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:51.486137" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:51.483961" elapsed="0.002202"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.483665" elapsed="0.002529"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.486360" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.486219" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.483621" elapsed="0.002814"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.487030" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:51.486570" elapsed="0.000487"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:51.487107" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:51.479986" elapsed="0.007244"/>
</kw>
<msg time="2026-06-06T03:37:51.487285" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:51.479151" elapsed="0.008185"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.487851" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.488352" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.488862" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.489041" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.489208" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.489561" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.489424" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:51.489408" elapsed="0.000248"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.489795" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.489954" elapsed="0.000054"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.490154" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:51.489380" elapsed="0.000828"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.489281" elapsed="0.000953"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.490372" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.490448" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:51.490564" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:51.474879" elapsed="0.015711"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:51.492032" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:51.491791" elapsed="0.000306">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:51.492197" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:51.491406" elapsed="0.000817"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.492534" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.492295" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.493094" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:51.492801" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.492617" elapsed="0.000540"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.492275" elapsed="0.000903"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.495502" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:51.493323" elapsed="0.002219"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:51.495595" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:51.495766" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:51.490919" elapsed="0.004873"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:51.496988" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:51.496750" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:51.497145" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:51.496404" elapsed="0.000766"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:51.497377" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:51.497242" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.497222" elapsed="0.000240"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.497602" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.497786" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.497854" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:51.499825" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:51.496087" elapsed="0.003765"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.501234" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.500982" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.501729" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.501466" elapsed="0.000308"/>
</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-06-06T03:37:51.508584" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:51.508738" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:51.508835" 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-06-06T03:37:51.503947" elapsed="0.004915"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.501843" elapsed="0.007063"/>
</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-06-06T03:37:51.509086" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.508933" elapsed="0.000220"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.501823" elapsed="0.007352"/>
</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-06-06T03:37:51.514493" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.510185" elapsed="0.004377"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.509968" elapsed="0.004643"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.509949" elapsed="0.004717"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.518368" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.515061" elapsed="0.003373"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.514750" elapsed="0.003732"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.514725" elapsed="0.003793"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.519298" 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-06-06T03:37:51.518759" elapsed="0.000577"/>
</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-06-06T03:37:51.519817" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.519436" elapsed="0.000464"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.520418" 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-06-06T03:37:51.520117" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.519934" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.519409" elapsed="0.001092"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.521034" 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-06-06T03:37:51.520670" elapsed="0.000390"/>
</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-06-06T03:37:51.521360" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.521132" elapsed="0.000285"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.521904" 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-06-06T03:37:51.521593" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.521441" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.521113" elapsed="0.000873"/>
</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-06-06T03:37:51.522133" elapsed="0.000345"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:51.522945" 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-06-06T03:37:51.522635" elapsed="0.000336"/>
</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-06-06T03:37:51.523120" elapsed="0.002338"/>
</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-06-06T03:37:51.509527" elapsed="0.015995"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.525716" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:51.525593" elapsed="0.000202"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.525573" elapsed="0.000248"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:51.528686" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:51.525959" elapsed="0.002757"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:51.528768" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:51.528923" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:51.500157" elapsed="0.028792"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:51.529010" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:51.529336" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:51.451545" elapsed="0.077828"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.545895" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:51.545503" elapsed="0.000421"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:51.546626" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:51.546408" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:51.546803" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:51.546081" elapsed="0.000747"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.547376" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:51.546986" elapsed="0.000417"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:51.547747" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:51.547887" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:51.547578" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.548459" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:51.548064" elapsed="0.000442"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:51.548878" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.548575" elapsed="0.000363"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.549395" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:51.549103" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.548963" elapsed="0.000495"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.548555" elapsed="0.000925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.550066" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:51.549619" elapsed="0.000476"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:51.550145" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:51.544906" elapsed="0.005364"/>
</kw>
<msg time="2026-06-06T03:37:51.550362" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:51.544125" elapsed="0.006292"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.550921" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.551429" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.551968" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.552153" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.552326" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.552703" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.552548" elapsed="0.000213"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:51.552532" elapsed="0.000252"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.552918" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.553086" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.553246" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:51.552504" elapsed="0.000803"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.552404" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.553472" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.553548" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:51.553677" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:51.541453" elapsed="0.012252"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:51.553874" elapsed="0.002221"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:51.557103" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:51.556823" elapsed="0.000340"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:51.557586" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:51.557314" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:51.557777" elapsed="0.000327"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:51.556404" elapsed="0.001761"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.556176" elapsed="0.002024"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:51.558367" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:51.558226" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.556157" elapsed="0.002287"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:51.530712" elapsed="0.027778"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:51.529904" elapsed="0.028659"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:51.529502" elapsed="0.029122"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.529469" elapsed="0.029223"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:51.558757" elapsed="0.000076"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:51.443421" elapsed="0.115617"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:51.428450" elapsed="0.130749"/>
</kw>
<msg time="2026-06-06T03:37:51.559288" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:51.559331" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:51.427536" elapsed="0.131818"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:51.559530" elapsed="0.000044"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:51.559423" elapsed="0.000182"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:51.559406" elapsed="0.000221"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.560082" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:51.559780" elapsed="0.000328"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:51.560546" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:51.560253" elapsed="0.000352">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:51.426555" elapsed="0.134181">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.618440" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:52.618041" elapsed="0.000434"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:52.619270" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:52.618998" elapsed="0.000350">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:52.619445" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:52.618663" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.620035" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:52.619630" elapsed="0.000435"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:52.620383" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:52.620605" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:52.620238" elapsed="0.000394"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.621055" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.620801" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.622071" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.621809" elapsed="0.000309"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.622548" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:52.622276" elapsed="0.000298"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.622920" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.623126" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.623295" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:52.622789" elapsed="0.000565"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.622629" elapsed="0.000756"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:52.623433" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:52.623600" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:52.621474" elapsed="0.002151"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.621181" elapsed="0.002492"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.623841" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.623699" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.621156" elapsed="0.002762"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.624538" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:52.624055" elapsed="0.000511"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:52.624616" elapsed="0.000049"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:52.617416" elapsed="0.007348"/>
</kw>
<msg time="2026-06-06T03:37:52.624820" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:52.616574" elapsed="0.008297"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.625359" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.625873" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.626556" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.626792" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.626963" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.627320" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.627182" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:52.627167" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.627534" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.627711" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.627874" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:52.627139" elapsed="0.000790"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.627038" elapsed="0.000916"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.628094" elapsed="0.000032"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.628183" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:52.628300" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:52.612124" elapsed="0.016202"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:52.629544" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:52.629305" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:52.629717" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:52.628972" elapsed="0.000771"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.630053" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.629814" elapsed="0.000297"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.630603" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:52.630311" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.630135" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.629794" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.633088" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:52.630847" elapsed="0.002268"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:52.633166" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:52.633319" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:52.628653" elapsed="0.004690"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:52.634542" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:52.634305" elapsed="0.000299">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:52.634720" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:52.633975" elapsed="0.000770"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:52.634954" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:52.634818" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.634798" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.635213" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.635381" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.635448" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:52.637393" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:52.633654" elapsed="0.003765"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.638816" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.638545" elapsed="0.000317"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.639252" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.639010" elapsed="0.000285"/>
</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-06-06T03:37:52.646281" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:52.646418" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:52.646513" 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-06-06T03:37:52.641613" elapsed="0.004927"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.639361" elapsed="0.007222"/>
</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-06-06T03:37:52.646780" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.646610" elapsed="0.000237"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.639342" elapsed="0.007526"/>
</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-06-06T03:37:52.650811" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.647864" elapsed="0.003014"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.647632" elapsed="0.003294"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.647612" elapsed="0.003349"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.654608" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.651343" elapsed="0.003348"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.651039" elapsed="0.003702"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.651015" elapsed="0.003760"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.655532" 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-06-06T03:37:52.654993" elapsed="0.000577"/>
</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-06-06T03:37:52.656016" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.655691" elapsed="0.000407"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.656822" 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-06-06T03:37:52.656381" elapsed="0.000478"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.656162" elapsed="0.000746"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.655663" elapsed="0.001275"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.657490" 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-06-06T03:37:52.657127" elapsed="0.000389"/>
</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-06-06T03:37:52.657831" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.657587" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.658361" 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-06-06T03:37:52.658066" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.657912" elapsed="0.000510"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.657568" elapsed="0.000875"/>
</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-06-06T03:37:52.658585" elapsed="0.000362"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:52.659436" 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-06-06T03:37:52.659141" elapsed="0.000321"/>
</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-06-06T03:37:52.659610" elapsed="0.002352"/>
</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-06-06T03:37:52.647213" elapsed="0.014812"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.662200" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:52.662095" elapsed="0.000148"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.662075" elapsed="0.000191"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:52.665081" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:52.662404" elapsed="0.002705"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:52.665162" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:52.665318" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:52.637738" elapsed="0.027607"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:52.665408" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:37:52.665753" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:52.589216" elapsed="0.076574"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.682409" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:52.682035" elapsed="0.000403"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:52.683157" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:52.682935" elapsed="0.000285">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:52.683312" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:52.682592" elapsed="0.000745"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.683908" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:52.683499" elapsed="0.000436"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:52.684234" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:52.684432" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:52.684087" elapsed="0.000372"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.684882" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:52.684613" elapsed="0.000315"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:52.685280" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.684995" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.685809" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:52.685502" elapsed="0.000333"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.685363" elapsed="0.000546"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.684975" elapsed="0.000957"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.686499" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:52.686073" elapsed="0.000455"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:52.686578" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:52.681411" elapsed="0.005311"/>
</kw>
<msg time="2026-06-06T03:37:52.686777" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:52.680629" elapsed="0.006199"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.687317" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.687837" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.688360" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.688542" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.688725" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.689085" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.688948" elapsed="0.000192"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:52.688932" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.689297" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.689456" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.689614" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:52.688905" elapsed="0.000777"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.688802" elapsed="0.000906"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.689849" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.689923" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:52.690073" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:52.677966" elapsed="0.012135"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:52.690272" elapsed="0.002400"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:52.693694" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:52.693397" elapsed="0.000326"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:52.694145" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:52.693870" elapsed="0.000303"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:52.694321" elapsed="0.000340"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:52.692990" elapsed="0.001732"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.692755" elapsed="0.002002"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:52.694926" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:52.694782" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.692735" elapsed="0.002267"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:52.667099" elapsed="0.027951"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:52.666287" elapsed="0.028838"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:52.665920" elapsed="0.029265"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.665887" elapsed="0.029341"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:52.695291" elapsed="0.000077"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:52.580553" elapsed="0.115018"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:52.563893" elapsed="0.131865"/>
</kw>
<msg time="2026-06-06T03:37:52.695848" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:52.695893" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:52.562791" elapsed="0.133125"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:52.696101" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:52.695987" elapsed="0.000187"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:52.695968" elapsed="0.000230"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.696660" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:52.696337" elapsed="0.000350"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:52.697132" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:52.696832" elapsed="0.000361">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:52.561768" elapsed="0.135535">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.752033" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:53.751613" elapsed="0.000454"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:53.752991" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:53.752706" elapsed="0.000364">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:53.753171" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:53.752336" elapsed="0.000860"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.753768" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:53.753359" elapsed="0.000437"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:53.754099" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:53.754261" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:53.753953" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.754705" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.754439" elapsed="0.000312"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.755790" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.755515" elapsed="0.000320"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.756267" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:53.755992" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.756622" elapsed="0.000038"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.756897" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.757068" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:53.756492" elapsed="0.000635"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.756347" elapsed="0.000810"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:53.757205" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:37:53.757377" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:53.755182" elapsed="0.002222"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.754834" elapsed="0.002601"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.757607" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.757462" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.754808" elapsed="0.002894"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.758302" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:53.757842" elapsed="0.000488"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:53.758378" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:53.750974" elapsed="0.007529"/>
</kw>
<msg time="2026-06-06T03:37:53.758560" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:53.749978" elapsed="0.008642"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.759145" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.759737" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.760237" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.760423" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.760596" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.761027" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.760879" elapsed="0.000204"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:53.760862" elapsed="0.000246"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.761244" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.761407" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.761567" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:53.760830" elapsed="0.000791"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.760718" elapsed="0.000945"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.761806" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.761884" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:53.762015" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:53.745394" elapsed="0.016648"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:53.763679" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:53.763368" elapsed="0.000390">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:53.763856" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:53.762975" elapsed="0.000907"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.764219" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.763956" elapsed="0.000322"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.764825" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:53.764474" elapsed="0.000377"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.764303" elapsed="0.000583"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.763936" elapsed="0.000972"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.767318" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:53.765055" elapsed="0.002290"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:53.767476" elapsed="0.000039"/>
</return>
<msg time="2026-06-06T03:37:53.767667" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:53.762366" elapsed="0.005328"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:53.769162" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:53.768825" elapsed="0.000415">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:53.769337" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:53.768389" elapsed="0.000973"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:53.769593" elapsed="0.000028"/>
</return>
<status status="PASS" start="2026-06-06T03:37:53.769441" elapsed="0.000232"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.769419" elapsed="0.000281"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.769846" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.770017" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.770085" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:53.772057" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:53.768032" elapsed="0.004054"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.773657" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.773344" elapsed="0.000366"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.774104" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.773858" elapsed="0.000289"/>
</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-06-06T03:37:53.781021" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:53.781245" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:53.781420" 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-06-06T03:37:53.776376" elapsed="0.005085"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.774223" elapsed="0.007319"/>
</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-06-06T03:37:53.781897" elapsed="0.000035"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.781589" elapsed="0.000408"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.774200" elapsed="0.007830"/>
</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-06-06T03:37:53.787869" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.783700" elapsed="0.004259"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.783333" elapsed="0.004691"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.783303" elapsed="0.004764"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.791183" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.788547" elapsed="0.002691"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.788172" elapsed="0.003107"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.788136" elapsed="0.003173"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.791979" 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-06-06T03:37:53.791526" elapsed="0.000591"/>
</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-06-06T03:37:53.792456" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.792208" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.793050" 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-06-06T03:37:53.792739" elapsed="0.000414"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.792541" elapsed="0.000652"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.792185" elapsed="0.001029"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.793763" 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-06-06T03:37:53.793371" elapsed="0.000420"/>
</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-06-06T03:37:53.794095" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.793864" elapsed="0.000290"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.794631" 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-06-06T03:37:53.794332" elapsed="0.000342"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.794178" elapsed="0.000534"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.793845" elapsed="0.000888"/>
</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-06-06T03:37:53.794895" elapsed="0.000355"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:53.795737" 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-06-06T03:37:53.795413" elapsed="0.000350"/>
</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-06-06T03:37:53.795918" elapsed="0.002459"/>
</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-06-06T03:37:53.782608" elapsed="0.015842"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.798654" elapsed="0.000020"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:53.798525" elapsed="0.000181"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.798504" elapsed="0.000225"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:53.801615" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:53.798870" elapsed="0.002792"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:53.801717" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:37:53.801884" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:53.772437" elapsed="0.029474"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:53.801975" elapsed="0.000026"/>
</return>
<msg time="2026-06-06T03:37:53.802331" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:53.721965" elapsed="0.080402"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.818978" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:53.818588" elapsed="0.000418"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:53.819763" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:53.819495" elapsed="0.000344">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:53.819936" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:53.819167" elapsed="0.000794"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.820704" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:53.820126" elapsed="0.000627"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:53.821191" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:53.821347" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:53.821044" elapsed="0.000330"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.821805" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:53.821525" elapsed="0.000327"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:53.822206" elapsed="0.000027"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.821921" elapsed="0.000346"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.822745" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:53.822432" elapsed="0.000339"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.822293" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.821901" elapsed="0.000929"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.823407" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:53.822970" elapsed="0.000466"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:53.823487" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:53.817993" elapsed="0.005621"/>
</kw>
<msg time="2026-06-06T03:37:53.823691" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:53.817199" elapsed="0.006545"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.824233" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.824776" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.825280" elapsed="0.000024"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.825460" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.825633" elapsed="0.000036"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.826054" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.825914" elapsed="0.000196"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:53.825898" elapsed="0.000236"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.826268" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.826432" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.826595" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:53.825868" elapsed="0.000796"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.825759" elapsed="0.000933"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.826835" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.826912" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:53.827028" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:53.814490" elapsed="0.012566"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:53.827224" elapsed="0.002208"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:53.830446" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:53.830165" elapsed="0.000309"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:53.830910" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:53.830621" elapsed="0.000317"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:53.831086" elapsed="0.000323"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:53.829759" elapsed="0.001710"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.829513" elapsed="0.001990"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:53.831683" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:53.831529" elapsed="0.000210"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.829494" elapsed="0.002266"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:53.803764" elapsed="0.028042"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:53.802920" elapsed="0.028960"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:53.802498" elapsed="0.029443"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.802465" elapsed="0.029522"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:53.832052" elapsed="0.000079"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:53.713418" elapsed="0.118922"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:53.699363" elapsed="0.133145"/>
</kw>
<msg time="2026-06-06T03:37:53.832597" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:53.832663" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:53.698754" elapsed="0.133935"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:53.832933" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:53.832821" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:53.832801" elapsed="0.000199"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.833442" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:53.833136" elapsed="0.000333"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:53.833929" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:53.833613" elapsed="0.000378">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:53.698069" elapsed="0.136029">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.890844" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:54.890429" elapsed="0.000449"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:54.891673" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:54.891384" elapsed="0.000372">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:54.891853" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:54.891050" elapsed="0.000827"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.892424" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:54.892038" elapsed="0.000413"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:54.892765" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:54.892932" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:54.892605" elapsed="0.000353"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.893380" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.893107" elapsed="0.000319"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.894433" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.894162" elapsed="0.000335"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.894972" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:54.894687" elapsed="0.000326"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.895390" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.895608" elapsed="0.000025"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.895831" elapsed="0.000024"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:54.895251" elapsed="0.000642"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.895069" elapsed="0.000856"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:54.895978" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:54.896146" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:54.893815" elapsed="0.002356"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.893506" elapsed="0.002696"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.896369" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.896228" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.893481" elapsed="0.002965"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.897122" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:54.896597" elapsed="0.000564"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:54.897307" elapsed="0.000043"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:54.889821" elapsed="0.007635"/>
</kw>
<msg time="2026-06-06T03:37:54.897523" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:54.888955" elapsed="0.008622"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.899582" elapsed="0.000030"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.900174" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.900707" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.900896" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.901067" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.901469" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.901325" elapsed="0.000202"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:54.901274" elapsed="0.000277"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.901702" elapsed="0.000023"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.901882" elapsed="0.000023"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.902048" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:54.901244" elapsed="0.000858"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.901142" elapsed="0.000985"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.902294" elapsed="0.000026"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.902386" elapsed="0.000022"/>
</return>
<msg time="2026-06-06T03:37:54.902609" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:54.884604" elapsed="0.018032"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:54.903993" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:54.903736" elapsed="0.000329">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:54.904165" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:54.903371" elapsed="0.000819"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.904531" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.904282" elapsed="0.000307"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.905141" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:54.904831" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.904613" elapsed="0.000591"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.904259" elapsed="0.000966"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.907781" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:54.905414" elapsed="0.002394"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:54.907868" elapsed="0.000038"/>
</return>
<msg time="2026-06-06T03:37:54.908043" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:54.903009" elapsed="0.005059"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:54.909375" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:54.909097" elapsed="0.000342">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:54.909535" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:54.908759" elapsed="0.000800"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:54.909788" elapsed="0.000027"/>
</return>
<status status="PASS" start="2026-06-06T03:37:54.909631" elapsed="0.000217"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.909611" elapsed="0.000262"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.910014" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.910181" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.910248" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:54.912406" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:54.908405" elapsed="0.004028"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.913912" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.913624" elapsed="0.000336"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.914358" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.914111" elapsed="0.000291"/>
</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-06-06T03:37:54.921426" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:54.921562" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:54.921692" 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-06-06T03:37:54.916558" elapsed="0.005163"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.914471" elapsed="0.007294"/>
</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-06-06T03:37:54.921949" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.921794" elapsed="0.000263"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.914451" elapsed="0.007630"/>
</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-06-06T03:37:54.925666" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.923111" elapsed="0.002607"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.922888" elapsed="0.002866"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.922868" elapsed="0.002912"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.929434" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.926062" elapsed="0.003437"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.925839" elapsed="0.003709"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.925821" elapsed="0.003762"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.930400" 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-06-06T03:37:54.929833" elapsed="0.000605"/>
</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-06-06T03:37:54.930893" elapsed="0.000032"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.930540" elapsed="0.000437"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.931793" 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-06-06T03:37:54.931231" elapsed="0.000605"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.931011" elapsed="0.000891"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.930513" elapsed="0.001430"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.932723" 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-06-06T03:37:54.932174" elapsed="0.000588"/>
</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-06-06T03:37:54.933190" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.932864" elapsed="0.000406"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.934023" 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-06-06T03:37:54.933579" elapsed="0.000481"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.933349" elapsed="0.000761"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.932836" elapsed="0.001303"/>
</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-06-06T03:37:54.934295" elapsed="0.000370"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:54.935135" 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-06-06T03:37:54.934829" elapsed="0.000332"/>
</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-06-06T03:37:54.935311" elapsed="0.002410"/>
</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-06-06T03:37:54.922439" elapsed="0.015347"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.937970" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:54.937860" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.937839" elapsed="0.000201"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:54.940974" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:54.938182" elapsed="0.002821"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:54.941057" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:54.941218" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:54.912755" elapsed="0.028489"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:54.941374" elapsed="0.000042"/>
</return>
<msg time="2026-06-06T03:37:54.941772" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:54.861653" elapsed="0.080159"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.958517" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:54.958144" elapsed="0.000401"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:54.959276" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:54.959046" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:54.959441" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:54.958717" elapsed="0.000749"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.960027" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:54.959626" elapsed="0.000428"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:54.960349" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:54.960496" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:54.960210" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.960939" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:54.960691" elapsed="0.000294"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:54.961374" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.961054" elapsed="0.000381"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.961910" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:54.961600" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.961459" elapsed="0.000513"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.961034" elapsed="0.000959"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.962560" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:54.962133" elapsed="0.000456"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:54.962653" elapsed="0.000032"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:54.957525" elapsed="0.005257"/>
</kw>
<msg time="2026-06-06T03:37:54.962837" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:54.956733" elapsed="0.006156"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.963377" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.963896" elapsed="0.000062"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.964441" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.964624" elapsed="0.000036"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.964814" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.965181" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.965043" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:54.965028" elapsed="0.000232"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.965407" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.965571" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.965746" elapsed="0.000022"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:54.964998" elapsed="0.000803"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.964894" elapsed="0.000934"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.965969" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.966045" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:54.966159" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:54.954077" elapsed="0.012109"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:54.966354" elapsed="0.002404"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:54.969814" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:54.969508" elapsed="0.000334"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:54.970261" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:54.969990" elapsed="0.000299"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:54.970434" elapsed="0.000340"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:54.969072" elapsed="0.001763"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.968841" elapsed="0.002028"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:54.971036" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:54.970894" elapsed="0.000197"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.968821" elapsed="0.002323"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:54.943188" elapsed="0.028009"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:54.942368" elapsed="0.028905"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:54.941986" elapsed="0.029349"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.941951" elapsed="0.029428"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:54.971443" elapsed="0.000077"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:54.853207" elapsed="0.118545"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:54.836983" elapsed="0.134934"/>
</kw>
<msg time="2026-06-06T03:37:54.972007" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:54.972051" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:54.836070" elapsed="0.136004"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:54.972252" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:54.972144" elapsed="0.000151"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:54.972126" elapsed="0.000191"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.972775" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:54.972453" elapsed="0.000347"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:54.973242" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:54.972947" elapsed="0.000356">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:54.835103" elapsed="0.138416">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.028177" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:56.027783" elapsed="0.000427"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:56.028991" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:56.028724" elapsed="0.000343">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:56.029160" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:56.028378" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.029761" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:56.029346" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:56.030106" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:56.030269" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:56.029962" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.030717" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.030445" elapsed="0.000318"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.031752" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.031459" elapsed="0.000339"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.032225" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:56.031954" elapsed="0.000297"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.032575" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.032930" elapsed="0.000026"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.033103" elapsed="0.000022"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:56.032446" elapsed="0.000715"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.032303" elapsed="0.000889"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:56.033239" elapsed="0.000033"/>
</return>
<msg time="2026-06-06T03:37:56.033408" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:56.031140" elapsed="0.002294"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.030842" elapsed="0.002624"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.033635" elapsed="0.000043"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.033492" elapsed="0.000221"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.030818" elapsed="0.002916"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.034355" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:56.033903" elapsed="0.000481"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:56.034434" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:56.027159" elapsed="0.007400"/>
</kw>
<msg time="2026-06-06T03:37:56.034615" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:56.026335" elapsed="0.008349"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.035185" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.035706" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.036208" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.036389" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.036556" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.036930" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.036791" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:56.036775" elapsed="0.000235"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.037142" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.037340" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.037502" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:56.036746" elapsed="0.000810"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.036631" elapsed="0.000951"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.037740" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.037818" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:56.037949" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:56.022034" elapsed="0.015942"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:56.039386" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:56.039146" elapsed="0.000305">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:56.039545" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:56.038807" elapsed="0.000762"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.039896" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.039655" elapsed="0.000298"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.040444" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:56.040152" elapsed="0.000318"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.039977" elapsed="0.000527"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.039621" elapsed="0.000905"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.042933" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:56.040686" elapsed="0.002273"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:56.043011" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:56.043164" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:56.038294" elapsed="0.004895"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:56.044391" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:56.044152" elapsed="0.000302">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:56.044547" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:56.043817" elapsed="0.000754"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:56.044797" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:56.044658" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.044624" elapsed="0.000256"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.045018" elapsed="0.000024"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.045190" elapsed="0.000024"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.045260" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:56.047190" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:56.043482" elapsed="0.003734"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.048630" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.048378" elapsed="0.000314"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.049083" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.048839" elapsed="0.000289"/>
</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-06-06T03:37:56.055633" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:56.055785" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:56.055896" 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-06-06T03:37:56.051308" elapsed="0.004615"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.049194" elapsed="0.006773"/>
</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-06-06T03:37:56.056142" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.055994" elapsed="0.000214"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.049175" elapsed="0.007054"/>
</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-06-06T03:37:56.060679" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.057248" elapsed="0.003504"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.057027" elapsed="0.003778"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.057008" elapsed="0.003835"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.064507" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.061248" elapsed="0.003333"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.060928" elapsed="0.003739"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.060901" elapsed="0.003806"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.065493" 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-06-06T03:37:56.064942" elapsed="0.000589"/>
</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-06-06T03:37:56.066043" elapsed="0.000034"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.065630" elapsed="0.000501"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.066656" 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-06-06T03:37:56.066337" elapsed="0.000346"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.066166" elapsed="0.000553"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.065603" elapsed="0.001137"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.067263" 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-06-06T03:37:56.066894" elapsed="0.000396"/>
</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-06-06T03:37:56.067588" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.067361" elapsed="0.000301"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.068137" 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-06-06T03:37:56.067842" elapsed="0.000320"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.067687" elapsed="0.000510"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.067342" elapsed="0.000876"/>
</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-06-06T03:37:56.068363" elapsed="0.000361"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:56.069203" 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-06-06T03:37:56.068885" elapsed="0.000344"/>
</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-06-06T03:37:56.069381" elapsed="0.002392"/>
</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-06-06T03:37:56.056583" elapsed="0.015256"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.072076" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:56.071964" elapsed="0.000160"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.071944" elapsed="0.000203"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:56.075047" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:56.072287" elapsed="0.002789"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:56.075129" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:56.075290" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:56.047554" elapsed="0.027762"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:56.075380" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:56.075746" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:55.998731" elapsed="0.077053"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.092534" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:56.092157" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:56.093294" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:56.093062" elapsed="0.000301">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:56.093456" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:56.092734" elapsed="0.000746"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.094065" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:56.093637" elapsed="0.000455"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:56.094399" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:56.094718" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:56.094247" elapsed="0.000500"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.095146" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:56.094898" elapsed="0.000295"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:56.095545" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.095260" elapsed="0.000344"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.096082" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:56.095787" elapsed="0.000322"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.095629" elapsed="0.000515"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.095240" elapsed="0.000925"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.096756" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:56.096310" elapsed="0.000475"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:56.096835" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:56.091541" elapsed="0.005421"/>
</kw>
<msg time="2026-06-06T03:37:56.097054" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:56.090771" elapsed="0.006337"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.097597" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.098142" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.098657" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.098842" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.099016" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.099390" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.099253" elapsed="0.000193"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:56.099237" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.099624" elapsed="0.000038"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.099808" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.099969" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:56.099206" elapsed="0.000817"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.099096" elapsed="0.000954"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.100193" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.100269" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:56.100383" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:56.088070" elapsed="0.012340"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:56.100614" elapsed="0.002245"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:56.103938" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:56.103628" elapsed="0.000340"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:56.104386" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:56.104117" elapsed="0.000297"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:56.104565" elapsed="0.000373"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:56.103172" elapsed="0.001828"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.102941" elapsed="0.002094"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:56.105205" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:56.105060" elapsed="0.000203"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.102921" elapsed="0.002363"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:56.077115" elapsed="0.028216"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:56.076295" elapsed="0.029112"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:56.075918" elapsed="0.029557"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.075884" elapsed="0.029639"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:56.105590" elapsed="0.000106"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:55.990576" elapsed="0.115345"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:55.976436" elapsed="0.129659"/>
</kw>
<msg time="2026-06-06T03:37:56.106190" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:56.106235" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:55.975468" elapsed="0.130791"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:56.106445" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:56.106332" elapsed="0.000156"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:56.106314" elapsed="0.000196"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.106980" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:56.106667" elapsed="0.000339"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:56.107455" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:56.107153" elapsed="0.000369">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:55.974478" elapsed="0.133157">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.164135" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:57.163731" elapsed="0.000438"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:57.164964" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:57.164687" elapsed="0.000354">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:57.165136" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:57.164342" elapsed="0.000818"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.165809" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:57.165396" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:57.166141" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:57.166298" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:57.165997" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.167081" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.166706" elapsed="0.000424"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.168121" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.167860" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.168601" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:57.168327" elapsed="0.000301"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.168977" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.169174" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.169344" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:57.168847" elapsed="0.000555"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.168699" elapsed="0.000733"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:57.169481" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:57.169665" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:57.167517" elapsed="0.002175"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.167211" elapsed="0.002513"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.169891" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.169750" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.167187" elapsed="0.002781"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.170588" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:57.170106" elapsed="0.000512"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:57.170683" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:57.163101" elapsed="0.007708"/>
</kw>
<msg time="2026-06-06T03:37:57.170865" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:57.162206" elapsed="0.008709"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.171411" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.172116" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.172675" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.172861" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.173028" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.173387" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.173249" elapsed="0.000195"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:57.173233" elapsed="0.000234"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.173601" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.173781" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.173943" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:57.173205" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.173103" elapsed="0.000919"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.174161" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.174237" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:57.174352" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:57.157873" elapsed="0.016505"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:57.175630" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:57.175383" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:57.175811" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:57.175053" elapsed="0.000782"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.176145" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.175907" elapsed="0.000295"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.176712" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:57.176398" elapsed="0.000340"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.176226" elapsed="0.000548"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.175887" elapsed="0.000908"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.179140" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:57.176939" elapsed="0.002227"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:57.179218" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:57.179372" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:57.174733" elapsed="0.004663"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:57.180584" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:57.180348" elapsed="0.000313">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:57.180793" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:57.180022" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:57.181026" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:57.180890" elapsed="0.000194"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.180870" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.181247" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.181412" elapsed="0.000022"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.181478" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:57.183546" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:57.179707" elapsed="0.003865"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.184977" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.184726" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.185411" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.185169" elapsed="0.000285"/>
</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-06-06T03:37:57.191806" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:57.191937" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:57.192031" 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-06-06T03:37:57.187622" elapsed="0.004436"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.185521" elapsed="0.006581"/>
</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-06-06T03:37:57.192306" elapsed="0.000031"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.192128" elapsed="0.000270"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.185502" elapsed="0.006925"/>
</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-06-06T03:37:57.197247" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.193859" elapsed="0.003455"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.193535" elapsed="0.003829"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.193509" elapsed="0.003890"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.201067" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.197801" elapsed="0.003331"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.197478" elapsed="0.003702"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.197453" elapsed="0.003762"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.201992" 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-06-06T03:37:57.201439" elapsed="0.000591"/>
</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-06-06T03:37:57.202465" elapsed="0.000080"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.202131" elapsed="0.000477"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.203276" 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-06-06T03:37:57.202887" elapsed="0.000416"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.202662" elapsed="0.000677"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.202104" elapsed="0.001256"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.203890" 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-06-06T03:37:57.203511" elapsed="0.000406"/>
</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-06-06T03:37:57.204213" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.203988" elapsed="0.000318"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.204802" 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-06-06T03:37:57.204486" elapsed="0.000343"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.204331" elapsed="0.000533"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.203968" elapsed="0.000917"/>
</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-06-06T03:37:57.205027" elapsed="0.000346"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:57.205846" 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-06-06T03:37:57.205530" elapsed="0.000342"/>
</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-06-06T03:37:57.206021" elapsed="0.002521"/>
</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-06-06T03:37:57.192938" elapsed="0.015669"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.208817" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:57.208709" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.208687" elapsed="0.000197"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:57.211717" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:57.209024" elapsed="0.002721"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:57.211798" elapsed="0.000031"/>
</return>
<msg time="2026-06-06T03:37:57.211955" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:57.183899" elapsed="0.028082"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:57.212043" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:57.212382" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:57.134888" elapsed="0.077531"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.229039" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:57.228665" elapsed="0.000402"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:57.229781" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:57.229549" elapsed="0.000298">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:57.229940" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:57.229223" elapsed="0.000741"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.230532" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:57.230121" elapsed="0.000439"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:57.230868" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:57.231003" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:57.230730" elapsed="0.000299"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.231466" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:57.231219" elapsed="0.000293"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:57.231879" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.231580" elapsed="0.000359"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.232395" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:57.232104" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.231964" elapsed="0.000492"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.231560" elapsed="0.000917"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.233053" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:57.232614" elapsed="0.000468"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:57.233131" elapsed="0.000030"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:57.228047" elapsed="0.005208"/>
</kw>
<msg time="2026-06-06T03:37:57.233309" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:57.227257" elapsed="0.006102"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.235188" elapsed="0.000029"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.235713" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.236214" elapsed="0.000026"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.236398" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.236567" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.236943" elapsed="0.000020"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.236805" elapsed="0.000194"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:57.236789" elapsed="0.000233"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.237154" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.237315" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.237510" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:57.236760" elapsed="0.000805"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.236657" elapsed="0.000934"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.237747" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.237825" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:57.237942" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:57.224589" elapsed="0.013380"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:57.238139" elapsed="0.002239"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:57.241407" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:57.241117" elapsed="0.000318"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:57.241872" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:57.241583" elapsed="0.000318"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:57.242049" elapsed="0.000327"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:57.240708" elapsed="0.001729"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.240460" elapsed="0.002011"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:57.242671" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:57.242497" elapsed="0.000233"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.240440" elapsed="0.002311"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:57.213761" elapsed="0.029037"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:57.212947" elapsed="0.029926"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:57.212547" elapsed="0.030389"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.212515" elapsed="0.030466"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:57.243046" elapsed="0.000079"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:57.126437" elapsed="0.116893"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:57.110466" elapsed="0.133027"/>
</kw>
<msg time="2026-06-06T03:37:57.243583" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:57.243627" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:57.109519" elapsed="0.134159"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:57.243859" elapsed="0.000014"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:57.243750" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:57.243732" elapsed="0.000192"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.244364" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:57.244059" elapsed="0.000330"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:57.244849" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:57.244534" elapsed="0.000377">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:57.108569" elapsed="0.136451">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.302599" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:58.302197" elapsed="0.000435"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:58.303492" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:58.303208" elapsed="0.000360">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:58.303679" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:58.302818" elapsed="0.000888"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.304259" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:58.303868" elapsed="0.000418"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:58.304584" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:58.304765" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:58.304441" elapsed="0.000351"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.305201" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.304946" elapsed="0.000301"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.306246" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.305986" elapsed="0.000306"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.306735" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:58.306446" elapsed="0.000316"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.307117" elapsed="0.000023"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.307321" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.307493" elapsed="0.000072"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:58.306961" elapsed="0.000647"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.306816" elapsed="0.000835"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:58.307701" elapsed="0.000035"/>
</return>
<msg time="2026-06-06T03:37:58.307873" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:58.305657" elapsed="0.002240"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.305325" elapsed="0.002605"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.308098" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.307955" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.305301" elapsed="0.002873"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.308772" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:58.308310" elapsed="0.000490"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:58.308848" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:58.301554" elapsed="0.007419"/>
</kw>
<msg time="2026-06-06T03:37:58.309029" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:58.300609" elapsed="0.008472"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.309656" elapsed="0.000028"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.310165" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.310891" elapsed="0.000027"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.311117" elapsed="0.000023"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.311290" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.311664" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.311510" elapsed="0.000212"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:58.311495" elapsed="0.000251"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.311881" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.312043" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.312204" elapsed="0.000020"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:58.311465" elapsed="0.000793"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.311365" elapsed="0.000918"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.312422" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.312498" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:58.312618" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:58.296125" elapsed="0.016534"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:58.313905" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:58.313636" elapsed="0.000341">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:58.314070" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:58.313299" elapsed="0.000796"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.314448" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.314203" elapsed="0.000304"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.315019" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:58.314720" elapsed="0.000325"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.314532" elapsed="0.000568"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.314183" elapsed="0.000939"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.317523" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:58.315268" elapsed="0.002282"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:58.317603" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:58.317776" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:58.312978" elapsed="0.004824"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:58.319017" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:58.318777" elapsed="0.000334">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:58.319206" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:58.318427" elapsed="0.000804"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:58.319441" elapsed="0.000026"/>
</return>
<status status="PASS" start="2026-06-06T03:37:58.319303" elapsed="0.000198"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.319284" elapsed="0.000242"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.319682" elapsed="0.000023"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.319851" elapsed="0.000021"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.319917" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:58.321865" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:58.318103" elapsed="0.003790"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.323361" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.323084" elapsed="0.000327"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.323825" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.323559" elapsed="0.000311"/>
</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-06-06T03:37:58.331015" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:58.331206" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:58.331359" 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-06-06T03:37:58.326324" elapsed="0.005066"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.323941" elapsed="0.007509"/>
</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-06-06T03:37:58.331719" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.331486" elapsed="0.000303"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.323921" elapsed="0.007891"/>
</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-06-06T03:37:58.335603" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.332973" elapsed="0.002707"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.332730" elapsed="0.002995"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.332708" elapsed="0.003047"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.339708" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.336078" elapsed="0.003817"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.335824" elapsed="0.004134"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.335802" elapsed="0.004198"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.340936" 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-06-06T03:37:58.340292" elapsed="0.000685"/>
</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-06-06T03:37:58.341454" elapsed="0.000033"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.341093" elapsed="0.000449"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.342300" 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-06-06T03:37:58.341838" elapsed="0.000502"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.341579" elapsed="0.000815"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.341061" elapsed="0.001365"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.343302" 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-06-06T03:37:58.342679" elapsed="0.000663"/>
</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-06-06T03:37:58.343893" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.343452" elapsed="0.000532"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.344542" 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-06-06T03:37:58.344238" elapsed="0.000331"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.344021" elapsed="0.000584"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.343422" elapsed="0.001205"/>
</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-06-06T03:37:58.344801" elapsed="0.000360"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:58.345626" 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-06-06T03:37:58.345323" elapsed="0.000346"/>
</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-06-06T03:37:58.345824" elapsed="0.002447"/>
</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-06-06T03:37:58.332224" elapsed="0.016121"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.348541" elapsed="0.000017"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:58.348426" elapsed="0.000162"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.348404" elapsed="0.000207"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:58.351535" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:58.348774" elapsed="0.002791"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:58.351624" elapsed="0.000054"/>
</return>
<msg time="2026-06-06T03:37:58.351819" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:58.322209" elapsed="0.029637"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:58.351913" elapsed="0.000027"/>
</return>
<msg time="2026-06-06T03:37:58.352280" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:58.273164" elapsed="0.079154"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.369599" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:58.369214" elapsed="0.000416"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:58.370476" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:58.370222" elapsed="0.000328">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:58.370662" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:58.369882" elapsed="0.000807"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.371264" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:58.370850" elapsed="0.000442"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:58.371592" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:58.371767" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:58.371449" elapsed="0.000346"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.372198" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:58.371946" elapsed="0.000300"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:58.372608" elapsed="0.000026"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.372318" elapsed="0.000367"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.373152" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:58.372854" elapsed="0.000324"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.372712" elapsed="0.000502"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.372296" elapsed="0.000941"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.373830" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:58.373377" elapsed="0.000482"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:58.373912" elapsed="0.000031"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:58.368594" elapsed="0.005447"/>
</kw>
<msg time="2026-06-06T03:37:58.374095" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:58.367746" elapsed="0.006402"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.374651" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.375189" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.375705" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.375922" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.376094" elapsed="0.000022"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.376472" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.376332" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:58.376316" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.376702" elapsed="0.000022"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.376868" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.377030" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:58.376286" elapsed="0.000799"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.376177" elapsed="0.000934"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.377253" elapsed="0.000022"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.377331" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:58.377447" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:58.364995" elapsed="0.012479"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:58.377658" elapsed="0.002380"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:58.381084" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:58.380778" elapsed="0.000334"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:58.381527" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:58.381260" elapsed="0.000295"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:58.381719" elapsed="0.000327"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:58.380356" elapsed="0.001752"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.380120" elapsed="0.002022"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:58.382311" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:58.382167" elapsed="0.000201"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.380099" elapsed="0.002290"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:58.353768" elapsed="0.028669"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:58.352910" elapsed="0.029601"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:58.352457" elapsed="0.030155"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.352421" elapsed="0.030264"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:58.382753" elapsed="0.000081"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:58.263959" elapsed="0.119087"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:58.247954" elapsed="0.135292"/>
</kw>
<msg time="2026-06-06T03:37:58.383339" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:58.383384" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:58.246924" elapsed="0.136484"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:58.383592" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:58.383481" elapsed="0.000155"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:58.383462" elapsed="0.000215"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.384123" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:58.383816" elapsed="0.000333"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:58.384598" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:58.384300" elapsed="0.000375">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:58.246003" elapsed="0.138782">None</status>
</kw>
<kw name="Invert_Failure" owner="WaitForFailure">
<kw name="Run Keyword And Ignore Error" owner="BuiltIn">
<kw name="Test_Unauthorized">
<kw name="Get_As_Json_Templated" owner="TemplatedRequests">
<kw name="Get_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.442781" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:59.442369" elapsed="0.000446"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.443576" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.443317" elapsed="0.000370">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:59.443784" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:59.442984" elapsed="0.000825"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.444364" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:59.443970" elapsed="0.000421"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.444703" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:59.444864" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:59.444545" elapsed="0.000345"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.445295" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.445043" elapsed="0.000297"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.446306" level="INFO">mapping: {}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.446048" elapsed="0.000304"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.446797" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:59.446508" elapsed="0.000315"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.447150" elapsed="0.000022"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.447346" elapsed="0.000024"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.447514" elapsed="0.000021"/>
</kw>
<var name="${key}"/>
<var name="${value}"/>
<status status="NOT RUN" start="2026-06-06T03:37:59.447021" elapsed="0.000551"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.446877" elapsed="0.000726"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:59.447692" elapsed="0.000036"/>
</return>
<msg time="2026-06-06T03:37:59.447926" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:59.445728" elapsed="0.002224"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.445418" elapsed="0.002567"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.448154" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.448010" elapsed="0.000200"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.445394" elapsed="0.002837"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.448831" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:59.448368" elapsed="0.000492"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:59.448910" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:59.441762" elapsed="0.007272"/>
</kw>
<msg time="2026-06-06T03:37:59.449089" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:59.440886" elapsed="0.008254"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.449630" elapsed="0.000042"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.450152" elapsed="0.000024"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.450668" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.450852" elapsed="0.000022"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.451022" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.451384" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.451244" elapsed="0.000197"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:59.451228" elapsed="0.000237"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.451601" elapsed="0.000027"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.451818" elapsed="0.000022"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.451981" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:59.451199" elapsed="0.000838"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.451098" elapsed="0.000964"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.452201" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.452312" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:37:59.452432" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=location</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:59.436493" elapsed="0.015965"/>
</kw>
<kw name="Resolve_Jmes_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.453901" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</msg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.453657" elapsed="0.000311">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/jmespath.expr' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:59.454062" level="INFO">${read_jmes_file} = False</msg>
<var>${read_jmes_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:59.453296" elapsed="0.000791"/>
</kw>
<if>
<branch type="IF" condition="${read_jmes_file} == ${true}">
<kw name="Get File" owner="OperatingSystem">
<var>${jmes_expression}</var>
<arg>${folder}${/}jmespath.expr</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.454409" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.454160" elapsed="0.000310"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.454976" level="INFO">${jmes_expression} = None</msg>
<var>${jmes_expression}</var>
<arg>${None}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:59.454681" elapsed="0.000321"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.454494" elapsed="0.000544"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.454140" elapsed="0.000919"/>
</if>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.457428" level="INFO">${expression} = </msg>
<var>${expression}</var>
<arg>${read_jmes_file} == ${true}</arg>
<arg>${jmes_expression}</arg>
<arg>${EMPTY}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:59.455206" elapsed="0.002248"/>
</kw>
<return>
<value>${expression}</value>
<status status="PASS" start="2026-06-06T03:37:59.457506" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:59.457675" level="INFO">${jmes_expression} = </msg>
<var>${jmes_expression}</var>
<arg>${folder}</arg>
<doc>Reads JMES path from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/jmespath.expr if the file exists and
returns the JMES path. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:59.452790" elapsed="0.004912"/>
</kw>
<kw name="Resolve_Volatiles_Path" owner="TemplatedRequests">
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.458901" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</msg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.458661" elapsed="0.000303">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/volatiles.list' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:59.459058" level="INFO">${read_volatiles_file} = False</msg>
<var>${read_volatiles_file}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${folder}${/}volatiles.list</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:59.458314" elapsed="0.000768"/>
</kw>
<if>
<branch type="IF" condition="${read_volatiles_file} == ${false}">
<return>
<value>${EMPTY}</value>
<status status="PASS" start="2026-06-06T03:37:59.459291" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:59.459154" elapsed="0.000195"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.459135" elapsed="0.000238"/>
</if>
<kw name="Get File" owner="OperatingSystem">
<var>${volatiles}</var>
<arg>${folder}${/}volatiles.list</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.459514" elapsed="0.000022"/>
</kw>
<kw name="Split String" owner="String">
<var>${volatiles_list}</var>
<arg>${volatiles}</arg>
<arg>${\n}</arg>
<doc>Splits the ``string`` using ``separator`` as a delimiter string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.459707" elapsed="0.000023"/>
</kw>
<return>
<value>${volatiles_list}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.459776" elapsed="0.000016"/>
</return>
<msg time="2026-06-06T03:37:59.461694" level="INFO">${volatiles_list} = </msg>
<var>${volatiles_list}</var>
<arg>${folder}</arg>
<doc>Reads Volatiles List from file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/volatiles.list if the file exists and
returns the Volatiles List. Empty string is returned otherwise.</doc>
<status status="PASS" start="2026-06-06T03:37:59.457997" elapsed="0.003725"/>
</kw>
<kw name="Get_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.463090" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.462840" elapsed="0.000296"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.463522" level="INFO">{}</msg>
<arg>${accept}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.463281" elapsed="0.000284"/>
</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-06-06T03:37:59.470178" level="INFO">GET Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node0lkagd7jhakuh1dw7x3x7klivp30.node0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:59.470360" level="INFO">GET Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology?content=nonconfig 
 status=200, reason=OK 
 headers={'Cache-Control': 'no-cache', 'Content-Type': 'application/yang-data+json', 'Content-Length': '123'} 
 body={"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]} 
 </msg>
<msg time="2026-06-06T03:37:59.470477" 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-06-06T03:37:59.465728" elapsed="0.004777"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.463631" elapsed="0.006919"/>
</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-06-06T03:37:59.470750" elapsed="0.000024"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.470576" elapsed="0.000242"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.463612" elapsed="0.007227"/>
</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-06-06T03:37:59.475530" level="INFO">{"network-topology:topology":[{"topology-id":"pcep-topology","topology-types":{"network-topology-pcep:topology-pcep":{}}}]}</msg>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.471965" elapsed="0.003635"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.471729" elapsed="0.003957"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.471706" elapsed="0.004018"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.479332" level="INFO">200</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.476110" elapsed="0.003286"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.475806" elapsed="0.003639"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.475781" elapsed="0.003699"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.480299" 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-06-06T03:37:59.479767" elapsed="0.000559"/>
</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-06-06T03:37:59.480631" elapsed="0.000037"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.480399" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.481188" 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-06-06T03:37:59.480886" elapsed="0.000328"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.480731" elapsed="0.000523"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.480379" elapsed="0.000897"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.481805" 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-06-06T03:37:59.481426" elapsed="0.000406"/>
</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-06-06T03:37:59.482127" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.481903" elapsed="0.000282"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.482669" 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-06-06T03:37:59.482360" elapsed="0.000336"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.482208" elapsed="0.000524"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.481884" elapsed="0.000869"/>
</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-06-06T03:37:59.482900" elapsed="0.000349"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:59.483737" 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-06-06T03:37:59.483408" elapsed="0.000355"/>
</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-06-06T03:37:59.483911" elapsed="0.002329"/>
</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-06-06T03:37:59.471200" elapsed="0.015103"/>
</kw>
<if>
<branch type="IF" condition="not ${normalize_json}">
<return>
<value>${response.text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.486482" elapsed="0.000016"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:59.486374" elapsed="0.000154"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.486354" elapsed="0.000197"/>
</if>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:59.489539" level="INFO">${text_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<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="PASS" start="2026-06-06T03:37:59.486706" elapsed="0.002860"/>
</kw>
<return>
<value>${text_normalized}</value>
<status status="PASS" start="2026-06-06T03:37:59.489618" elapsed="0.000047"/>
</return>
<msg time="2026-06-06T03:37:59.489794" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>accept=${accept}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=${normalize_json}</arg>
<arg>jmes_path=${jmes_expression}</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>keys_with_volatiles=${volatiles_list}</arg>
<arg>log_response=${log_response}</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-06-06T03:37:59.462021" elapsed="0.027848"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:59.489935" elapsed="0.000028"/>
</return>
<msg time="2026-06-06T03:37:59.490284" level="INFO">${response_text} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${response_text}</var>
<arg>folder=${folder}</arg>
<arg>mapping=${mapping}</arg>
<arg>accept=${ACCEPT_EMPTY}</arg>
<arg>session=${session}</arg>
<arg>normalize_json=True</arg>
<arg>http_timeout=${http_timeout}</arg>
<arg>log_response=${log_response}</arg>
<doc>Resolve URI from folder, call Get_From_Uri, return response text.</doc>
<status status="PASS" start="2026-06-06T03:37:59.412937" elapsed="0.077385"/>
</kw>
<if>
<branch type="IF" condition="${verify}">
<kw name="Verify_Response_As_Json_Templated" owner="TemplatedRequests">
<kw name="Verify_Response_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.507070" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/data.json</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:59.506693" elapsed="0.000405"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.507866" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.507581" elapsed="0.000358">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off.vanadium/data.json' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:59.508032" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:59.507254" elapsed="0.000802"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.508766" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/data.json</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:59.508214" elapsed="0.000580"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.509090" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/default_off/data.json&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:59.509251" level="INFO">${template} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:59.508950" elapsed="0.000328"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.509692" level="INFO">{
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
        }
    ]
}
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.509427" elapsed="0.000311"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="NOT RUN" start="2026-06-06T03:37:59.510091" elapsed="0.000025"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.509806" elapsed="0.000345"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.510609" level="INFO">${mapping_to_use} = {}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:59.510318" elapsed="0.000316"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.510175" elapsed="0.000511"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.509786" elapsed="0.000922"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.511274" level="INFO">${final_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:59.510847" elapsed="0.000455"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:59.511351" elapsed="0.000029"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:59.506077" elapsed="0.005398"/>
</kw>
<msg time="2026-06-06T03:37:59.511529" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:59.505276" elapsed="0.006304"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.512152" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.512701" elapsed="0.000027"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/default_off/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.513206" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.513410" elapsed="0.000024"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.513588" elapsed="0.000021"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.513996" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.513854" elapsed="0.000198"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:59.513838" elapsed="0.000239"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.514212" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.514378" elapsed="0.000021"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.514538" elapsed="0.000021"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:59.513804" elapsed="0.000787"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.513690" elapsed="0.000928"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.514778" elapsed="0.000021"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.514856" elapsed="0.000018"/>
</return>
<msg time="2026-06-06T03:37:59.514984" level="INFO">${expected_text} = {
    "network-topology:topology": [
        {
            "topology-id": "pcep-topology",
            "topology-types": {
                "network-topology-pcep:topology-pcep": {}
            }
     ...</msg>
<var>${expected_text}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>endline=${endline}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from 1, by one  times.
Template variable ${j} is calculated as ${i} incremented by offset 0 ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:59.502582" elapsed="0.012430"/>
</kw>
<kw name="Run Keyword And Return If" owner="BuiltIn">
<arg>"""${expected_text}""" == """${EMPTY}"""</arg>
<arg>BuiltIn.Should_Be_Equal</arg>
<arg>${EMPTY}</arg>
<arg>${response}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:59.515182" elapsed="0.002352"/>
</kw>
<if>
<branch type="IF" condition="${normalize_json}">
<kw name="Normalize_Jsons_And_Compare" owner="TemplatedRequests">
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:59.518622" level="INFO">${expected_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${expected_normalized}</var>
<arg>${expected_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:59.518289" elapsed="0.000381"/>
</kw>
<kw name="Normalize Json Text" owner="norm_json">
<msg time="2026-06-06T03:37:59.519090" level="INFO">${actual_normalized} = {
 "network-topology:topology": [
  {
   "topology-id": "pcep-topology",
   "topology-types": {
    "network-topology-pcep:topology-pcep": {}
   }
  }
 ]
}
</msg>
<var>${actual_normalized}</var>
<arg>${actual_raw}</arg>
<doc>Attempt to return sorted indented JSON string.</doc>
<status status="PASS" start="2026-06-06T03:37:59.518819" elapsed="0.000344"/>
</kw>
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_normalized}</arg>
<arg>${actual_normalized}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="PASS" start="2026-06-06T03:37:59.519322" elapsed="0.000350"/>
</kw>
<arg>expected_raw=${expected_text}</arg>
<arg>actual_raw=${response}</arg>
<doc>Use norm_json to normalize both JSON arguments, call Should_Be_Equal.</doc>
<status status="PASS" start="2026-06-06T03:37:59.517870" elapsed="0.001888"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.517617" elapsed="0.002174"/>
</branch>
<branch type="ELSE">
<kw name="Should Be Equal" owner="BuiltIn">
<arg>${expected_text}</arg>
<arg>${response}</arg>
<doc>Fails if the given objects are unequal.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.519961" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.519817" elapsed="0.000199"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.517597" elapsed="0.002440"/>
</if>
<arg>response=${response}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=${base_name}</arg>
<arg>extension=json</arg>
<arg>mapping=${mapping}</arg>
<arg>normalize_json=True</arg>
<arg>endline=${\n}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected text from template, provided response shuld be equal.
If ${normalize_json}, perform normalization before comparison.</doc>
<status status="PASS" start="2026-06-06T03:37:59.491724" elapsed="0.028360"/>
</kw>
<arg>response=${response_text}</arg>
<arg>folder=${folder}</arg>
<arg>base_name=data</arg>
<arg>mapping=${mapping}</arg>
<arg>iterations=${iterations}</arg>
<arg>iter_start=${iter_start}</arg>
<arg>iter_j_offset=${iter_j_offset}</arg>
<doc>Resolve expected JSON data, should be equal to provided ${response}.
JSON normalization is used, endlines enabled for readability.</doc>
<status status="PASS" start="2026-06-06T03:37:59.490860" elapsed="0.029299"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.490455" elapsed="0.029778"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.490421" elapsed="0.029860"/>
</if>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:59.520348" elapsed="0.000082"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}default_off</arg>
<arg>session=${CONFIG_SESSION}</arg>
<arg>verify=True</arg>
<doc>Add arguments sensible for JSON data, return Get_Templated response text.
Optionally, verification against JSON data (may be iterated) is called.
Only subset of JSON data is verified and returned if JMES path is specified in
file ${folder}/jmespath.expr.</doc>
<status status="PASS" start="2026-06-06T03:37:59.404359" elapsed="0.116302"/>
</kw>
<doc>Try to access pcep topology with wrong password, should get empty topology</doc>
<status status="PASS" start="2026-06-06T03:37:59.387743" elapsed="0.133089"/>
</kw>
<msg time="2026-06-06T03:37:59.520925" level="INFO">${status} = PASS</msg>
<msg time="2026-06-06T03:37:59.520969" level="INFO">${output} = None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:59.386762" elapsed="0.134230"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.521173" elapsed="0.000015"/>
</return>
<status status="NOT RUN" start="2026-06-06T03:37:59.521064" elapsed="0.000152"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.521046" elapsed="0.000192"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.521697" level="INFO">${output} = None</msg>
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:59.521375" elapsed="0.000349"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.522176" level="FAIL">None</msg>
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.521868" elapsed="0.000379">None</status>
</kw>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.385774" elapsed="0.136588">None</status>
</kw>
<msg time="2026-06-06T03:37:59.522455" level="FAIL">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</msg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Invert_Failure</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and retries if it fails.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.159903" elapsed="10.362645">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</status>
</kw>
<msg time="2026-06-06T03:37:59.522600" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>BuiltIn.Wait_Until_Keyword_Succeeds</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>Invert_Failure</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.159524" elapsed="10.363139"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Test_Unauthorized</arg>
<doc>Some Keywords need several tries to finally fail, this keyword passes if and only if the failure ultimately happens.</doc>
<status status="FAIL" start="2026-06-06T03:37:49.159053" elapsed="10.363714">Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</status>
</kw>
<msg time="2026-06-06T03:37:59.522876" level="INFO">${status} = FAIL</msg>
<msg time="2026-06-06T03:37:59.522920" level="INFO">${output} = Keyword 'Invert_Failure' failed after retrying for 10 seconds. The last error was: None</msg>
<var>${status}</var>
<var>${output}</var>
<arg>@{cell_sequence}</arg>
<doc>Runs the given keyword with the given arguments and ignores possible error.</doc>
<status status="PASS" start="2026-06-06T03:37:49.157244" elapsed="10.365700"/>
</kw>
<if>
<branch type="IF" condition="&quot;${status}&quot; != &quot;PASS&quot;">
<return>
<value>${output}</value>
<status status="PASS" start="2026-06-06T03:37:59.523128" elapsed="0.000025"/>
</return>
<status status="PASS" start="2026-06-06T03:37:59.523017" elapsed="0.000169"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.522998" elapsed="0.000213"/>
</if>
<kw name="Convert To String" owner="BuiltIn">
<var>${output}</var>
<arg>${output}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.523349" elapsed="0.000022"/>
</kw>
<kw name="Fail" owner="BuiltIn">
<arg>${output}</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.523510" elapsed="0.000021"/>
</kw>
<arg>Confirm_Keyword_Fails_Within_Timeout</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>The response of Keyword execution is either a return value or a failure message.
This keyword calls the argument keyword and returns its failure message string,
or fails with its return value converted to string.</doc>
<status status="PASS" start="2026-06-06T03:37:49.156857" elapsed="10.366770"/>
</kw>
<msg time="2026-06-06T03:37:59.523733" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>Invert_Failure</arg>
<arg>Confirm_Keyword_Fails_Within_Timeout</arg>
<arg>${timeout}</arg>
<arg>${refresh}</arg>
<arg>@{cell_list}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:49.156403" elapsed="10.367384"/>
</kw>
<arg>10s</arg>
<arg>1s</arg>
<arg>Test_Unauthorized</arg>
<doc>Some positive checks report false success for a short time. This keyword verifies no failure does happen within timeout period.
This implementation needs more complicated logic than, Verify_Keyword_Never_Passes_Within_Timeout,
so use that keyword in case you have a negative check handy.</doc>
<status status="PASS" start="2026-06-06T03:37:49.156080" elapsed="10.367827"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:59.524718" elapsed="0.000248"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:59.524193" elapsed="0.000839"/>
</kw>
<doc>Verify that pcep-topology stays empty.</doc>
<tag>critical</tag>
<status status="PASS" start="2026-06-06T03:37:49.154708" elapsed="10.370364"/>
</test>
<test id="s1-s21-t20" name="Delete_Pcep_Client_Module" line="200">
<kw name="Fail_This_Fast_On_Previous_Error" owner="FailFast" type="SETUP">
<if>
<branch type="IF" condition="'''${SuiteFastFail}'''=='True'">
<kw name="Fail" owner="BuiltIn">
<arg>SKIPPED due to a failure in a previous fundamental test case.</arg>
<doc>Fails the test with the given message and optionally alters its tags.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.526527" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.526316" elapsed="0.000268"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.526297" elapsed="0.000311"/>
</if>
<doc>Mark (immediately) this test case as failed when fast-fail is enabled in suite.</doc>
<status status="PASS" start="2026-06-06T03:37:59.526109" elapsed="0.000563"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.527225" level="INFO">&amp;{mapping} = { IP=10.30.171.194 }</msg>
<var>&amp;{mapping}</var>
<arg>IP=${TOOLS_SYSTEM_IP}</arg>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:59.526829" elapsed="0.000423"/>
</kw>
<kw name="Delete_Templated" owner="TemplatedRequests">
<kw name="Resolve_Text_From_Template_Folder" owner="TemplatedRequests">
<kw name="Run Keyword And Return If" owner="BuiltIn">
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.557665" level="INFO">${file_path_stream} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/location.uri</msg>
<var>${file_path_stream}</var>
<arg>${folder}.${ODL_STREAM}${/}${file_name}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="PASS" start="2026-06-06T03:37:59.557278" elapsed="0.000417"/>
</kw>
<kw name="Run Keyword And Return Status" owner="BuiltIn">
<kw name="File Should Exist" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.558428" level="FAIL">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/location.uri' does not exist.</msg>
<arg>${file_path_stream}</arg>
<doc>Fails unless the given ``path`` points to an existing file.</doc>
<status status="FAIL" start="2026-06-06T03:37:59.558181" elapsed="0.000314">File '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/location.uri' does not exist.</status>
</kw>
<msg time="2026-06-06T03:37:59.558589" level="INFO">${file_stream_exists} = False</msg>
<var>${file_stream_exists}</var>
<arg>OperatingSystem.File Should Exist</arg>
<arg>${file_path_stream}</arg>
<doc>Runs the specified keyword and returns the status as a Boolean value.</doc>
<status status="PASS" start="2026-06-06T03:37:59.557853" elapsed="0.000760"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.559171" level="INFO">${file_path} = /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node/location.uri</msg>
<var>${file_path}</var>
<arg>${file_stream_exists}</arg>
<arg>${file_path_stream}</arg>
<arg>${folder}${/}${file_name}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="PASS" start="2026-06-06T03:37:59.558787" elapsed="0.000411"/>
</kw>
<kw name="Get File" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.559489" level="INFO" html="true">Getting file '&lt;a href="file:///w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node/location.uri"&gt;/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/variables/tcpmd5user/vanadium/pcep_topology_node/location.uri&lt;/a&gt;'.</msg>
<msg time="2026-06-06T03:37:59.559658" level="INFO">${template} = rests/data/network-topology:network-topology/topology=pcep-topology/node=$IP
</msg>
<var>${template}</var>
<arg>${file_path}</arg>
<doc>Returns the contents of a specified file.</doc>
<status status="PASS" start="2026-06-06T03:37:59.559352" elapsed="0.000334"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.560095" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology/node=$IP
</msg>
<arg>${template}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.559850" elapsed="0.000289"/>
</kw>
<if>
<branch type="IF" condition="${percent_encode} == True">
<kw name="Encode_Mapping" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.561080" level="INFO">mapping: {'IP': '10.30.171.194'}</msg>
<arg>mapping: ${mapping}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.560825" elapsed="0.000300"/>
</kw>
<kw name="Create Dictionary" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.561535" level="INFO">${encoded_mapping} = {}</msg>
<var>${encoded_mapping}</var>
<doc>Creates and returns a dictionary based on the given ``items``.</doc>
<status status="PASS" start="2026-06-06T03:37:59.561276" elapsed="0.000285"/>
</kw>
<for flavor="IN">
<iter>
<kw name="Convert To String" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.562218" level="INFO">${value} = 10.30.171.194</msg>
<var>${value}</var>
<arg>${value}</arg>
<doc>Converts the given item to a Unicode string.</doc>
<status status="PASS" start="2026-06-06T03:37:59.561926" elapsed="0.000318"/>
</kw>
<kw name="Percent_Encode_String" owner="TemplatedRequests">
<kw name="Replace String Using Regexp" owner="String">
<msg time="2026-06-06T03:37:59.563109" level="INFO">${encoded} = 10.30.171.194</msg>
<var>${encoded}</var>
<arg>${value}</arg>
<arg>:</arg>
<arg>%3A</arg>
<doc>Replaces ``pattern`` in the given ``string`` with ``replace_with``.</doc>
<status status="PASS" start="2026-06-06T03:37:59.562751" elapsed="0.000386"/>
</kw>
<return>
<value>${encoded}</value>
<status status="PASS" start="2026-06-06T03:37:59.563189" elapsed="0.000030"/>
</return>
<msg time="2026-06-06T03:37:59.563341" level="INFO">${encoded_value} = 10.30.171.194</msg>
<var>${encoded_value}</var>
<arg>${value}</arg>
<doc>Percent encodes reserved characters in the given string so it can be used as part of url.</doc>
<status status="PASS" start="2026-06-06T03:37:59.562423" elapsed="0.000945"/>
</kw>
<kw name="Set To Dictionary" owner="Collections">
<arg>${encoded_mapping}</arg>
<arg>${key}</arg>
<arg>${encoded_value}</arg>
<doc>Adds the given ``key_value_pairs`` and/or ``items`` to the ``dictionary``.</doc>
<status status="PASS" start="2026-06-06T03:37:59.563550" elapsed="0.000304"/>
</kw>
<var name="${key}">IP</var>
<var name="${value}">10.30.171.194</var>
<status status="PASS" start="2026-06-06T03:37:59.561798" elapsed="0.002099"/>
</iter>
<var>${key}</var>
<var>${value}</var>
<value>&amp;{mapping}</value>
<status status="PASS" start="2026-06-06T03:37:59.561612" elapsed="0.002357"/>
</for>
<return>
<value>${encoded_mapping}</value>
<status status="PASS" start="2026-06-06T03:37:59.564016" elapsed="0.000029"/>
</return>
<msg time="2026-06-06T03:37:59.564176" level="INFO">${mapping_to_use} = {'IP': '10.30.171.194'}</msg>
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<status status="PASS" start="2026-06-06T03:37:59.560493" elapsed="0.003708"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.560207" elapsed="0.004027"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<var>${mapping_to_use}</var>
<arg>${mapping}</arg>
<doc>Returns the given values which can then be assigned to a variables.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.564399" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.564258" elapsed="0.000196"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.560188" elapsed="0.004286"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.565173" level="INFO">${final_text} = rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194</msg>
<var>${final_text}</var>
<arg>string.Template('''${template}'''.rstrip()).safe_substitute(${mapping_to_use})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="PASS" start="2026-06-06T03:37:59.564608" elapsed="0.000593"/>
</kw>
<return>
<value>${final_text}</value>
<status status="PASS" start="2026-06-06T03:37:59.565250" elapsed="0.000028"/>
</return>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="PASS" start="2026-06-06T03:37:59.556676" elapsed="0.008697"/>
</kw>
<msg time="2026-06-06T03:37:59.565426" level="INFO">Returning from the enclosing user keyword.</msg>
<arg>not "${iterations}"</arg>
<arg>Resolve_Text_From_Template_File</arg>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Runs the specified keyword and returns from the enclosing user keyword.</doc>
<status status="PASS" start="2026-06-06T03:37:59.555886" elapsed="0.009586"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${prolog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.prolog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.565972" elapsed="0.000026"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${epilog}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${name_prefix}${base_name}.epilog.${extension}</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=${percent_encode}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.566476" elapsed="0.000025"/>
</kw>
<kw name="Resolve_Text_From_Template_File" owner="TemplatedRequests">
<var>${item_template}</var>
<arg>folder=${folder}</arg>
<arg>file_name=${base_name}.item.${extension}</arg>
<arg>mapping=${mapping}</arg>
<doc>Check if /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar exists. If yes read and Log contents of file /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node.vanadium/pcep-pcc-mock-2.0.0-executable.jar,
remove endline, perform safe substitution, return result.
If no do it with the default /w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/suites/bgpcep/tcpmd5user/../../../variables/tcpmd5user/vanadium/pcep_topology_node/pcep-pcc-mock-2.0.0-executable.jar.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.566989" elapsed="0.000025"/>
</kw>
<kw name="Create List" owner="BuiltIn">
<var>${items}</var>
<doc>Returns a list containing given items.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.567170" elapsed="0.000021"/>
</kw>
<kw name="Set Variable If" owner="BuiltIn">
<var>${separator}</var>
<arg>'${extension}' != 'json'</arg>
<arg>${endline}</arg>
<arg>,${endline}</arg>
<doc>Sets variable based on the given condition.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.567337" elapsed="0.000020"/>
</kw>
<for flavor="IN RANGE">
<iter>
<if>
<branch type="IF" condition="${iteration} &gt; ${iter_start}">
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${separator}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.567701" elapsed="0.000036"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.567551" elapsed="0.000222"/>
</branch>
<status status="NOT RUN" start="2026-06-06T03:37:59.567536" elapsed="0.000261"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<var>${j}</var>
<arg>${iteration}+${iter_j_offset}</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.567930" elapsed="0.000021"/>
</kw>
<kw name="Evaluate" owner="BuiltIn">
<var>${item}</var>
<arg>string.Template('''${item_template}''').substitute({"i":"${iteration}", "j":${j}})</arg>
<arg>modules=string</arg>
<doc>Evaluates the given expression in Python and returns the result.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.568091" elapsed="0.000020"/>
</kw>
<kw name="Append To List" owner="Collections">
<arg>${items}</arg>
<arg>${item}</arg>
<doc>Adds ``values`` to the end of ``list``.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.568249" elapsed="0.000019"/>
</kw>
<var name="${iteration}"/>
<status status="NOT RUN" start="2026-06-06T03:37:59.567509" elapsed="0.000792"/>
</iter>
<var>${iteration}</var>
<value>${iter_start}</value>
<value>${iterations}+${iter_start}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.567410" elapsed="0.000952"/>
</for>
<kw name="Catenate" owner="BuiltIn">
<var>${final_text}</var>
<arg>SEPARATOR=</arg>
<arg>${prolog}</arg>
<arg>${endline}</arg>
<arg>@{items}</arg>
<arg>${endline}</arg>
<arg>${epilog}</arg>
<doc>Catenates the given items together and returns the resulted string.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.568508" elapsed="0.000020"/>
</kw>
<return>
<value>${final_text}</value>
<status status="NOT RUN" start="2026-06-06T03:37:59.568583" elapsed="0.000015"/>
</return>
<msg time="2026-06-06T03:37:59.568713" level="INFO">${uri} = rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194</msg>
<var>${uri}</var>
<arg>folder=${folder}</arg>
<arg>base_name=${location}</arg>
<arg>extension=uri</arg>
<arg>mapping=${mapping}</arg>
<arg>percent_encode=True</arg>
<doc>Read a template from folder, strip endline, make changes according to mapping, return the result.
If ${iterations} value is present, put text together from "prolog", "item" and "epilog" parts,
where additional template variable ${i} goes from ${iter_start}, by one ${iterations} times.
Template variable ${j} is calculated as ${i} incremented by offset ${iter_j_offset} ( j = i + iter_j_offset )
used to create non uniform data in order to be able to validate UPDATE operations.
POST (as opposed to PUT) needs slightly different data, ${name_prefix} may be used to distinguish.
(Actually, it is GET who formats data differently when URI is a top-level container.)</doc>
<status status="PASS" start="2026-06-06T03:37:59.551493" elapsed="0.017246"/>
</kw>
<kw name="Delete_From_Uri" owner="TemplatedRequests">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.569825" level="INFO">rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194</msg>
<arg>${uri}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.569558" elapsed="0.000313"/>
</kw>
<if>
<branch type="IF" condition="&quot;&quot;&quot;${http_timeout}&quot;&quot;&quot; == &quot;&quot;&quot;${EMPTY}&quot;&quot;&quot;">
<kw name="DELETE On Session" owner="RequestsLibrary">
<msg time="2026-06-06T03:37:59.577475" level="INFO">DELETE Request : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194 
 path_url=/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194 
 headers={'User-Agent': 'python-requests/2.34.2', 'Accept-Encoding': 'gzip, deflate', 'Accept': '*/*', 'Connection': 'keep-alive', 'Cookie': 'JSESSIONID=node01dvrpaqtsq5w5p93uzk1wvcoh31.node0', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:59.577520" level="INFO">DELETE Response : url=http://10.30.170.38:8181/rests/data/network-topology:network-topology/topology=pcep-topology/node=10.30.171.194 
 status=204, reason=No Content 
 headers={} 
 body=None 
 </msg>
<msg time="2026-06-06T03:37:59.577609" level="INFO">${response} = &lt;Response [204]&gt;</msg>
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="PASS" start="2026-06-06T03:37:59.571989" elapsed="0.005645"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.569936" elapsed="0.007758"/>
</branch>
<branch type="ELSE">
<kw name="DELETE On Session" owner="RequestsLibrary">
<var>${response}</var>
<arg>${session}</arg>
<arg>${uri}</arg>
<arg>timeout=${http_timeout}</arg>
<doc>Sends a DELETE request on a previously created HTTP Session.</doc>
<status status="NOT RUN" start="2026-06-06T03:37:59.577865" elapsed="0.000022"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.577720" elapsed="0.000206"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.569918" elapsed="0.008029"/>
</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-06-06T03:37:59.583578" level="INFO"/>
<arg>${response.text}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.578925" elapsed="0.004733"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.578714" elapsed="0.004996"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.578695" elapsed="0.005067"/>
</if>
<if>
<branch type="IF" condition="&quot;${log_response}&quot; == &quot;True&quot;">
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.587418" level="INFO">204</msg>
<arg>${response.status_code}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.584150" elapsed="0.003333"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.583845" elapsed="0.003686"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.583819" elapsed="0.003747"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.588358" 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-06-06T03:37:59.587847" elapsed="0.000538"/>
</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-06-06T03:37:59.588705" elapsed="0.000023"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.588457" elapsed="0.000308"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.589250" 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-06-06T03:37:59.588947" elapsed="0.000329"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.588790" elapsed="0.000521"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.588438" elapsed="0.000894"/>
</if>
<kw name="Evaluate" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.589864" 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-06-06T03:37:59.589484" elapsed="0.000407"/>
</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-06-06T03:37:59.590188" elapsed="0.000021"/>
</kw>
<status status="NOT RUN" start="2026-06-06T03:37:59.589962" elapsed="0.000282"/>
</branch>
<branch type="ELSE">
<kw name="Set Variable" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.590728" 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-06-06T03:37:59.590418" elapsed="0.000337"/>
</kw>
<status status="PASS" start="2026-06-06T03:37:59.590268" elapsed="0.000522"/>
</branch>
<status status="PASS" start="2026-06-06T03:37:59.589944" elapsed="0.000867"/>
</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-06-06T03:37:59.590954" elapsed="0.000347"/>
</kw>
<kw name="Combine Lists" owner="Collections">
<msg time="2026-06-06T03:37:59.591819" 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-06-06T03:37:59.591501" elapsed="0.000345"/>
</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-06-06T03:37:59.591995" elapsed="0.002438"/>
</kw>
<arg>${response}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</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-06-06T03:37:59.578297" elapsed="0.016204"/>
</kw>
<return>
<value>${response.text}</value>
<status status="PASS" start="2026-06-06T03:37:59.594550" elapsed="0.000034"/>
</return>
<msg time="2026-06-06T03:37:59.596922" level="INFO">${response_text} = </msg>
<var>${response_text}</var>
<arg>uri=${uri}</arg>
<arg>session=${session}</arg>
<arg>additional_allowed_status_codes=${additional_allowed_status_codes}</arg>
<arg>http_timeout=${http_timeout}</arg>
<doc>DELETE resource at URI, check status_code and return response text..</doc>
<status status="PASS" start="2026-06-06T03:37:59.568990" elapsed="0.027960"/>
</kw>
<return>
<value>${response_text}</value>
<status status="PASS" start="2026-06-06T03:37:59.597006" elapsed="0.000028"/>
</return>
<arg>${DIR_WITH_TEMPLATES}${/}pcep_topology_node</arg>
<arg>${mapping}</arg>
<doc>Resolve URI from folder, issue DELETE request.</doc>
<status status="PASS" start="2026-06-06T03:37:59.527476" elapsed="0.069656"/>
</kw>
<kw name="Start_Failing_Fast_If_This_Failed" owner="FailFast" type="TEARDOWN">
<kw name="Run Keyword If Test Failed" owner="BuiltIn">
<arg>BuiltIn.Set_Suite_Variable</arg>
<arg>${SuiteFastFail}</arg>
<arg>True</arg>
<doc>Runs the given keyword with the given arguments, if the test failed.</doc>
<status status="PASS" start="2026-06-06T03:37:59.597770" elapsed="0.000262"/>
</kw>
<doc>Set suite fail fast behavior on, if current test case has failed.</doc>
<status status="PASS" start="2026-06-06T03:37:59.597438" elapsed="0.000657"/>
</kw>
<doc>Delete Pcep client module.</doc>
<status status="PASS" start="2026-06-06T03:37:59.525518" elapsed="0.072615"/>
</test>
<kw name="Tear_It_Down" type="TEARDOWN">
<kw name="Get File" owner="SSHLibrary">
<msg time="2026-06-06T03:37:59.610283" level="INFO">[chan 5] Opened sftp connection (server version 3)</msg>
<msg time="2026-06-06T03:37:59.615321" level="INFO">'pccmock.log' -&gt; '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/pccmock.log'</msg>
<arg>pccmock.log</arg>
<doc>Downloads file(s) from the remote machine to the local machine.</doc>
<status status="PASS" start="2026-06-06T03:37:59.599051" elapsed="0.016416"/>
</kw>
<kw name="Run" owner="OperatingSystem">
<msg time="2026-06-06T03:37:59.617025" level="INFO">Running command 'cat pccmock.log 2&gt;&amp;1'.</msg>
<msg time="2026-06-06T03:37:59.620809" level="INFO">${pccmocklog} = </msg>
<var>${pccmocklog}</var>
<arg>cat pccmock.log</arg>
<doc>_This keyword is considered deprecated. Use the
[http://robotframework.org/robotframework/latest/libraries/Process.html|
Process] library instead._</doc>
<status status="PASS" start="2026-06-06T03:37:59.615932" elapsed="0.004941"/>
</kw>
<kw name="Log" owner="BuiltIn">
<msg time="2026-06-06T03:37:59.621888" level="INFO"/>
<arg>${pccmocklog}</arg>
<doc>Logs the given message with the given level.</doc>
<status status="PASS" start="2026-06-06T03:37:59.621233" elapsed="0.000753"/>
</kw>
<kw name="Delete All Sessions" owner="RequestsLibrary">
<msg time="2026-06-06T03:37:59.622473" level="INFO">Deleting All Sessions</msg>
<doc>Removes all the session objects</doc>
<status status="PASS" start="2026-06-06T03:37:59.622311" elapsed="0.000412"/>
</kw>
<kw name="Close All Connections" owner="SSHLibrary">
<doc>Closes all open connections.</doc>
<status status="PASS" start="2026-06-06T03:37:59.623039" elapsed="0.000693"/>
</kw>
<doc>Download pccmock.log and Log its contents.
Compute and Log the diff between expected and actual normalized responses.
Close both HTTP client session and SSH connection to Mininet.</doc>
<status status="PASS" start="2026-06-06T03:37:59.598835" elapsed="0.025104"/>
</kw>
<doc>TCPMD5 user-facing feature system tests, using PCEP.

Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.

This program and the accompanying materials are made available under the
terms of the Eclipse Public License v1.0 which accompanies this distribution,
and is available at http://www.eclipse.org/legal/epl-v10.html

Test suite performs basic pcep md5 password authorization test cases:
(Run entire basic PCEP suite without passwords.)
Start pcc-mock (reconnecting mode): 1 pcc, 1 lsp, password set, check pcep-topology stays empty.
Use restconf to change PCEP configuration to use a wrong password, check pcep-topology stays empty.
Change ODL PCEP configuration to use the correct password, check pcep-topology shows the lsp.
Stop pcc-mock, check pcep-topology stays empty.
Start pcc-mock with new password, check pcep-topology stays empty.
Change ODL PCEP configuration to use the correct password, check pcep-topology shows the lsp.
Update the lsp, check a change in pcep-topology.
Change ODL PCEP configuration to not use password, pcep-topology empties, kill pcep-pcc-mock.

Test cases no longer need netconf-connector-ssh, and they include comparison of
pcep-session-state.</doc>
<status status="FAIL" start="2026-06-06T03:32:34.639545" elapsed="324.984474"/>
</suite>
<status status="FAIL" start="2026-06-06T03:05:30.003881" elapsed="1949.623190"/>
</suite>
<statistics>
<total>
<stat pass="343" fail="49" skip="0">All Tests</stat>
</total>
<tag>
<stat pass="115" fail="34" skip="0">critical</stat>
<stat pass="0" fail="1" skip="0">https://bugs.opendaylight.org/show_bug.cgi?id=4834</stat>
<stat pass="0" fail="1" skip="0">https://bugs.opendaylight.org/show_bug.cgi?id=4835</stat>
<stat pass="1" fail="0" skip="0">local_run</stat>
</tag>
<suite>
<stat name="bgpcep-userfeatures.txt" id="s1" pass="343" fail="49" skip="0">bgpcep-userfeatures.txt</stat>
<stat name="050 Bmp Basic" id="s1-s1" pass="4" fail="0" skip="0">bgpcep-userfeatures.txt.050 Bmp Basic</stat>
<stat name="Pcepuser" id="s1-s2" pass="1" fail="15" skip="0">bgpcep-userfeatures.txt.Pcepuser</stat>
<stat name="Bgp Functional Md5" id="s1-s3" pass="2" fail="0" skip="0">bgpcep-userfeatures.txt.Bgp Functional Md5</stat>
<stat name="Basic" id="s1-s4" pass="38" fail="0" skip="0">bgpcep-userfeatures.txt.Basic</stat>
<stat name="Bgp Ipv6 Basic" id="s1-s5" pass="36" fail="0" skip="0">bgpcep-userfeatures.txt.Bgp Ipv6 Basic</stat>
<stat name="Bgp Llgr Basic" id="s1-s6" pass="4" fail="0" skip="0">bgpcep-userfeatures.txt.Bgp Llgr Basic</stat>
<stat name="Bgp App Peer Basic" id="s1-s7" pass="28" fail="0" skip="0">bgpcep-userfeatures.txt.Bgp App Peer Basic</stat>
<stat name="Ibgp Peers Basic" id="s1-s8" pass="32" fail="4" skip="0">bgpcep-userfeatures.txt.Ibgp Peers Basic</stat>
<stat name="Ebgp Peers Basic" id="s1-s9" pass="15" fail="7" skip="0">bgpcep-userfeatures.txt.Ebgp Peers Basic</stat>
<stat name="010 Bgp Flowspec" id="s1-s10" pass="5" fail="0" skip="0">bgpcep-userfeatures.txt.010 Bgp Flowspec</stat>
<stat name="Ibgp Peer Lsp" id="s1-s11" pass="11" fail="1" skip="0">bgpcep-userfeatures.txt.Ibgp Peer Lsp</stat>
<stat name="010 Bgp Functional L3Vpn" id="s1-s12" pass="9" fail="0" skip="0">bgpcep-userfeatures.txt.010 Bgp Functional L3Vpn</stat>
<stat name="030 Bgp Functional Evpn" id="s1-s13" pass="78" fail="0" skip="0">bgpcep-userfeatures.txt.030 Bgp Functional Evpn</stat>
<stat name="040 Bgp Functional Route Ref" id="s1-s14" pass="4" fail="2" skip="0">bgpcep-userfeatures.txt.040 Bgp Functional Route Ref</stat>
<stat name="020 Bgp Functional Multipath" id="s1-s15" pass="2" fail="2" skip="0">bgpcep-userfeatures.txt.020 Bgp Functional Multipath</stat>
<stat name="060 Bgp Functional Mvpn" id="s1-s16" pass="29" fail="0" skip="0">bgpcep-userfeatures.txt.060 Bgp Functional Mvpn</stat>
<stat name="070 Bgp Functional L3Vpn Mcast" id="s1-s17" pass="10" fail="0" skip="0">bgpcep-userfeatures.txt.070 Bgp Functional L3Vpn Mcast</stat>
<stat name="080 Bgp Functional Rt Constrain" id="s1-s18" pass="14" fail="0" skip="0">bgpcep-userfeatures.txt.080 Bgp Functional Rt Constrain</stat>
<stat name="090 Bgp Functional Rt Constrain Validation" id="s1-s19" pass="8" fail="3" skip="0">bgpcep-userfeatures.txt.090 Bgp Functional Rt Constrain Validation</stat>
<stat name="Bgp Policies Default" id="s1-s20" pass="7" fail="1" skip="0">bgpcep-userfeatures.txt.Bgp Policies Default</stat>
<stat name="Tcpmd5User" id="s1-s21" pass="6" fail="14" skip="0">bgpcep-userfeatures.txt.Tcpmd5User</stat>
</suite>
</statistics>
<errors>
<msg time="2026-06-06T03:12:00.528177" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.Bgp Functional Md5' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:12:29.808023" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPSpeaker.robot' on line 27: Suite 'bgpcep-userfeatures.txt.Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:12:29.808808" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/RemoteBash.robot' on line 25: Suite 'bgpcep-userfeatures.txt.Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:12:29.809392" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/SSHKeywords.robot' on line 16: Suite 'bgpcep-userfeatures.txt.Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:12:29.809931" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/Utils.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:12:29.815802" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/NexusKeywords.robot' on line 20: Suite 'bgpcep-userfeatures.txt.Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:12:29.818603" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/KarafKeywords.robot' on line 9: Suite 'bgpcep-userfeatures.txt.Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:13:47.856956" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.Bgp Ipv6 Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:16:46.883058" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.Bgp Llgr Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:17:20.840236" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPSpeaker.robot' on line 27: Suite 'bgpcep-userfeatures.txt.Bgp App Peer Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:17:20.841077" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/RemoteBash.robot' on line 25: Suite 'bgpcep-userfeatures.txt.Bgp App Peer Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:17:20.841692" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/SSHKeywords.robot' on line 16: Suite 'bgpcep-userfeatures.txt.Bgp App Peer Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:17:20.842212" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/Utils.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Bgp App Peer Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:17:20.848000" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/NexusKeywords.robot' on line 20: Suite 'bgpcep-userfeatures.txt.Bgp App Peer Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:17:20.851139" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/KarafKeywords.robot' on line 9: Suite 'bgpcep-userfeatures.txt.Bgp App Peer Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:06.979585" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPSpeaker.robot' on line 27: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:06.980678" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/RemoteBash.robot' on line 25: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:06.981290" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/SSHKeywords.robot' on line 16: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:06.981823" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/Utils.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:06.987801" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/NexusKeywords.robot' on line 20: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:07.015775" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BgpOperations.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:18:07.022763" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/KarafKeywords.robot' on line 9: Suite 'bgpcep-userfeatures.txt.Ibgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.403401" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPSpeaker.robot' on line 27: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.404190" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/RemoteBash.robot' on line 25: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.404801" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/SSHKeywords.robot' on line 16: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.405317" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/Utils.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.411194" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/NexusKeywords.robot' on line 20: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.414055" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BgpOperations.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:20:41.415891" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/KarafKeywords.robot' on line 9: Suite 'bgpcep-userfeatures.txt.Ebgp Peers Basic' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:12.724159" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.010 Bgp Flowspec' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.188967" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPSpeaker.robot' on line 27: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.189772" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/RemoteBash.robot' on line 25: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.190311" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/SSHKeywords.robot' on line 16: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.190795" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/Utils.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.196364" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/NexusKeywords.robot' on line 20: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.199298" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BgpOperations.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:23:27.200774" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/KarafKeywords.robot' on line 9: Suite 'bgpcep-userfeatures.txt.Ibgp Peer Lsp' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:24:16.609243" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.010 Bgp Functional L3Vpn' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:24:41.324696" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.030 Bgp Functional Evpn' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:27:36.951755" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.040 Bgp Functional Route Ref' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:28:24.526311" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.020 Bgp Functional Multipath' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:29:16.161865" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.060 Bgp Functional Mvpn' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:30:38.506330" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.070 Bgp Functional L3Vpn Mcast' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:30:59.699377" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.080 Bgp Functional Rt Constrain' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:31:32.243104" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.090 Bgp Functional Rt Constrain Validation' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:31:49.658868" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/BGPcliKeywords.robot' on line 15: Suite 'bgpcep-userfeatures.txt.Bgp Policies Default' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:32:34.649323" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/KarafKeywords.robot' on line 9: Suite 'bgpcep-userfeatures.txt.Tcpmd5User' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:32:34.653413" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/SSHKeywords.robot' on line 16: Suite 'bgpcep-userfeatures.txt.Tcpmd5User' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:32:34.653953" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/Utils.robot' on line 4: Suite 'bgpcep-userfeatures.txt.Tcpmd5User' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:32:34.665414" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/NexusKeywords.robot' on line 20: Suite 'bgpcep-userfeatures.txt.Tcpmd5User' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
<msg time="2026-06-06T03:32:34.667195" level="WARN">Error in file '/w/workspace/bgpcep-csit-1node-userfeatures-all-vanadium/test/csit/libraries/RemoteBash.robot' on line 25: Suite 'bgpcep-userfeatures.txt.Tcpmd5User' has already imported library 'SSHLibrary' with different arguments. This import is ignored.</msg>
</errors>
</robot>
